Compare commits
19 commits
develop
...
feat-searc
Author | SHA1 | Date | |
---|---|---|---|
|
228167823c | ||
|
c618064b13 | ||
|
d23b4a45ad | ||
|
4af9d00d6f | ||
|
e8bd066f93 | ||
|
4dc691e29c | ||
|
6c07ab8bb6 | ||
|
a98bffbe2b | ||
|
4b674a167a | ||
|
bd4b051460 | ||
|
963980d13b | ||
|
c498668345 | ||
|
cb388d93e6 | ||
|
7ba0666cb1 | ||
|
75b7f8f0c4 | ||
|
9b8f0e0152 | ||
|
92ea452680 | ||
|
65de030244 | ||
|
54eab87806 |
404 changed files with 1512 additions and 2773 deletions
8
Gemfile
8
Gemfile
|
@ -4,7 +4,7 @@ ruby '3.0.4'
|
||||||
|
|
||||||
##-- base gems for rails --##
|
##-- base gems for rails --##
|
||||||
gem 'rack-cors', require: 'rack/cors'
|
gem 'rack-cors', require: 'rack/cors'
|
||||||
gem 'rails', '~> 6.1', '>= 6.1.6.1'
|
gem 'rails', '~>6.1'
|
||||||
# Reduces boot times through caching; required in config/boot.rb
|
# Reduces boot times through caching; required in config/boot.rb
|
||||||
gem 'bootsnap', require: false
|
gem 'bootsnap', require: false
|
||||||
|
|
||||||
|
@ -56,7 +56,7 @@ gem 'activerecord-import'
|
||||||
gem 'dotenv-rails'
|
gem 'dotenv-rails'
|
||||||
gem 'foreman'
|
gem 'foreman'
|
||||||
gem 'puma'
|
gem 'puma'
|
||||||
gem 'webpacker', '~> 5.4', '>= 5.4.3'
|
gem 'webpacker', '~> 5.x'
|
||||||
# metrics on heroku
|
# metrics on heroku
|
||||||
gem 'barnes'
|
gem 'barnes'
|
||||||
|
|
||||||
|
@ -94,7 +94,7 @@ gem 'ddtrace'
|
||||||
gem 'elastic-apm'
|
gem 'elastic-apm'
|
||||||
gem 'newrelic_rpm'
|
gem 'newrelic_rpm'
|
||||||
gem 'scout_apm'
|
gem 'scout_apm'
|
||||||
gem 'sentry-rails', '~> 5.3', '>= 5.3.1'
|
gem 'sentry-rails', '~> 5.3'
|
||||||
gem 'sentry-ruby', '~> 5.3'
|
gem 'sentry-ruby', '~> 5.3'
|
||||||
gem 'sentry-sidekiq', '~> 5.3'
|
gem 'sentry-sidekiq', '~> 5.3'
|
||||||
|
|
||||||
|
@ -175,7 +175,7 @@ group :development, :test do
|
||||||
gem 'mock_redis'
|
gem 'mock_redis'
|
||||||
gem 'pry-rails'
|
gem 'pry-rails'
|
||||||
gem 'rspec_junit_formatter'
|
gem 'rspec_junit_formatter'
|
||||||
gem 'rspec-rails', '~> 5.0.3'
|
gem 'rspec-rails', '~> 5.0.0'
|
||||||
gem 'rubocop', require: false
|
gem 'rubocop', require: false
|
||||||
gem 'rubocop-performance', require: false
|
gem 'rubocop-performance', require: false
|
||||||
gem 'rubocop-rails', require: false
|
gem 'rubocop-rails', require: false
|
||||||
|
|
14
Gemfile.lock
14
Gemfile.lock
|
@ -398,7 +398,7 @@ GEM
|
||||||
llhttp-ffi (0.4.0)
|
llhttp-ffi (0.4.0)
|
||||||
ffi-compiler (~> 1.0)
|
ffi-compiler (~> 1.0)
|
||||||
rake (~> 13.0)
|
rake (~> 13.0)
|
||||||
loofah (2.19.1)
|
loofah (2.18.0)
|
||||||
crass (~> 1.0.2)
|
crass (~> 1.0.2)
|
||||||
nokogiri (>= 1.5.9)
|
nokogiri (>= 1.5.9)
|
||||||
mail (2.7.1)
|
mail (2.7.1)
|
||||||
|
@ -488,8 +488,8 @@ GEM
|
||||||
rails-dom-testing (2.0.3)
|
rails-dom-testing (2.0.3)
|
||||||
activesupport (>= 4.2.0)
|
activesupport (>= 4.2.0)
|
||||||
nokogiri (>= 1.6)
|
nokogiri (>= 1.6)
|
||||||
rails-html-sanitizer (1.4.4)
|
rails-html-sanitizer (1.4.3)
|
||||||
loofah (~> 2.19, >= 2.19.1)
|
loofah (~> 2.3)
|
||||||
railties (6.1.6.1)
|
railties (6.1.6.1)
|
||||||
actionpack (= 6.1.6.1)
|
actionpack (= 6.1.6.1)
|
||||||
activesupport (= 6.1.6.1)
|
activesupport (= 6.1.6.1)
|
||||||
|
@ -765,12 +765,12 @@ DEPENDENCIES
|
||||||
rack-attack
|
rack-attack
|
||||||
rack-cors
|
rack-cors
|
||||||
rack-timeout
|
rack-timeout
|
||||||
rails (~> 6.1, >= 6.1.6.1)
|
rails (~> 6.1)
|
||||||
redis
|
redis
|
||||||
redis-namespace
|
redis-namespace
|
||||||
responders
|
responders
|
||||||
rest-client
|
rest-client
|
||||||
rspec-rails (~> 5.0.3)
|
rspec-rails (~> 5.0.0)
|
||||||
rspec_junit_formatter
|
rspec_junit_formatter
|
||||||
rubocop
|
rubocop
|
||||||
rubocop-performance
|
rubocop-performance
|
||||||
|
@ -778,7 +778,7 @@ DEPENDENCIES
|
||||||
rubocop-rspec
|
rubocop-rspec
|
||||||
scout_apm
|
scout_apm
|
||||||
seed_dump
|
seed_dump
|
||||||
sentry-rails (~> 5.3, >= 5.3.1)
|
sentry-rails (~> 5.3)
|
||||||
sentry-ruby (~> 5.3)
|
sentry-ruby (~> 5.3)
|
||||||
sentry-sidekiq (~> 5.3)
|
sentry-sidekiq (~> 5.3)
|
||||||
shoulda-matchers
|
shoulda-matchers
|
||||||
|
@ -799,7 +799,7 @@ DEPENDENCIES
|
||||||
valid_email2
|
valid_email2
|
||||||
web-console
|
web-console
|
||||||
webmock
|
webmock
|
||||||
webpacker (~> 5.4, >= 5.4.3)
|
webpacker (~> 5.x)
|
||||||
webpush
|
webpush
|
||||||
wisper (= 2.0.0)
|
wisper (= 2.0.0)
|
||||||
working_hours
|
working_hours
|
||||||
|
|
|
@ -2,8 +2,8 @@ class Api::V1::Accounts::ConversationsController < Api::V1::Accounts::BaseContro
|
||||||
include Events::Types
|
include Events::Types
|
||||||
include DateRangeHelper
|
include DateRangeHelper
|
||||||
|
|
||||||
before_action :conversation, except: [:index, :meta, :search, :create, :filter]
|
before_action :conversation, except: [:index, :meta, :search, :create, :filter, :text_search]
|
||||||
before_action :inbox, :contact, :contact_inbox, only: [:create]
|
before_action :inbox, :contact, :contact_inbox, :text_search, only: [:create]
|
||||||
|
|
||||||
def index
|
def index
|
||||||
result = conversation_finder.perform
|
result = conversation_finder.perform
|
||||||
|
@ -11,6 +11,10 @@ class Api::V1::Accounts::ConversationsController < Api::V1::Accounts::BaseContro
|
||||||
@conversations_count = result[:count]
|
@conversations_count = result[:count]
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def text_search
|
||||||
|
@result = TextSearch.new(Current.user, params).perform
|
||||||
|
end
|
||||||
|
|
||||||
def meta
|
def meta
|
||||||
result = conversation_finder.perform
|
result = conversation_finder.perform
|
||||||
@conversations_count = result[:count]
|
@conversations_count = result[:count]
|
||||||
|
|
|
@ -18,10 +18,6 @@ class Api::V1::ProfilesController < Api::BaseController
|
||||||
head :ok
|
head :ok
|
||||||
end
|
end
|
||||||
|
|
||||||
def auto_offline
|
|
||||||
@user.account_users.find_by!(account_id: auto_offline_params[:account_id]).update!(auto_offline: auto_offline_params[:auto_offline] || false)
|
|
||||||
end
|
|
||||||
|
|
||||||
def availability
|
def availability
|
||||||
@user.account_users.find_by!(account_id: availability_params[:account_id]).update!(availability: availability_params[:availability])
|
@user.account_users.find_by!(account_id: availability_params[:account_id]).update!(availability: availability_params[:availability])
|
||||||
end
|
end
|
||||||
|
@ -41,10 +37,6 @@ class Api::V1::ProfilesController < Api::BaseController
|
||||||
params.require(:profile).permit(:account_id, :availability)
|
params.require(:profile).permit(:account_id, :availability)
|
||||||
end
|
end
|
||||||
|
|
||||||
def auto_offline_params
|
|
||||||
params.require(:profile).permit(:account_id, :auto_offline)
|
|
||||||
end
|
|
||||||
|
|
||||||
def profile_params
|
def profile_params
|
||||||
params.require(:profile).permit(
|
params.require(:profile).permit(
|
||||||
:email,
|
:email,
|
||||||
|
|
|
@ -1,7 +1,8 @@
|
||||||
class Platform::Api::V1::AccountsController < PlatformController
|
class Platform::Api::V1::AccountsController < PlatformController
|
||||||
def create
|
def create
|
||||||
@resource = Account.create!(account_params)
|
@resource = Account.new(account_params)
|
||||||
update_resource_features
|
update_resource_features
|
||||||
|
@resource.save!
|
||||||
@platform_app.platform_app_permissibles.find_or_create_by(permissible: @resource)
|
@platform_app.platform_app_permissibles.find_or_create_by(permissible: @resource)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
36
app/finders/text_search.rb
Normal file
36
app/finders/text_search.rb
Normal file
|
@ -0,0 +1,36 @@
|
||||||
|
class TextSearch
|
||||||
|
attr_reader :current_user, :current_account, :params
|
||||||
|
|
||||||
|
DEFAULT_STATUS = 'open'.freeze
|
||||||
|
|
||||||
|
def initialize(current_user, params)
|
||||||
|
@current_account = current_user.account || Current.account
|
||||||
|
@params = params
|
||||||
|
end
|
||||||
|
|
||||||
|
def perform
|
||||||
|
{
|
||||||
|
messages: filter_messages,
|
||||||
|
conversations: filter_conversations,
|
||||||
|
contacts: filter_contacts
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def filter_conversations
|
||||||
|
conversation_ids = PgSearch.multisearch("#{@params[:q]}%").where(account_id: @current_account,
|
||||||
|
searchable_type: 'Conversation').pluck(:searchable_id)
|
||||||
|
@conversations = Conversation.where(id: conversation_ids)
|
||||||
|
end
|
||||||
|
|
||||||
|
def filter_messages
|
||||||
|
message_ids = PgSearch.multisearch("#{@params[:q]}%").where(account_id: @current_account, searchable_type: 'Message').pluck(:searchable_id)
|
||||||
|
@messages = Message.where(id: message_ids)
|
||||||
|
end
|
||||||
|
|
||||||
|
def filter_contacts
|
||||||
|
contact_ids = PgSearch.multisearch("#{@params[:q]}%").where(account_id: @current_account, searchable_type: 'Contact').pluck(:searchable_id)
|
||||||
|
@contacts = Contact.where(id: contact_ids)
|
||||||
|
end
|
||||||
|
end
|
|
@ -144,12 +144,6 @@ export default {
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
updateAutoOffline(accountId, autoOffline = false) {
|
|
||||||
return axios.post(endPoints('autoOffline').url, {
|
|
||||||
profile: { account_id: accountId, auto_offline: autoOffline },
|
|
||||||
});
|
|
||||||
},
|
|
||||||
|
|
||||||
deleteAvatar() {
|
deleteAvatar() {
|
||||||
return axios.delete(endPoints('deleteAvatar').url);
|
return axios.delete(endPoints('deleteAvatar').url);
|
||||||
},
|
},
|
||||||
|
|
|
@ -16,9 +16,6 @@ const endPoints = {
|
||||||
availabilityUpdate: {
|
availabilityUpdate: {
|
||||||
url: '/api/v1/profile/availability',
|
url: '/api/v1/profile/availability',
|
||||||
},
|
},
|
||||||
autoOffline: {
|
|
||||||
url: '/api/v1/profile/auto_offline',
|
|
||||||
},
|
|
||||||
logout: {
|
logout: {
|
||||||
url: 'auth/sign_out',
|
url: 'auth/sign_out',
|
||||||
},
|
},
|
||||||
|
|
|
@ -45,6 +45,12 @@ class ConversationApi extends ApiClient {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
textSearch(query) {
|
||||||
|
return axios.post(`${this.url}/text_search`, null, {
|
||||||
|
params: { query },
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
toggleStatus({ conversationId, status, snoozedUntil = null }) {
|
toggleStatus({ conversationId, status, snoozedUntil = null }) {
|
||||||
return axios.post(`${this.url}/${conversationId}/toggle_status`, {
|
return axios.post(`${this.url}/${conversationId}/toggle_status`, {
|
||||||
status,
|
status,
|
||||||
|
|
|
@ -74,8 +74,8 @@ Tahoma,
|
||||||
Arial,
|
Arial,
|
||||||
sans-serif;
|
sans-serif;
|
||||||
$body-antialiased: true;
|
$body-antialiased: true;
|
||||||
$global-margin: $space-small;
|
$global-margin: $space-one;
|
||||||
$global-padding: $space-micro;
|
$global-padding: $space-one;
|
||||||
$global-weight-normal: normal;
|
$global-weight-normal: normal;
|
||||||
$global-weight-bold: bold;
|
$global-weight-bold: bold;
|
||||||
$global-radius: 0;
|
$global-radius: 0;
|
||||||
|
|
|
@ -20,24 +20,6 @@
|
||||||
|
|
||||||
@include foundation-everything($flex: true);
|
@include foundation-everything($flex: true);
|
||||||
|
|
||||||
@include foundation-prototype-text-utilities;
|
|
||||||
@include foundation-prototype-text-transformation;
|
|
||||||
@include foundation-prototype-text-decoration;
|
|
||||||
@include foundation-prototype-font-styling;
|
|
||||||
@include foundation-prototype-list-style-type;
|
|
||||||
@include foundation-prototype-rounded;
|
|
||||||
@include foundation-prototype-bordered;
|
|
||||||
@include foundation-prototype-shadow;
|
|
||||||
@include foundation-prototype-separator;
|
|
||||||
@include foundation-prototype-overflow;
|
|
||||||
@include foundation-prototype-display;
|
|
||||||
@include foundation-prototype-position;
|
|
||||||
@include foundation-prototype-border-box;
|
|
||||||
@include foundation-prototype-border-none;
|
|
||||||
@include foundation-prototype-sizing;
|
|
||||||
@include foundation-prototype-spacing;
|
|
||||||
|
|
||||||
|
|
||||||
@import 'typography';
|
@import 'typography';
|
||||||
@import 'layout';
|
@import 'layout';
|
||||||
@import 'animations';
|
@import 'animations';
|
||||||
|
|
|
@ -155,20 +155,12 @@ $default-button-height: 4.0rem;
|
||||||
// Sizes
|
// Sizes
|
||||||
&.tiny {
|
&.tiny {
|
||||||
height: var(--space-medium);
|
height: var(--space-medium);
|
||||||
|
|
||||||
.icon+.button__content {
|
|
||||||
padding-left: var(--space-micro);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
&.small {
|
&.small {
|
||||||
height: var(--space-large);
|
height: var(--space-large);
|
||||||
padding-bottom: var(--space-smaller);
|
padding-bottom: var(--space-smaller);
|
||||||
padding-top: var(--space-smaller);
|
padding-top: var(--space-smaller);
|
||||||
|
|
||||||
.icon+.button__content {
|
|
||||||
padding-left: var(--space-smaller);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
&.large {
|
&.large {
|
||||||
|
@ -198,10 +190,6 @@ $default-button-height: 4.0rem;
|
||||||
height: auto;
|
height: auto;
|
||||||
margin: 0;
|
margin: 0;
|
||||||
padding: 0;
|
padding: 0;
|
||||||
|
|
||||||
&:hover {
|
|
||||||
text-decoration: underline;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -59,8 +59,12 @@
|
||||||
|
|
||||||
.hamburger--menu {
|
.hamburger--menu {
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
display: block;
|
display: none;
|
||||||
margin-right: $space-normal;
|
margin-right: $space-normal;
|
||||||
|
|
||||||
|
@media screen and (max-width: 1200px) {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.header--icon {
|
.header--icon {
|
||||||
|
|
|
@ -1,12 +1,7 @@
|
||||||
<template>
|
<template>
|
||||||
<woot-button
|
<button @click="onMenuItemClick">
|
||||||
size="small"
|
<fluent-icon class="hamburger--menu" icon="list" />
|
||||||
variant="clear"
|
</button>
|
||||||
color-scheme="secondary"
|
|
||||||
icon="list"
|
|
||||||
class="toggle-sidebar"
|
|
||||||
@click="onMenuItemClick"
|
|
||||||
/>
|
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
|
@ -21,8 +16,13 @@ export default {
|
||||||
};
|
};
|
||||||
</script>
|
</script>
|
||||||
<style scoped lang="scss">
|
<style scoped lang="scss">
|
||||||
.toggle-sidebar {
|
.hamburger--menu {
|
||||||
margin-right: var(--space-small);
|
cursor: pointer;
|
||||||
margin-left: var(--space-minus-small);
|
display: none;
|
||||||
|
margin-right: var(--space-normal);
|
||||||
|
|
||||||
|
@media screen and (max-width: 1200px) {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|
|
@ -18,35 +18,12 @@
|
||||||
</woot-button>
|
</woot-button>
|
||||||
</woot-dropdown-item>
|
</woot-dropdown-item>
|
||||||
<woot-dropdown-divider />
|
<woot-dropdown-divider />
|
||||||
<woot-dropdown-item class="auto-offline--toggle">
|
|
||||||
<div class="info-wrap">
|
|
||||||
<fluent-icon
|
|
||||||
v-tooltip.right-start="$t('SIDEBAR.SET_AUTO_OFFLINE.INFO_TEXT')"
|
|
||||||
icon="info"
|
|
||||||
size="14"
|
|
||||||
class="info-icon"
|
|
||||||
/>
|
|
||||||
|
|
||||||
<span class="auto-offline--text">
|
|
||||||
{{ $t('SIDEBAR.SET_AUTO_OFFLINE.TEXT') }}
|
|
||||||
</span>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<woot-switch
|
|
||||||
size="small"
|
|
||||||
class="auto-offline--switch"
|
|
||||||
:value="currentUserAutoOffline"
|
|
||||||
@input="updateAutoOffline"
|
|
||||||
/>
|
|
||||||
</woot-dropdown-item>
|
|
||||||
<woot-dropdown-divider />
|
|
||||||
</woot-dropdown-menu>
|
</woot-dropdown-menu>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script>
|
<script>
|
||||||
import { mapGetters } from 'vuex';
|
import { mapGetters } from 'vuex';
|
||||||
import { mixin as clickaway } from 'vue-clickaway';
|
import { mixin as clickaway } from 'vue-clickaway';
|
||||||
import alertMixin from 'shared/mixins/alertMixin';
|
|
||||||
import WootDropdownItem from 'shared/components/ui/dropdown/DropdownItem';
|
import WootDropdownItem from 'shared/components/ui/dropdown/DropdownItem';
|
||||||
import WootDropdownMenu from 'shared/components/ui/dropdown/DropdownMenu';
|
import WootDropdownMenu from 'shared/components/ui/dropdown/DropdownMenu';
|
||||||
import WootDropdownHeader from 'shared/components/ui/dropdown/DropdownHeader';
|
import WootDropdownHeader from 'shared/components/ui/dropdown/DropdownHeader';
|
||||||
|
@ -64,7 +41,7 @@ export default {
|
||||||
AvailabilityStatusBadge,
|
AvailabilityStatusBadge,
|
||||||
},
|
},
|
||||||
|
|
||||||
mixins: [clickaway, alertMixin],
|
mixins: [clickaway],
|
||||||
|
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
|
@ -77,7 +54,6 @@ export default {
|
||||||
...mapGetters({
|
...mapGetters({
|
||||||
getCurrentUserAvailability: 'getCurrentUserAvailability',
|
getCurrentUserAvailability: 'getCurrentUserAvailability',
|
||||||
currentAccountId: 'getCurrentAccountId',
|
currentAccountId: 'getCurrentAccountId',
|
||||||
currentUserAutoOffline: 'getCurrentUserAutoOffline',
|
|
||||||
}),
|
}),
|
||||||
availabilityDisplayLabel() {
|
availabilityDisplayLabel() {
|
||||||
const availabilityIndex = AVAILABILITY_STATUS_KEYS.findIndex(
|
const availabilityIndex = AVAILABILITY_STATUS_KEYS.findIndex(
|
||||||
|
@ -109,30 +85,21 @@ export default {
|
||||||
closeStatusMenu() {
|
closeStatusMenu() {
|
||||||
this.isStatusMenuOpened = false;
|
this.isStatusMenuOpened = false;
|
||||||
},
|
},
|
||||||
updateAutoOffline(autoOffline) {
|
|
||||||
this.$store.dispatch('updateAutoOffline', {
|
|
||||||
accountId: this.currentAccountId,
|
|
||||||
autoOffline,
|
|
||||||
});
|
|
||||||
},
|
|
||||||
changeAvailabilityStatus(availability) {
|
changeAvailabilityStatus(availability) {
|
||||||
|
const accountId = this.currentAccountId;
|
||||||
if (this.isUpdating) {
|
if (this.isUpdating) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
this.isUpdating = true;
|
this.isUpdating = true;
|
||||||
try {
|
this.$store
|
||||||
this.$store.dispatch('updateAvailability', {
|
.dispatch('updateAvailability', {
|
||||||
availability,
|
availability: availability,
|
||||||
account_id: this.currentAccountId,
|
account_id: accountId,
|
||||||
|
})
|
||||||
|
.finally(() => {
|
||||||
|
this.isUpdating = false;
|
||||||
});
|
});
|
||||||
} catch (error) {
|
|
||||||
this.showAlert(
|
|
||||||
this.$t('PROFILE_SETTINGS.FORM.AVAILABILITY.SET_AVAILABILITY_ERROR')
|
|
||||||
);
|
|
||||||
} finally {
|
|
||||||
this.isUpdating = false;
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
@ -176,32 +143,4 @@ export default {
|
||||||
align-items: baseline;
|
align-items: baseline;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.auto-offline--toggle {
|
|
||||||
align-items: center;
|
|
||||||
display: flex;
|
|
||||||
justify-content: space-between;
|
|
||||||
padding: var(--space-smaller) 0 var(--space-smaller) var(--space-small);
|
|
||||||
margin: 0;
|
|
||||||
|
|
||||||
.info-wrap {
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
}
|
|
||||||
|
|
||||||
.info-icon {
|
|
||||||
margin-top: -1px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.auto-offline--switch {
|
|
||||||
margin: -1px var(--space-micro) 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.auto-offline--text {
|
|
||||||
margin: 0 var(--space-smaller);
|
|
||||||
font-size: var(--font-size-mini);
|
|
||||||
font-weight: var(--font-weight-medium);
|
|
||||||
color: var(--s-700);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
</style>
|
</style>
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
import { FEATURE_FLAGS } from '../../../../featureFlags';
|
|
||||||
import { frontendURL } from '../../../../helper/URLHelper';
|
import { frontendURL } from '../../../../helper/URLHelper';
|
||||||
|
|
||||||
const primaryMenuItems = accountId => [
|
const primaryMenuItems = accountId => [
|
||||||
|
@ -14,7 +13,6 @@ const primaryMenuItems = accountId => [
|
||||||
icon: 'book-contacts',
|
icon: 'book-contacts',
|
||||||
key: 'contacts',
|
key: 'contacts',
|
||||||
label: 'CONTACTS',
|
label: 'CONTACTS',
|
||||||
featureFlag: FEATURE_FLAGS.CRM,
|
|
||||||
toState: frontendURL(`accounts/${accountId}/contacts`),
|
toState: frontendURL(`accounts/${accountId}/contacts`),
|
||||||
toStateName: 'contacts_dashboard',
|
toStateName: 'contacts_dashboard',
|
||||||
roles: ['administrator', 'agent'],
|
roles: ['administrator', 'agent'],
|
||||||
|
@ -23,7 +21,6 @@ const primaryMenuItems = accountId => [
|
||||||
icon: 'arrow-trending-lines',
|
icon: 'arrow-trending-lines',
|
||||||
key: 'reports',
|
key: 'reports',
|
||||||
label: 'REPORTS',
|
label: 'REPORTS',
|
||||||
featureFlag: FEATURE_FLAGS.REPORTS,
|
|
||||||
toState: frontendURL(`accounts/${accountId}/reports`),
|
toState: frontendURL(`accounts/${accountId}/reports`),
|
||||||
toStateName: 'settings_account_reports',
|
toStateName: 'settings_account_reports',
|
||||||
roles: ['administrator'],
|
roles: ['administrator'],
|
||||||
|
@ -32,7 +29,6 @@ const primaryMenuItems = accountId => [
|
||||||
icon: 'megaphone',
|
icon: 'megaphone',
|
||||||
key: 'campaigns',
|
key: 'campaigns',
|
||||||
label: 'CAMPAIGNS',
|
label: 'CAMPAIGNS',
|
||||||
featureFlag: FEATURE_FLAGS.CAMPAIGNS,
|
|
||||||
toState: frontendURL(`accounts/${accountId}/campaigns`),
|
toState: frontendURL(`accounts/${accountId}/campaigns`),
|
||||||
toStateName: 'settings_account_campaigns',
|
toStateName: 'settings_account_campaigns',
|
||||||
roles: ['administrator'],
|
roles: ['administrator'],
|
||||||
|
@ -41,7 +37,7 @@ const primaryMenuItems = accountId => [
|
||||||
icon: 'library',
|
icon: 'library',
|
||||||
key: 'helpcenter',
|
key: 'helpcenter',
|
||||||
label: 'HELP_CENTER.TITLE',
|
label: 'HELP_CENTER.TITLE',
|
||||||
featureFlag: FEATURE_FLAGS.HELP_CENTER,
|
featureFlag: 'help_center',
|
||||||
toState: frontendURL(`accounts/${accountId}/portals`),
|
toState: frontendURL(`accounts/${accountId}/portals`),
|
||||||
toStateName: 'default_portal_articles',
|
toStateName: 'default_portal_articles',
|
||||||
roles: ['administrator'],
|
roles: ['administrator'],
|
||||||
|
|
|
@ -102,7 +102,6 @@ const settings = accountId => ({
|
||||||
label: 'AGENT_BOTS',
|
label: 'AGENT_BOTS',
|
||||||
beta: true,
|
beta: true,
|
||||||
hasSubMenu: false,
|
hasSubMenu: false,
|
||||||
globalConfigFlag: 'csmlEditorHost',
|
|
||||||
toState: frontendURL(`accounts/${accountId}/settings/agent-bots`),
|
toState: frontendURL(`accounts/${accountId}/settings/agent-bots`),
|
||||||
toStateName: 'agent_bots',
|
toStateName: 'agent_bots',
|
||||||
featureFlag: FEATURE_FLAGS.AGENT_BOTS,
|
featureFlag: FEATURE_FLAGS.AGENT_BOTS,
|
||||||
|
|
|
@ -61,24 +61,6 @@
|
||||||
</a>
|
</a>
|
||||||
</router-link>
|
</router-link>
|
||||||
</woot-dropdown-item>
|
</woot-dropdown-item>
|
||||||
<woot-dropdown-item v-if="currentUser.type === 'SuperAdmin'">
|
|
||||||
<a
|
|
||||||
href="/super_admin"
|
|
||||||
class="button small clear secondary"
|
|
||||||
target="_blank"
|
|
||||||
rel="noopener nofollow noreferrer"
|
|
||||||
@click="$emit('close')"
|
|
||||||
>
|
|
||||||
<fluent-icon
|
|
||||||
icon="content-settings"
|
|
||||||
size="14"
|
|
||||||
class="icon icon--font"
|
|
||||||
/>
|
|
||||||
<span class="button__content">
|
|
||||||
{{ $t('SIDEBAR_ITEMS.SUPER_ADMIN_CONSOLE') }}
|
|
||||||
</span>
|
|
||||||
</a>
|
|
||||||
</woot-dropdown-item>
|
|
||||||
<woot-dropdown-item>
|
<woot-dropdown-item>
|
||||||
<woot-button
|
<woot-button
|
||||||
variant="clear"
|
variant="clear"
|
||||||
|
@ -153,7 +135,7 @@ export default {
|
||||||
.dropdown-pane {
|
.dropdown-pane {
|
||||||
left: var(--space-slab);
|
left: var(--space-slab);
|
||||||
bottom: var(--space-larger);
|
bottom: var(--space-larger);
|
||||||
min-width: 22rem;
|
min-width: 16.8rem;
|
||||||
z-index: var(--z-index-low);
|
z-index: var(--z-index-much-higher);
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|
|
@ -261,7 +261,14 @@ export default {
|
||||||
width: 20rem;
|
width: 20rem;
|
||||||
flex-shrink: 0;
|
flex-shrink: 0;
|
||||||
overflow-y: hidden;
|
overflow-y: hidden;
|
||||||
position: unset;
|
|
||||||
|
@include breakpoint(xlarge down) {
|
||||||
|
position: absolute;
|
||||||
|
}
|
||||||
|
|
||||||
|
@include breakpoint(xlarge up) {
|
||||||
|
position: unset;
|
||||||
|
}
|
||||||
|
|
||||||
&:hover {
|
&:hover {
|
||||||
overflow-y: hidden;
|
overflow-y: hidden;
|
||||||
|
|
|
@ -106,22 +106,18 @@ export default {
|
||||||
activeInbox: 'getSelectedInbox',
|
activeInbox: 'getSelectedInbox',
|
||||||
accountId: 'getCurrentAccountId',
|
accountId: 'getCurrentAccountId',
|
||||||
isFeatureEnabledonAccount: 'accounts/isFeatureEnabledonAccount',
|
isFeatureEnabledonAccount: 'accounts/isFeatureEnabledonAccount',
|
||||||
globalConfig: 'globalConfig/get',
|
|
||||||
}),
|
}),
|
||||||
hasSubMenu() {
|
hasSubMenu() {
|
||||||
return !!this.menuItem.children;
|
return !!this.menuItem.children;
|
||||||
},
|
},
|
||||||
isMenuItemVisible() {
|
isMenuItemVisible() {
|
||||||
if (this.menuItem.globalConfigFlag) {
|
if (!this.menuItem.featureFlag) {
|
||||||
return !!this.globalConfig[this.menuItem.globalConfigFlag];
|
return true;
|
||||||
}
|
}
|
||||||
if (this.menuItem.featureFlag) {
|
return this.isFeatureEnabledonAccount(
|
||||||
return this.isFeatureEnabledonAccount(
|
this.accountId,
|
||||||
this.accountId,
|
this.menuItem.featureFlag
|
||||||
this.menuItem.featureFlag
|
);
|
||||||
);
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
},
|
},
|
||||||
isAllConversations() {
|
isAllConversations() {
|
||||||
return (
|
return (
|
||||||
|
|
|
@ -1,11 +1,10 @@
|
||||||
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
// Jest Snapshot v1, https://goo.gl/fbAQLP
|
||||||
|
|
||||||
exports[`SidemenuIcon matches snapshot 1`] = `
|
exports[`SidemenuIcon matches snapshot 1`] = `
|
||||||
<woot-button
|
<button>
|
||||||
class="toggle-sidebar"
|
<fluent-icon
|
||||||
color-scheme="secondary"
|
class="hamburger--menu"
|
||||||
icon="list"
|
icon="list"
|
||||||
size="small"
|
/>
|
||||||
variant="clear"
|
</button>
|
||||||
/>
|
|
||||||
`;
|
`;
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
<fluent-icon :icon="icon" size="12" class="label--icon" />
|
<fluent-icon :icon="icon" size="12" class="label--icon" />
|
||||||
</span>
|
</span>
|
||||||
<span
|
<span
|
||||||
v-if="variant === 'smooth' && title && !icon"
|
v-if="variant === 'smooth'"
|
||||||
:style="{ background: color }"
|
:style="{ background: color }"
|
||||||
class="label-color-dot"
|
class="label-color-dot"
|
||||||
/>
|
/>
|
||||||
|
@ -117,16 +117,14 @@ export default {
|
||||||
height: var(--space-medium);
|
height: var(--space-medium);
|
||||||
|
|
||||||
&.small {
|
&.small {
|
||||||
font-size: var(--font-size-mini);
|
font-size: var(--font-size-micro);
|
||||||
padding: var(--space-micro) var(--space-smaller);
|
padding: var(--space-micro) var(--space-smaller);
|
||||||
line-height: 1.2;
|
line-height: 1.2;
|
||||||
height: var(--space-two);
|
letter-spacing: 0.15px;
|
||||||
}
|
}
|
||||||
|
|
||||||
.label--icon {
|
.label--icon {
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
}
|
|
||||||
.label-color-dot {
|
|
||||||
margin-right: var(--space-smaller);
|
margin-right: var(--space-smaller);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -201,8 +199,8 @@ export default {
|
||||||
|
|
||||||
&.smooth {
|
&.smooth {
|
||||||
background: transparent;
|
background: transparent;
|
||||||
border: 1px solid var(--s-100);
|
border: 1px solid var(--s-75);
|
||||||
color: var(--s-700);
|
color: var(--s-800);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -223,22 +221,14 @@ export default {
|
||||||
}
|
}
|
||||||
|
|
||||||
.label-action--button {
|
.label-action--button {
|
||||||
display: flex;
|
margin-bottom: var(--space-minus-micro);
|
||||||
margin-right: var(--space-smaller);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.label-color-dot {
|
.label-color-dot {
|
||||||
display: inline-block;
|
display: inline-block;
|
||||||
width: var(--space-slab);
|
width: var(--space-one);
|
||||||
height: var(--space-slab);
|
height: var(--space-one);
|
||||||
border-radius: var(--border-radius-small);
|
border-radius: var(--border-radius-small);
|
||||||
margin-right: var(--space-smaller);
|
margin-right: var(--space-smaller);
|
||||||
box-shadow: var(--shadow-small);
|
|
||||||
}
|
|
||||||
.label.small .label-color-dot {
|
|
||||||
width: var(--space-small);
|
|
||||||
height: var(--space-small);
|
|
||||||
border-radius: var(--border-radius-small);
|
|
||||||
box-shadow: var(--shadow-small);
|
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
<button
|
<button
|
||||||
type="button"
|
type="button"
|
||||||
class="toggle-button"
|
class="toggle-button"
|
||||||
:class="{ active: value, small: size === 'small' }"
|
:class="{ active: value }"
|
||||||
role="switch"
|
role="switch"
|
||||||
:aria-checked="value.toString()"
|
:aria-checked="value.toString()"
|
||||||
@click="onClick"
|
@click="onClick"
|
||||||
|
@ -15,7 +15,6 @@
|
||||||
export default {
|
export default {
|
||||||
props: {
|
props: {
|
||||||
value: { type: Boolean, default: false },
|
value: { type: Boolean, default: false },
|
||||||
size: { type: String, default: '' },
|
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
onClick() {
|
onClick() {
|
||||||
|
@ -46,20 +45,6 @@ export default {
|
||||||
background-color: var(--w-500);
|
background-color: var(--w-500);
|
||||||
}
|
}
|
||||||
|
|
||||||
&.small {
|
|
||||||
width: 22px;
|
|
||||||
height: 14px;
|
|
||||||
|
|
||||||
span {
|
|
||||||
height: var(--space-one);
|
|
||||||
width: var(--space-one);
|
|
||||||
|
|
||||||
&.active {
|
|
||||||
transform: translate(var(--space-small), var(--space-zero));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
span {
|
span {
|
||||||
--space-one-point-five: 1.5rem;
|
--space-one-point-five: 1.5rem;
|
||||||
background-color: var(--white);
|
background-color: var(--white);
|
||||||
|
|
|
@ -67,9 +67,6 @@ export default {
|
||||||
if (Object.keys(this.enabledFeatures).length === 0) {
|
if (Object.keys(this.enabledFeatures).length === 0) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (key === 'website') {
|
|
||||||
return this.enabledFeatures.channel_website;
|
|
||||||
}
|
|
||||||
if (key === 'facebook') {
|
if (key === 'facebook') {
|
||||||
return this.enabledFeatures.channel_facebook;
|
return this.enabledFeatures.channel_facebook;
|
||||||
}
|
}
|
||||||
|
|
|
@ -61,7 +61,6 @@ export default {
|
||||||
}
|
}
|
||||||
|
|
||||||
.colorpicker--selected {
|
.colorpicker--selected {
|
||||||
border: 1px solid var(--color-border-light);
|
|
||||||
border-radius: $space-smaller;
|
border-radius: $space-smaller;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
height: $space-large;
|
height: $space-large;
|
||||||
|
|
|
@ -10,11 +10,11 @@ import 'videojs-record/dist/css/videojs.record.css';
|
||||||
|
|
||||||
import videojs from 'video.js';
|
import videojs from 'video.js';
|
||||||
|
|
||||||
|
import inboxMixin from '../../../../shared/mixins/inboxMixin';
|
||||||
import alertMixin from '../../../../shared/mixins/alertMixin';
|
import alertMixin from '../../../../shared/mixins/alertMixin';
|
||||||
|
|
||||||
import Recorder from 'opus-recorder';
|
import Recorder from 'opus-recorder';
|
||||||
import encoderWorker from 'opus-recorder/dist/encoderWorker.min';
|
import encoderWorker from 'opus-recorder/dist/encoderWorker.min';
|
||||||
import waveWorker from 'opus-recorder/dist/waveWorker.min';
|
|
||||||
|
|
||||||
import WaveSurfer from 'wavesurfer.js';
|
import WaveSurfer from 'wavesurfer.js';
|
||||||
import MicrophonePlugin from 'wavesurfer.js/dist/plugin/wavesurfer.microphone.js';
|
import MicrophonePlugin from 'wavesurfer.js/dist/plugin/wavesurfer.microphone.js';
|
||||||
|
@ -29,19 +29,14 @@ WaveSurfer.microphone = MicrophonePlugin;
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: 'WootAudioRecorder',
|
name: 'WootAudioRecorder',
|
||||||
mixins: [alertMixin],
|
mixins: [inboxMixin, alertMixin],
|
||||||
props: {
|
|
||||||
audioRecordFormat: {
|
|
||||||
type: String,
|
|
||||||
default: AUDIO_FORMATS.WEBM,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
data() {
|
data() {
|
||||||
return {
|
return {
|
||||||
player: false,
|
player: false,
|
||||||
recordingDateStarted: new Date(0),
|
recordingDateStarted: new Date(0),
|
||||||
initialTimeDuration: '00:00',
|
initialTimeDuration: '00:00',
|
||||||
recorderOptions: {
|
recorderOptions: {
|
||||||
|
debug: true,
|
||||||
controls: true,
|
controls: true,
|
||||||
bigPlayButton: false,
|
bigPlayButton: false,
|
||||||
fluid: false,
|
fluid: false,
|
||||||
|
@ -76,9 +71,6 @@ export default {
|
||||||
record: {
|
record: {
|
||||||
audio: true,
|
audio: true,
|
||||||
video: false,
|
video: false,
|
||||||
maxLength: 900,
|
|
||||||
timeSlice: 1000,
|
|
||||||
maxFileSize: 15 * 1024 * 1024,
|
|
||||||
...(this.audioRecordFormat === AUDIO_FORMATS.WEBM && {
|
...(this.audioRecordFormat === AUDIO_FORMATS.WEBM && {
|
||||||
monitorGain: 0,
|
monitorGain: 0,
|
||||||
recordingGain: 1,
|
recordingGain: 1,
|
||||||
|
@ -88,10 +80,11 @@ export default {
|
||||||
streamPages: true,
|
streamPages: true,
|
||||||
maxFramesPerPage: 1,
|
maxFramesPerPage: 1,
|
||||||
encoderFrameSize: 1,
|
encoderFrameSize: 1,
|
||||||
encoderPath: waveWorker,
|
encoderPath: 'opus-recorder/dist/waveWorker.min.js',
|
||||||
}),
|
}),
|
||||||
...(this.audioRecordFormat === AUDIO_FORMATS.OGG && {
|
...(this.audioRecordFormat === AUDIO_FORMATS.OGG && {
|
||||||
displayMilliseconds: false,
|
displayMilliseconds: false,
|
||||||
|
maxLength: 300,
|
||||||
audioEngine: 'opus-recorder',
|
audioEngine: 'opus-recorder',
|
||||||
audioWorkerURL: encoderWorker,
|
audioWorkerURL: encoderWorker,
|
||||||
audioChannels: 1,
|
audioChannels: 1,
|
||||||
|
@ -107,6 +100,12 @@ export default {
|
||||||
isRecording() {
|
isRecording() {
|
||||||
return this.player && this.player.record().isRecording();
|
return this.player && this.player.record().isRecording();
|
||||||
},
|
},
|
||||||
|
audioRecordFormat() {
|
||||||
|
if (this.isAWebWidgetInbox) {
|
||||||
|
return AUDIO_FORMATS.WEBM;
|
||||||
|
}
|
||||||
|
return AUDIO_FORMATS.OGG;
|
||||||
|
},
|
||||||
},
|
},
|
||||||
mounted() {
|
mounted() {
|
||||||
window.Recorder = Recorder;
|
window.Recorder = Recorder;
|
||||||
|
|
|
@ -91,7 +91,6 @@
|
||||||
</span>
|
</span>
|
||||||
<span class="unread">{{ unreadCount > 9 ? '9+' : unreadCount }}</span>
|
<span class="unread">{{ unreadCount > 9 ? '9+' : unreadCount }}</span>
|
||||||
</div>
|
</div>
|
||||||
<card-labels :conversation-id="chat.id" />
|
|
||||||
</div>
|
</div>
|
||||||
<woot-context-menu
|
<woot-context-menu
|
||||||
v-if="showContextMenu"
|
v-if="showContextMenu"
|
||||||
|
@ -126,8 +125,8 @@ import InboxName from '../InboxName';
|
||||||
import inboxMixin from 'shared/mixins/inboxMixin';
|
import inboxMixin from 'shared/mixins/inboxMixin';
|
||||||
import ConversationContextMenu from './contextMenu/Index.vue';
|
import ConversationContextMenu from './contextMenu/Index.vue';
|
||||||
import alertMixin from 'shared/mixins/alertMixin';
|
import alertMixin from 'shared/mixins/alertMixin';
|
||||||
import TimeAgo from 'dashboard/components/ui/TimeAgo';
|
import timeAgo from 'dashboard/components/ui/TimeAgo';
|
||||||
import CardLabels from './conversationCardComponents/CardLabels.vue';
|
|
||||||
const ATTACHMENT_ICONS = {
|
const ATTACHMENT_ICONS = {
|
||||||
image: 'image',
|
image: 'image',
|
||||||
audio: 'headphones-sound-wave',
|
audio: 'headphones-sound-wave',
|
||||||
|
@ -139,11 +138,10 @@ const ATTACHMENT_ICONS = {
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
components: {
|
components: {
|
||||||
CardLabels,
|
|
||||||
InboxName,
|
InboxName,
|
||||||
Thumbnail,
|
Thumbnail,
|
||||||
ConversationContextMenu,
|
ConversationContextMenu,
|
||||||
TimeAgo,
|
timeAgo,
|
||||||
},
|
},
|
||||||
|
|
||||||
mixins: [
|
mixins: [
|
||||||
|
@ -372,15 +370,11 @@ export default {
|
||||||
</script>
|
</script>
|
||||||
<style lang="scss" scoped>
|
<style lang="scss" scoped>
|
||||||
.conversation {
|
.conversation {
|
||||||
align-items: flex-start;
|
align-items: center;
|
||||||
|
|
||||||
&:hover {
|
&:hover {
|
||||||
background: var(--color-background-light);
|
background: var(--color-background-light);
|
||||||
}
|
}
|
||||||
|
|
||||||
&::v-deep .user-thumbnail-box {
|
|
||||||
margin-top: var(--space-normal);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
.conversation-selected {
|
.conversation-selected {
|
||||||
|
@ -389,10 +383,8 @@ export default {
|
||||||
|
|
||||||
.has-inbox-name {
|
.has-inbox-name {
|
||||||
&::v-deep .user-thumbnail-box {
|
&::v-deep .user-thumbnail-box {
|
||||||
margin-top: var(--space-large);
|
margin-top: var(--space-normal);
|
||||||
}
|
align-items: flex-start;
|
||||||
.checkbox-wrapper {
|
|
||||||
margin-top: var(--space-large);
|
|
||||||
}
|
}
|
||||||
.conversation--meta {
|
.conversation--meta {
|
||||||
margin-top: var(--space-normal);
|
margin-top: var(--space-normal);
|
||||||
|
@ -437,7 +429,6 @@ export default {
|
||||||
margin-top: var(--space-minus-micro);
|
margin-top: var(--space-minus-micro);
|
||||||
vertical-align: middle;
|
vertical-align: middle;
|
||||||
}
|
}
|
||||||
|
|
||||||
.checkbox-wrapper {
|
.checkbox-wrapper {
|
||||||
height: 40px;
|
height: 40px;
|
||||||
width: 40px;
|
width: 40px;
|
||||||
|
@ -447,7 +438,6 @@ export default {
|
||||||
border-radius: 100%;
|
border-radius: 100%;
|
||||||
margin-top: var(--space-normal);
|
margin-top: var(--space-normal);
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
|
|
||||||
&:hover {
|
&:hover {
|
||||||
background-color: var(--w-100);
|
background-color: var(--w-100);
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,11 +21,7 @@
|
||||||
/>
|
/>
|
||||||
</h3>
|
</h3>
|
||||||
<div class="conversation--header--actions">
|
<div class="conversation--header--actions">
|
||||||
<inbox-name
|
<inbox-name :inbox="inbox" class="margin-right-small" />
|
||||||
v-if="hasMultipleInboxes"
|
|
||||||
:inbox="inbox"
|
|
||||||
class="margin-right-small"
|
|
||||||
/>
|
|
||||||
<span
|
<span
|
||||||
v-if="isSnoozed"
|
v-if="isSnoozed"
|
||||||
class="snoozed--display-text margin-right-small"
|
class="snoozed--display-text margin-right-small"
|
||||||
|
@ -149,9 +145,6 @@ export default {
|
||||||
const { inbox_id: inboxId } = this.chat;
|
const { inbox_id: inboxId } = this.chat;
|
||||||
return this.$store.getters['inboxes/getInbox'](inboxId);
|
return this.$store.getters['inboxes/getInbox'](inboxId);
|
||||||
},
|
},
|
||||||
hasMultipleInboxes() {
|
|
||||||
return this.$store.getters['inboxes/getInboxes'].length > 1;
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
|
|
||||||
methods: {
|
methods: {
|
||||||
|
|
|
@ -15,6 +15,7 @@
|
||||||
v-if="data.content"
|
v-if="data.content"
|
||||||
:message="message"
|
:message="message"
|
||||||
:is-email="isEmailContentType"
|
:is-email="isEmailContentType"
|
||||||
|
:readable-time="readableTime"
|
||||||
:display-quoted-button="displayQuotedButton"
|
:display-quoted-button="displayQuotedButton"
|
||||||
/>
|
/>
|
||||||
<span
|
<span
|
||||||
|
@ -28,6 +29,7 @@
|
||||||
<bubble-image
|
<bubble-image
|
||||||
v-if="attachment.file_type === 'image' && !hasImageError"
|
v-if="attachment.file_type === 'image' && !hasImageError"
|
||||||
:url="attachment.data_url"
|
:url="attachment.data_url"
|
||||||
|
:readable-time="readableTime"
|
||||||
@error="onImageLoadError"
|
@error="onImageLoadError"
|
||||||
/>
|
/>
|
||||||
<audio v-else-if="attachment.file_type === 'audio'" controls>
|
<audio v-else-if="attachment.file_type === 'audio'" controls>
|
||||||
|
@ -36,6 +38,7 @@
|
||||||
<bubble-video
|
<bubble-video
|
||||||
v-else-if="attachment.file_type === 'video'"
|
v-else-if="attachment.file_type === 'video'"
|
||||||
:url="attachment.data_url"
|
:url="attachment.data_url"
|
||||||
|
:readable-time="readableTime"
|
||||||
/>
|
/>
|
||||||
<bubble-location
|
<bubble-location
|
||||||
v-else-if="attachment.file_type === 'location'"
|
v-else-if="attachment.file_type === 'location'"
|
||||||
|
@ -43,7 +46,11 @@
|
||||||
:longitude="attachment.coordinates_long"
|
:longitude="attachment.coordinates_long"
|
||||||
:name="attachment.fallback_title"
|
:name="attachment.fallback_title"
|
||||||
/>
|
/>
|
||||||
<bubble-file v-else :url="attachment.data_url" />
|
<bubble-file
|
||||||
|
v-else
|
||||||
|
:url="attachment.data_url"
|
||||||
|
:readable-time="readableTime"
|
||||||
|
/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<bubble-actions
|
<bubble-actions
|
||||||
|
@ -58,9 +65,10 @@
|
||||||
:is-private="data.private"
|
:is-private="data.private"
|
||||||
:message-type="data.message_type"
|
:message-type="data.message_type"
|
||||||
:message-status="status"
|
:message-status="status"
|
||||||
|
:readable-time="readableTime"
|
||||||
:source-id="data.source_id"
|
:source-id="data.source_id"
|
||||||
:inbox-id="data.inbox_id"
|
:inbox-id="data.inbox_id"
|
||||||
:created-at="createdAt"
|
:message-read="showReadTicks"
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
<spinner v-if="isPending" size="tiny" />
|
<spinner v-if="isPending" size="tiny" />
|
||||||
|
@ -111,6 +119,8 @@
|
||||||
</template>
|
</template>
|
||||||
<script>
|
<script>
|
||||||
import messageFormatterMixin from 'shared/mixins/messageFormatterMixin';
|
import messageFormatterMixin from 'shared/mixins/messageFormatterMixin';
|
||||||
|
import timeMixin from '../../../mixins/time';
|
||||||
|
|
||||||
import BubbleMailHead from './bubble/MailHead';
|
import BubbleMailHead from './bubble/MailHead';
|
||||||
import BubbleText from './bubble/Text';
|
import BubbleText from './bubble/Text';
|
||||||
import BubbleImage from './bubble/Image';
|
import BubbleImage from './bubble/Image';
|
||||||
|
@ -139,7 +149,7 @@ export default {
|
||||||
ContextMenu,
|
ContextMenu,
|
||||||
Spinner,
|
Spinner,
|
||||||
},
|
},
|
||||||
mixins: [alertMixin, messageFormatterMixin, contentTypeMixin],
|
mixins: [alertMixin, timeMixin, messageFormatterMixin, contentTypeMixin],
|
||||||
props: {
|
props: {
|
||||||
data: {
|
data: {
|
||||||
type: Object,
|
type: Object,
|
||||||
|
@ -157,6 +167,10 @@ export default {
|
||||||
type: Boolean,
|
type: Boolean,
|
||||||
default: false,
|
default: false,
|
||||||
},
|
},
|
||||||
|
hasUserReadMessage: {
|
||||||
|
type: Boolean,
|
||||||
|
default: false,
|
||||||
|
},
|
||||||
isWebWidgetInbox: {
|
isWebWidgetInbox: {
|
||||||
type: Boolean,
|
type: Boolean,
|
||||||
default: false,
|
default: false,
|
||||||
|
@ -259,8 +273,11 @@ export default {
|
||||||
'has-tweet-menu': this.isATweet,
|
'has-tweet-menu': this.isATweet,
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
createdAt() {
|
readableTime() {
|
||||||
return this.contentAttributes.external_created_at || this.data.created_at;
|
return this.messageStamp(
|
||||||
|
this.contentAttributes.external_created_at || this.data.created_at,
|
||||||
|
'LLL d, h:mm a'
|
||||||
|
);
|
||||||
},
|
},
|
||||||
isBubble() {
|
isBubble() {
|
||||||
return [0, 1, 3].includes(this.data.message_type);
|
return [0, 1, 3].includes(this.data.message_type);
|
||||||
|
@ -271,6 +288,14 @@ export default {
|
||||||
isOutgoing() {
|
isOutgoing() {
|
||||||
return this.data.message_type === MESSAGE_TYPE.OUTGOING;
|
return this.data.message_type === MESSAGE_TYPE.OUTGOING;
|
||||||
},
|
},
|
||||||
|
showReadTicks() {
|
||||||
|
return (
|
||||||
|
(this.isOutgoing || this.isTemplate) &&
|
||||||
|
this.hasUserReadMessage &&
|
||||||
|
this.isWebWidgetInbox &&
|
||||||
|
!this.data.private
|
||||||
|
);
|
||||||
|
},
|
||||||
isTemplate() {
|
isTemplate() {
|
||||||
return this.data.message_type === MESSAGE_TYPE.TEMPLATE;
|
return this.data.message_type === MESSAGE_TYPE.TEMPLATE;
|
||||||
},
|
},
|
||||||
|
|
|
@ -40,6 +40,9 @@
|
||||||
:is-a-tweet="isATweet"
|
:is-a-tweet="isATweet"
|
||||||
:is-a-whatsapp-channel="isAWhatsAppChannel"
|
:is-a-whatsapp-channel="isAWhatsAppChannel"
|
||||||
:has-instagram-story="hasInstagramStory"
|
:has-instagram-story="hasInstagramStory"
|
||||||
|
:has-user-read-message="
|
||||||
|
hasUserReadMessage(message.created_at, getLastSeenAt)
|
||||||
|
"
|
||||||
:is-web-widget-inbox="isAWebWidgetInbox"
|
:is-web-widget-inbox="isAWebWidgetInbox"
|
||||||
/>
|
/>
|
||||||
<li v-show="unreadMessageCount != 0" class="unread--toast">
|
<li v-show="unreadMessageCount != 0" class="unread--toast">
|
||||||
|
@ -60,6 +63,9 @@
|
||||||
:is-a-tweet="isATweet"
|
:is-a-tweet="isATweet"
|
||||||
:is-a-whatsapp-channel="isAWhatsAppChannel"
|
:is-a-whatsapp-channel="isAWhatsAppChannel"
|
||||||
:has-instagram-story="hasInstagramStory"
|
:has-instagram-story="hasInstagramStory"
|
||||||
|
:has-user-read-message="
|
||||||
|
hasUserReadMessage(message.created_at, getLastSeenAt)
|
||||||
|
"
|
||||||
:is-web-widget-inbox="isAWebWidgetInbox"
|
:is-web-widget-inbox="isAWebWidgetInbox"
|
||||||
/>
|
/>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
|
@ -37,7 +37,6 @@
|
||||||
<woot-audio-recorder
|
<woot-audio-recorder
|
||||||
v-if="showAudioRecorderEditor"
|
v-if="showAudioRecorderEditor"
|
||||||
ref="audioRecorderInput"
|
ref="audioRecorderInput"
|
||||||
:audio-record-format="audioRecordFormat"
|
|
||||||
@state-recorder-progress-changed="onStateProgressRecorderChanged"
|
@state-recorder-progress-changed="onStateProgressRecorderChanged"
|
||||||
@state-recorder-changed="onStateRecorderChanged"
|
@state-recorder-changed="onStateRecorderChanged"
|
||||||
@finish-record="onFinishRecorder"
|
@finish-record="onFinishRecorder"
|
||||||
|
@ -148,7 +147,6 @@ import { checkFileSizeLimit } from 'shared/helpers/FileHelper';
|
||||||
import {
|
import {
|
||||||
MAXIMUM_FILE_UPLOAD_SIZE,
|
MAXIMUM_FILE_UPLOAD_SIZE,
|
||||||
MAXIMUM_FILE_UPLOAD_SIZE_TWILIO_SMS_CHANNEL,
|
MAXIMUM_FILE_UPLOAD_SIZE_TWILIO_SMS_CHANNEL,
|
||||||
AUDIO_FORMATS,
|
|
||||||
} from 'shared/constants/messages';
|
} from 'shared/constants/messages';
|
||||||
import { BUS_EVENTS } from 'shared/constants/busEvents';
|
import { BUS_EVENTS } from 'shared/constants/busEvents';
|
||||||
|
|
||||||
|
@ -464,12 +462,6 @@ export default {
|
||||||
editorStateId() {
|
editorStateId() {
|
||||||
return `draft-${this.conversationIdByRoute}-${this.replyType}`;
|
return `draft-${this.conversationIdByRoute}-${this.replyType}`;
|
||||||
},
|
},
|
||||||
audioRecordFormat() {
|
|
||||||
if (this.isAWebWidgetInbox) {
|
|
||||||
return AUDIO_FORMATS.WEBM;
|
|
||||||
}
|
|
||||||
return AUDIO_FORMATS.OGG;
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
watch: {
|
watch: {
|
||||||
currentChat(conversation) {
|
currentChat(conversation) {
|
||||||
|
|
|
@ -1,14 +1,8 @@
|
||||||
<template>
|
<template>
|
||||||
<div class="message-text--metadata">
|
<div class="message-text--metadata">
|
||||||
<span
|
<span class="time" :class="{ delivered: messageRead }">{{
|
||||||
class="time"
|
readableTime
|
||||||
:class="{
|
}}</span>
|
||||||
'has-status-icon':
|
|
||||||
showSentIndicator || showDeliveredIndicator || showReadIndicator,
|
|
||||||
}"
|
|
||||||
>
|
|
||||||
{{ readableTime }}
|
|
||||||
</span>
|
|
||||||
<span v-if="showReadIndicator" class="read-indicator-wrap">
|
<span v-if="showReadIndicator" class="read-indicator-wrap">
|
||||||
<fluent-icon
|
<fluent-icon
|
||||||
v-tooltip.top-start="$t('CHAT_LIST.MESSAGE_READ')"
|
v-tooltip.top-start="$t('CHAT_LIST.MESSAGE_READ')"
|
||||||
|
@ -17,7 +11,7 @@
|
||||||
size="14"
|
size="14"
|
||||||
/>
|
/>
|
||||||
</span>
|
</span>
|
||||||
<span v-else-if="showDeliveredIndicator" class="read-indicator-wrap">
|
<span v-if="showDeliveredIndicator" class="read-indicator-wrap">
|
||||||
<fluent-icon
|
<fluent-icon
|
||||||
v-tooltip.top-start="$t('CHAT_LIST.DELIVERED')"
|
v-tooltip.top-start="$t('CHAT_LIST.DELIVERED')"
|
||||||
icon="checkmark-double"
|
icon="checkmark-double"
|
||||||
|
@ -25,7 +19,7 @@
|
||||||
size="14"
|
size="14"
|
||||||
/>
|
/>
|
||||||
</span>
|
</span>
|
||||||
<span v-else-if="showSentIndicator" class="read-indicator-wrap">
|
<span v-if="showSentIndicator" class="read-indicator-wrap">
|
||||||
<fluent-icon
|
<fluent-icon
|
||||||
v-tooltip.top-start="$t('CHAT_LIST.SENT')"
|
v-tooltip.top-start="$t('CHAT_LIST.SENT')"
|
||||||
icon="checkmark"
|
icon="checkmark"
|
||||||
|
@ -80,19 +74,17 @@
|
||||||
import { MESSAGE_TYPE, MESSAGE_STATUS } from 'shared/constants/messages';
|
import { MESSAGE_TYPE, MESSAGE_STATUS } from 'shared/constants/messages';
|
||||||
import { BUS_EVENTS } from 'shared/constants/busEvents';
|
import { BUS_EVENTS } from 'shared/constants/busEvents';
|
||||||
import inboxMixin from 'shared/mixins/inboxMixin';
|
import inboxMixin from 'shared/mixins/inboxMixin';
|
||||||
import { mapGetters } from 'vuex';
|
|
||||||
import timeMixin from '../../../../mixins/time';
|
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
mixins: [inboxMixin, timeMixin],
|
mixins: [inboxMixin],
|
||||||
props: {
|
props: {
|
||||||
sender: {
|
sender: {
|
||||||
type: Object,
|
type: Object,
|
||||||
default: () => ({}),
|
default: () => ({}),
|
||||||
},
|
},
|
||||||
createdAt: {
|
readableTime: {
|
||||||
type: Number,
|
type: String,
|
||||||
default: 0,
|
default: '',
|
||||||
},
|
},
|
||||||
storySender: {
|
storySender: {
|
||||||
type: String,
|
type: String,
|
||||||
|
@ -138,9 +130,12 @@ export default {
|
||||||
type: [String, Number],
|
type: [String, Number],
|
||||||
default: 0,
|
default: 0,
|
||||||
},
|
},
|
||||||
|
messageRead: {
|
||||||
|
type: Boolean,
|
||||||
|
default: false,
|
||||||
|
},
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
...mapGetters({ currentChat: 'getSelectedChat' }),
|
|
||||||
inbox() {
|
inbox() {
|
||||||
return this.$store.getters['inboxes/getInbox'](this.inboxId);
|
return this.$store.getters['inboxes/getInbox'](this.inboxId);
|
||||||
},
|
},
|
||||||
|
@ -150,9 +145,6 @@ export default {
|
||||||
isOutgoing() {
|
isOutgoing() {
|
||||||
return MESSAGE_TYPE.OUTGOING === this.messageType;
|
return MESSAGE_TYPE.OUTGOING === this.messageType;
|
||||||
},
|
},
|
||||||
isTemplate() {
|
|
||||||
return MESSAGE_TYPE.TEMPLATE === this.messageType;
|
|
||||||
},
|
|
||||||
isDelivered() {
|
isDelivered() {
|
||||||
return MESSAGE_STATUS.DELIVERED === this.messageStatus;
|
return MESSAGE_STATUS.DELIVERED === this.messageStatus;
|
||||||
},
|
},
|
||||||
|
@ -162,9 +154,6 @@ export default {
|
||||||
isSent() {
|
isSent() {
|
||||||
return MESSAGE_STATUS.SENT === this.messageStatus;
|
return MESSAGE_STATUS.SENT === this.messageStatus;
|
||||||
},
|
},
|
||||||
readableTime() {
|
|
||||||
return this.messageStamp(this.createdAt, 'LLL d, h:mm a');
|
|
||||||
},
|
|
||||||
screenName() {
|
screenName() {
|
||||||
const { additional_attributes: additionalAttributes = {} } =
|
const { additional_attributes: additionalAttributes = {} } =
|
||||||
this.sender || {};
|
this.sender || {};
|
||||||
|
@ -185,52 +174,28 @@ export default {
|
||||||
const { storySender, storyId } = this;
|
const { storySender, storyId } = this;
|
||||||
return `https://www.instagram.com/stories/${storySender}/${storyId}`;
|
return `https://www.instagram.com/stories/${storySender}/${storyId}`;
|
||||||
},
|
},
|
||||||
showStatusIndicators() {
|
|
||||||
if ((this.isOutgoing || this.isTemplate) && !this.private) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
},
|
|
||||||
showSentIndicator() {
|
showSentIndicator() {
|
||||||
if (!this.showStatusIndicators) {
|
return (
|
||||||
return false;
|
this.isOutgoing &&
|
||||||
}
|
this.sourceId &&
|
||||||
|
(this.isAnEmailChannel || (this.isAWhatsAppChannel && this.isSent))
|
||||||
if (this.isAnEmailChannel) {
|
);
|
||||||
return !!this.sourceId;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this.isAWhatsAppChannel) {
|
|
||||||
return this.sourceId && this.isSent;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
},
|
},
|
||||||
showDeliveredIndicator() {
|
showDeliveredIndicator() {
|
||||||
if (!this.showStatusIndicators) {
|
return (
|
||||||
return false;
|
this.isOutgoing &&
|
||||||
}
|
this.sourceId &&
|
||||||
|
this.isAWhatsAppChannel &&
|
||||||
if (this.isAWhatsAppChannel) {
|
this.isDelivered
|
||||||
return this.sourceId && this.isDelivered;
|
);
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
},
|
},
|
||||||
showReadIndicator() {
|
showReadIndicator() {
|
||||||
if (!this.showStatusIndicators) {
|
return (
|
||||||
return false;
|
this.isOutgoing &&
|
||||||
}
|
this.sourceId &&
|
||||||
|
this.isAWhatsAppChannel &&
|
||||||
if (this.isAWebWidgetInbox) {
|
this.isRead
|
||||||
const { contact_last_seen_at: contactLastSeenAt } = this.currentChat;
|
);
|
||||||
return contactLastSeenAt >= this.createdAt;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (this.isAWhatsAppChannel) {
|
|
||||||
return this.sourceId && this.isRead;
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
|
@ -253,13 +218,12 @@ export default {
|
||||||
|
|
||||||
.action--icon {
|
.action--icon {
|
||||||
color: var(--white);
|
color: var(--white);
|
||||||
|
|
||||||
&.read-tick {
|
&.read-tick {
|
||||||
color: var(--v-100);
|
color: var(--v-100);
|
||||||
}
|
}
|
||||||
|
|
||||||
&.read-indicator {
|
&.read-indicator {
|
||||||
color: var(--g-200);
|
color: var(--g-300);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -324,9 +288,8 @@ export default {
|
||||||
position: absolute;
|
position: absolute;
|
||||||
right: var(--space-small);
|
right: var(--space-small);
|
||||||
white-space: nowrap;
|
white-space: nowrap;
|
||||||
|
&.delivered {
|
||||||
&.has-status-icon {
|
right: var(--space-medium);
|
||||||
right: var(--space-large);
|
|
||||||
line-height: 2;
|
line-height: 2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -35,6 +35,10 @@ export default {
|
||||||
type: String,
|
type: String,
|
||||||
default: '',
|
default: '',
|
||||||
},
|
},
|
||||||
|
readableTime: {
|
||||||
|
type: String,
|
||||||
|
default: '',
|
||||||
|
},
|
||||||
isEmail: {
|
isEmail: {
|
||||||
type: Boolean,
|
type: Boolean,
|
||||||
default: true,
|
default: true,
|
||||||
|
|
|
@ -1,136 +0,0 @@
|
||||||
<template>
|
|
||||||
<div
|
|
||||||
v-show="activeLabels.length"
|
|
||||||
ref="labelContainer"
|
|
||||||
class="label-container"
|
|
||||||
>
|
|
||||||
<div class="labels-wrap" :class="{ expand: showAllLabels }">
|
|
||||||
<woot-label
|
|
||||||
v-for="(label, index) in activeLabels"
|
|
||||||
:key="label.id"
|
|
||||||
:title="label.title"
|
|
||||||
:description="label.description"
|
|
||||||
:color="label.color"
|
|
||||||
variant="smooth"
|
|
||||||
small
|
|
||||||
:class="{ hidden: !showAllLabels && index > labelPosition }"
|
|
||||||
/>
|
|
||||||
<woot-button
|
|
||||||
v-if="showExpandLabelButton"
|
|
||||||
:title="
|
|
||||||
showAllLabels
|
|
||||||
? $t('CONVERSATION.CARD.HIDE_LABELS')
|
|
||||||
: $t('CONVERSATION.CARD.SHOW_LABELS')
|
|
||||||
"
|
|
||||||
class="show-more--button"
|
|
||||||
color-scheme="secondary"
|
|
||||||
variant="hollow"
|
|
||||||
:icon="showAllLabels ? 'chevron-left' : 'chevron-right'"
|
|
||||||
size="tiny"
|
|
||||||
@click="onShowLabels"
|
|
||||||
/>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</template>
|
|
||||||
<script>
|
|
||||||
import conversationLabelMixin from 'dashboard/mixins/conversation/labelMixin';
|
|
||||||
export default {
|
|
||||||
mixins: [conversationLabelMixin],
|
|
||||||
props: {
|
|
||||||
conversationId: {
|
|
||||||
type: Number,
|
|
||||||
required: true,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
data() {
|
|
||||||
return {
|
|
||||||
showAllLabels: false,
|
|
||||||
showExpandLabelButton: false,
|
|
||||||
labelPosition: -1,
|
|
||||||
};
|
|
||||||
},
|
|
||||||
watch: {
|
|
||||||
activeLabels() {
|
|
||||||
this.$nextTick(() => this.computeVisibleLabelPosition());
|
|
||||||
},
|
|
||||||
},
|
|
||||||
mounted() {
|
|
||||||
this.computeVisibleLabelPosition();
|
|
||||||
},
|
|
||||||
methods: {
|
|
||||||
onShowLabels(e) {
|
|
||||||
e.stopPropagation();
|
|
||||||
this.showAllLabels = !this.showAllLabels;
|
|
||||||
},
|
|
||||||
computeVisibleLabelPosition() {
|
|
||||||
const labelContainer = this.$refs.labelContainer;
|
|
||||||
const labels = this.$refs.labelContainer.querySelectorAll('.label');
|
|
||||||
let labelOffset = 0;
|
|
||||||
this.showExpandLabelButton = false;
|
|
||||||
|
|
||||||
Array.from(labels).forEach((label, index) => {
|
|
||||||
labelOffset += label.offsetWidth + 8;
|
|
||||||
|
|
||||||
if (labelOffset < labelContainer.clientWidth - 16) {
|
|
||||||
this.labelPosition = index;
|
|
||||||
} else {
|
|
||||||
this.showExpandLabelButton = true;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
},
|
|
||||||
},
|
|
||||||
};
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<style lang="scss" scoped>
|
|
||||||
.show-more--button {
|
|
||||||
height: var(--space-two);
|
|
||||||
position: sticky;
|
|
||||||
flex-shrink: 0;
|
|
||||||
right: 0;
|
|
||||||
margin-right: var(--space-medium);
|
|
||||||
|
|
||||||
&.secondary:focus {
|
|
||||||
color: var(--s-700);
|
|
||||||
border-color: var(--s-300);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.label-container {
|
|
||||||
margin-top: var(--space-micro);
|
|
||||||
}
|
|
||||||
|
|
||||||
.labels-wrap {
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
min-width: 0;
|
|
||||||
flex-shrink: 1;
|
|
||||||
|
|
||||||
&.expand {
|
|
||||||
height: auto;
|
|
||||||
overflow: visible;
|
|
||||||
flex-flow: row wrap;
|
|
||||||
|
|
||||||
.label {
|
|
||||||
margin-bottom: var(--space-smaller);
|
|
||||||
}
|
|
||||||
|
|
||||||
.show-more--button {
|
|
||||||
margin-bottom: var(--space-smaller);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.secondary {
|
|
||||||
border: 1px solid var(--s-100);
|
|
||||||
}
|
|
||||||
|
|
||||||
.label {
|
|
||||||
margin-bottom: 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.hidden {
|
|
||||||
visibility: hidden;
|
|
||||||
position: absolute;
|
|
||||||
}
|
|
||||||
</style>
|
|
|
@ -1,18 +1,13 @@
|
||||||
export const FEATURE_FLAGS = {
|
export const FEATURE_FLAGS = {
|
||||||
AGENT_BOTS: 'agent_bots',
|
AGENT_BOTS: 'agent_bots',
|
||||||
AGENT_MANAGEMENT: 'agent_management',
|
AGENT_MANAGEMENT: 'agent_management',
|
||||||
AUTO_RESOLVE_CONVERSATIONS: 'auto_resolve_conversations',
|
|
||||||
AUTOMATIONS: 'automations',
|
AUTOMATIONS: 'automations',
|
||||||
CAMPAIGNS: 'campaigns',
|
|
||||||
CANNED_RESPONSES: 'canned_responses',
|
CANNED_RESPONSES: 'canned_responses',
|
||||||
CRM: 'crm',
|
|
||||||
CUSTOM_ATTRIBUTES: 'custom_attributes',
|
CUSTOM_ATTRIBUTES: 'custom_attributes',
|
||||||
INBOX_MANAGEMENT: 'inbox_management',
|
INBOX_MANAGEMENT: 'inbox_management',
|
||||||
INTEGRATIONS: 'integrations',
|
INTEGRATIONS: 'integrations',
|
||||||
LABELS: 'labels',
|
LABELS: 'labels',
|
||||||
MACROS: 'macros',
|
MACROS: 'macros',
|
||||||
HELP_CENTER: 'help_center',
|
|
||||||
REPORTS: 'reports',
|
|
||||||
TEAM_MANAGEMENT: 'team_management',
|
TEAM_MANAGEMENT: 'team_management',
|
||||||
VOICE_RECORDER: 'voice_recorder',
|
VOICE_RECORDER: 'voice_recorder',
|
||||||
};
|
};
|
||||||
|
|
|
@ -60,11 +60,15 @@ export const getFormattedPreChatFields = ({ preChatFields }) => {
|
||||||
return {
|
return {
|
||||||
...item,
|
...item,
|
||||||
label: getLabel({
|
label: getLabel({
|
||||||
key: item.name,
|
key: standardFieldKeys[item.name]
|
||||||
|
? standardFieldKeys[item.name].key
|
||||||
|
: item.name,
|
||||||
label: item.label ? item.label : item.name,
|
label: item.label ? item.label : item.name,
|
||||||
}),
|
}),
|
||||||
placeholder: getPlaceHolder({
|
placeholder: getPlaceHolder({
|
||||||
key: item.name,
|
key: standardFieldKeys[item.name]
|
||||||
|
? standardFieldKeys[item.name].key
|
||||||
|
: item.name,
|
||||||
placeholder: item.placeholder ? item.placeholder : item.name,
|
placeholder: item.placeholder ? item.placeholder : item.name,
|
||||||
}),
|
}),
|
||||||
};
|
};
|
||||||
|
|
|
@ -41,10 +41,6 @@
|
||||||
"NO_RESPONSE": "لا توجد استجابة",
|
"NO_RESPONSE": "لا توجد استجابة",
|
||||||
"RATING_TITLE": "التقييم",
|
"RATING_TITLE": "التقييم",
|
||||||
"FEEDBACK_TITLE": "الملاحظات",
|
"FEEDBACK_TITLE": "الملاحظات",
|
||||||
"CARD": {
|
|
||||||
"SHOW_LABELS": "Show labels",
|
|
||||||
"HIDE_LABELS": "Hide labels"
|
|
||||||
},
|
|
||||||
"HEADER": {
|
"HEADER": {
|
||||||
"RESOLVE_ACTION": "إغلاق المحادثة",
|
"RESOLVE_ACTION": "إغلاق المحادثة",
|
||||||
"REOPEN_ACTION": "إعادة فتح",
|
"REOPEN_ACTION": "إعادة فتح",
|
||||||
|
|
|
@ -1,6 +0,0 @@
|
||||||
{
|
|
||||||
"EMOJI": {
|
|
||||||
"PLACEHOLDER": "Search emojis",
|
|
||||||
"NOT_FOUND": "No emoji match your search"
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -134,7 +134,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "رقم الهاتف",
|
"LABEL": "رقم الهاتف",
|
||||||
"PLACEHOLDER": "الرجاء إدخال رقم الهاتف الذي سيتم إرسال الرسائل منه.",
|
"PLACEHOLDER": "الرجاء إدخال رقم الهاتف الذي سيتم إرسال الرسائل منه.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "الرجاء إدخال قيمة صحيحة. يجب أن يبدأ رقم الهاتف بعلامة `+`."
|
||||||
},
|
},
|
||||||
"API_CALLBACK": {
|
"API_CALLBACK": {
|
||||||
"TITLE": "عنوان Callback URL",
|
"TITLE": "عنوان Callback URL",
|
||||||
|
@ -185,7 +185,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "رقم الهاتف",
|
"LABEL": "رقم الهاتف",
|
||||||
"PLACEHOLDER": "الرجاء إدخال رقم الهاتف الذي سيتم إرسال الرسائل منه.",
|
"PLACEHOLDER": "الرجاء إدخال رقم الهاتف الذي سيتم إرسال الرسائل منه.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "الرجاء إدخال قيمة صحيحة. يجب أن يبدأ رقم الهاتف بعلامة `+`."
|
||||||
},
|
},
|
||||||
"SUBMIT_BUTTON": "إنشاء قناة عرض التردد",
|
"SUBMIT_BUTTON": "إنشاء قناة عرض التردد",
|
||||||
"API": {
|
"API": {
|
||||||
|
@ -214,7 +214,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "رقم الهاتف",
|
"LABEL": "رقم الهاتف",
|
||||||
"PLACEHOLDER": "الرجاء إدخال رقم الهاتف الذي سيتم إرسال الرسائل منه.",
|
"PLACEHOLDER": "الرجاء إدخال رقم الهاتف الذي سيتم إرسال الرسائل منه.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "الرجاء إدخال قيمة صحيحة. يجب أن يبدأ رقم الهاتف بعلامة `+`."
|
||||||
},
|
},
|
||||||
"PHONE_NUMBER_ID": {
|
"PHONE_NUMBER_ID": {
|
||||||
"LABEL": "رقم الهاتف",
|
"LABEL": "رقم الهاتف",
|
||||||
|
|
|
@ -103,9 +103,7 @@
|
||||||
"متصل",
|
"متصل",
|
||||||
"مشغول",
|
"مشغول",
|
||||||
"غير متصل"
|
"غير متصل"
|
||||||
],
|
]
|
||||||
"SET_AVAILABILITY_SUCCESS": "Availability has been set successfully",
|
|
||||||
"SET_AVAILABILITY_ERROR": "Couldn't set availability, please try again"
|
|
||||||
},
|
},
|
||||||
"EMAIL": {
|
"EMAIL": {
|
||||||
"LABEL": "عنوان البريد الإلكتروني الخاص بك",
|
"LABEL": "عنوان البريد الإلكتروني الخاص بك",
|
||||||
|
@ -136,7 +134,6 @@
|
||||||
"SELECTOR_SUBTITLE": "اختر حساباً من القائمة التالية",
|
"SELECTOR_SUBTITLE": "اختر حساباً من القائمة التالية",
|
||||||
"PROFILE_SETTINGS": "إعدادات الملف الشخصي",
|
"PROFILE_SETTINGS": "إعدادات الملف الشخصي",
|
||||||
"KEYBOARD_SHORTCUTS": "اختصارات لوحة المفاتيح",
|
"KEYBOARD_SHORTCUTS": "اختصارات لوحة المفاتيح",
|
||||||
"SUPER_ADMIN_CONSOLE": "Super Admin Console",
|
|
||||||
"LOGOUT": "تسجيل الخروج"
|
"LOGOUT": "تسجيل الخروج"
|
||||||
},
|
},
|
||||||
"APP_GLOBAL": {
|
"APP_GLOBAL": {
|
||||||
|
@ -229,10 +226,6 @@
|
||||||
"CATEGORY": "الفئة",
|
"CATEGORY": "الفئة",
|
||||||
"CATEGORY_EMPTY_MESSAGE": "لم يتم العثور على فئات"
|
"CATEGORY_EMPTY_MESSAGE": "لم يتم العثور على فئات"
|
||||||
},
|
},
|
||||||
"SET_AUTO_OFFLINE": {
|
|
||||||
"TEXT": "Mark offline automatically",
|
|
||||||
"INFO_TEXT": "Let the system automatically mark you offline when you aren't using the app or dashboard."
|
|
||||||
},
|
|
||||||
"DOCS": "قراءة المستندات"
|
"DOCS": "قراءة المستندات"
|
||||||
},
|
},
|
||||||
"BILLING_SETTINGS": {
|
"BILLING_SETTINGS": {
|
||||||
|
@ -264,7 +257,7 @@
|
||||||
},
|
},
|
||||||
"FORM": {
|
"FORM": {
|
||||||
"NAME": {
|
"NAME": {
|
||||||
"LABEL": "اسم الشركة",
|
"LABEL": "اسم الحساب",
|
||||||
"PLACEHOLDER": "مؤسسة Wayne"
|
"PLACEHOLDER": "مؤسسة Wayne"
|
||||||
},
|
},
|
||||||
"SUBMIT": "إرسال"
|
"SUBMIT": "إرسال"
|
||||||
|
|
|
@ -2,13 +2,11 @@
|
||||||
"REGISTER": {
|
"REGISTER": {
|
||||||
"TRY_WOOT": "تسجيل حساب",
|
"TRY_WOOT": "تسجيل حساب",
|
||||||
"TITLE": "تسجيل",
|
"TITLE": "تسجيل",
|
||||||
"TESTIMONIAL_HEADER": "All it takes is one step to move forward",
|
|
||||||
"TESTIMONIAL_CONTENT": "You're one step away from engaging your customers, retaining them and finding new ones.",
|
|
||||||
"TERMS_ACCEPT": "من خلال التسجيل، فإنك توافق على <a href=\"https://www.chatwoot.com/terms\">شروط الخدمة</a> و <a href=\"https://www.chatwoot.com/privacy-policy\">سياسة الخصوصية</a>",
|
"TERMS_ACCEPT": "من خلال التسجيل، فإنك توافق على <a href=\"https://www.chatwoot.com/terms\">شروط الخدمة</a> و <a href=\"https://www.chatwoot.com/privacy-policy\">سياسة الخصوصية</a>",
|
||||||
"COMPANY_NAME": {
|
"ACCOUNT_NAME": {
|
||||||
"LABEL": "Company name",
|
"LABEL": "اسم الحساب",
|
||||||
"PLACEHOLDER": "Enter your company name. eg: Wayne Enterprises",
|
"PLACEHOLDER": "أدخل اسم الحساب. مثال: Wayne Enterprises",
|
||||||
"ERROR": "Company name is too short"
|
"ERROR": "اسم الحساب قصير جداً"
|
||||||
},
|
},
|
||||||
"FULL_NAME": {
|
"FULL_NAME": {
|
||||||
"LABEL": "الاسم الكامل",
|
"LABEL": "الاسم الكامل",
|
||||||
|
@ -18,7 +16,7 @@
|
||||||
"EMAIL": {
|
"EMAIL": {
|
||||||
"LABEL": "البريد الإلكتروني للعمل",
|
"LABEL": "البريد الإلكتروني للعمل",
|
||||||
"PLACEHOLDER": "أدخل عنوان بريدك الإلكتروني للعمل. مثال: bruce@wayne.enterprises",
|
"PLACEHOLDER": "أدخل عنوان بريدك الإلكتروني للعمل. مثال: bruce@wayne.enterprises",
|
||||||
"ERROR": "Please enter a valid work email address"
|
"ERROR": "عنوان البريد الإلكتروني غير صالح"
|
||||||
},
|
},
|
||||||
"PASSWORD": {
|
"PASSWORD": {
|
||||||
"LABEL": "كلمة المرور",
|
"LABEL": "كلمة المرور",
|
||||||
|
|
|
@ -41,10 +41,6 @@
|
||||||
"NO_RESPONSE": "No response",
|
"NO_RESPONSE": "No response",
|
||||||
"RATING_TITLE": "Rating",
|
"RATING_TITLE": "Rating",
|
||||||
"FEEDBACK_TITLE": "Feedback",
|
"FEEDBACK_TITLE": "Feedback",
|
||||||
"CARD": {
|
|
||||||
"SHOW_LABELS": "Show labels",
|
|
||||||
"HIDE_LABELS": "Hide labels"
|
|
||||||
},
|
|
||||||
"HEADER": {
|
"HEADER": {
|
||||||
"RESOLVE_ACTION": "Resolve",
|
"RESOLVE_ACTION": "Resolve",
|
||||||
"REOPEN_ACTION": "Reopen",
|
"REOPEN_ACTION": "Reopen",
|
||||||
|
|
|
@ -1,6 +0,0 @@
|
||||||
{
|
|
||||||
"EMOJI": {
|
|
||||||
"PLACEHOLDER": "Search emojis",
|
|
||||||
"NOT_FOUND": "No emoji match your search"
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -134,7 +134,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Phone number",
|
"LABEL": "Phone number",
|
||||||
"PLACEHOLDER": "Please enter the phone number from which message will be sent.",
|
"PLACEHOLDER": "Please enter the phone number from which message will be sent.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "Please enter a valid value. Phone number should start with `+` sign."
|
||||||
},
|
},
|
||||||
"API_CALLBACK": {
|
"API_CALLBACK": {
|
||||||
"TITLE": "Callback URL",
|
"TITLE": "Callback URL",
|
||||||
|
@ -185,7 +185,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Телефон",
|
"LABEL": "Телефон",
|
||||||
"PLACEHOLDER": "Please enter the phone number from which message will be sent.",
|
"PLACEHOLDER": "Please enter the phone number from which message will be sent.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "Please enter a valid value. Phone number should start with `+` sign."
|
||||||
},
|
},
|
||||||
"SUBMIT_BUTTON": "Create Bandwidth Channel",
|
"SUBMIT_BUTTON": "Create Bandwidth Channel",
|
||||||
"API": {
|
"API": {
|
||||||
|
@ -214,7 +214,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Phone number",
|
"LABEL": "Phone number",
|
||||||
"PLACEHOLDER": "Please enter the phone number from which message will be sent.",
|
"PLACEHOLDER": "Please enter the phone number from which message will be sent.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "Please enter a valid value. Phone number should start with `+` sign."
|
||||||
},
|
},
|
||||||
"PHONE_NUMBER_ID": {
|
"PHONE_NUMBER_ID": {
|
||||||
"LABEL": "Phone number ID",
|
"LABEL": "Phone number ID",
|
||||||
|
|
|
@ -103,9 +103,7 @@
|
||||||
"Online",
|
"Online",
|
||||||
"Busy",
|
"Busy",
|
||||||
"Offline"
|
"Offline"
|
||||||
],
|
]
|
||||||
"SET_AVAILABILITY_SUCCESS": "Availability has been set successfully",
|
|
||||||
"SET_AVAILABILITY_ERROR": "Couldn't set availability, please try again"
|
|
||||||
},
|
},
|
||||||
"EMAIL": {
|
"EMAIL": {
|
||||||
"LABEL": "Your email address",
|
"LABEL": "Your email address",
|
||||||
|
@ -136,7 +134,6 @@
|
||||||
"SELECTOR_SUBTITLE": "Select an account from the following list",
|
"SELECTOR_SUBTITLE": "Select an account from the following list",
|
||||||
"PROFILE_SETTINGS": "Profile Settings",
|
"PROFILE_SETTINGS": "Profile Settings",
|
||||||
"KEYBOARD_SHORTCUTS": "Keyboard Shortcuts",
|
"KEYBOARD_SHORTCUTS": "Keyboard Shortcuts",
|
||||||
"SUPER_ADMIN_CONSOLE": "Super Admin Console",
|
|
||||||
"LOGOUT": "Logout"
|
"LOGOUT": "Logout"
|
||||||
},
|
},
|
||||||
"APP_GLOBAL": {
|
"APP_GLOBAL": {
|
||||||
|
@ -229,10 +226,6 @@
|
||||||
"CATEGORY": "Category",
|
"CATEGORY": "Category",
|
||||||
"CATEGORY_EMPTY_MESSAGE": "No categories found"
|
"CATEGORY_EMPTY_MESSAGE": "No categories found"
|
||||||
},
|
},
|
||||||
"SET_AUTO_OFFLINE": {
|
|
||||||
"TEXT": "Mark offline automatically",
|
|
||||||
"INFO_TEXT": "Let the system automatically mark you offline when you aren't using the app or dashboard."
|
|
||||||
},
|
|
||||||
"DOCS": "Read docs"
|
"DOCS": "Read docs"
|
||||||
},
|
},
|
||||||
"BILLING_SETTINGS": {
|
"BILLING_SETTINGS": {
|
||||||
|
@ -264,7 +257,7 @@
|
||||||
},
|
},
|
||||||
"FORM": {
|
"FORM": {
|
||||||
"NAME": {
|
"NAME": {
|
||||||
"LABEL": "Име на фирма",
|
"LABEL": "Account Name",
|
||||||
"PLACEHOLDER": "Wayne Enterprises"
|
"PLACEHOLDER": "Wayne Enterprises"
|
||||||
},
|
},
|
||||||
"SUBMIT": "Изпращане"
|
"SUBMIT": "Изпращане"
|
||||||
|
|
|
@ -2,13 +2,11 @@
|
||||||
"REGISTER": {
|
"REGISTER": {
|
||||||
"TRY_WOOT": "Register an account",
|
"TRY_WOOT": "Register an account",
|
||||||
"TITLE": "Register",
|
"TITLE": "Register",
|
||||||
"TESTIMONIAL_HEADER": "All it takes is one step to move forward",
|
|
||||||
"TESTIMONIAL_CONTENT": "You're one step away from engaging your customers, retaining them and finding new ones.",
|
|
||||||
"TERMS_ACCEPT": "By signing up, you agree to our <a href=\"https://www.chatwoot.com/terms\">T & C</a> and <a href=\"https://www.chatwoot.com/privacy-policy\">Privacy policy</a>",
|
"TERMS_ACCEPT": "By signing up, you agree to our <a href=\"https://www.chatwoot.com/terms\">T & C</a> and <a href=\"https://www.chatwoot.com/privacy-policy\">Privacy policy</a>",
|
||||||
"COMPANY_NAME": {
|
"ACCOUNT_NAME": {
|
||||||
"LABEL": "Company name",
|
"LABEL": "Account name",
|
||||||
"PLACEHOLDER": "Enter your company name. eg: Wayne Enterprises",
|
"PLACEHOLDER": "Enter an account name. eg: Wayne Enterprises",
|
||||||
"ERROR": "Company name is too short"
|
"ERROR": "Account name is too short"
|
||||||
},
|
},
|
||||||
"FULL_NAME": {
|
"FULL_NAME": {
|
||||||
"LABEL": "Full name",
|
"LABEL": "Full name",
|
||||||
|
@ -18,7 +16,7 @@
|
||||||
"EMAIL": {
|
"EMAIL": {
|
||||||
"LABEL": "Work email",
|
"LABEL": "Work email",
|
||||||
"PLACEHOLDER": "Enter your work email address. eg: bruce@wayne.enterprises",
|
"PLACEHOLDER": "Enter your work email address. eg: bruce@wayne.enterprises",
|
||||||
"ERROR": "Please enter a valid work email address"
|
"ERROR": "Email address is invalid"
|
||||||
},
|
},
|
||||||
"PASSWORD": {
|
"PASSWORD": {
|
||||||
"LABEL": "Password",
|
"LABEL": "Password",
|
||||||
|
|
|
@ -41,10 +41,6 @@
|
||||||
"NO_RESPONSE": "Sense resposta",
|
"NO_RESPONSE": "Sense resposta",
|
||||||
"RATING_TITLE": "Rating",
|
"RATING_TITLE": "Rating",
|
||||||
"FEEDBACK_TITLE": "Feedback",
|
"FEEDBACK_TITLE": "Feedback",
|
||||||
"CARD": {
|
|
||||||
"SHOW_LABELS": "Show labels",
|
|
||||||
"HIDE_LABELS": "Hide labels"
|
|
||||||
},
|
|
||||||
"HEADER": {
|
"HEADER": {
|
||||||
"RESOLVE_ACTION": "Resoldre",
|
"RESOLVE_ACTION": "Resoldre",
|
||||||
"REOPEN_ACTION": "Tornar a obrir",
|
"REOPEN_ACTION": "Tornar a obrir",
|
||||||
|
|
|
@ -1,6 +0,0 @@
|
||||||
{
|
|
||||||
"EMOJI": {
|
|
||||||
"PLACEHOLDER": "Search emojis",
|
|
||||||
"NOT_FOUND": "No emoji match your search"
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -134,7 +134,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Número de telèfon",
|
"LABEL": "Número de telèfon",
|
||||||
"PLACEHOLDER": "Introduïu el número de telèfon des del qual serà enviat el missatge.",
|
"PLACEHOLDER": "Introduïu el número de telèfon des del qual serà enviat el missatge.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "Introduïu un valor vàlid. El número de telèfon hauria de començar amb el signe `+`."
|
||||||
},
|
},
|
||||||
"API_CALLBACK": {
|
"API_CALLBACK": {
|
||||||
"TITLE": "Callback URL",
|
"TITLE": "Callback URL",
|
||||||
|
@ -185,7 +185,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Número de telèfon",
|
"LABEL": "Número de telèfon",
|
||||||
"PLACEHOLDER": "Introduïu el número de telèfon des del qual serà enviat el missatge.",
|
"PLACEHOLDER": "Introduïu el número de telèfon des del qual serà enviat el missatge.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "Introduïu un valor vàlid. El número de telèfon hauria de començar amb el signe `+`."
|
||||||
},
|
},
|
||||||
"SUBMIT_BUTTON": "Create Bandwidth Channel",
|
"SUBMIT_BUTTON": "Create Bandwidth Channel",
|
||||||
"API": {
|
"API": {
|
||||||
|
@ -214,7 +214,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Número de telèfon",
|
"LABEL": "Número de telèfon",
|
||||||
"PLACEHOLDER": "Introduïu el número de telèfon des del qual serà enviat el missatge.",
|
"PLACEHOLDER": "Introduïu el número de telèfon des del qual serà enviat el missatge.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "Introduïu un valor vàlid. El número de telèfon hauria de començar amb el signe `+`."
|
||||||
},
|
},
|
||||||
"PHONE_NUMBER_ID": {
|
"PHONE_NUMBER_ID": {
|
||||||
"LABEL": "Phone number ID",
|
"LABEL": "Phone number ID",
|
||||||
|
|
|
@ -103,9 +103,7 @@
|
||||||
"En línia",
|
"En línia",
|
||||||
"Ocupat",
|
"Ocupat",
|
||||||
"Fora de línia"
|
"Fora de línia"
|
||||||
],
|
]
|
||||||
"SET_AVAILABILITY_SUCCESS": "Availability has been set successfully",
|
|
||||||
"SET_AVAILABILITY_ERROR": "Couldn't set availability, please try again"
|
|
||||||
},
|
},
|
||||||
"EMAIL": {
|
"EMAIL": {
|
||||||
"LABEL": "La teva adreça de correu electrònic",
|
"LABEL": "La teva adreça de correu electrònic",
|
||||||
|
@ -136,7 +134,6 @@
|
||||||
"SELECTOR_SUBTITLE": "Selecciona un compte de la llista següent",
|
"SELECTOR_SUBTITLE": "Selecciona un compte de la llista següent",
|
||||||
"PROFILE_SETTINGS": "Configuració del Perfil",
|
"PROFILE_SETTINGS": "Configuració del Perfil",
|
||||||
"KEYBOARD_SHORTCUTS": "Keyboard Shortcuts",
|
"KEYBOARD_SHORTCUTS": "Keyboard Shortcuts",
|
||||||
"SUPER_ADMIN_CONSOLE": "Super Admin Console",
|
|
||||||
"LOGOUT": "Sortir"
|
"LOGOUT": "Sortir"
|
||||||
},
|
},
|
||||||
"APP_GLOBAL": {
|
"APP_GLOBAL": {
|
||||||
|
@ -229,10 +226,6 @@
|
||||||
"CATEGORY": "Category",
|
"CATEGORY": "Category",
|
||||||
"CATEGORY_EMPTY_MESSAGE": "No categories found"
|
"CATEGORY_EMPTY_MESSAGE": "No categories found"
|
||||||
},
|
},
|
||||||
"SET_AUTO_OFFLINE": {
|
|
||||||
"TEXT": "Mark offline automatically",
|
|
||||||
"INFO_TEXT": "Let the system automatically mark you offline when you aren't using the app or dashboard."
|
|
||||||
},
|
|
||||||
"DOCS": "Read docs"
|
"DOCS": "Read docs"
|
||||||
},
|
},
|
||||||
"BILLING_SETTINGS": {
|
"BILLING_SETTINGS": {
|
||||||
|
@ -264,7 +257,7 @@
|
||||||
},
|
},
|
||||||
"FORM": {
|
"FORM": {
|
||||||
"NAME": {
|
"NAME": {
|
||||||
"LABEL": "Nom de la companyia",
|
"LABEL": "Nom del compte",
|
||||||
"PLACEHOLDER": "Wayne Enterprises"
|
"PLACEHOLDER": "Wayne Enterprises"
|
||||||
},
|
},
|
||||||
"SUBMIT": "Envia"
|
"SUBMIT": "Envia"
|
||||||
|
|
|
@ -2,13 +2,11 @@
|
||||||
"REGISTER": {
|
"REGISTER": {
|
||||||
"TRY_WOOT": "Registra un compte",
|
"TRY_WOOT": "Registra un compte",
|
||||||
"TITLE": "Registre",
|
"TITLE": "Registre",
|
||||||
"TESTIMONIAL_HEADER": "All it takes is one step to move forward",
|
|
||||||
"TESTIMONIAL_CONTENT": "You're one step away from engaging your customers, retaining them and finding new ones.",
|
|
||||||
"TERMS_ACCEPT": "En registrar-vos, esteu d’acord amb el nostre <a href=\"https://www.chatwoot.com/terms\">T & C</a> i <a href=\"https://www.chatwoot.com/privacy-policy\">Polítiques de Privadesa</a>",
|
"TERMS_ACCEPT": "En registrar-vos, esteu d’acord amb el nostre <a href=\"https://www.chatwoot.com/terms\">T & C</a> i <a href=\"https://www.chatwoot.com/privacy-policy\">Polítiques de Privadesa</a>",
|
||||||
"COMPANY_NAME": {
|
"ACCOUNT_NAME": {
|
||||||
"LABEL": "Company name",
|
"LABEL": "Nom del compte",
|
||||||
"PLACEHOLDER": "Enter your company name. eg: Wayne Enterprises",
|
"PLACEHOLDER": "Introdueix el nom del compte. ex: Wayne Enterprises",
|
||||||
"ERROR": "Company name is too short"
|
"ERROR": "El nom del compte és massa curt"
|
||||||
},
|
},
|
||||||
"FULL_NAME": {
|
"FULL_NAME": {
|
||||||
"LABEL": "Nom complet",
|
"LABEL": "Nom complet",
|
||||||
|
@ -18,7 +16,7 @@
|
||||||
"EMAIL": {
|
"EMAIL": {
|
||||||
"LABEL": "Email de treball",
|
"LABEL": "Email de treball",
|
||||||
"PLACEHOLDER": "Introdueix la teva adreça email de treball. ex: bruce@wayne.enterprises",
|
"PLACEHOLDER": "Introdueix la teva adreça email de treball. ex: bruce@wayne.enterprises",
|
||||||
"ERROR": "Please enter a valid work email address"
|
"ERROR": "Adreça email invàlida"
|
||||||
},
|
},
|
||||||
"PASSWORD": {
|
"PASSWORD": {
|
||||||
"LABEL": "Contrasenya",
|
"LABEL": "Contrasenya",
|
||||||
|
|
|
@ -41,10 +41,6 @@
|
||||||
"NO_RESPONSE": "Bez odpovědi",
|
"NO_RESPONSE": "Bez odpovědi",
|
||||||
"RATING_TITLE": "Hodnocení",
|
"RATING_TITLE": "Hodnocení",
|
||||||
"FEEDBACK_TITLE": "Zpětná vazba",
|
"FEEDBACK_TITLE": "Zpětná vazba",
|
||||||
"CARD": {
|
|
||||||
"SHOW_LABELS": "Show labels",
|
|
||||||
"HIDE_LABELS": "Hide labels"
|
|
||||||
},
|
|
||||||
"HEADER": {
|
"HEADER": {
|
||||||
"RESOLVE_ACTION": "Vyřešit",
|
"RESOLVE_ACTION": "Vyřešit",
|
||||||
"REOPEN_ACTION": "Znovu otevřít",
|
"REOPEN_ACTION": "Znovu otevřít",
|
||||||
|
|
|
@ -1,6 +0,0 @@
|
||||||
{
|
|
||||||
"EMOJI": {
|
|
||||||
"PLACEHOLDER": "Search emojis",
|
|
||||||
"NOT_FOUND": "No emoji match your search"
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -134,7 +134,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Telefonní číslo",
|
"LABEL": "Telefonní číslo",
|
||||||
"PLACEHOLDER": "Zadejte prosím telefonní číslo, ze kterého bude zpráva odeslána.",
|
"PLACEHOLDER": "Zadejte prosím telefonní číslo, ze kterého bude zpráva odeslána.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "Zadejte platnou hodnotu. Telefonní číslo by mělo začínat znakem `+`."
|
||||||
},
|
},
|
||||||
"API_CALLBACK": {
|
"API_CALLBACK": {
|
||||||
"TITLE": "Callback URL",
|
"TITLE": "Callback URL",
|
||||||
|
@ -185,7 +185,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Telefonní číslo",
|
"LABEL": "Telefonní číslo",
|
||||||
"PLACEHOLDER": "Zadejte prosím telefonní číslo, ze kterého bude zpráva odeslána.",
|
"PLACEHOLDER": "Zadejte prosím telefonní číslo, ze kterého bude zpráva odeslána.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "Zadejte platnou hodnotu. Telefonní číslo by mělo začínat znakem `+`."
|
||||||
},
|
},
|
||||||
"SUBMIT_BUTTON": "Create Bandwidth Channel",
|
"SUBMIT_BUTTON": "Create Bandwidth Channel",
|
||||||
"API": {
|
"API": {
|
||||||
|
@ -214,7 +214,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Telefonní číslo",
|
"LABEL": "Telefonní číslo",
|
||||||
"PLACEHOLDER": "Zadejte prosím telefonní číslo, ze kterého bude zpráva odeslána.",
|
"PLACEHOLDER": "Zadejte prosím telefonní číslo, ze kterého bude zpráva odeslána.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "Zadejte platnou hodnotu. Telefonní číslo by mělo začínat znakem `+`."
|
||||||
},
|
},
|
||||||
"PHONE_NUMBER_ID": {
|
"PHONE_NUMBER_ID": {
|
||||||
"LABEL": "Phone number ID",
|
"LABEL": "Phone number ID",
|
||||||
|
|
|
@ -103,9 +103,7 @@
|
||||||
"Online",
|
"Online",
|
||||||
"Zaneprázdněn",
|
"Zaneprázdněn",
|
||||||
"Offline"
|
"Offline"
|
||||||
],
|
]
|
||||||
"SET_AVAILABILITY_SUCCESS": "Availability has been set successfully",
|
|
||||||
"SET_AVAILABILITY_ERROR": "Couldn't set availability, please try again"
|
|
||||||
},
|
},
|
||||||
"EMAIL": {
|
"EMAIL": {
|
||||||
"LABEL": "Vaše e-mailová adresa",
|
"LABEL": "Vaše e-mailová adresa",
|
||||||
|
@ -136,7 +134,6 @@
|
||||||
"SELECTOR_SUBTITLE": "Vyberte účet z následujícího seznamu",
|
"SELECTOR_SUBTITLE": "Vyberte účet z následujícího seznamu",
|
||||||
"PROFILE_SETTINGS": "Nastavení profilu",
|
"PROFILE_SETTINGS": "Nastavení profilu",
|
||||||
"KEYBOARD_SHORTCUTS": "Keyboard Shortcuts",
|
"KEYBOARD_SHORTCUTS": "Keyboard Shortcuts",
|
||||||
"SUPER_ADMIN_CONSOLE": "Super Admin Console",
|
|
||||||
"LOGOUT": "Odhlásit se"
|
"LOGOUT": "Odhlásit se"
|
||||||
},
|
},
|
||||||
"APP_GLOBAL": {
|
"APP_GLOBAL": {
|
||||||
|
@ -229,10 +226,6 @@
|
||||||
"CATEGORY": "Category",
|
"CATEGORY": "Category",
|
||||||
"CATEGORY_EMPTY_MESSAGE": "No categories found"
|
"CATEGORY_EMPTY_MESSAGE": "No categories found"
|
||||||
},
|
},
|
||||||
"SET_AUTO_OFFLINE": {
|
|
||||||
"TEXT": "Mark offline automatically",
|
|
||||||
"INFO_TEXT": "Let the system automatically mark you offline when you aren't using the app or dashboard."
|
|
||||||
},
|
|
||||||
"DOCS": "Read docs"
|
"DOCS": "Read docs"
|
||||||
},
|
},
|
||||||
"BILLING_SETTINGS": {
|
"BILLING_SETTINGS": {
|
||||||
|
@ -264,7 +257,7 @@
|
||||||
},
|
},
|
||||||
"FORM": {
|
"FORM": {
|
||||||
"NAME": {
|
"NAME": {
|
||||||
"LABEL": "Název společnosti",
|
"LABEL": "Název účtu",
|
||||||
"PLACEHOLDER": "Wayne podniky"
|
"PLACEHOLDER": "Wayne podniky"
|
||||||
},
|
},
|
||||||
"SUBMIT": "Odeslat"
|
"SUBMIT": "Odeslat"
|
||||||
|
|
|
@ -2,13 +2,11 @@
|
||||||
"REGISTER": {
|
"REGISTER": {
|
||||||
"TRY_WOOT": "Registrovat účet",
|
"TRY_WOOT": "Registrovat účet",
|
||||||
"TITLE": "Registrovat se",
|
"TITLE": "Registrovat se",
|
||||||
"TESTIMONIAL_HEADER": "All it takes is one step to move forward",
|
|
||||||
"TESTIMONIAL_CONTENT": "You're one step away from engaging your customers, retaining them and finding new ones.",
|
|
||||||
"TERMS_ACCEPT": "Registrací souhlasíte s našimi <a href=\"https://www.chatwoot.com/terms\">T & C</a> a <a href=\"https://www.chatwoot.com/privacy-policy\">Zásadami ochrany osobních údajů</a>",
|
"TERMS_ACCEPT": "Registrací souhlasíte s našimi <a href=\"https://www.chatwoot.com/terms\">T & C</a> a <a href=\"https://www.chatwoot.com/privacy-policy\">Zásadami ochrany osobních údajů</a>",
|
||||||
"COMPANY_NAME": {
|
"ACCOUNT_NAME": {
|
||||||
"LABEL": "Company name",
|
"LABEL": "Název účtu",
|
||||||
"PLACEHOLDER": "Enter your company name. eg: Wayne Enterprises",
|
"PLACEHOLDER": "Zadejte název účtu. např.: Novákova společnost",
|
||||||
"ERROR": "Company name is too short"
|
"ERROR": "Název účtu je příliš krátký"
|
||||||
},
|
},
|
||||||
"FULL_NAME": {
|
"FULL_NAME": {
|
||||||
"LABEL": "Celé jméno",
|
"LABEL": "Celé jméno",
|
||||||
|
@ -18,7 +16,7 @@
|
||||||
"EMAIL": {
|
"EMAIL": {
|
||||||
"LABEL": "Pracovní e-mail",
|
"LABEL": "Pracovní e-mail",
|
||||||
"PLACEHOLDER": "Zadejte svou pracovní e-mailovou adresu. např.: jan@novak.spolecnost",
|
"PLACEHOLDER": "Zadejte svou pracovní e-mailovou adresu. např.: jan@novak.spolecnost",
|
||||||
"ERROR": "Please enter a valid work email address"
|
"ERROR": "E-mailová adresa je neplatná"
|
||||||
},
|
},
|
||||||
"PASSWORD": {
|
"PASSWORD": {
|
||||||
"LABEL": "Heslo",
|
"LABEL": "Heslo",
|
||||||
|
|
|
@ -41,10 +41,6 @@
|
||||||
"NO_RESPONSE": "Intet svar",
|
"NO_RESPONSE": "Intet svar",
|
||||||
"RATING_TITLE": "Bedømmelse",
|
"RATING_TITLE": "Bedømmelse",
|
||||||
"FEEDBACK_TITLE": "Tilbagemelding",
|
"FEEDBACK_TITLE": "Tilbagemelding",
|
||||||
"CARD": {
|
|
||||||
"SHOW_LABELS": "Show labels",
|
|
||||||
"HIDE_LABELS": "Hide labels"
|
|
||||||
},
|
|
||||||
"HEADER": {
|
"HEADER": {
|
||||||
"RESOLVE_ACTION": "Løs",
|
"RESOLVE_ACTION": "Løs",
|
||||||
"REOPEN_ACTION": "Genåben",
|
"REOPEN_ACTION": "Genåben",
|
||||||
|
|
|
@ -1,6 +0,0 @@
|
||||||
{
|
|
||||||
"EMOJI": {
|
|
||||||
"PLACEHOLDER": "Search emojis",
|
|
||||||
"NOT_FOUND": "No emoji match your search"
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -134,7 +134,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Telefonnummer",
|
"LABEL": "Telefonnummer",
|
||||||
"PLACEHOLDER": "Indtast venligst det telefonnummer, hvorfra beskeden vil blive sendt.",
|
"PLACEHOLDER": "Indtast venligst det telefonnummer, hvorfra beskeden vil blive sendt.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "Angiv en gyldig værdi. Telefonnummer skal starte med `+` tegn."
|
||||||
},
|
},
|
||||||
"API_CALLBACK": {
|
"API_CALLBACK": {
|
||||||
"TITLE": "Callback URL",
|
"TITLE": "Callback URL",
|
||||||
|
@ -185,7 +185,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Telefonnummer",
|
"LABEL": "Telefonnummer",
|
||||||
"PLACEHOLDER": "Indtast venligst det telefonnummer, hvorfra beskeden vil blive sendt.",
|
"PLACEHOLDER": "Indtast venligst det telefonnummer, hvorfra beskeden vil blive sendt.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "Angiv en gyldig værdi. Telefonnummer skal starte med `+` tegn."
|
||||||
},
|
},
|
||||||
"SUBMIT_BUTTON": "Opret Båndbredde Kanal",
|
"SUBMIT_BUTTON": "Opret Båndbredde Kanal",
|
||||||
"API": {
|
"API": {
|
||||||
|
@ -214,7 +214,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Telefonnummer",
|
"LABEL": "Telefonnummer",
|
||||||
"PLACEHOLDER": "Indtast venligst det telefonnummer, hvorfra beskeden vil blive sendt.",
|
"PLACEHOLDER": "Indtast venligst det telefonnummer, hvorfra beskeden vil blive sendt.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "Angiv en gyldig værdi. Telefonnummer skal starte med `+` tegn."
|
||||||
},
|
},
|
||||||
"PHONE_NUMBER_ID": {
|
"PHONE_NUMBER_ID": {
|
||||||
"LABEL": "Telefonnummer ID",
|
"LABEL": "Telefonnummer ID",
|
||||||
|
|
|
@ -103,9 +103,7 @@
|
||||||
"Online",
|
"Online",
|
||||||
"Optaget",
|
"Optaget",
|
||||||
"Offline"
|
"Offline"
|
||||||
],
|
]
|
||||||
"SET_AVAILABILITY_SUCCESS": "Availability has been set successfully",
|
|
||||||
"SET_AVAILABILITY_ERROR": "Couldn't set availability, please try again"
|
|
||||||
},
|
},
|
||||||
"EMAIL": {
|
"EMAIL": {
|
||||||
"LABEL": "Din e-mail adresse",
|
"LABEL": "Din e-mail adresse",
|
||||||
|
@ -136,7 +134,6 @@
|
||||||
"SELECTOR_SUBTITLE": "Vælg en konto fra følgende liste",
|
"SELECTOR_SUBTITLE": "Vælg en konto fra følgende liste",
|
||||||
"PROFILE_SETTINGS": "Profilindstillinger",
|
"PROFILE_SETTINGS": "Profilindstillinger",
|
||||||
"KEYBOARD_SHORTCUTS": "Tastaturgenveje",
|
"KEYBOARD_SHORTCUTS": "Tastaturgenveje",
|
||||||
"SUPER_ADMIN_CONSOLE": "Super Admin Console",
|
|
||||||
"LOGOUT": "Log Ud"
|
"LOGOUT": "Log Ud"
|
||||||
},
|
},
|
||||||
"APP_GLOBAL": {
|
"APP_GLOBAL": {
|
||||||
|
@ -229,10 +226,6 @@
|
||||||
"CATEGORY": "Kategori",
|
"CATEGORY": "Kategori",
|
||||||
"CATEGORY_EMPTY_MESSAGE": "Ingen kategorier fundet"
|
"CATEGORY_EMPTY_MESSAGE": "Ingen kategorier fundet"
|
||||||
},
|
},
|
||||||
"SET_AUTO_OFFLINE": {
|
|
||||||
"TEXT": "Mark offline automatically",
|
|
||||||
"INFO_TEXT": "Let the system automatically mark you offline when you aren't using the app or dashboard."
|
|
||||||
},
|
|
||||||
"DOCS": "Læs dokumenter"
|
"DOCS": "Læs dokumenter"
|
||||||
},
|
},
|
||||||
"BILLING_SETTINGS": {
|
"BILLING_SETTINGS": {
|
||||||
|
@ -264,7 +257,7 @@
|
||||||
},
|
},
|
||||||
"FORM": {
|
"FORM": {
|
||||||
"NAME": {
|
"NAME": {
|
||||||
"LABEL": "Virksomhedens Navn",
|
"LABEL": "Kontonavn",
|
||||||
"PLACEHOLDER": "Wayne Enterprises"
|
"PLACEHOLDER": "Wayne Enterprises"
|
||||||
},
|
},
|
||||||
"SUBMIT": "Send"
|
"SUBMIT": "Send"
|
||||||
|
|
|
@ -2,13 +2,11 @@
|
||||||
"REGISTER": {
|
"REGISTER": {
|
||||||
"TRY_WOOT": "Registrer en konto",
|
"TRY_WOOT": "Registrer en konto",
|
||||||
"TITLE": "Registrer",
|
"TITLE": "Registrer",
|
||||||
"TESTIMONIAL_HEADER": "All it takes is one step to move forward",
|
|
||||||
"TESTIMONIAL_CONTENT": "You're one step away from engaging your customers, retaining them and finding new ones.",
|
|
||||||
"TERMS_ACCEPT": "Ved at tilmelde dig, accepterer du vores <a href=\"https://www.chatwoot.com/terms\">T & C</a> og <a href=\"https://www.chatwoot.com/privacy-policy\">Privatlivspolitik</a>",
|
"TERMS_ACCEPT": "Ved at tilmelde dig, accepterer du vores <a href=\"https://www.chatwoot.com/terms\">T & C</a> og <a href=\"https://www.chatwoot.com/privacy-policy\">Privatlivspolitik</a>",
|
||||||
"COMPANY_NAME": {
|
"ACCOUNT_NAME": {
|
||||||
"LABEL": "Company name",
|
"LABEL": "Kontonavn",
|
||||||
"PLACEHOLDER": "Enter your company name. eg: Wayne Enterprises",
|
"PLACEHOLDER": "Indtast et kontonavn, fx: Wayne Enterprises",
|
||||||
"ERROR": "Company name is too short"
|
"ERROR": "Kontonavn er for kort"
|
||||||
},
|
},
|
||||||
"FULL_NAME": {
|
"FULL_NAME": {
|
||||||
"LABEL": "Fulde navn",
|
"LABEL": "Fulde navn",
|
||||||
|
@ -18,7 +16,7 @@
|
||||||
"EMAIL": {
|
"EMAIL": {
|
||||||
"LABEL": "Arbejde e-mail",
|
"LABEL": "Arbejde e-mail",
|
||||||
"PLACEHOLDER": "Indtast din arbejdsmailadresse fx: bruce@wayne.enterprises",
|
"PLACEHOLDER": "Indtast din arbejdsmailadresse fx: bruce@wayne.enterprises",
|
||||||
"ERROR": "Please enter a valid work email address"
|
"ERROR": "E-mail adresse er ugyldig"
|
||||||
},
|
},
|
||||||
"PASSWORD": {
|
"PASSWORD": {
|
||||||
"LABEL": "Adgangskode",
|
"LABEL": "Adgangskode",
|
||||||
|
|
|
@ -1,39 +1,39 @@
|
||||||
{
|
{
|
||||||
"AGENT_BOTS": {
|
"AGENT_BOTS": {
|
||||||
"HEADER": "Bots",
|
"HEADER": "Bots",
|
||||||
"LOADING_EDITOR": "Editor wird geladen...",
|
"LOADING_EDITOR": "Loading Editor...",
|
||||||
"HEADER_BTN_TXT": "Bot-Konfiguration hinzufügen",
|
"HEADER_BTN_TXT": "Add Bot Configuration",
|
||||||
"SIDEBAR_TXT": "<p><b>Agenten Bots</b> <p>Agenten Bots erlauben es Ihnen, die Unterhaltungen zu automatisieren</p>",
|
"SIDEBAR_TXT": "<p><b>Agent Bots</b> <p>Agent bots allows you to automate the conversations</p>",
|
||||||
"CSML_BOT_EDITOR": {
|
"CSML_BOT_EDITOR": {
|
||||||
"NAME": {
|
"NAME": {
|
||||||
"LABEL": "Bot Name",
|
"LABEL": "Bot Name",
|
||||||
"PLACEHOLDER": "Geben Sie Ihrem Bot einen Namen",
|
"PLACEHOLDER": "Give your bot a name",
|
||||||
"ERROR": "Bot Name ist erforderlich"
|
"ERROR": "Bot name is required"
|
||||||
},
|
},
|
||||||
"DESCRIPTION": {
|
"DESCRIPTION": {
|
||||||
"LABEL": "Bot Beschreibung",
|
"LABEL": "Bot Description",
|
||||||
"PLACEHOLDER": "Was macht dieser Bot?"
|
"PLACEHOLDER": "What does this bot do?"
|
||||||
},
|
},
|
||||||
"BOT_CONFIG": {
|
"BOT_CONFIG": {
|
||||||
"ERROR": "Bitte geben Sie Ihre CSML Bot-Konfiguration oben ein",
|
"ERROR": "Please enter your CSML bot configuration above",
|
||||||
"API_ERROR": "Ihre CSML-Konfiguration ist ungültig, bitte korrigieren Sie sie und versuchen es erneut."
|
"API_ERROR": "Your CSML configuration is invalid, please fix it and try again."
|
||||||
},
|
},
|
||||||
"SUBMIT": "Validieren und speichern"
|
"SUBMIT": "Validate and save"
|
||||||
},
|
},
|
||||||
"BOT_CONFIGURATION": {
|
"BOT_CONFIGURATION": {
|
||||||
"TITLE": "Agenten-Bot auswählen",
|
"TITLE": "Select an agent bot",
|
||||||
"DESC": "Sie können einen Agenten-Bot aus der Liste in diesen Posteingang setzen. Der Bot kann die Unterhaltung anfangs bearbeiten und bei Bedarf an einen Agenten übertragen.",
|
"DESC": "You can set an agent bot from the list to this inbox. The bot can initially handle the conversation and transfer it to an agent when needed.",
|
||||||
"SUBMIT": "Aktualisieren",
|
"SUBMIT": "Aktualisieren",
|
||||||
"SUCCESS_MESSAGE": "Agenten-Bot erfolgreich aktualisiert",
|
"SUCCESS_MESSAGE": "Successfully updated the agent bot",
|
||||||
"ERROR_MESSAGE": "Konnte den Agenten-Bot nicht aktualisieren, bitte versuchen Sie es später erneut",
|
"ERROR_MESSAGE": "Could not update the agent bot, please try again later",
|
||||||
"SELECT_PLACEHOLDER": "Bot auswählen"
|
"SELECT_PLACEHOLDER": "Select Bot"
|
||||||
},
|
},
|
||||||
"ADD": {
|
"ADD": {
|
||||||
"TITLE": "Neuen Bot konfigurieren",
|
"TITLE": "Configure new bot",
|
||||||
"CANCEL_BUTTON_TEXT": "Stornieren",
|
"CANCEL_BUTTON_TEXT": "Stornieren",
|
||||||
"API": {
|
"API": {
|
||||||
"SUCCESS_MESSAGE": "Bot erfolgreich hinzugefügt",
|
"SUCCESS_MESSAGE": "Bot added successfully",
|
||||||
"ERROR_MESSAGE": "Bot konnte nicht hinzugefügt werden, bitte versuchen Sie es später erneut"
|
"ERROR_MESSAGE": "Could not add bot, Please try again later"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"LIST": {
|
"LIST": {
|
||||||
|
|
|
@ -41,10 +41,6 @@
|
||||||
"NO_RESPONSE": "Keine Antwort",
|
"NO_RESPONSE": "Keine Antwort",
|
||||||
"RATING_TITLE": "Bewertung",
|
"RATING_TITLE": "Bewertung",
|
||||||
"FEEDBACK_TITLE": "Feedback",
|
"FEEDBACK_TITLE": "Feedback",
|
||||||
"CARD": {
|
|
||||||
"SHOW_LABELS": "Show labels",
|
|
||||||
"HIDE_LABELS": "Hide labels"
|
|
||||||
},
|
|
||||||
"HEADER": {
|
"HEADER": {
|
||||||
"RESOLVE_ACTION": "Fall schließen",
|
"RESOLVE_ACTION": "Fall schließen",
|
||||||
"REOPEN_ACTION": "Wieder öffnen",
|
"REOPEN_ACTION": "Wieder öffnen",
|
||||||
|
|
|
@ -1,6 +0,0 @@
|
||||||
{
|
|
||||||
"EMOJI": {
|
|
||||||
"PLACEHOLDER": "Search emojis",
|
|
||||||
"NOT_FOUND": "No emoji match your search"
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -362,7 +362,7 @@
|
||||||
},
|
},
|
||||||
"BUTTONS": {
|
"BUTTONS": {
|
||||||
"CREATE": "Kategorie erstellen",
|
"CREATE": "Kategorie erstellen",
|
||||||
"CANCEL": "Abbrechen"
|
"CANCEL": "Stornieren"
|
||||||
},
|
},
|
||||||
"API": {
|
"API": {
|
||||||
"SUCCESS_MESSAGE": "Kategorie erfolgreich erstellt",
|
"SUCCESS_MESSAGE": "Kategorie erfolgreich erstellt",
|
||||||
|
|
|
@ -134,7 +134,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Telefonnummer",
|
"LABEL": "Telefonnummer",
|
||||||
"PLACEHOLDER": "Bitte geben Sie die Telefonnummer ein, von der die Nachricht gesendet wird.",
|
"PLACEHOLDER": "Bitte geben Sie die Telefonnummer ein, von der die Nachricht gesendet wird.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "Bitte geben sie einen gültigen Wert ein. Die Telefonnummer sollte mit dem Pluszeichen beginnen."
|
||||||
},
|
},
|
||||||
"API_CALLBACK": {
|
"API_CALLBACK": {
|
||||||
"TITLE": "Callback URL",
|
"TITLE": "Callback URL",
|
||||||
|
@ -185,7 +185,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Telefonnummer",
|
"LABEL": "Telefonnummer",
|
||||||
"PLACEHOLDER": "Bitte geben Sie die Telefonnummer ein, von der die Nachricht gesendet wird.",
|
"PLACEHOLDER": "Bitte geben Sie die Telefonnummer ein, von der die Nachricht gesendet wird.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "Bitte geben sie einen gültigen Wert ein. Die Telefonnummer sollte mit dem Pluszeichen beginnen."
|
||||||
},
|
},
|
||||||
"SUBMIT_BUTTON": "Bitte geben Sie Ihre Bandbreitenanwendungs-ID ein",
|
"SUBMIT_BUTTON": "Bitte geben Sie Ihre Bandbreitenanwendungs-ID ein",
|
||||||
"API": {
|
"API": {
|
||||||
|
@ -214,7 +214,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Telefonnummer",
|
"LABEL": "Telefonnummer",
|
||||||
"PLACEHOLDER": "Bitte geben Sie die Telefonnummer ein, von der die Nachricht gesendet wird.",
|
"PLACEHOLDER": "Bitte geben Sie die Telefonnummer ein, von der die Nachricht gesendet wird.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "Bitte geben sie einen gültigen Wert ein. Die Telefonnummer sollte mit dem Pluszeichen beginnen."
|
||||||
},
|
},
|
||||||
"PHONE_NUMBER_ID": {
|
"PHONE_NUMBER_ID": {
|
||||||
"LABEL": "Telefonnummer-ID",
|
"LABEL": "Telefonnummer-ID",
|
||||||
|
|
|
@ -103,9 +103,7 @@
|
||||||
"Online",
|
"Online",
|
||||||
"Beschäftigt",
|
"Beschäftigt",
|
||||||
"Offline"
|
"Offline"
|
||||||
],
|
]
|
||||||
"SET_AVAILABILITY_SUCCESS": "Availability has been set successfully",
|
|
||||||
"SET_AVAILABILITY_ERROR": "Couldn't set availability, please try again"
|
|
||||||
},
|
},
|
||||||
"EMAIL": {
|
"EMAIL": {
|
||||||
"LABEL": "Deine Emailadresse",
|
"LABEL": "Deine Emailadresse",
|
||||||
|
@ -136,7 +134,6 @@
|
||||||
"SELECTOR_SUBTITLE": "Wählen Sie ein Benutzerkonto aus der folgenden Liste",
|
"SELECTOR_SUBTITLE": "Wählen Sie ein Benutzerkonto aus der folgenden Liste",
|
||||||
"PROFILE_SETTINGS": "Profileinstellungen",
|
"PROFILE_SETTINGS": "Profileinstellungen",
|
||||||
"KEYBOARD_SHORTCUTS": "Tastenkombinationen",
|
"KEYBOARD_SHORTCUTS": "Tastenkombinationen",
|
||||||
"SUPER_ADMIN_CONSOLE": "Super Admin Console",
|
|
||||||
"LOGOUT": "Ausloggen"
|
"LOGOUT": "Ausloggen"
|
||||||
},
|
},
|
||||||
"APP_GLOBAL": {
|
"APP_GLOBAL": {
|
||||||
|
@ -229,10 +226,6 @@
|
||||||
"CATEGORY": "Kategorie",
|
"CATEGORY": "Kategorie",
|
||||||
"CATEGORY_EMPTY_MESSAGE": "Keine Kategorien gefunden"
|
"CATEGORY_EMPTY_MESSAGE": "Keine Kategorien gefunden"
|
||||||
},
|
},
|
||||||
"SET_AUTO_OFFLINE": {
|
|
||||||
"TEXT": "Mark offline automatically",
|
|
||||||
"INFO_TEXT": "Let the system automatically mark you offline when you aren't using the app or dashboard."
|
|
||||||
},
|
|
||||||
"DOCS": "Dokumente lesen"
|
"DOCS": "Dokumente lesen"
|
||||||
},
|
},
|
||||||
"BILLING_SETTINGS": {
|
"BILLING_SETTINGS": {
|
||||||
|
@ -264,7 +257,7 @@
|
||||||
},
|
},
|
||||||
"FORM": {
|
"FORM": {
|
||||||
"NAME": {
|
"NAME": {
|
||||||
"LABEL": "Firmenname",
|
"LABEL": "Kontobezeichnung",
|
||||||
"PLACEHOLDER": "Wayne Enterprises"
|
"PLACEHOLDER": "Wayne Enterprises"
|
||||||
},
|
},
|
||||||
"SUBMIT": "Abschicken"
|
"SUBMIT": "Abschicken"
|
||||||
|
|
|
@ -2,13 +2,11 @@
|
||||||
"REGISTER": {
|
"REGISTER": {
|
||||||
"TRY_WOOT": "Einen Account registrieren",
|
"TRY_WOOT": "Einen Account registrieren",
|
||||||
"TITLE": "Registrieren",
|
"TITLE": "Registrieren",
|
||||||
"TESTIMONIAL_HEADER": "All it takes is one step to move forward",
|
|
||||||
"TESTIMONIAL_CONTENT": "You're one step away from engaging your customers, retaining them and finding new ones.",
|
|
||||||
"TERMS_ACCEPT": "Mit Ihrer Anmeldung stimmen Sie unseren <a href=\"https://www.chatwoot.com/terms\"> AGB </a> und <a href=\"https://www.chatwoot.com/privacy-policy\"> Datenschutzrichtlinie </a>",
|
"TERMS_ACCEPT": "Mit Ihrer Anmeldung stimmen Sie unseren <a href=\"https://www.chatwoot.com/terms\"> AGB </a> und <a href=\"https://www.chatwoot.com/privacy-policy\"> Datenschutzrichtlinie </a>",
|
||||||
"COMPANY_NAME": {
|
"ACCOUNT_NAME": {
|
||||||
"LABEL": "Company name",
|
"LABEL": "Kontobezeichnung",
|
||||||
"PLACEHOLDER": "Enter your company name. eg: Wayne Enterprises",
|
"PLACEHOLDER": "Geben Sie einen Kontonamen ein, z. B.: Wayne Enterprises",
|
||||||
"ERROR": "Company name is too short"
|
"ERROR": "Kontoname ist zu kurz"
|
||||||
},
|
},
|
||||||
"FULL_NAME": {
|
"FULL_NAME": {
|
||||||
"LABEL": "Vollständiger Name",
|
"LABEL": "Vollständiger Name",
|
||||||
|
@ -18,7 +16,7 @@
|
||||||
"EMAIL": {
|
"EMAIL": {
|
||||||
"LABEL": "Geschäftliche E-Mail-Adresse",
|
"LABEL": "Geschäftliche E-Mail-Adresse",
|
||||||
"PLACEHOLDER": "Geben Sie Ihre geschäftliche E-Mail-Adresse ein, z. B.: bruce@wayne.enterprises",
|
"PLACEHOLDER": "Geben Sie Ihre geschäftliche E-Mail-Adresse ein, z. B.: bruce@wayne.enterprises",
|
||||||
"ERROR": "Please enter a valid work email address"
|
"ERROR": "E-Mail-Adresse ist ungültig"
|
||||||
},
|
},
|
||||||
"PASSWORD": {
|
"PASSWORD": {
|
||||||
"LABEL": "Passwort",
|
"LABEL": "Passwort",
|
||||||
|
|
|
@ -41,10 +41,6 @@
|
||||||
"NO_RESPONSE": "Καμία ανταπόκριση",
|
"NO_RESPONSE": "Καμία ανταπόκριση",
|
||||||
"RATING_TITLE": "Αξιολόγηση",
|
"RATING_TITLE": "Αξιολόγηση",
|
||||||
"FEEDBACK_TITLE": "Ανατροφοδότηση",
|
"FEEDBACK_TITLE": "Ανατροφοδότηση",
|
||||||
"CARD": {
|
|
||||||
"SHOW_LABELS": "Προβολή ετικετών",
|
|
||||||
"HIDE_LABELS": "Απόκρυψη ετικετών"
|
|
||||||
},
|
|
||||||
"HEADER": {
|
"HEADER": {
|
||||||
"RESOLVE_ACTION": "Επίλυση",
|
"RESOLVE_ACTION": "Επίλυση",
|
||||||
"REOPEN_ACTION": "Επαναφορά",
|
"REOPEN_ACTION": "Επαναφορά",
|
||||||
|
|
|
@ -1,6 +0,0 @@
|
||||||
{
|
|
||||||
"EMOJI": {
|
|
||||||
"PLACEHOLDER": "Αναζήτηση emojis",
|
|
||||||
"NOT_FOUND": "Κανένα emoji δεν ταιριάζει με την αναζήτησή σας"
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -134,7 +134,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Αριθμός τηλεφώνου",
|
"LABEL": "Αριθμός τηλεφώνου",
|
||||||
"PLACEHOLDER": "Παρακαλώ εισάγετε έναν αριθμό τηλεφώνου από τον οποίο θα σταλεί το μήνυμα.",
|
"PLACEHOLDER": "Παρακαλώ εισάγετε έναν αριθμό τηλεφώνου από τον οποίο θα σταλεί το μήνυμα.",
|
||||||
"ERROR": "Παρακαλώ δώστε έναν έγκυρο αριθμό τηλεφώνου που ξεκινά με ένα σύμβολο `+` και δεν περιέχει κενά."
|
"ERROR": "Παρακαλώ καταχωρήστε μια έγκυρη τιμή. Ο αριθμός του τηλεφώνου πρέπει να ξεκινά με το σύμβολο `+`."
|
||||||
},
|
},
|
||||||
"API_CALLBACK": {
|
"API_CALLBACK": {
|
||||||
"TITLE": "URL επανάκλησης",
|
"TITLE": "URL επανάκλησης",
|
||||||
|
@ -185,7 +185,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Αριθμός τηλεφώνου",
|
"LABEL": "Αριθμός τηλεφώνου",
|
||||||
"PLACEHOLDER": "Παρακαλώ εισάγετε έναν αριθμό τηλεφώνου από τον οποίο θα σταλεί το μήνυμα.",
|
"PLACEHOLDER": "Παρακαλώ εισάγετε έναν αριθμό τηλεφώνου από τον οποίο θα σταλεί το μήνυμα.",
|
||||||
"ERROR": "Παρακαλώ δώστε έναν έγκυρο αριθμό τηλεφώνου που ξεκινά με ένα σύμβολο `+` και δεν περιέχει κενά."
|
"ERROR": "Παρακαλώ καταχωρήστε μια έγκυρη τιμή. Ο αριθμός του τηλεφώνου πρέπει να ξεκινά με το σύμβολο `+`."
|
||||||
},
|
},
|
||||||
"SUBMIT_BUTTON": "Δημιουργήστε Bandwidth",
|
"SUBMIT_BUTTON": "Δημιουργήστε Bandwidth",
|
||||||
"API": {
|
"API": {
|
||||||
|
@ -214,7 +214,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Αριθμός τηλεφώνου",
|
"LABEL": "Αριθμός τηλεφώνου",
|
||||||
"PLACEHOLDER": "Παρακαλώ εισάγετε έναν αριθμό τηλεφώνου από τον οποίο θα σταλεί το μήνυμα.",
|
"PLACEHOLDER": "Παρακαλώ εισάγετε έναν αριθμό τηλεφώνου από τον οποίο θα σταλεί το μήνυμα.",
|
||||||
"ERROR": "Παρακαλώ δώστε έναν έγκυρο αριθμό τηλεφώνου που ξεκινά με ένα σύμβολο `+` και δεν περιέχει κενά."
|
"ERROR": "Παρακαλώ καταχωρήστε μια έγκυρη τιμή. Ο αριθμός του τηλεφώνου πρέπει να ξεκινά με το σύμβολο `+`."
|
||||||
},
|
},
|
||||||
"PHONE_NUMBER_ID": {
|
"PHONE_NUMBER_ID": {
|
||||||
"LABEL": "Αριθμός Τηλεφώνου",
|
"LABEL": "Αριθμός Τηλεφώνου",
|
||||||
|
|
|
@ -103,9 +103,7 @@
|
||||||
"Στην Γραμμή",
|
"Στην Γραμμή",
|
||||||
"Απασχολημένος",
|
"Απασχολημένος",
|
||||||
"Εκτός"
|
"Εκτός"
|
||||||
],
|
]
|
||||||
"SET_AVAILABILITY_SUCCESS": "Η διαθεσιμότητα ορίστηκε με επιτυχία",
|
|
||||||
"SET_AVAILABILITY_ERROR": "Αδυναμία ορισμού διαθεσιμότητας, παρακαλώ προσπαθήστε ξανά"
|
|
||||||
},
|
},
|
||||||
"EMAIL": {
|
"EMAIL": {
|
||||||
"LABEL": "Η διεύθυνση email",
|
"LABEL": "Η διεύθυνση email",
|
||||||
|
@ -136,7 +134,6 @@
|
||||||
"SELECTOR_SUBTITLE": "Επιλέξτε ένα λογαριασμό από την Λίστα",
|
"SELECTOR_SUBTITLE": "Επιλέξτε ένα λογαριασμό από την Λίστα",
|
||||||
"PROFILE_SETTINGS": "Ρυθμίσεις Προφίλ",
|
"PROFILE_SETTINGS": "Ρυθμίσεις Προφίλ",
|
||||||
"KEYBOARD_SHORTCUTS": "Συντομεύσεις Πληκτρολογίου",
|
"KEYBOARD_SHORTCUTS": "Συντομεύσεις Πληκτρολογίου",
|
||||||
"SUPER_ADMIN_CONSOLE": "Super Admin Κονσόλα",
|
|
||||||
"LOGOUT": "Έξοδος (Logout)"
|
"LOGOUT": "Έξοδος (Logout)"
|
||||||
},
|
},
|
||||||
"APP_GLOBAL": {
|
"APP_GLOBAL": {
|
||||||
|
@ -229,10 +226,6 @@
|
||||||
"CATEGORY": "Κατηγορία",
|
"CATEGORY": "Κατηγορία",
|
||||||
"CATEGORY_EMPTY_MESSAGE": "Δεν βρέθηκαν κατηγορίες"
|
"CATEGORY_EMPTY_MESSAGE": "Δεν βρέθηκαν κατηγορίες"
|
||||||
},
|
},
|
||||||
"SET_AUTO_OFFLINE": {
|
|
||||||
"TEXT": "Αυτόματη σήμανση εκτός σύνδεσης",
|
|
||||||
"INFO_TEXT": "Αφήστε το σύστημα να σας σηματοδοτήσει αυτόματα εκτός σύνδεσης, όταν δεν χρησιμοποιείτε την εφαρμογή ή τον πίνακα ελέγχου."
|
|
||||||
},
|
|
||||||
"DOCS": "Ανάγνωση εγγράφων"
|
"DOCS": "Ανάγνωση εγγράφων"
|
||||||
},
|
},
|
||||||
"BILLING_SETTINGS": {
|
"BILLING_SETTINGS": {
|
||||||
|
@ -264,7 +257,7 @@
|
||||||
},
|
},
|
||||||
"FORM": {
|
"FORM": {
|
||||||
"NAME": {
|
"NAME": {
|
||||||
"LABEL": "Όνομα Εταιρείας",
|
"LABEL": "Ονομασία Λογαριασμού",
|
||||||
"PLACEHOLDER": "Wayne Α. Ε"
|
"PLACEHOLDER": "Wayne Α. Ε"
|
||||||
},
|
},
|
||||||
"SUBMIT": "Καταχώρηση"
|
"SUBMIT": "Καταχώρηση"
|
||||||
|
|
|
@ -2,13 +2,11 @@
|
||||||
"REGISTER": {
|
"REGISTER": {
|
||||||
"TRY_WOOT": "Καταχωρήστε ένα λογαριασμό",
|
"TRY_WOOT": "Καταχωρήστε ένα λογαριασμό",
|
||||||
"TITLE": "Καταχώρηση",
|
"TITLE": "Καταχώρηση",
|
||||||
"TESTIMONIAL_HEADER": "Το μόνο που χρειάζεται είναι ένα βήμα για να προχωρήσουμε",
|
|
||||||
"TESTIMONIAL_CONTENT": "Είστε ένα βήμα μακριά από την εμπλοκή των πελατών σας, και την εύρεση νέων.",
|
|
||||||
"TERMS_ACCEPT": "Με την καταχώρηση, έχετε συμφωνήσει με τους όρους μας <a href=\"https://www.chatwoot.com/terms\">T & C</a> και <a href=\"https://www.chatwoot.com/privacy-policy\">την πολιτική ιδιωτικών δεδομένων</a>",
|
"TERMS_ACCEPT": "Με την καταχώρηση, έχετε συμφωνήσει με τους όρους μας <a href=\"https://www.chatwoot.com/terms\">T & C</a> και <a href=\"https://www.chatwoot.com/privacy-policy\">την πολιτική ιδιωτικών δεδομένων</a>",
|
||||||
"COMPANY_NAME": {
|
"ACCOUNT_NAME": {
|
||||||
"LABEL": "Επωνυμία εταιρείας",
|
"LABEL": "Ονομασία Λογαριασμού",
|
||||||
"PLACEHOLDER": "Εισάγετε το όνομα της εταιρείας σας. π. χ.: Wayne Enterprises",
|
"PLACEHOLDER": "Συμπληρώστε όνομα λογαριασμού π. χ. Wayne Α. Ε",
|
||||||
"ERROR": "Το όνομα της εταιρείας είναι πολύ σύντομο"
|
"ERROR": "Το όνομα του λογαριασμού είναι πολύ σύντομο"
|
||||||
},
|
},
|
||||||
"FULL_NAME": {
|
"FULL_NAME": {
|
||||||
"LABEL": "Πλήρες όνομα",
|
"LABEL": "Πλήρες όνομα",
|
||||||
|
@ -18,7 +16,7 @@
|
||||||
"EMAIL": {
|
"EMAIL": {
|
||||||
"LABEL": "email εργασίας",
|
"LABEL": "email εργασίας",
|
||||||
"PLACEHOLDER": "συμπληρώστε το email εργασίας πχ: papadopoulos@wyane.com",
|
"PLACEHOLDER": "συμπληρώστε το email εργασίας πχ: papadopoulos@wyane.com",
|
||||||
"ERROR": "Παρακαλώ εισάγετε μια έγκυρη διεύθυνση email"
|
"ERROR": "Η διεύθυνση email είναι εσφαλμένη"
|
||||||
},
|
},
|
||||||
"PASSWORD": {
|
"PASSWORD": {
|
||||||
"LABEL": "Κωδικός",
|
"LABEL": "Κωδικός",
|
||||||
|
|
|
@ -41,10 +41,6 @@
|
||||||
"NO_RESPONSE": "No response",
|
"NO_RESPONSE": "No response",
|
||||||
"RATING_TITLE": "Rating",
|
"RATING_TITLE": "Rating",
|
||||||
"FEEDBACK_TITLE": "Feedback",
|
"FEEDBACK_TITLE": "Feedback",
|
||||||
"CARD": {
|
|
||||||
"SHOW_LABELS": "Show labels",
|
|
||||||
"HIDE_LABELS": "Hide labels"
|
|
||||||
},
|
|
||||||
"HEADER": {
|
"HEADER": {
|
||||||
"RESOLVE_ACTION": "Resolve",
|
"RESOLVE_ACTION": "Resolve",
|
||||||
"REOPEN_ACTION": "Reopen",
|
"REOPEN_ACTION": "Reopen",
|
||||||
|
|
|
@ -97,6 +97,7 @@
|
||||||
"SEARCH_PLACEHOLDER": "Search or jump to",
|
"SEARCH_PLACEHOLDER": "Search or jump to",
|
||||||
"SECTIONS": {
|
"SECTIONS": {
|
||||||
"GENERAL": "General",
|
"GENERAL": "General",
|
||||||
|
"CHATWOOT": "Search Chatwoot",
|
||||||
"REPORTS": "Reports",
|
"REPORTS": "Reports",
|
||||||
"CONVERSATION": "Conversation",
|
"CONVERSATION": "Conversation",
|
||||||
"CHANGE_ASSIGNEE": "Change Assignee",
|
"CHANGE_ASSIGNEE": "Change Assignee",
|
||||||
|
@ -107,6 +108,7 @@
|
||||||
},
|
},
|
||||||
"COMMANDS": {
|
"COMMANDS": {
|
||||||
"GO_TO_CONVERSATION_DASHBOARD": "Go to Conversation Dashboard",
|
"GO_TO_CONVERSATION_DASHBOARD": "Go to Conversation Dashboard",
|
||||||
|
"SEARCH_EVEYTHING": "Search everything",
|
||||||
"GO_TO_CONTACTS_DASHBOARD": "Go to Contacts Dashboard",
|
"GO_TO_CONTACTS_DASHBOARD": "Go to Contacts Dashboard",
|
||||||
"GO_TO_REPORTS_OVERVIEW": "Go to Reports Overview",
|
"GO_TO_REPORTS_OVERVIEW": "Go to Reports Overview",
|
||||||
"GO_TO_CONVERSATION_REPORTS": "Go to Conversation Reports",
|
"GO_TO_CONVERSATION_REPORTS": "Go to Conversation Reports",
|
||||||
|
|
|
@ -134,7 +134,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Phone number",
|
"LABEL": "Phone number",
|
||||||
"PLACEHOLDER": "Please enter the phone number from which message will be sent.",
|
"PLACEHOLDER": "Please enter the phone number from which message will be sent.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "Please enter a valid value. Phone number should start with `+` sign."
|
||||||
},
|
},
|
||||||
"API_CALLBACK": {
|
"API_CALLBACK": {
|
||||||
"TITLE": "Callback URL",
|
"TITLE": "Callback URL",
|
||||||
|
@ -185,7 +185,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Phone number",
|
"LABEL": "Phone number",
|
||||||
"PLACEHOLDER": "Please enter the phone number from which message will be sent.",
|
"PLACEHOLDER": "Please enter the phone number from which message will be sent.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "Please enter a valid value. Phone number should start with `+` sign."
|
||||||
},
|
},
|
||||||
"SUBMIT_BUTTON": "Create Bandwidth Channel",
|
"SUBMIT_BUTTON": "Create Bandwidth Channel",
|
||||||
"API": {
|
"API": {
|
||||||
|
@ -214,7 +214,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Phone number",
|
"LABEL": "Phone number",
|
||||||
"PLACEHOLDER": "Please enter the phone number from which message will be sent.",
|
"PLACEHOLDER": "Please enter the phone number from which message will be sent.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "Please enter a valid value. Phone number should start with `+` sign."
|
||||||
},
|
},
|
||||||
"PHONE_NUMBER_ID": {
|
"PHONE_NUMBER_ID": {
|
||||||
"LABEL": "Phone number ID",
|
"LABEL": "Phone number ID",
|
||||||
|
|
|
@ -99,9 +99,7 @@
|
||||||
},
|
},
|
||||||
"AVAILABILITY": {
|
"AVAILABILITY": {
|
||||||
"LABEL": "Availability",
|
"LABEL": "Availability",
|
||||||
"STATUSES_LIST": ["Online", "Busy", "Offline"],
|
"STATUSES_LIST": ["Online", "Busy", "Offline"]
|
||||||
"SET_AVAILABILITY_SUCCESS": "Availability has been set successfully",
|
|
||||||
"SET_AVAILABILITY_ERROR": "Couldn't set availability, please try again"
|
|
||||||
},
|
},
|
||||||
"EMAIL": {
|
"EMAIL": {
|
||||||
"LABEL": "Your email address",
|
"LABEL": "Your email address",
|
||||||
|
@ -132,7 +130,6 @@
|
||||||
"SELECTOR_SUBTITLE": "Select an account from the following list",
|
"SELECTOR_SUBTITLE": "Select an account from the following list",
|
||||||
"PROFILE_SETTINGS": "Profile Settings",
|
"PROFILE_SETTINGS": "Profile Settings",
|
||||||
"KEYBOARD_SHORTCUTS": "Keyboard Shortcuts",
|
"KEYBOARD_SHORTCUTS": "Keyboard Shortcuts",
|
||||||
"SUPER_ADMIN_CONSOLE": "Super Admin Console",
|
|
||||||
"LOGOUT": "Logout"
|
"LOGOUT": "Logout"
|
||||||
},
|
},
|
||||||
"APP_GLOBAL": {
|
"APP_GLOBAL": {
|
||||||
|
@ -225,10 +222,6 @@
|
||||||
"CATEGORY": "Category",
|
"CATEGORY": "Category",
|
||||||
"CATEGORY_EMPTY_MESSAGE": "No categories found"
|
"CATEGORY_EMPTY_MESSAGE": "No categories found"
|
||||||
},
|
},
|
||||||
"SET_AUTO_OFFLINE": {
|
|
||||||
"TEXT": "Mark offline automatically",
|
|
||||||
"INFO_TEXT": "Let the system automatically mark you offline when you aren't using the app or dashboard."
|
|
||||||
},
|
|
||||||
"DOCS": "Read docs"
|
"DOCS": "Read docs"
|
||||||
},
|
},
|
||||||
"BILLING_SETTINGS": {
|
"BILLING_SETTINGS": {
|
||||||
|
|
|
@ -41,10 +41,6 @@
|
||||||
"NO_RESPONSE": "No hay respuesta",
|
"NO_RESPONSE": "No hay respuesta",
|
||||||
"RATING_TITLE": "Calificación",
|
"RATING_TITLE": "Calificación",
|
||||||
"FEEDBACK_TITLE": "Comentarios",
|
"FEEDBACK_TITLE": "Comentarios",
|
||||||
"CARD": {
|
|
||||||
"SHOW_LABELS": "Show labels",
|
|
||||||
"HIDE_LABELS": "Hide labels"
|
|
||||||
},
|
|
||||||
"HEADER": {
|
"HEADER": {
|
||||||
"RESOLVE_ACTION": "Resolver",
|
"RESOLVE_ACTION": "Resolver",
|
||||||
"REOPEN_ACTION": "Reabrir",
|
"REOPEN_ACTION": "Reabrir",
|
||||||
|
|
|
@ -1,6 +0,0 @@
|
||||||
{
|
|
||||||
"EMOJI": {
|
|
||||||
"PLACEHOLDER": "Search emojis",
|
|
||||||
"NOT_FOUND": "No emoji match your search"
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -134,7 +134,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Número de teléfono",
|
"LABEL": "Número de teléfono",
|
||||||
"PLACEHOLDER": "Por favor, introduzca el número de teléfono desde el que se enviará el mensaje.",
|
"PLACEHOLDER": "Por favor, introduzca el número de teléfono desde el que se enviará el mensaje.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "Por favor, introduzca un valor válido. El número de teléfono debe comenzar con la firma `+`."
|
||||||
},
|
},
|
||||||
"API_CALLBACK": {
|
"API_CALLBACK": {
|
||||||
"TITLE": "URL de devolución de llamada",
|
"TITLE": "URL de devolución de llamada",
|
||||||
|
@ -185,7 +185,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Número de teléfono",
|
"LABEL": "Número de teléfono",
|
||||||
"PLACEHOLDER": "Por favor, introduzca el número de teléfono desde el que se enviará el mensaje.",
|
"PLACEHOLDER": "Por favor, introduzca el número de teléfono desde el que se enviará el mensaje.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "Por favor, introduzca un valor válido. El número de teléfono debe comenzar con la firma `+`."
|
||||||
},
|
},
|
||||||
"SUBMIT_BUTTON": "Crear Canal de Bandwidth",
|
"SUBMIT_BUTTON": "Crear Canal de Bandwidth",
|
||||||
"API": {
|
"API": {
|
||||||
|
@ -214,7 +214,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Número de teléfono",
|
"LABEL": "Número de teléfono",
|
||||||
"PLACEHOLDER": "Por favor, introduzca el número de teléfono desde el que se enviará el mensaje.",
|
"PLACEHOLDER": "Por favor, introduzca el número de teléfono desde el que se enviará el mensaje.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "Por favor, introduzca un valor válido. El número de teléfono debe comenzar con la firma `+`."
|
||||||
},
|
},
|
||||||
"PHONE_NUMBER_ID": {
|
"PHONE_NUMBER_ID": {
|
||||||
"LABEL": "ID de número de teléfono",
|
"LABEL": "ID de número de teléfono",
|
||||||
|
|
|
@ -103,9 +103,7 @@
|
||||||
"En línea",
|
"En línea",
|
||||||
"Ocupado",
|
"Ocupado",
|
||||||
"Fuera de línea"
|
"Fuera de línea"
|
||||||
],
|
]
|
||||||
"SET_AVAILABILITY_SUCCESS": "Availability has been set successfully",
|
|
||||||
"SET_AVAILABILITY_ERROR": "Couldn't set availability, please try again"
|
|
||||||
},
|
},
|
||||||
"EMAIL": {
|
"EMAIL": {
|
||||||
"LABEL": "Tu dirección de correo",
|
"LABEL": "Tu dirección de correo",
|
||||||
|
@ -136,7 +134,6 @@
|
||||||
"SELECTOR_SUBTITLE": "Seleccione una cuenta de la siguiente lista",
|
"SELECTOR_SUBTITLE": "Seleccione una cuenta de la siguiente lista",
|
||||||
"PROFILE_SETTINGS": "Ajustes del perfil",
|
"PROFILE_SETTINGS": "Ajustes del perfil",
|
||||||
"KEYBOARD_SHORTCUTS": "Atajos de teclado",
|
"KEYBOARD_SHORTCUTS": "Atajos de teclado",
|
||||||
"SUPER_ADMIN_CONSOLE": "Super Admin Console",
|
|
||||||
"LOGOUT": "Cerrar sesión"
|
"LOGOUT": "Cerrar sesión"
|
||||||
},
|
},
|
||||||
"APP_GLOBAL": {
|
"APP_GLOBAL": {
|
||||||
|
@ -229,10 +226,6 @@
|
||||||
"CATEGORY": "Categoría",
|
"CATEGORY": "Categoría",
|
||||||
"CATEGORY_EMPTY_MESSAGE": "No se encontraron categorías"
|
"CATEGORY_EMPTY_MESSAGE": "No se encontraron categorías"
|
||||||
},
|
},
|
||||||
"SET_AUTO_OFFLINE": {
|
|
||||||
"TEXT": "Mark offline automatically",
|
|
||||||
"INFO_TEXT": "Let the system automatically mark you offline when you aren't using the app or dashboard."
|
|
||||||
},
|
|
||||||
"DOCS": "Leer documentos"
|
"DOCS": "Leer documentos"
|
||||||
},
|
},
|
||||||
"BILLING_SETTINGS": {
|
"BILLING_SETTINGS": {
|
||||||
|
@ -264,7 +257,7 @@
|
||||||
},
|
},
|
||||||
"FORM": {
|
"FORM": {
|
||||||
"NAME": {
|
"NAME": {
|
||||||
"LABEL": "Empresa",
|
"LABEL": "Nombre de cuenta",
|
||||||
"PLACEHOLDER": "Empresas de Wayne"
|
"PLACEHOLDER": "Empresas de Wayne"
|
||||||
},
|
},
|
||||||
"SUBMIT": "Enviar"
|
"SUBMIT": "Enviar"
|
||||||
|
|
|
@ -2,13 +2,11 @@
|
||||||
"REGISTER": {
|
"REGISTER": {
|
||||||
"TRY_WOOT": "Registrar una cuenta",
|
"TRY_WOOT": "Registrar una cuenta",
|
||||||
"TITLE": "Registrarse",
|
"TITLE": "Registrarse",
|
||||||
"TESTIMONIAL_HEADER": "All it takes is one step to move forward",
|
|
||||||
"TESTIMONIAL_CONTENT": "You're one step away from engaging your customers, retaining them and finding new ones.",
|
|
||||||
"TERMS_ACCEPT": "Al registrarte, aceptas nuestra <a href=\"https://www.chatwoot.com/terms\">T & C</a> y nuestra <a href=\"https://www.chatwoot.com/privacy-policy\">política de privacidad</a>",
|
"TERMS_ACCEPT": "Al registrarte, aceptas nuestra <a href=\"https://www.chatwoot.com/terms\">T & C</a> y nuestra <a href=\"https://www.chatwoot.com/privacy-policy\">política de privacidad</a>",
|
||||||
"COMPANY_NAME": {
|
"ACCOUNT_NAME": {
|
||||||
"LABEL": "Company name",
|
"LABEL": "Nombre de cuenta",
|
||||||
"PLACEHOLDER": "Enter your company name. eg: Wayne Enterprises",
|
"PLACEHOLDER": "Empresas de Wayne",
|
||||||
"ERROR": "Company name is too short"
|
"ERROR": "El nombre de la cuenta es demasiado corto"
|
||||||
},
|
},
|
||||||
"FULL_NAME": {
|
"FULL_NAME": {
|
||||||
"LABEL": "Nombre completo",
|
"LABEL": "Nombre completo",
|
||||||
|
@ -18,7 +16,7 @@
|
||||||
"EMAIL": {
|
"EMAIL": {
|
||||||
"LABEL": "E-mail",
|
"LABEL": "E-mail",
|
||||||
"PLACEHOLDER": "bruce@wayne.empresas",
|
"PLACEHOLDER": "bruce@wayne.empresas",
|
||||||
"ERROR": "Please enter a valid work email address"
|
"ERROR": "El correo no es válido"
|
||||||
},
|
},
|
||||||
"PASSWORD": {
|
"PASSWORD": {
|
||||||
"LABEL": "Contraseña",
|
"LABEL": "Contraseña",
|
||||||
|
|
|
@ -41,10 +41,6 @@
|
||||||
"NO_RESPONSE": "بدون پاسخ",
|
"NO_RESPONSE": "بدون پاسخ",
|
||||||
"RATING_TITLE": "رتبه",
|
"RATING_TITLE": "رتبه",
|
||||||
"FEEDBACK_TITLE": "بازخورد",
|
"FEEDBACK_TITLE": "بازخورد",
|
||||||
"CARD": {
|
|
||||||
"SHOW_LABELS": "مشاهده کردن برچسبها",
|
|
||||||
"HIDE_LABELS": "پنهان کردن برچسبها"
|
|
||||||
},
|
|
||||||
"HEADER": {
|
"HEADER": {
|
||||||
"RESOLVE_ACTION": "حل شد",
|
"RESOLVE_ACTION": "حل شد",
|
||||||
"REOPEN_ACTION": "دوباره باز کنید",
|
"REOPEN_ACTION": "دوباره باز کنید",
|
||||||
|
|
|
@ -1,6 +0,0 @@
|
||||||
{
|
|
||||||
"EMOJI": {
|
|
||||||
"PLACEHOLDER": "جستجوی ایموجی",
|
|
||||||
"NOT_FOUND": "هیچ ایموجی با جستجوی شما مطابقت ندارد"
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -134,7 +134,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "شماره تلفن",
|
"LABEL": "شماره تلفن",
|
||||||
"PLACEHOLDER": "لطفا شمارهای که پیام میبایست به آن ارسال شود را وارد کنید",
|
"PLACEHOLDER": "لطفا شمارهای که پیام میبایست به آن ارسال شود را وارد کنید",
|
||||||
"ERROR": "لطفا یک شماره تلفن معتبر ارائه دهید که با علامت «+» شروع شود و بدون فاصله بین اعداد باشد."
|
"ERROR": "لطفا شماره تلفن را به شکل صحیح وارد کنید. شماره میبایست با کاراکتر `+` شروع شود"
|
||||||
},
|
},
|
||||||
"API_CALLBACK": {
|
"API_CALLBACK": {
|
||||||
"TITLE": "آدرس URL مربوط به API",
|
"TITLE": "آدرس URL مربوط به API",
|
||||||
|
@ -185,7 +185,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "شماره تلفن",
|
"LABEL": "شماره تلفن",
|
||||||
"PLACEHOLDER": "لطفا شمارهای که پیام میبایست به آن ارسال شود را وارد کنید",
|
"PLACEHOLDER": "لطفا شمارهای که پیام میبایست به آن ارسال شود را وارد کنید",
|
||||||
"ERROR": "لطفا یک شماره تلفن معتبر ارائه دهید که با علامت «+» شروع شود و بدون فاصله بین اعداد باشد."
|
"ERROR": "لطفا شماره تلفن را به شکل صحیح وارد کنید. شماره میبایست با کاراکتر `+` شروع شود"
|
||||||
},
|
},
|
||||||
"SUBMIT_BUTTON": "ایجاد کانال Bandwidth",
|
"SUBMIT_BUTTON": "ایجاد کانال Bandwidth",
|
||||||
"API": {
|
"API": {
|
||||||
|
@ -214,7 +214,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "شماره تلفن",
|
"LABEL": "شماره تلفن",
|
||||||
"PLACEHOLDER": "لطفا شمارهای که پیام میبایست به آن ارسال شود را وارد کنید",
|
"PLACEHOLDER": "لطفا شمارهای که پیام میبایست به آن ارسال شود را وارد کنید",
|
||||||
"ERROR": "لطفا یک شماره تلفن معتبر ارائه دهید که با علامت «+» شروع شود و بدون فاصله بین اعداد باشد."
|
"ERROR": "لطفا شماره تلفن را به شکل صحیح وارد کنید. شماره میبایست با کاراکتر `+` شروع شود"
|
||||||
},
|
},
|
||||||
"PHONE_NUMBER_ID": {
|
"PHONE_NUMBER_ID": {
|
||||||
"LABEL": "شناسه شماره تلفن",
|
"LABEL": "شناسه شماره تلفن",
|
||||||
|
@ -445,8 +445,8 @@
|
||||||
"ENABLE_CSAT_SUB_TEXT": "پس از پایان گفتگو ، نظرسنجی CSAT (رضایت مشتری) را فعال/غیرفعال کنید",
|
"ENABLE_CSAT_SUB_TEXT": "پس از پایان گفتگو ، نظرسنجی CSAT (رضایت مشتری) را فعال/غیرفعال کنید",
|
||||||
"ENABLE_CONTINUITY_VIA_EMAIL": "ادامه مکالمه را از طریق ایمیل فعال کنید",
|
"ENABLE_CONTINUITY_VIA_EMAIL": "ادامه مکالمه را از طریق ایمیل فعال کنید",
|
||||||
"ENABLE_CONTINUITY_VIA_EMAIL_SUB_TEXT": "اگر آدرس ایمیل تماس در دسترس باشد، مکالمات از طریق ایمیل ادامه خواهد یافت.",
|
"ENABLE_CONTINUITY_VIA_EMAIL_SUB_TEXT": "اگر آدرس ایمیل تماس در دسترس باشد، مکالمات از طریق ایمیل ادامه خواهد یافت.",
|
||||||
"LOCK_TO_SINGLE_CONVERSATION": "قفل کردن مکالمه تکی",
|
"LOCK_TO_SINGLE_CONVERSATION": "Lock to single conversation",
|
||||||
"LOCK_TO_SINGLE_CONVERSATION_SUB_TEXT": "چند مکالمه را برای یک مخاطب در این صندوق ورودی فعال یا غیرفعال کنید",
|
"LOCK_TO_SINGLE_CONVERSATION_SUB_TEXT": "Enable or disable multiple conversations for the same contact in this inbox",
|
||||||
"INBOX_UPDATE_TITLE": "تنظیمات صندوق ورودی",
|
"INBOX_UPDATE_TITLE": "تنظیمات صندوق ورودی",
|
||||||
"INBOX_UPDATE_SUB_TEXT": "تغییر پارامترهای صندوق ورودی",
|
"INBOX_UPDATE_SUB_TEXT": "تغییر پارامترهای صندوق ورودی",
|
||||||
"AUTO_ASSIGNMENT_SUB_TEXT": "فعال کردن یا غیرفعال کردن واگذاری خودکار گفتگوها به ایجنت های عضو این صندوق ورودی.",
|
"AUTO_ASSIGNMENT_SUB_TEXT": "فعال کردن یا غیرفعال کردن واگذاری خودکار گفتگوها به ایجنت های عضو این صندوق ورودی.",
|
||||||
|
|
|
@ -103,9 +103,7 @@
|
||||||
"آنلاین",
|
"آنلاین",
|
||||||
"مشغول",
|
"مشغول",
|
||||||
"آفلاین"
|
"آفلاین"
|
||||||
],
|
]
|
||||||
"SET_AVAILABILITY_SUCCESS": "در دسترس بودن با موفقیت تنظیم شد",
|
|
||||||
"SET_AVAILABILITY_ERROR": "در دسترس بودن تنظیم نشد، لطفا دوباره امتحان کنید"
|
|
||||||
},
|
},
|
||||||
"EMAIL": {
|
"EMAIL": {
|
||||||
"LABEL": "ایمیل شما",
|
"LABEL": "ایمیل شما",
|
||||||
|
@ -136,7 +134,6 @@
|
||||||
"SELECTOR_SUBTITLE": "از لیست یکی از حسابها را انتخاب کنید",
|
"SELECTOR_SUBTITLE": "از لیست یکی از حسابها را انتخاب کنید",
|
||||||
"PROFILE_SETTINGS": "تنظیمات پروفایل",
|
"PROFILE_SETTINGS": "تنظیمات پروفایل",
|
||||||
"KEYBOARD_SHORTCUTS": "میانبرهای صفحهکلید",
|
"KEYBOARD_SHORTCUTS": "میانبرهای صفحهکلید",
|
||||||
"SUPER_ADMIN_CONSOLE": "کنسول سوپر مدیر",
|
|
||||||
"LOGOUT": "خروج از حسابکاربری"
|
"LOGOUT": "خروج از حسابکاربری"
|
||||||
},
|
},
|
||||||
"APP_GLOBAL": {
|
"APP_GLOBAL": {
|
||||||
|
@ -229,10 +226,6 @@
|
||||||
"CATEGORY": "دستهبندی",
|
"CATEGORY": "دستهبندی",
|
||||||
"CATEGORY_EMPTY_MESSAGE": "هیچ دستهبندیای یافت نشد"
|
"CATEGORY_EMPTY_MESSAGE": "هیچ دستهبندیای یافت نشد"
|
||||||
},
|
},
|
||||||
"SET_AUTO_OFFLINE": {
|
|
||||||
"TEXT": "علامت گذاری خودکار به صورت آفلاین",
|
|
||||||
"INFO_TEXT": "هنگامی که از برنامه یا پیشخوان استفاده نمیکنید، به سیستم اجازه دهید به طور خودکار شما را به صورت آفلاین علامت گذاری کند."
|
|
||||||
},
|
|
||||||
"DOCS": "اسناد را بخوانید"
|
"DOCS": "اسناد را بخوانید"
|
||||||
},
|
},
|
||||||
"BILLING_SETTINGS": {
|
"BILLING_SETTINGS": {
|
||||||
|
@ -264,7 +257,7 @@
|
||||||
},
|
},
|
||||||
"FORM": {
|
"FORM": {
|
||||||
"NAME": {
|
"NAME": {
|
||||||
"LABEL": "نام شرکت",
|
"LABEL": "عنوان حساب",
|
||||||
"PLACEHOLDER": "شرکت ایران ناسیونال"
|
"PLACEHOLDER": "شرکت ایران ناسیونال"
|
||||||
},
|
},
|
||||||
"SUBMIT": "ثبت"
|
"SUBMIT": "ثبت"
|
||||||
|
|
|
@ -2,13 +2,11 @@
|
||||||
"REGISTER": {
|
"REGISTER": {
|
||||||
"TRY_WOOT": "ثبتنام حسابکاربری",
|
"TRY_WOOT": "ثبتنام حسابکاربری",
|
||||||
"TITLE": "ثبت نام",
|
"TITLE": "ثبت نام",
|
||||||
"TESTIMONIAL_HEADER": "تنها چیزی که لازم است یک قدم برای حرکت به جلو است",
|
|
||||||
"TESTIMONIAL_CONTENT": "شما یک قدم تا جذب مشتریان خود، حفظ آنها و یافتن مشتریان جدید فاصله دارید.",
|
|
||||||
"TERMS_ACCEPT": "با ثبت نام، اعلام میدارید که <a href=\"https://www.chatwoot.com/terms\">قوانین</a> و <a href=\"https://www.chatwoot.com/privacy-policy\">شرایط استفاده</a> از این نرم افزار را تایید کرده و میپذیرید",
|
"TERMS_ACCEPT": "با ثبت نام، اعلام میدارید که <a href=\"https://www.chatwoot.com/terms\">قوانین</a> و <a href=\"https://www.chatwoot.com/privacy-policy\">شرایط استفاده</a> از این نرم افزار را تایید کرده و میپذیرید",
|
||||||
"COMPANY_NAME": {
|
"ACCOUNT_NAME": {
|
||||||
"LABEL": "نام شرکت",
|
"LABEL": "نام حسابکاربری",
|
||||||
"PLACEHOLDER": "نام شرکت خود را وارد کنید. به عنوان مثال: شرکت وین",
|
"PLACEHOLDER": "نام حسابکاربری را وارد کنید. به عنوان مثال: شرکت وین",
|
||||||
"ERROR": "نام شرکت خیلی کوتاه است"
|
"ERROR": "نام حسابکاربری خیلی کوتاه است"
|
||||||
},
|
},
|
||||||
"FULL_NAME": {
|
"FULL_NAME": {
|
||||||
"LABEL": "نام کامل",
|
"LABEL": "نام کامل",
|
||||||
|
@ -18,7 +16,7 @@
|
||||||
"EMAIL": {
|
"EMAIL": {
|
||||||
"LABEL": "ایمیل کاری",
|
"LABEL": "ایمیل کاری",
|
||||||
"PLACEHOLDER": "ایمیل کاری خود را وارد کنید به عنوان مثال: jafari@wayne.enterprises",
|
"PLACEHOLDER": "ایمیل کاری خود را وارد کنید به عنوان مثال: jafari@wayne.enterprises",
|
||||||
"ERROR": "لطفا یک آدرس ایمیل کاری معتبر وارد کنید"
|
"ERROR": "آدرس ایمیل معتبر نیست"
|
||||||
},
|
},
|
||||||
"PASSWORD": {
|
"PASSWORD": {
|
||||||
"LABEL": "رمز عبور",
|
"LABEL": "رمز عبور",
|
||||||
|
|
|
@ -41,10 +41,6 @@
|
||||||
"NO_RESPONSE": "No response",
|
"NO_RESPONSE": "No response",
|
||||||
"RATING_TITLE": "Arvio",
|
"RATING_TITLE": "Arvio",
|
||||||
"FEEDBACK_TITLE": "Palaute",
|
"FEEDBACK_TITLE": "Palaute",
|
||||||
"CARD": {
|
|
||||||
"SHOW_LABELS": "Show labels",
|
|
||||||
"HIDE_LABELS": "Hide labels"
|
|
||||||
},
|
|
||||||
"HEADER": {
|
"HEADER": {
|
||||||
"RESOLVE_ACTION": "Ratkaise",
|
"RESOLVE_ACTION": "Ratkaise",
|
||||||
"REOPEN_ACTION": "Uudelleenavaa",
|
"REOPEN_ACTION": "Uudelleenavaa",
|
||||||
|
|
|
@ -1,6 +0,0 @@
|
||||||
{
|
|
||||||
"EMOJI": {
|
|
||||||
"PLACEHOLDER": "Search emojis",
|
|
||||||
"NOT_FOUND": "No emoji match your search"
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -134,7 +134,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Puhelinnumero",
|
"LABEL": "Puhelinnumero",
|
||||||
"PLACEHOLDER": "Ole hyvä ja syötä puhelinnumero, josta viesti lähetetään.",
|
"PLACEHOLDER": "Ole hyvä ja syötä puhelinnumero, josta viesti lähetetään.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "Anna kelvollinen arvo. Puhelinnumeron pitäisi alkaa `+` merkillä."
|
||||||
},
|
},
|
||||||
"API_CALLBACK": {
|
"API_CALLBACK": {
|
||||||
"TITLE": "Callback URL",
|
"TITLE": "Callback URL",
|
||||||
|
@ -185,7 +185,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Puhelinnumero",
|
"LABEL": "Puhelinnumero",
|
||||||
"PLACEHOLDER": "Ole hyvä ja syötä puhelinnumero, josta viesti lähetetään.",
|
"PLACEHOLDER": "Ole hyvä ja syötä puhelinnumero, josta viesti lähetetään.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "Anna kelvollinen arvo. Puhelinnumeron pitäisi alkaa `+` merkillä."
|
||||||
},
|
},
|
||||||
"SUBMIT_BUTTON": "Create Bandwidth Channel",
|
"SUBMIT_BUTTON": "Create Bandwidth Channel",
|
||||||
"API": {
|
"API": {
|
||||||
|
@ -214,7 +214,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Puhelinnumero",
|
"LABEL": "Puhelinnumero",
|
||||||
"PLACEHOLDER": "Ole hyvä ja syötä puhelinnumero, josta viesti lähetetään.",
|
"PLACEHOLDER": "Ole hyvä ja syötä puhelinnumero, josta viesti lähetetään.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "Anna kelvollinen arvo. Puhelinnumeron pitäisi alkaa `+` merkillä."
|
||||||
},
|
},
|
||||||
"PHONE_NUMBER_ID": {
|
"PHONE_NUMBER_ID": {
|
||||||
"LABEL": "Phone number ID",
|
"LABEL": "Phone number ID",
|
||||||
|
|
|
@ -103,9 +103,7 @@
|
||||||
"Paikalla",
|
"Paikalla",
|
||||||
"Kiireinen",
|
"Kiireinen",
|
||||||
"Poissa"
|
"Poissa"
|
||||||
],
|
]
|
||||||
"SET_AVAILABILITY_SUCCESS": "Availability has been set successfully",
|
|
||||||
"SET_AVAILABILITY_ERROR": "Couldn't set availability, please try again"
|
|
||||||
},
|
},
|
||||||
"EMAIL": {
|
"EMAIL": {
|
||||||
"LABEL": "Sinun sähköpostiosoitteesi",
|
"LABEL": "Sinun sähköpostiosoitteesi",
|
||||||
|
@ -136,7 +134,6 @@
|
||||||
"SELECTOR_SUBTITLE": "Valitse tili tästä luettelosta",
|
"SELECTOR_SUBTITLE": "Valitse tili tästä luettelosta",
|
||||||
"PROFILE_SETTINGS": "Profiilin asetukset",
|
"PROFILE_SETTINGS": "Profiilin asetukset",
|
||||||
"KEYBOARD_SHORTCUTS": "Keyboard Shortcuts",
|
"KEYBOARD_SHORTCUTS": "Keyboard Shortcuts",
|
||||||
"SUPER_ADMIN_CONSOLE": "Super Admin Console",
|
|
||||||
"LOGOUT": "Kirjaudu ulos"
|
"LOGOUT": "Kirjaudu ulos"
|
||||||
},
|
},
|
||||||
"APP_GLOBAL": {
|
"APP_GLOBAL": {
|
||||||
|
@ -229,10 +226,6 @@
|
||||||
"CATEGORY": "Category",
|
"CATEGORY": "Category",
|
||||||
"CATEGORY_EMPTY_MESSAGE": "No categories found"
|
"CATEGORY_EMPTY_MESSAGE": "No categories found"
|
||||||
},
|
},
|
||||||
"SET_AUTO_OFFLINE": {
|
|
||||||
"TEXT": "Mark offline automatically",
|
|
||||||
"INFO_TEXT": "Let the system automatically mark you offline when you aren't using the app or dashboard."
|
|
||||||
},
|
|
||||||
"DOCS": "Read docs"
|
"DOCS": "Read docs"
|
||||||
},
|
},
|
||||||
"BILLING_SETTINGS": {
|
"BILLING_SETTINGS": {
|
||||||
|
@ -264,7 +257,7 @@
|
||||||
},
|
},
|
||||||
"FORM": {
|
"FORM": {
|
||||||
"NAME": {
|
"NAME": {
|
||||||
"LABEL": "Yrityksen nimi",
|
"LABEL": "Tilin nimi",
|
||||||
"PLACEHOLDER": "Wayne Enterprises"
|
"PLACEHOLDER": "Wayne Enterprises"
|
||||||
},
|
},
|
||||||
"SUBMIT": "Lähetä"
|
"SUBMIT": "Lähetä"
|
||||||
|
|
|
@ -2,13 +2,11 @@
|
||||||
"REGISTER": {
|
"REGISTER": {
|
||||||
"TRY_WOOT": "Luo tili",
|
"TRY_WOOT": "Luo tili",
|
||||||
"TITLE": "Rekisteröidy",
|
"TITLE": "Rekisteröidy",
|
||||||
"TESTIMONIAL_HEADER": "All it takes is one step to move forward",
|
|
||||||
"TESTIMONIAL_CONTENT": "You're one step away from engaging your customers, retaining them and finding new ones.",
|
|
||||||
"TERMS_ACCEPT": "Rekisteröitymällä hyväksyt <a href=\"https://www.chatwoot.com/terms\">käyttöehdot & säännöt</a> sekä <a href=\"https://www.chatwoot.com/privacy-policy\">yksityisyydensuojan</a>",
|
"TERMS_ACCEPT": "Rekisteröitymällä hyväksyt <a href=\"https://www.chatwoot.com/terms\">käyttöehdot & säännöt</a> sekä <a href=\"https://www.chatwoot.com/privacy-policy\">yksityisyydensuojan</a>",
|
||||||
"COMPANY_NAME": {
|
"ACCOUNT_NAME": {
|
||||||
"LABEL": "Company name",
|
"LABEL": "Tilin nimi",
|
||||||
"PLACEHOLDER": "Enter your company name. eg: Wayne Enterprises",
|
"PLACEHOLDER": "Anna käyttäjän nimi, esim: Wayne Enterprises",
|
||||||
"ERROR": "Company name is too short"
|
"ERROR": "Tilin nimi on liian lyhyt"
|
||||||
},
|
},
|
||||||
"FULL_NAME": {
|
"FULL_NAME": {
|
||||||
"LABEL": "Koko nimi",
|
"LABEL": "Koko nimi",
|
||||||
|
@ -18,7 +16,7 @@
|
||||||
"EMAIL": {
|
"EMAIL": {
|
||||||
"LABEL": "Työsähköposti",
|
"LABEL": "Työsähköposti",
|
||||||
"PLACEHOLDER": "Anna työsi sähköpostiosoite, esim: bruce@wayne.enterprises",
|
"PLACEHOLDER": "Anna työsi sähköpostiosoite, esim: bruce@wayne.enterprises",
|
||||||
"ERROR": "Please enter a valid work email address"
|
"ERROR": "Sähköpostiosoite ei ole kelvollinen"
|
||||||
},
|
},
|
||||||
"PASSWORD": {
|
"PASSWORD": {
|
||||||
"LABEL": "Salasana",
|
"LABEL": "Salasana",
|
||||||
|
|
|
@ -1,50 +1,50 @@
|
||||||
{
|
{
|
||||||
"FILTER": {
|
"FILTER": {
|
||||||
"TITLE": "Filtrer les conversations",
|
"TITLE": "Filter Conversations",
|
||||||
"SUBTITLE": "Ajoutez des filtres ci-dessous et appuyez sur 'Appliquer des filtres' pour filtrer les conversations.",
|
"SUBTITLE": "Add filters below and hit 'Apply filters' to filter conversations.",
|
||||||
"ADD_NEW_FILTER": "Ajouter un filtre",
|
"ADD_NEW_FILTER": "Add Filter",
|
||||||
"FILTER_DELETE_ERROR": "Vous devriez avoir au moins un filtre afin d'enregistrer",
|
"FILTER_DELETE_ERROR": "You should have atleast one filter to save",
|
||||||
"SUBMIT_BUTTON_LABEL": "Appliquer les filtres",
|
"SUBMIT_BUTTON_LABEL": "Apply filters",
|
||||||
"CANCEL_BUTTON_LABEL": "Annuler",
|
"CANCEL_BUTTON_LABEL": "Annuler",
|
||||||
"CLEAR_BUTTON_LABEL": "Effacer les filtres",
|
"CLEAR_BUTTON_LABEL": "Clear Filters",
|
||||||
"EMPTY_VALUE_ERROR": "Value is required",
|
"EMPTY_VALUE_ERROR": "Value is required",
|
||||||
"TOOLTIP_LABEL": "Filtrer les conversations",
|
"TOOLTIP_LABEL": "Filter conversations",
|
||||||
"QUERY_DROPDOWN_LABELS": {
|
"QUERY_DROPDOWN_LABELS": {
|
||||||
"AND": "ET",
|
"AND": "AND",
|
||||||
"OR": "OU"
|
"OR": "OR"
|
||||||
},
|
},
|
||||||
"OPERATOR_LABELS": {
|
"OPERATOR_LABELS": {
|
||||||
"equal_to": "Égal à",
|
"equal_to": "Equal to",
|
||||||
"not_equal_to": "Pas égal à",
|
"not_equal_to": "Not equal to",
|
||||||
"contains": "Contient",
|
"contains": "Contains",
|
||||||
"does_not_contain": "Ne contient pas",
|
"does_not_contain": "Does not contain",
|
||||||
"is_present": "Est présent",
|
"is_present": "Is present",
|
||||||
"is_not_present": "N'est pas présent",
|
"is_not_present": "Is not present",
|
||||||
"is_greater_than": "Est plus grand que",
|
"is_greater_than": "Is greater than",
|
||||||
"is_less_than": "Est inférieur à",
|
"is_less_than": "Is lesser than",
|
||||||
"days_before": "Est x jours avant"
|
"days_before": "Is x days before"
|
||||||
},
|
},
|
||||||
"ATTRIBUTE_LABELS": {
|
"ATTRIBUTE_LABELS": {
|
||||||
"TRUE": "Vrai",
|
"TRUE": "True",
|
||||||
"FALSE": "Faux"
|
"FALSE": "False"
|
||||||
},
|
},
|
||||||
"ATTRIBUTES": {
|
"ATTRIBUTES": {
|
||||||
"STATUS": "État",
|
"STATUS": "État",
|
||||||
"ASSIGNEE_NAME": "Assignee Name",
|
"ASSIGNEE_NAME": "Assignee Name",
|
||||||
"INBOX_NAME": "Nom de la boîte de réception",
|
"INBOX_NAME": "Nom de la boîte de réception",
|
||||||
"TEAM_NAME": "Nom de l'équipe",
|
"TEAM_NAME": "Team Name",
|
||||||
"CONVERSATION_IDENTIFIER": "Conversation Identifier",
|
"CONVERSATION_IDENTIFIER": "Conversation Identifier",
|
||||||
"CAMPAIGN_NAME": "Campaign Name",
|
"CAMPAIGN_NAME": "Campaign Name",
|
||||||
"LABELS": "Étiquettes",
|
"LABELS": "Étiquettes",
|
||||||
"BROWSER_LANGUAGE": "Langue du navigateur",
|
"BROWSER_LANGUAGE": "Browser Language",
|
||||||
"COUNTRY_NAME": "Nom du pays",
|
"COUNTRY_NAME": "Country Name",
|
||||||
"REFERER_LINK": "Referer link",
|
"REFERER_LINK": "Referer link",
|
||||||
"CUSTOM_ATTRIBUTE_LIST": "Liste",
|
"CUSTOM_ATTRIBUTE_LIST": "List",
|
||||||
"CUSTOM_ATTRIBUTE_TEXT": "Texte",
|
"CUSTOM_ATTRIBUTE_TEXT": "Text",
|
||||||
"CUSTOM_ATTRIBUTE_NUMBER": "Nombre",
|
"CUSTOM_ATTRIBUTE_NUMBER": "Number",
|
||||||
"CUSTOM_ATTRIBUTE_LINK": "Lien",
|
"CUSTOM_ATTRIBUTE_LINK": "Link",
|
||||||
"CUSTOM_ATTRIBUTE_CHECKBOX": "Case à cocher",
|
"CUSTOM_ATTRIBUTE_CHECKBOX": "Checkbox",
|
||||||
"CREATED_AT": "Créé le",
|
"CREATED_AT": "Created At",
|
||||||
"LAST_ACTIVITY": "Dernière activité"
|
"LAST_ACTIVITY": "Dernière activité"
|
||||||
},
|
},
|
||||||
"GROUPS": {
|
"GROUPS": {
|
||||||
|
@ -54,7 +54,7 @@
|
||||||
},
|
},
|
||||||
"CUSTOM_VIEWS": {
|
"CUSTOM_VIEWS": {
|
||||||
"ADD": {
|
"ADD": {
|
||||||
"TITLE": "Voulez-vous enregistrer ce filtre ?",
|
"TITLE": "Do you want to save this filter?",
|
||||||
"LABEL": "Name this filter",
|
"LABEL": "Name this filter",
|
||||||
"PLACEHOLDER": "Enter a name for this filter",
|
"PLACEHOLDER": "Enter a name for this filter",
|
||||||
"ERROR_MESSAGE": "Le nom est requis",
|
"ERROR_MESSAGE": "Le nom est requis",
|
||||||
|
@ -70,7 +70,7 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"DELETE": {
|
"DELETE": {
|
||||||
"DELETE_BUTTON": "Supprimer le filtre",
|
"DELETE_BUTTON": "Delete filter",
|
||||||
"MODAL": {
|
"MODAL": {
|
||||||
"CONFIRM": {
|
"CONFIRM": {
|
||||||
"TITLE": "Confirmer la suppression",
|
"TITLE": "Confirmer la suppression",
|
||||||
|
|
|
@ -87,13 +87,13 @@
|
||||||
},
|
},
|
||||||
"CONDITION": {
|
"CONDITION": {
|
||||||
"DELETE_MESSAGE": "Vous devez avoir au moins une condition pour enregistrer",
|
"DELETE_MESSAGE": "Vous devez avoir au moins une condition pour enregistrer",
|
||||||
"CONTACT_CUSTOM_ATTR_LABEL": "Attributs personnalisés des contacts",
|
"CONTACT_CUSTOM_ATTR_LABEL": "Contact Custom Attributes",
|
||||||
"CONVERSATION_CUSTOM_ATTR_LABEL": "Conversation Custom Attributes"
|
"CONVERSATION_CUSTOM_ATTR_LABEL": "Conversation Custom Attributes"
|
||||||
},
|
},
|
||||||
"ACTION": {
|
"ACTION": {
|
||||||
"DELETE_MESSAGE": "Vous devez avoir au moins une action pour enregistrer",
|
"DELETE_MESSAGE": "Vous devez avoir au moins une action pour enregistrer",
|
||||||
"TEAM_MESSAGE_INPUT_PLACEHOLDER": "Saisissez votre message ici",
|
"TEAM_MESSAGE_INPUT_PLACEHOLDER": "Enter your message here",
|
||||||
"TEAM_DROPDOWN_PLACEHOLDER": "Sélectionner une équipe"
|
"TEAM_DROPDOWN_PLACEHOLDER": "Select teams"
|
||||||
},
|
},
|
||||||
"TOGGLE": {
|
"TOGGLE": {
|
||||||
"ACTIVATION_TITLE": "Activer la règle d'automatisation",
|
"ACTIVATION_TITLE": "Activer la règle d'automatisation",
|
||||||
|
|
|
@ -8,7 +8,7 @@
|
||||||
},
|
},
|
||||||
"TAB_HEADING": "Conversations",
|
"TAB_HEADING": "Conversations",
|
||||||
"MENTION_HEADING": "Mentions",
|
"MENTION_HEADING": "Mentions",
|
||||||
"UNATTENDED_HEADING": "Sans suivi",
|
"UNATTENDED_HEADING": "Unattended",
|
||||||
"SEARCH": {
|
"SEARCH": {
|
||||||
"INPUT": "Rechercher des personnes, des conversations, des réponses standardisées ..."
|
"INPUT": "Rechercher des personnes, des conversations, des réponses standardisées ..."
|
||||||
},
|
},
|
||||||
|
@ -57,12 +57,12 @@
|
||||||
"REPLY_TO_TWEET": "Répondre à ce tweet",
|
"REPLY_TO_TWEET": "Répondre à ce tweet",
|
||||||
"LINK_TO_STORY": "Aller à l'histoire instagram",
|
"LINK_TO_STORY": "Aller à l'histoire instagram",
|
||||||
"SENT": "Envoyé avec succès",
|
"SENT": "Envoyé avec succès",
|
||||||
"READ": "Lu",
|
"READ": "Read successfully",
|
||||||
"DELIVERED": "Reçu",
|
"DELIVERED": "Delivered successfully",
|
||||||
"NO_MESSAGES": "Pas de messages",
|
"NO_MESSAGES": "Pas de messages",
|
||||||
"NO_CONTENT": "Aucun contenu disponible",
|
"NO_CONTENT": "Aucun contenu disponible",
|
||||||
"HIDE_QUOTED_TEXT": "Masquer le texte cité",
|
"HIDE_QUOTED_TEXT": "Masquer le texte cité",
|
||||||
"SHOW_QUOTED_TEXT": "Afficher le texte cité",
|
"SHOW_QUOTED_TEXT": "Afficher le texte cité",
|
||||||
"MESSAGE_READ": "Lu"
|
"MESSAGE_READ": "Read"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,7 +7,7 @@
|
||||||
"COPY_SUCCESSFUL": "Copié dans le presse-papiers avec succès",
|
"COPY_SUCCESSFUL": "Copié dans le presse-papiers avec succès",
|
||||||
"COMPANY": "Société",
|
"COMPANY": "Société",
|
||||||
"LOCATION": "Localisation",
|
"LOCATION": "Localisation",
|
||||||
"BROWSER_LANGUAGE": "Langue du navigateur",
|
"BROWSER_LANGUAGE": "Browser Language",
|
||||||
"CONVERSATION_TITLE": "Détails de la conversation",
|
"CONVERSATION_TITLE": "Détails de la conversation",
|
||||||
"VIEW_PROFILE": "Voir le profil",
|
"VIEW_PROFILE": "Voir le profil",
|
||||||
"BROWSER": "Navigateur",
|
"BROWSER": "Navigateur",
|
||||||
|
|
|
@ -2,28 +2,28 @@
|
||||||
"CONTACTS_FILTER": {
|
"CONTACTS_FILTER": {
|
||||||
"TITLE": "Filter Contacts",
|
"TITLE": "Filter Contacts",
|
||||||
"SUBTITLE": "Add filters below and hit 'Submit' to filter contacts.",
|
"SUBTITLE": "Add filters below and hit 'Submit' to filter contacts.",
|
||||||
"ADD_NEW_FILTER": "Ajouter un filtre",
|
"ADD_NEW_FILTER": "Add Filter",
|
||||||
"CLEAR_ALL_FILTERS": "Clear All Filters",
|
"CLEAR_ALL_FILTERS": "Clear All Filters",
|
||||||
"FILTER_DELETE_ERROR": "Vous devriez avoir au moins un filtre afin d'enregistrer",
|
"FILTER_DELETE_ERROR": "You should have atleast one filter to save",
|
||||||
"SUBMIT_BUTTON_LABEL": "Envoyer",
|
"SUBMIT_BUTTON_LABEL": "Envoyer",
|
||||||
"CANCEL_BUTTON_LABEL": "Annuler",
|
"CANCEL_BUTTON_LABEL": "Annuler",
|
||||||
"CLEAR_BUTTON_LABEL": "Effacer les filtres",
|
"CLEAR_BUTTON_LABEL": "Clear Filters",
|
||||||
"EMPTY_VALUE_ERROR": "Value is required",
|
"EMPTY_VALUE_ERROR": "Value is required",
|
||||||
"TOOLTIP_LABEL": "Filter contacts",
|
"TOOLTIP_LABEL": "Filter contacts",
|
||||||
"QUERY_DROPDOWN_LABELS": {
|
"QUERY_DROPDOWN_LABELS": {
|
||||||
"AND": "ET",
|
"AND": "AND",
|
||||||
"OR": "OU"
|
"OR": "OR"
|
||||||
},
|
},
|
||||||
"OPERATOR_LABELS": {
|
"OPERATOR_LABELS": {
|
||||||
"equal_to": "Égal à",
|
"equal_to": "Equal to",
|
||||||
"not_equal_to": "Pas égal à",
|
"not_equal_to": "Not equal to",
|
||||||
"contains": "Contient",
|
"contains": "Contains",
|
||||||
"does_not_contain": "Ne contient pas",
|
"does_not_contain": "Does not contain",
|
||||||
"is_present": "Est présent",
|
"is_present": "Is present",
|
||||||
"is_not_present": "N'est pas présent",
|
"is_not_present": "Is not present",
|
||||||
"is_greater_than": "Est plus grand que",
|
"is_greater_than": "Is greater than",
|
||||||
"is_lesser_than": "Is lesser than",
|
"is_lesser_than": "Is lesser than",
|
||||||
"days_before": "Est x jours avant"
|
"days_before": "Is x days before"
|
||||||
},
|
},
|
||||||
"ATTRIBUTES": {
|
"ATTRIBUTES": {
|
||||||
"NAME": "Nom",
|
"NAME": "Nom",
|
||||||
|
@ -32,12 +32,12 @@
|
||||||
"IDENTIFIER": "Identifier",
|
"IDENTIFIER": "Identifier",
|
||||||
"CITY": "Ville",
|
"CITY": "Ville",
|
||||||
"COUNTRY": "Pays",
|
"COUNTRY": "Pays",
|
||||||
"CUSTOM_ATTRIBUTE_LIST": "Liste",
|
"CUSTOM_ATTRIBUTE_LIST": "List",
|
||||||
"CUSTOM_ATTRIBUTE_TEXT": "Texte",
|
"CUSTOM_ATTRIBUTE_TEXT": "Text",
|
||||||
"CUSTOM_ATTRIBUTE_NUMBER": "Nombre",
|
"CUSTOM_ATTRIBUTE_NUMBER": "Number",
|
||||||
"CUSTOM_ATTRIBUTE_LINK": "Lien",
|
"CUSTOM_ATTRIBUTE_LINK": "Link",
|
||||||
"CUSTOM_ATTRIBUTE_CHECKBOX": "Case à cocher",
|
"CUSTOM_ATTRIBUTE_CHECKBOX": "Checkbox",
|
||||||
"CREATED_AT": "Créé le",
|
"CREATED_AT": "Created At",
|
||||||
"LAST_ACTIVITY": "Dernière activité",
|
"LAST_ACTIVITY": "Dernière activité",
|
||||||
"REFERER_LINK": "Referrer link"
|
"REFERER_LINK": "Referrer link"
|
||||||
},
|
},
|
||||||
|
|
|
@ -41,10 +41,6 @@
|
||||||
"NO_RESPONSE": "Pas de réponse",
|
"NO_RESPONSE": "Pas de réponse",
|
||||||
"RATING_TITLE": "Note",
|
"RATING_TITLE": "Note",
|
||||||
"FEEDBACK_TITLE": "Commentaires",
|
"FEEDBACK_TITLE": "Commentaires",
|
||||||
"CARD": {
|
|
||||||
"SHOW_LABELS": "Show labels",
|
|
||||||
"HIDE_LABELS": "Hide labels"
|
|
||||||
},
|
|
||||||
"HEADER": {
|
"HEADER": {
|
||||||
"RESOLVE_ACTION": "Résoudre",
|
"RESOLVE_ACTION": "Résoudre",
|
||||||
"REOPEN_ACTION": "Ré-ouvrir",
|
"REOPEN_ACTION": "Ré-ouvrir",
|
||||||
|
|
|
@ -1,6 +0,0 @@
|
||||||
{
|
|
||||||
"EMOJI": {
|
|
||||||
"PLACEHOLDER": "Rechercher des émojis",
|
|
||||||
"NOT_FOUND": "Aucun émoji ne correspond à votre recherche"
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -134,7 +134,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Numéro de téléphone",
|
"LABEL": "Numéro de téléphone",
|
||||||
"PLACEHOLDER": "Veuillez entrer le numéro de téléphone à partir duquel le message sera envoyé.",
|
"PLACEHOLDER": "Veuillez entrer le numéro de téléphone à partir duquel le message sera envoyé.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "Veuillez entrer une valeur valide. Le numéro de téléphone doit commencer par le signe `+`."
|
||||||
},
|
},
|
||||||
"API_CALLBACK": {
|
"API_CALLBACK": {
|
||||||
"TITLE": "URL de rappel (callback)",
|
"TITLE": "URL de rappel (callback)",
|
||||||
|
@ -185,7 +185,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Numéro de téléphone",
|
"LABEL": "Numéro de téléphone",
|
||||||
"PLACEHOLDER": "Veuillez entrer le numéro de téléphone à partir duquel le message sera envoyé.",
|
"PLACEHOLDER": "Veuillez entrer le numéro de téléphone à partir duquel le message sera envoyé.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "Veuillez entrer une valeur valide. Le numéro de téléphone doit commencer par le signe `+`."
|
||||||
},
|
},
|
||||||
"SUBMIT_BUTTON": "Créer un canal de bande passante",
|
"SUBMIT_BUTTON": "Créer un canal de bande passante",
|
||||||
"API": {
|
"API": {
|
||||||
|
@ -214,7 +214,7 @@
|
||||||
"PHONE_NUMBER": {
|
"PHONE_NUMBER": {
|
||||||
"LABEL": "Numéro de téléphone",
|
"LABEL": "Numéro de téléphone",
|
||||||
"PLACEHOLDER": "Veuillez entrer le numéro de téléphone à partir duquel le message sera envoyé.",
|
"PLACEHOLDER": "Veuillez entrer le numéro de téléphone à partir duquel le message sera envoyé.",
|
||||||
"ERROR": "Please provide a valid phone number that starts with a `+` sign and does not contain any spaces."
|
"ERROR": "Veuillez entrer une valeur valide. Le numéro de téléphone doit commencer par le signe `+`."
|
||||||
},
|
},
|
||||||
"PHONE_NUMBER_ID": {
|
"PHONE_NUMBER_ID": {
|
||||||
"LABEL": "Phone number ID",
|
"LABEL": "Phone number ID",
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue