diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index d5f2a762a..dbdf59f65 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -20,6 +20,8 @@ stages: - lint - test - analysis + - docs_build + - docs_deploy before_script: - mix local.hex --force @@ -43,3 +45,38 @@ analysis: stage: analysis script: - mix credo --strict --only=warnings,todo,fixme,consistency,readability + +docs_build: + stage: docs_build + services: + only: + - master@pleroma/pleroma + - develop@pleroma/pleroma + variables: + MIX_ENV: dev + before_script: + - mix local.hex --force + - mix local.rebar --force + - mix deps.get + - mix compile + script: + - mix docs + artifacts: + paths: + - priv/static/doc + +docs_deploy: + stage: docs_deploy + image: alpine:3.9 + services: + only: + - master@pleroma/pleroma + - develop@pleroma/pleroma + before_script: + - apk update && apk add openssh-client rsync + script: + - mkdir -p ~/.ssh + - echo "${SSH_HOST_KEY}" > ~/.ssh/known_hosts + - eval $(ssh-agent -s) + - echo "$SSH_PRIVATE_KEY" | tr -d '\r' | ssh-add - + - rsync -hrvz --delete -e "ssh -p ${SSH_PORT}" priv/static/doc/ "${SSH_USER_HOST_LOCATION}/${CI_COMMIT_REF_NAME}" diff --git a/README.md b/README.md index 4f22445d0..c45190fc3 100644 --- a/README.md +++ b/README.md @@ -1,14 +1,16 @@ # Pleroma +**Note**: This readme as well as complete documentation is also availible at + ## About Pleroma Pleroma is a microblogging server software that can federate (= exchange messages with) other servers that support the same federation standards (OStatus and ActivityPub). What that means is that you can host a server for yourself or your friends and stay in control of your online identity, but still exchange messages with people on larger servers. Pleroma will federate with all servers that implement either OStatus or ActivityPub, like Friendica, GNU Social, Hubzilla, Mastodon, Misskey, Peertube, and Pixelfed. Pleroma is written in Elixir, high-performance and can run on small devices like a Raspberry Pi. -For clients it supports both the [GNU Social API with Qvitter extensions](https://twitter-api.readthedocs.io/en/latest/index.html) and the [Mastodon client API](https://github.com/tootsuite/documentation/blob/master/Using-the-API/API.md). +For clients it supports both the [GNU Social API with Qvitter extensions](https://twitter-api.readthedocs.io/en/latest/index.html) and the [Mastodon client API](https://docs.joinmastodon.org/api/guidelines/). -- [Client Applications for Pleroma](docs/Clients.md) +- [Client Applications for Pleroma](https://docs-develop.pleroma.social/clients.html) No release has been made yet, but several servers have been online for months already. If you want to run your own server, feel free to contact us at @lain@pleroma.soykaf.com or in our dev chat at #pleroma on freenode or via matrix at . @@ -28,7 +30,7 @@ While we don’t provide docker files, other people have written very good ones. * Run `mix deps.get` to install elixir dependencies. * Run `mix pleroma.instance gen`. This will ask you questions about your instance and generate a configuration file in `config/generated_config.exs`. Check that and copy it to either `config/dev.secret.exs` or `config/prod.secret.exs`. It will also create a `config/setup_db.psql`, which you should run as the PostgreSQL superuser (i.e., `sudo -u postgres psql -f config/setup_db.psql`). It will create the database, user, and password you gave `mix pleroma.gen.instance` earlier, as well as set up the necessary extensions in the database. PostgreSQL superuser privileges are only needed for this step. -* For these next steps, the default will be to run pleroma using the dev configuration file, `config/dev.secret.exs`. To run them using the prod config file, prefix each command at the shell with `MIX_ENV=prod`. For example: `MIX_ENV=prod mix phx.server`. Documentation for the config can be found at [`docs/config.md`](docs/config.md) +* For these next steps, the default will be to run pleroma using the dev configuration file, `config/dev.secret.exs`. To run them using the prod config file, prefix each command at the shell with `MIX_ENV=prod`. For example: `MIX_ENV=prod mix phx.server`. Documentation for the config can be found at [`docs/config.md`](docs/config.md) in the repository, or at the "Configuration" page on * Run `mix ecto.migrate` to run the database migrations. You will have to do this again after certain updates. * You can check if your instance is configured correctly by running it with `mix phx.server` and checking the instance info endpoint at `/api/v1/instance`. If it shows your uri, name and email correctly, you are configured correctly. If it shows something like `localhost:4000`, your configuration is probably wrong, unless you are running a local development setup. * The common and convenient way for adding HTTPS is by using Nginx as a reverse proxy. You can look at example Nginx configuration in `installation/pleroma.nginx`. If you need TLS/SSL certificates for HTTPS, you can look get some for free with letsencrypt: . The simplest way to obtain and install a certificate is to use [Certbot.](https://certbot.eff.org) Depending on your specific setup, certbot may be able to get a certificate and configure your web server automatically. @@ -66,7 +68,7 @@ This is useful for running Pleroma inside Tor or I2P. ## Customization and contribution -The [Pleroma Wiki](https://git.pleroma.social/pleroma/pleroma/wikis/home) offers manuals and guides on how to further customize your instance to your liking and how you can contribute to the project. +The [Pleroma Documentation](https://docs-develop.pleroma.social/readme.html) offers manuals and guides on how to further customize your instance to your liking and how you can contribute to the project. ## Troubleshooting diff --git a/config/config.exs b/config/config.exs index ccdd35777..dccf7b263 100644 --- a/config/config.exs +++ b/config/config.exs @@ -8,8 +8,6 @@ # General application configuration config :pleroma, ecto_repos: [Pleroma.Repo] -config :pleroma, Pleroma.Repo, types: Pleroma.PostgresTypes - config :pleroma, Pleroma.Captcha, enabled: false, seconds_valid: 60, @@ -174,7 +172,8 @@ no_attachment_links: false, welcome_user_nickname: nil, welcome_message: nil, - max_report_comment_size: 1000 + max_report_comment_size: 1000, + safe_dm_mentions: false config :pleroma, :markup, # XXX - unfortunately, inline images must be enabled by default right now, because @@ -273,8 +272,6 @@ config :pleroma, :chat, enabled: true -config :ecto, json_library: Jason - config :phoenix, :format_encoders, json: Jason config :pleroma, :gopher, @@ -351,10 +348,10 @@ initial_timeout: 30, max_retries: 5 -config :pleroma, Pleroma.Jobs, - federator_incoming: [max_jobs: 50], - federator_outgoing: [max_jobs: 50], - mailer: [max_jobs: 10] +config :pleroma_job_queue, :queues, + federator_incoming: 50, + federator_outgoing: 50, + mailer: 10 config :pleroma, :fetch_initial_posts, enabled: false, @@ -381,6 +378,8 @@ base: System.get_env("LDAP_BASE") || "dc=example,dc=com", uid: System.get_env("LDAP_UID") || "cn" +config :pleroma, Pleroma.Mailer, adapter: Swoosh.Adapters.Sendmail + # Import environment specific config. This must remain at the bottom # of this file so it overrides the configuration defined above. import_config "#{Mix.env()}.exs" diff --git a/config/test.exs b/config/test.exs index 3691e5bd1..6a7b9067e 100644 --- a/config/test.exs +++ b/config/test.exs @@ -48,7 +48,7 @@ config :web_push_encryption, :http_client, Pleroma.Web.WebPushHttpClientMock -config :pleroma, Pleroma.Jobs, testing: [max_jobs: 2] +config :pleroma_job_queue, disabled: true try do import_config "test.secret.exs" diff --git a/docs/admin/backup.md b/docs/admin/backup.md new file mode 100644 index 000000000..2c70e7bf8 --- /dev/null +++ b/docs/admin/backup.md @@ -0,0 +1,17 @@ +# Backup/Restore your instance + +## Backup + +1. Stop the Pleroma service. +2. Go to the working directory of Pleroma (default is `/opt/pleroma`) +3. Run `sudo -Hu postgres pg_dump -d --format=custom -f ` +4. Copy `pleroma.pgdump`, `config/prod.secret.exs` and the `uploads` folder to your backup destination. If you have other modifications, copy those changes too. +5. Restart the Pleroma service. + +## Restore + +1. Stop the Pleroma service. +2. Go to the working directory of Pleroma (default is `/opt/pleroma`) +3. Copy the above mentioned files back to their original position. +4. Run `sudo -Hu postgres pg_restore -d -v -1 ` +5. Restart the Pleroma service. diff --git a/docs/admin/updating.md b/docs/admin/updating.md new file mode 100644 index 000000000..84e6ef18d --- /dev/null +++ b/docs/admin/updating.md @@ -0,0 +1,9 @@ +# Updating your instance +1. Go to the working directory of Pleroma (default is `/opt/pleroma`) +2. Run `git pull`. This pulls the latest changes from upstream. +3. Run `mix deps.get`. This pulls in any new dependencies. +4. Stop the Pleroma service. +5. Run `mix ecto.migrate`[^1]. This task performs database migrations, if there were any. +6. Start the Pleroma service. + +[^1]: Prefix with `MIX_ENV=prod` to run it using the production config file. diff --git a/docs/Admin-API.md b/docs/api/admin_api.md similarity index 76% rename from docs/Admin-API.md rename to docs/api/admin_api.md index 2edb31f3c..53b68ffd4 100644 --- a/docs/Admin-API.md +++ b/docs/api/admin_api.md @@ -8,10 +8,15 @@ Authentication is required and the user must be an admin. - Method `GET` - Query Params: - - `query`: **string** *optional* search term - - `local_only`: **bool** *optional* whether to return only local users - - `page`: **integer** *optional* page number - - `page_size`: **integer** *optional* number of users per page (default is `50`) + - *optional* `query`: **string** search term + - *optional* `filters`: **string** comma-separated string of filters: + - `local`: only local users + - `external`: only external users + - `active`: only active users + - `deactivated`: only deactivated users + - *optional* `page`: **integer** page number + - *optional* `page_size`: **integer** number of users per page (default is `50`) +- Example: `https://mypleroma.org/api/pleroma/admin/users?query=john&filters=local,active&page=1&page_size=10` - Response: ```JSON @@ -22,7 +27,13 @@ Authentication is required and the user must be an admin. { "deactivated": bool, "id": integer, - "nickname": string + "nickname": string, + "roles": { + "admin": bool, + "moderator": bool + }, + "local": bool, + "tags": array }, ... ] @@ -99,7 +110,7 @@ Authentication is required and the user must be an admin. Note: Available `:permission_group` is currently moderator and admin. 404 is returned when the permission group doesn’t exist. -### Get user user permission groups membership +### Get user user permission groups membership per permission group - Method: `GET` - Params: none @@ -138,6 +149,17 @@ Note: Available `:permission_group` is currently moderator and admin. 404 is ret - `nickname` - `status` BOOLEAN field, false value means deactivation. +## `/api/pleroma/admin/users/:nickname` + +### Retrive the details of a user + +- Method: `GET` +- Params: + - `nickname` +- Response: + - On failure: `Not found` + - On success: JSON of the user + ## `/api/pleroma/admin/relay` ### Follow a Relay diff --git a/docs/Differences-in-MastodonAPI-Responses.md b/docs/api/differences_in_mastoapi_responses.md similarity index 63% rename from docs/Differences-in-MastodonAPI-Responses.md rename to docs/api/differences_in_mastoapi_responses.md index 621de6603..d993d1383 100644 --- a/docs/Differences-in-MastodonAPI-Responses.md +++ b/docs/api/differences_in_mastoapi_responses.md @@ -19,6 +19,7 @@ Adding the parameter `with_muted=true` to the timeline queries will also return Has these additional fields under the `pleroma` object: - `local`: true if the post was made on the local instance. +- `conversation_id`: the ID of the conversation the status is associated with (if any) ## Attachments @@ -29,3 +30,17 @@ Has these additional fields under the `pleroma` object: ## Accounts - `/api/v1/accounts/:id`: The `id` parameter can also be the `nickname` of the user. This only works in this endpoint, not the deeper nested ones for following etc. + +Has these additional fields under the `pleroma` object: + +- `tags`: Lists an array of tags for the user +- `relationship{}`: Includes fields as documented for Mastodon API https://docs.joinmastodon.org/api/entities/#relationship +- `is_moderator`: boolean, true if user is a moderator +- `is_admin`: boolean, true if user is an admin +- `confirmation_pending`: boolean, true if a new user account is waiting on email confirmation to be activated + +## Notifications + +Has these additional fields under the `pleroma` object: + +- `is_seen`: true if the notification was read by the user diff --git a/docs/Pleroma-API.md b/docs/api/pleroma_api.md similarity index 100% rename from docs/Pleroma-API.md rename to docs/api/pleroma_api.md diff --git a/docs/Clients.md b/docs/clients.md similarity index 100% rename from docs/Clients.md rename to docs/clients.md diff --git a/docs/config.md b/docs/config.md index 201180373..97a0e6ffa 100644 --- a/docs/config.md +++ b/docs/config.md @@ -101,7 +101,8 @@ config :pleroma, Pleroma.Mailer, * `no_attachment_links`: Set to true to disable automatically adding attachment link text to statuses * `welcome_message`: A message that will be send to a newly registered users as a direct message. * `welcome_user_nickname`: The nickname of the local user that sends the welcome message. -* `max_report_size`: The maximum size of the report comment (Default: `1000`) +* `max_report_comment_size`: The maximum size of the report comment (Default: `1000`) +* `safe_dm_mentions`: If set to true, only mentions at the beginning of a post will be used to address people in direct messages. This is to prevent accidental mentioning of people when talking about them (e.g. "@friend hey i really don't like @enemy"). (Default: `false`) ## :logger * `backends`: `:console` is used to send logs to stdout, `{ExSyslogger, :ex_syslogger}` to log to syslog @@ -190,6 +191,45 @@ This section is used to configure Pleroma-FE, unless ``:managed_config`` in ``:i * `enabled`: Enables the gopher interface * `ip`: IP address to bind to * `port`: Port to bind to +* `dstport`: Port advertised in urls (optional, defaults to `port`) + +## Pleroma.Web.Endpoint +`Phoenix` endpoint configuration, all configuration options can be viewed [here](https://hexdocs.pm/phoenix/Phoenix.Endpoint.html#module-dynamic-configuration), only common options are listed here +* `http` - a list containing http protocol configuration, all configuration options can be viewed [here](https://hexdocs.pm/plug_cowboy/Plug.Cowboy.html#module-options), only common options are listed here + - `ip` - a tuple consisting of 4 integers + - `port` +* `url` - a list containing the configuration for generating urls, accepts + - `host` - the host without the scheme and a post (e.g `example.com`, not `https://example.com:2020`) + - `scheme` - e.g `http`, `https` + - `port` + - `path` + + +**Important note**: if you modify anything inside these lists, default `config.exs` values will be overwritten, which may result in breakage, to make sure this does not happen please copy the default value for the list from `config.exs` and modify/add only what you need + +Example: +```elixir +config :pleroma, Pleroma.Web.Endpoint, + url: [host: "example.com", port: 2020, scheme: "https"], + http: [ + # start copied from config.exs + dispatch: [ + {:_, + [ + {"/api/v1/streaming", Pleroma.Web.MastodonAPI.WebsocketHandler, []}, + {"/websocket", Phoenix.Endpoint.CowboyWebSocket, + {Phoenix.Transports.WebSocket, + {Pleroma.Web.Endpoint, Pleroma.Web.UserSocket, websocket_config}}}, + {:_, Phoenix.Endpoint.Cowboy2Handler, {Pleroma.Web.Endpoint, []}} + ]} + # end copied from config.exs + ], + port: 8080, + ip: {127, 0, 0, 1} + ] +``` + +This will make Pleroma listen on `127.0.0.1` port `8080` and generate urls starting with `https://example.com:2020` ## :activitypub * ``accept_blocks``: Whether to accept incoming block activities from other instances @@ -251,25 +291,25 @@ You can then do curl "http://localhost:4000/api/pleroma/admin/invite_token?admin_token=somerandomtoken" ``` -## Pleroma.Jobs +## :pleroma_job_queue -A list of job queues and their settings. +[Pleroma Job Queue](https://git.pleroma.social/pleroma/pleroma_job_queue) configuration: a list of queues with maximum concurrent jobs. -Job queue settings: - -* `max_jobs`: The maximum amount of parallel jobs running at the same time. +Pleroma has the following queues: +* `federator_outgoing` - Outgoing federation +* `federator_incoming` - Incoming federation +* `mailer` - Email sender, see [`Pleroma.Mailer`](#pleroma-mailer) Example: -```exs -config :pleroma, Pleroma.Jobs, - federator_incoming: [max_jobs: 50], - federator_outgoing: [max_jobs: 50] +```elixir +config :pleroma_job_queue, :queues, + federator_incoming: 50, + federator_outgoing: 50 ``` This config contains two queues: `federator_incoming` and `federator_outgoing`. Both have the `max_jobs` set to `50`. - ## Pleroma.Web.Federator.RetryQueue * `enabled`: If set to `true`, failed federation jobs will be retried diff --git a/docs/config/General-tips-for-customizing-Pleroma-FE.md b/docs/config/General-tips-for-customizing-Pleroma-FE.md new file mode 100644 index 000000000..15c4882dd --- /dev/null +++ b/docs/config/General-tips-for-customizing-Pleroma-FE.md @@ -0,0 +1,17 @@ +# General tips for customizing Pleroma FE +There are some configuration scripts for Pleroma BE and FE: + +1. `config/prod.secret.exs` +1. `config/config.exs` +1. `priv/static/static/config.json` + +The `prod.secret.exs` affects first. `config.exs` is for fallback or default. `config.json` is for GNU-social-BE-Pleroma-FE instances. + +Usually all you have to do is: + +1. Copy the section in the `config/config.exs` which you want to activate. +1. Paste into `config/prod.secret.exs`. +1. Edit `config/prod.secret.exs`. +1. Restart the Pleroma daemon. + +`prod.secret.exs` is for the `MIX_ENV=prod` environment. `dev.secret.exs` is for the `MIX_ENV=dev` environment respectively. diff --git a/docs/Custom-Emoji.md b/docs/config/custom_emoji.md similarity index 97% rename from docs/Custom-Emoji.md rename to docs/config/custom_emoji.md index 9d90e5822..e833d2080 100644 --- a/docs/Custom-Emoji.md +++ b/docs/config/custom_emoji.md @@ -1,4 +1,4 @@ -# Custom emoji +# Custom Emoji To add custom emoji: * Add the image file(s) to `priv/static/emoji/custom` diff --git a/docs/config/hardening.md b/docs/config/hardening.md new file mode 100644 index 000000000..b54c28850 --- /dev/null +++ b/docs/config/hardening.md @@ -0,0 +1,103 @@ +# Hardening your instance +Here are some suggestions which improve the security of parts of your Pleroma instance. + +## Configuration file + +These changes should go into `prod.secret.exs` or `dev.secret.exs`, depending on your `MIX_ENV` value. + +### `http` + +> Recommended value: `[ip: {127, 0, 0, 1}]` + +This sets the Pleroma application server to only listen to the localhost interface. This way, you can only reach your server over the Internet by going through the reverse proxy. By default, Pleroma listens on all interfaces. + +### `secure_cookie_flag` + +> Recommended value: `true` + +This sets the `secure` flag on Pleroma’s session cookie. This makes sure, that the cookie is only accepted over encrypted HTTPs connections. This implicitly renames the cookie from `pleroma_key` to `__Host-pleroma-key` which enforces some restrictions. (see [cookie prefixes](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Set-Cookie#Cookie_prefixes)) + +### `:http_security` + +> Recommended value: `true` + +This will send additional HTTP security headers to the clients, including: + +* `X-XSS-Protection: "1; mode=block"` +* `X-Permitted-Cross-Domain-Policies: "none"` +* `X-Frame-Options: "DENY"` +* `X-Content-Type-Options: "nosniff"` +* `X-Download-Options: "noopen"` + +A content security policy (CSP) will also be set: + +```csp +content-security-policy: + default-src 'none'; + base-uri 'self'; + frame-ancestors 'none'; + img-src 'self' data: https:; + media-src 'self' https:; + style-src 'self' 'unsafe-inline'; + font-src 'self'; + script-src 'self'; + connect-src 'self' wss://example.tld; + manifest-src 'self'; + upgrade-insecure-requests; +``` + +#### `sts` + +> Recommended value: `true` + +An additional “Strict transport security” header will be sent with the configured `sts_max_age` parameter. This tells the browser, that the domain should only be accessed over a secure HTTPs connection. + +#### `ct_max_age` + +An additional “Expect-CT” header will be sent with the configured `ct_max_age` parameter. This enforces the use of TLS certificates that are published in the certificate transparency log. (see [Expect-CT](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Expect-CT)) + +#### `referrer_policy` + +> Recommended value: `same-origin` + +If you click on a link, your browser’s request to the other site will include from where it is coming from. The “Referrer policy” header tells the browser how and if it should send this information. (see [Referrer policy](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Referrer-Policy)) + +## systemd + +A systemd unit example is provided at `installation/pleroma.service`. + +### PrivateTmp + +> Recommended value: `true` + +Use private `/tmp` and `/var/tmp` folders inside a new file system namespace, which are discarded after the process stops. + +### ProtectHome + +> Recommended value: `true` + +The `/home`, `/root`, and `/run/user` folders can not be accessed by this service anymore. If your Pleroma user has its home folder in one of the restricted places, or use one of these folders as its working directory, you have to set this to `false`. + +### ProtectSystem + +> Recommended value: `full` + +Mount `/usr`, `/boot`, and `/etc` as read-only for processes invoked by this service. + +### PrivateDevices + +> Recommended value: `true` + +Sets up a new `/dev` mount for the process and only adds API pseudo devices like `/dev/null`, `/dev/zero` or `/dev/random` but not physical devices. This may not work on devices like the Raspberry Pi, where you need to set this to `false`. + +### NoNewPrivileges + +> Recommended value: `true` + +Ensures that the service process and all its children can never gain new privileges through `execve()`. + +### CapabilityBoundingSet + +> Recommended value: `~CAP_SYS_ADMIN` + +Drops the sysadmin capability from the daemon. diff --git a/docs/config/howto_mediaproxy.md b/docs/config/howto_mediaproxy.md new file mode 100644 index 000000000..fb731112b --- /dev/null +++ b/docs/config/howto_mediaproxy.md @@ -0,0 +1,32 @@ +# How to activate mediaproxy +## Explanation + +Without the `mediaproxy` function, Pleroma don't store any remote content like pictures, video etc. locally. So every time you open Pleroma, the content is loaded from the source server, from where the post is coming. This can result in slowly loading content or/and increased bandwidth usage on the source server. +With the `mediaproxy` function you can use the cache ability of nginx, to cache these content, so user can access it faster, cause it's loaded from your server. + +## Activate it + +* Edit your nginx config and add the following location: +``` +location /proxy { + proxy_cache pleroma_media_cache; + proxy_cache_lock on; + proxy_pass http://localhost:4000; +} +``` +Also add the following on top of the configuration, outside of the `server` block: +``` +proxy_cache_path /tmp/pleroma-media-cache levels=1:2 keys_zone=pleroma_media_cache:10m max_size=10g inactive=720m use_temp_path=off; +``` +If you came here from one of the installation guides, take a look at the example configuration `/installation/pleroma.nginx`, where this part is already included. + +* Append the following to your `prod.secret.exs` or `dev.secret.exs` (depends on which mode your instance is running): +``` +config :pleroma, :media_proxy, + enabled: true, + redirect_on_failure: true + #base_url: "https://cache.pleroma.social" +``` +If you want to use a subdomain to serve the files, uncomment `base_url`, change the url and add a comma after `true` in the previous line. + +* Restart nginx and Pleroma diff --git a/docs/config/howto_proxy.md b/docs/config/howto_proxy.md new file mode 100644 index 000000000..10a635266 --- /dev/null +++ b/docs/config/howto_proxy.md @@ -0,0 +1,12 @@ +# How to configure upstream proxy for federation +If you want to proxify all http requests (e.g. for TOR) that pleroma makes to an upstream proxy server, edit you config file (`dev.secret.exs` or `prod.secret.exs`) and add the following: + +``` +config :pleroma, :http, + proxy_url: "127.0.0.1:8123" +``` + +The other way to do it, for example, with Tor you would most likely add something like this: +``` +config :pleroma, :http, proxy_url: {:socks5, :localhost, 9050} +``` diff --git a/docs/config/howto_user_recomendation.md b/docs/config/howto_user_recomendation.md new file mode 100644 index 000000000..27c0760dd --- /dev/null +++ b/docs/config/howto_user_recomendation.md @@ -0,0 +1,31 @@ +# How to activate user recommendation (Who to follow panel) +![who-to-follow-panel-small](/uploads/9de1b1300436c32461d272945f1bc23e/who-to-follow-panel-small.png) + +To show the *who to follow* panel, edit `config/prod.secret.exs` in the Pleroma backend. Following code activates the *who to follow* panel: + +```elixir +config :pleroma, :suggestions, + enabled: true, + third_party_engine: + "http://vinayaka.distsn.org/cgi-bin/vinayaka-user-match-suggestions-api.cgi?{{host}}+{{user}}", + timeout: 300_000, + limit: 23, + web: "https://vinayaka.distsn.org/?{{host}}+{{user}}" + +``` + +`config/config.exs` already includes this code, but `enabled:` is `false`. + +`/api/v1/suggestions` is also provided when *who to follow* panel is enabled. + +For advanced customization, following code shows the newcomers of the fediverse at the *who to follow* panel: + +```elixir +config :pleroma, :suggestions, + enabled: true, + third_party_engine: + "http://vinayaka.distsn.org/cgi-bin/vinayaka-user-new-suggestions-api.cgi?{{host}}+{{user}}", + timeout: 60_000, + limit: 23, + web: "https://vinayaka.distsn.org/user-new.html" +``` diff --git a/docs/config/i2p.md b/docs/config/i2p.md new file mode 100644 index 000000000..62ced8b7a --- /dev/null +++ b/docs/config/i2p.md @@ -0,0 +1,196 @@ +# I2P Federation and Accessability + +This guide is going to focus on the Pleroma federation aspect. The actual installation is neatly explained in the official documentation, and more likely to remain up-to-date. +It might be added to this guide if there will be a need for that. + +We're going to use I2PD for its lightweightness over the official client. +Follow the documentation according to your distro: https://i2pd.readthedocs.io/en/latest/user-guide/install/#installing + +How to run it: https://i2pd.readthedocs.io/en/latest/user-guide/run/ + +## I2P Federation + +There are 2 ways to go about this. +One using the config, and one using external software (fedproxy). The external software works better so far. + +### Using the Config + +**Warning:** So far, everytime I followed this way of federating using I2P, the rest of my federation stopped working. I'm leaving this here in case it will help with making it work. + +Assuming you're running in prod, cd to your Pleroma folder and append the following to `config/prod.secret.exs`: +``` +config :pleroma, :http, proxy_url: {:socks5, :localhost, 4447} +``` +And then run the following: +``` +su pleroma +MIX_ENV=prod mix deps.get +MIX_ENV=prod mix ecto.migrate +exit +``` +You can restart I2PD here and finish if you don't wish to make your instance viewable or accessible over I2P. +``` +systemctl stop i2pd.service --no-block +systemctl start i2pd.service +``` +*Notice:* The stop command initiates a graceful shutdown process, i2pd stops after finishing to route transit tunnels (maximum 10 minutes). + +You can change the socks proxy port in `/etc/i2pd/i2pd.conf`. + +### Using Fedproxy + +Fedproxy passes through clearnet requests direct to where they are going. It doesn't force anything over Tor. + +To use [fedproxy](https://github.com/majestrate/fedproxy) you'll need to install Golang. +``` +apt install golang +``` +Use a different user than pleroma or root. Run the following to add the Gopath to your ~/.bashrc. +``` +echo "export GOPATH=/home/ren/.go" >> ~/.bashrc +``` +Restart that bash session (you can exit and log back in). +Run the following to get fedproxy. +``` +go get -u github.com/majestrate/fedproxy$ +cp $(GOPATH)/bin/fedproxy /usr/local/bin/fedproxy +``` +And then the following to start it for I2P only. +``` +fedproxy 127.0.0.1:2000 127.0.0.1:4447 +``` +If you want to also use it for Tor, add `127.0.0.1:9050` to that command. +You'll also need to modify your Pleroma config. + +Assuming you're running in prod, cd to your Pleroma folder and append the following to `config/prod.secret.exs`: +``` +config :pleroma, :http, proxy_url: {:socks5, :localhost, 2000} +``` +And then run the following: +``` +su pleroma +MIX_ENV=prod mix deps.get +MIX_ENV=prod mix ecto.migrate +exit +``` +You can restart I2PD here and finish if you don't wish to make your instance viewable or accessible over I2P. + +``` +systemctl stop i2pd.service --no-block +systemctl start i2pd.service +``` +*Notice:* The stop command initiates a graceful shutdown process, i2pd stops after finishing to route transit tunnels (maximum 10 minutes). + +You can change the socks proxy port in `/etc/i2pd/i2pd.conf`. + +## I2P Instance Access + +Make your instance accessible using I2P. + +Add the following to your I2PD config `/etc/i2pd/tunnels.conf`: +``` +[pleroma] +type = http +host = 127.0.0.1 +port = 14447 +keys = pleroma.dat +``` +Restart I2PD: +``` +systemctl stop i2pd.service --no-block +systemctl start i2pd.service +``` +*Notice:* The stop command initiates a graceful shutdown process, i2pd stops after finishing to route transit tunnels (maximum 10 minutes). + +Now you'll have to find your address. +To do that you can download and use I2PD tools.[^1] +Or you'll need to access your web-console on localhost:7070. +If you don't have a GUI, you'll have to SSH tunnel into it like this: +`ssh -L 7070:127.0.0.1:7070 user@ip -p port`. +Now you can access it at localhost:7070. +Go to I2P tunnels page. Look for Server tunnels and you will see an address that ends with `.b32.i2p` next to "pleroma". +This is your site's address. + +### I2P-only Instance + +If creating an I2P-only instance, open `config/prod.secret.exs` and under "config :pleroma, Pleroma.Web.Endpoint," edit "https" and "port: 443" to the following: +``` + url: [host: "i2paddress", scheme: "http", port: 80], +``` +In addition to that, replace the existing nginx config's contents with the example below. + +### Existing Instance (Clearnet Instance) + +If not an I2P-only instance, add the nginx config below to your existing config at `/etc/nginx/sites-enabled/pleroma.nginx`. + +And for both cases, disable CSP in Pleroma's config (STS is disabled by default) so you can define those yourself seperately from the clearnet (if your instance is also on the clearnet). +Copy the following into the `config/prod.secret.exs` in your Pleroma folder (/home/pleroma/pleroma/): +``` +config :pleroma, :http_security, + enabled: false +``` + +Use this as the Nginx config: +``` +proxy_cache_path /tmp/pleroma-media-cache levels=1:2 keys_zone=pleroma_media_cache:10m max_size=10g inactive=720m use_temp_path=off; +# The above already exists in a clearnet instance's config. +# If not, add it. + +server { + listen 127.0.0.1:14447; + server_name youri2paddress; + + # Comment to enable logs + access_log /dev/null; + error_log /dev/null; + + gzip_vary on; + gzip_proxied any; + gzip_comp_level 6; + gzip_buffers 16 8k; + gzip_http_version 1.1; + gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript application/activity+json application/atom+xml; + + client_max_body_size 16m; + + location / { + + add_header X-XSS-Protection "1; mode=block"; + add_header X-Permitted-Cross-Domain-Policies none; + add_header X-Frame-Options DENY; + add_header X-Content-Type-Options nosniff; + add_header Referrer-Policy same-origin; + add_header X-Download-Options noopen; + + proxy_http_version 1.1; + proxy_set_header Upgrade $http_upgrade; + proxy_set_header Connection "upgrade"; + proxy_set_header Host $http_host; + + proxy_pass http://localhost:4000; + + client_max_body_size 16m; + } + + location /proxy { + proxy_cache pleroma_media_cache; + proxy_cache_lock on; + proxy_ignore_client_abort on; + proxy_pass http://localhost:4000; + } +} +``` +reload Nginx: +``` +systemctl stop i2pd.service --no-block +systemctl start i2pd.service +``` +*Notice:* The stop command initiates a graceful shutdown process, i2pd stops after finishing to route transit tunnels (maximum 10 minutes). + +You should now be able to both access your instance using I2P and federate with other I2P instances! + +[^1]: [I2PD tools](https://github.com/purplei2p/i2pd-tools) to print information about a router info file or an I2P private key, generate an I2P private key, and generate vanity addresses. + +### Possible Issues + +Will be added when encountered. diff --git a/docs/Message-Rewrite-Facility-configuration.md b/docs/config/mrf.md similarity index 98% rename from docs/Message-Rewrite-Facility-configuration.md rename to docs/config/mrf.md index 35ce52ea9..2cc16cef0 100644 --- a/docs/Message-Rewrite-Facility-configuration.md +++ b/docs/config/mrf.md @@ -1,4 +1,4 @@ -# Message Rewrite Facility configuration +# Message Rewrite Facility The Message Rewrite Facility (MRF) is a subsystem that is implemented as a series of hooks that allows the administrator to rewrite or discard messages. Possible uses include: @@ -70,7 +70,7 @@ As discussed above, the MRF system is a modular system that supports pluggable p For example, here is a sample policy module which rewrites all messages to "new message content": -```!elixir +```elixir # This is a sample MRF policy which rewrites all Notes to have "new message # content." defmodule Site.RewritePolicy do @@ -116,4 +116,4 @@ config :pleroma, :instance, ] ``` -Please note that the Pleroma developers consider custom MRF policy modules to fall under the purview of the AGPL. As such, you are obligated to release the sources to your custom MRF policy modules upon request. \ No newline at end of file +Please note that the Pleroma developers consider custom MRF policy modules to fall under the purview of the AGPL. As such, you are obligated to release the sources to your custom MRF policy modules upon request. diff --git a/docs/config/onion_federation.md b/docs/config/onion_federation.md new file mode 100644 index 000000000..99f104995 --- /dev/null +++ b/docs/config/onion_federation.md @@ -0,0 +1,159 @@ +# Easy Onion Federation (Tor) +Tor can free people from the necessity of a domain, in addition to helping protect their privacy. As Pleroma's goal is to empower the people and let as many as possible host an instance with as little resources as possible, the ability to host an instance with a small, cheap computer like a RaspberryPi along with Tor, would be a great way to achieve that. +In addition, federating with such instances will also help furthering that goal. + +This is a guide to show you how it can be easily done. + +This guide assumes you already got Pleroma working, and that it's running on the default port 4000. +Currently only has an Nginx example. + +To install Tor on Debian / Ubuntu: +``` +apt -yq install tor +``` +If using an old server version (older than Debian Stretch or Ubuntu 18.04), install from backports or PPA. +I recommend using a newer server version instead. + +To have the newest, V3 onion addresses (which I recommend) in Debian, install Tor from backports. +If you do not have backports, uncomment the stretch-backports links at the end of `/etc/apt/sources.list`. +Then install: +``` +apt update +apt -t stretch-backports -yq install tor +``` +**WARNING:** Onion instances not using a Tor version supporting V3 addresses will not be able to federate with you. + +Create the hidden service for your Pleroma instance in `/etc/tor/torrc`: +``` +HiddenServiceDir /var/lib/tor/pleroma_hidden_service/ +HiddenServicePort 80 127.0.0.1:8099 +HiddenServiceVersion 3 # Remove if Tor version is below 0.3 ( tor --version ) +``` +Restart Tor to generate an adress: +``` +systemctl restart tor@default.service +``` +Get the address: +``` +cat /var/lib/tor/pleroma_hidden_service/hostname +``` + +# Federation + +Next, edit your Pleroma config. +If running in prod, cd to your Pleroma directory, edit `config/prod.secret.exs` +and append this line: +``` +config :pleroma, :http, proxy_url: {:socks5, :localhost, 9050} +``` +In your Pleroma directory, assuming you're running prod, +run the following: +``` +su pleroma +MIX_ENV=prod mix deps.get +MIX_ENV=prod mix ecto.migrate +exit +``` +restart Pleroma (if using systemd): +``` +systemctl restart pleroma +``` + +# Tor Instance Access + +Make your instance accessible using Tor. + +## Tor-only Instance +If creating a Tor-only instance, open `config/prod.secret.exs` and under "config :pleroma, Pleroma.Web.Endpoint," edit "https" and "port: 443" to the following: +``` + url: [host: "onionaddress", scheme: "http", port: 80], +``` +In addition to that, replace the existing nginx config's contents with the example below. + +## Existing Instance (Clearnet Instance) +If not a Tor-only instance, +add the nginx config below to your existing config at `/etc/nginx/sites-enabled/pleroma.nginx`. + +--- +For both cases, disable CSP in Pleroma's config (STS is disabled by default) so you can define those yourself seperately from the clearnet (if your instance is also on the clearnet). +Copy the following into the `config/prod.secret.exs` in your Pleroma folder (/home/pleroma/pleroma/): +``` +config :pleroma, :http_security, + enabled: false +``` + +Use this as the Nginx config: +``` +proxy_cache_path /tmp/pleroma-media-cache levels=1:2 keys_zone=pleroma_media_cache:10m max_size=10g inactive=720m use_temp_path=off; +# The above already exists in a clearnet instance's config. +# If not, add it. + +server { + listen 127.0.0.1:8099; + server_name youronionaddress; + + # Comment to enable logs + access_log /dev/null; + error_log /dev/null; + + gzip_vary on; + gzip_proxied any; + gzip_comp_level 6; + gzip_buffers 16 8k; + gzip_http_version 1.1; + gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript application/activity+json application/atom+xml; + + client_max_body_size 16m; + + location / { + + add_header X-XSS-Protection "1; mode=block"; + add_header X-Permitted-Cross-Domain-Policies none; + add_header X-Frame-Options DENY; + add_header X-Content-Type-Options nosniff; + add_header Referrer-Policy same-origin; + add_header X-Download-Options noopen; + + proxy_http_version 1.1; + proxy_set_header Upgrade $http_upgrade; + proxy_set_header Connection "upgrade"; + proxy_set_header Host $http_host; + + proxy_pass http://localhost:4000; + + client_max_body_size 16m; + } + + location /proxy { + proxy_cache pleroma_media_cache; + proxy_cache_lock on; + proxy_ignore_client_abort on; + proxy_pass http://localhost:4000; + } +} +``` +reload Nginx: +``` +systemctl reload nginx +``` + +You should now be able to both access your instance using Tor and federate with other Tor instances! + +--- + +### Possible Issues + +* In Debian, make sure your hidden service folder `/var/lib/tor/pleroma_hidden_service/` and its contents, has debian-tor as both owner and group by using +``` +ls -la /var/lib/tor/ +``` +If it's not, run: +``` +chown -R debian-tor:debian-tor /var/lib/tor/pleroma_hidden_service/ +``` +* Make sure *only* the owner has *only* read and write permissions. +If not, run: +``` +chmod -R 600 /var/lib/tor/pleroma_hidden_service/ +``` +* If you have trouble logging in to the Mastodon Frontend when using Tor, use the Tor Browser Bundle. diff --git a/docs/config/small_customizations.md b/docs/config/small_customizations.md new file mode 100644 index 000000000..09e8d6041 --- /dev/null +++ b/docs/config/small_customizations.md @@ -0,0 +1,35 @@ +# Small customizations +Replace `dev.secret.exs` with `prod.secret.exs` according to your setup. + +# Thumbnail + +Replace `priv/static/instance/thumbnail.jpeg` with your selfie or other neat picture. It will appear in [Pleroma Instances](http://distsn.org/pleroma-instances.html). + +# Instance-specific panel + +![instance-specific panel demo](/uploads/296b19ec806b130e0b49b16bfe29ce8a/image.png) + +To show the instance specific panel, set `show_instance_panel` to `true` in `config/dev.secret.exs`. You can modify its content by editing `priv/static/instance/panel.html`. + +# Background + +You can change the background of your Pleroma instance by uploading it to `priv/static/static`, and then changing `"background"` in `config/dev.secret.exs` accordingly. + +# Logo + +![logo modification demo](/uploads/c70b14de60fa74245e7f0dcfa695ebff/image.png) + +If you want to give a brand to your instance, look no further. You can change the logo of your instance by uploading it to `priv/static/static`, and then changing `logo` in `config/dev.secret.exs` accordingly. + +# Theme + +All users of your instance will be able to change the theme they use by going to the settings (the cog in the top-right hand corner). However, if you wish to change the default theme, you can do so by editing `theme` in `config/dev.secret.exs` accordingly. + +# Terms of Service + +Terms of Service will be shown to all users on the registration page. It's the best place where to write down the rules for your instance. You can modify the rules by changing `priv/static/static/terms-of-service.html`. + +# Message Visibility + +To enable message visibility options when posting like in the Mastodon frontend, set +`scope_options_enabled` to `true` in `config/dev.secret.exs`. diff --git a/docs/static_dir.md b/docs/config/static_dir.md similarity index 100% rename from docs/static_dir.md rename to docs/config/static_dir.md diff --git a/docs/installation/alpine_linux_en.md b/docs/installation/alpine_linux_en.md new file mode 100644 index 000000000..c493816d6 --- /dev/null +++ b/docs/installation/alpine_linux_en.md @@ -0,0 +1,215 @@ +# Installing on Alpine Linux +## Installation + +This guide is a step-by-step installation guide for Alpine Linux. It also assumes that you have administrative rights, either as root or a user with [sudo permissions](https://www.linode.com/docs/tools-reference/custom-kernels-distros/install-alpine-linux-on-your-linode/#configuration). If you want to run this guide with root, ignore the `sudo` at the beginning of the lines, unless it calls a user like `sudo -Hu pleroma`; in this case, use `su -l -s $SHELL -c 'command'` instead. + +### Required packages + +* `postgresql` +* `elixir` +* `erlang` +* `erlang-parsetools` +* `erlang-xmerl` +* `git` +* Development Tools + +#### Optional packages used in this guide + +* `nginx` (preferred, example configs for other reverse proxies can be found in the repo) +* `certbot` (or any other ACME client for Let’s Encrypt certificates) + +### Prepare the system + +* First make sure to have the community repository enabled: + +```shell +echo "https://nl.alpinelinux.org/alpine/latest-stable/community" | sudo tee -a /etc/apk/repository +``` + +* Then update the system, if not already done: + +```shell +sudo apk update +sudo apk upgrade +``` + +* Install some tools, which are needed later: + +```shell +sudo apk add git build-base +``` + +### Install Elixir and Erlang + +* Install Erlang and Elixir: + +```shell +sudo apk add erlang erlang-runtime-tools erlang-xmerl elixir +``` + +* Install `erlang-eldap` if you want to enable ldap authenticator + +```shell +sudo apk add erlang-eldap +``` +### Install PostgreSQL + +* Install Postgresql server: + +```shell +sudo apk add postgresql postgresql-contrib +``` + +* Initialize database: + +```shell +sudo /etc/init.d/postgresql start +``` + +* Enable and start postgresql server: + +```shell +sudo rc-update add postgresql +``` + +### Install PleromaBE + +* Add a new system user for the Pleroma service: + +```shell +sudo adduser -S -s /bin/false -h /opt/pleroma -H pleroma +``` + +**Note**: To execute a single command as the Pleroma system user, use `sudo -Hu pleroma command`. You can also switch to a shell by using `sudo -Hu pleroma $SHELL`. If you don’t have and want `sudo` on your system, you can use `su` as root user (UID 0) for a single command by using `su -l pleroma -s $SHELL -c 'command'` and `su -l pleroma -s $SHELL` for starting a shell. + +* Git clone the PleromaBE repository and make the Pleroma user the owner of the directory: + +```shell +sudo mkdir -p /opt/pleroma +sudo chown -R pleroma:pleroma /opt/pleroma +sudo -Hu pleroma git clone https://git.pleroma.social/pleroma/pleroma /opt/pleroma +``` + +* Change to the new directory: + +```shell +cd /opt/pleroma +``` + +* Install the dependencies for Pleroma and answer with `yes` if it asks you to install `Hex`: + +```shell +sudo -Hu pleroma mix deps.get +``` + +* Generate the configuration: `sudo -Hu pleroma mix pleroma.instance gen` + * Answer with `yes` if it asks you to install `rebar3`. + * This may take some time, because parts of pleroma get compiled first. + * After that it will ask you a few questions about your instance and generates a configuration file in `config/generated_config.exs`. + +* Check the configuration and if all looks right, rename it, so Pleroma will load it (`prod.secret.exs` for productive instance, `dev.secret.exs` for development instances): + +```shell +mv config/{generated_config.exs,prod.secret.exs} +``` + +* The previous command creates also the file `config/setup_db.psql`, with which you can create the database: + +```shell +sudo -Hu postgres psql -f config/setup_db.psql +``` + +* Now run the database migration: + +```shell +sudo -Hu pleroma MIX_ENV=prod mix ecto.migrate +``` + +* Now you can start Pleroma already + +```shell +sudo -Hu pleroma MIX_ENV=prod mix phx.server +``` + +### Finalize installation + +If you want to open your newly installed instance to the world, you should run nginx or some other webserver/proxy in front of Pleroma and you should consider to create an OpenRC service file for Pleroma. + +#### Nginx + +* Install nginx, if not already done: + +```shell +sudo apk add nginx +``` + +* Setup your SSL cert, using your method of choice or certbot. If using certbot, first install it: + +```shell +sudo apk add certbot +``` + +and then set it up: + +```shell +sudo mkdir -p /var/lib/letsencrypt/ +sudo certbot certonly --email -d --standalone +``` + +If that doesn’t work, make sure, that nginx is not already running. If it still doesn’t work, try setting up nginx first (change ssl “on” to “off” and try again). + +* Copy the example nginx configuration to the nginx folder + +```shell +sudo cp /opt/pleroma/installation/pleroma.nginx /etc/nginx/conf.d/pleroma.conf +``` + +* Before starting nginx edit the configuration and change it to your needs (e.g. change servername, change cert paths) +* Enable and start nginx: + +```shell +sudo rc-update add nginx +sudo service nginx start +``` + +If you need to renew the certificate in the future, uncomment the relevant location block in the nginx config and run: + +```shell +sudo certbot certonly --email -d --webroot -w /var/lib/letsencrypt/ +``` + +#### OpenRC service + +* Copy example service file: + +```shell +sudo cp /opt/pleroma/installation/init.d/pleroma /etc/init.d/pleroma +``` + +* Make sure to start it during the boot + +```shell +sudo rc-update add pleroma +``` + +#### Create your first user + +If your instance is up and running, you can create your first user with administrative rights with the following task: + +```shell +sudo -Hu pleroma MIX_ENV=prod mix pleroma.user new --admin +``` + +#### Further reading + +* [Admin tasks](Admin tasks) +* [Backup your instance](Backup-your-instance) +* [Configuration tips](General tips for customizing pleroma fe) +* [Hardening your instance](Hardening-your-instance) +* [How to activate mediaproxy](How-to-activate-mediaproxy) +* [Small Pleroma-FE customizations](Small customizations) +* [Updating your instance](Updating-your-instance) + +## Questions + +Questions about the installation or didn’t it work as it should be, ask in [#pleroma:matrix.org](https://matrix.heldscal.la/#/room/#freenode_#pleroma:matrix.org) or IRC Channel **#pleroma** on **Freenode**. diff --git a/docs/installation/arch_linux_en.md b/docs/installation/arch_linux_en.md new file mode 100644 index 000000000..4b3bbbbb0 --- /dev/null +++ b/docs/installation/arch_linux_en.md @@ -0,0 +1,214 @@ +# Installing on Arch Linux +## Installation + +This guide will assume that you have administrative rights, either as root or a user with [sudo permissions](https://wiki.archlinux.org/index.php/Sudo). If you want to run this guide with root, ignore the `sudo` at the beginning of the lines, unless it calls a user like `sudo -Hu pleroma`; in this case, use `su -s $SHELL -c 'command'` instead. + +### Required packages + +* `postgresql` +* `elixir` +* `erlang-unixodbc` +* `git` +* `base-devel` + +#### Optional packages used in this guide + +* `nginx` (preferred, example configs for other reverse proxies can be found in the repo) +* `certbot` (or any other ACME client for Let’s Encrypt certificates) + +### Prepare the system + +* First update the system, if not already done: + +```shell +sudo pacman -Syu +``` + +* Install some of the above mentioned programs: + +```shell +sudo pacman -S git base-devel elixir erlang-unixodbc +``` + +### Install PostgreSQL + +[Arch Wiki article](https://wiki.archlinux.org/index.php/PostgreSQL) + +* Install the `postgresql` package: + +```shell +sudo pacman -S postgresql +``` + +* Initialize the database cluster: + +```shell +sudo -iu postgres initdb -D /var/lib/postgres/data +``` + +* Start and enable the `postgresql.service` + +```shell +sudo systemctl enable --now postgresql.service +``` + +### Install PleromaBE + +* Add a new system user for the Pleroma service: + +```shell +sudo useradd -r -s /bin/false -m -d /var/lib/pleroma -U pleroma +``` + +**Note**: To execute a single command as the Pleroma system user, use `sudo -Hu pleroma command`. You can also switch to a shell by using `sudo -Hu pleroma $SHELL`. If you don’t have and want `sudo` on your system, you can use `su` as root user (UID 0) for a single command by using `su -l pleroma -s $SHELL -c 'command'` and `su -l pleroma -s $SHELL` for starting a shell. + +* Git clone the PleromaBE repository and make the Pleroma user the owner of the directory: + +```shell +sudo mkdir -p /opt/pleroma +sudo chown -R pleroma:pleroma /opt/pleroma +sudo -Hu pleroma git clone https://git.pleroma.social/pleroma/pleroma /opt/pleroma +``` + +* Change to the new directory: + +```shell +cd /opt/pleroma +``` + +* Install the dependencies for Pleroma and answer with `yes` if it asks you to install `Hex`: + +```shell +sudo -Hu pleroma mix deps.get +``` + +* Generate the configuration: `sudo -Hu pleroma mix pleroma.instance gen` + * Answer with `yes` if it asks you to install `rebar3`. + * This may take some time, because parts of pleroma get compiled first. + * After that it will ask you a few questions about your instance and generates a configuration file in `config/generated_config.exs`. + +* Check the configuration and if all looks right, rename it, so Pleroma will load it (`prod.secret.exs` for productive instance, `dev.secret.exs` for development instances): + +```shell +mv config/{generated_config.exs,prod.secret.exs} +``` + +* The previous command creates also the file `config/setup_db.psql`, with which you can create the database: + +```shell +sudo -Hu postgres psql -f config/setup_db.psql +``` + +* Now run the database migration: + +```shell +sudo -Hu pleroma MIX_ENV=prod mix ecto.migrate +``` + +* Now you can start Pleroma already + +```shell +sudo -Hu pleroma MIX_ENV=prod mix phx.server +``` + +### Finalize installation + +If you want to open your newly installed instance to the world, you should run nginx or some other webserver/proxy in front of Pleroma and you should consider to create a systemd service file for Pleroma. + +#### Nginx + +* Install nginx, if not already done: + +```shell +sudo pacman -S nginx +``` + +* Create directories for available and enabled sites: + +```shell +sudo mkdir -p /etc/nginx/sites-{available,enabled} +``` + +* Append the following line at the end of the `http` block in `/etc/nginx/nginx.conf`: + +```Nginx +include sites-enabled/*; +``` + +* Setup your SSL cert, using your method of choice or certbot. If using certbot, first install it: + +```shell +sudo pacman -S certbot certbot-nginx +``` + +and then set it up: + +```shell +sudo mkdir -p /var/lib/letsencrypt/ +sudo certbot certonly --email -d --standalone +``` + +If that doesn’t work, make sure, that nginx is not already running. If it still doesn’t work, try setting up nginx first (change ssl “on” to “off” and try again). + +--- + +* Copy the example nginx configuration and activate it: + +```shell +sudo cp /opt/pleroma/installation/pleroma.nginx /etc/nginx/sites-available/pleroma.nginx +sudo ln -s /etc/nginx/sites-available/pleroma.nginx /etc/nginx/sites-enabled/pleroma.nginx +``` + +* Before starting nginx edit the configuration and change it to your needs (e.g. change servername, change cert paths) +* Enable and start nginx: + +```shell +sudo systemctl enable --now nginx.service +``` + +If you need to renew the certificate in the future, uncomment the relevant location block in the nginx config and run: + +```shell +sudo certbot certonly --email -d --webroot -w /var/lib/letsencrypt/ +``` + +#### Other webserver/proxies + +You can find example configurations for them in `/opt/pleroma/installation/`. + +#### Systemd service + +* Copy example service file + +```shell +sudo cp /opt/pleroma/installation/pleroma.service /etc/systemd/system/pleroma.service +``` + +* Edit the service file and make sure that all paths fit your installation +* Enable and start `pleroma.service`: + +```shell +sudo systemctl enable --now pleroma.service +``` + +#### Create your first user + +If your instance is up and running, you can create your first user with administrative rights with the following task: + +```shell +sudo -Hu pleroma MIX_ENV=prod mix pleroma.user new --admin +``` + +#### Further reading + +* [Admin tasks](Admin tasks) +* [Backup your instance](Backup-your-instance) +* [Configuration tips](General tips for customizing pleroma fe) +* [Hardening your instance](Hardening-your-instance) +* [How to activate mediaproxy](How-to-activate-mediaproxy) +* [Small Pleroma-FE customizations](Small customizations) +* [Updating your instance](Updating-your-instance) + +## Questions + +Questions about the installation or didn’t it work as it should be, ask in [#pleroma:matrix.org](https://matrix.heldscal.la/#/room/#freenode_#pleroma:matrix.org) or IRC Channel **#pleroma** on **Freenode**. diff --git a/docs/installation/centos7_en.md b/docs/installation/centos7_en.md new file mode 100644 index 000000000..76de21ed8 --- /dev/null +++ b/docs/installation/centos7_en.md @@ -0,0 +1,277 @@ +# Installing on CentOS 7 +## Installation + +This guide is a step-by-step installation guide for CentOS 7. It also assumes that you have administrative rights, either as root or a user with [sudo permissions](https://www.digitalocean.com/community/tutorials/how-to-create-a-sudo-user-on-centos-quickstart). If you want to run this guide with root, ignore the `sudo` at the beginning of the lines, unless it calls a user like `sudo -Hu pleroma`; in this case, use `su -s $SHELL -c 'command'` instead. + +### Required packages + +* `postgresql` (9,6+, CentOS 7 comes with 9.2, we will install version 11 in this guide) +* `elixir` (1.5+) +* `erlang` +* `erlang-parsetools` +* `erlang-xmerl` +* `git` +* Development Tools + +#### Optional packages used in this guide + +* `nginx` (preferred, example configs for other reverse proxies can be found in the repo) +* `certbot` (or any other ACME client for Let’s Encrypt certificates) + +### Prepare the system + +* First update the system, if not already done: + +```shell +sudo yum update +``` + +* Install some of the above mentioned programs: + +```shell +sudo yum install wget git unzip +``` + +* Install development tools: + +```shell +sudo yum group install "Development Tools" +``` + +### Install Elixir and Erlang + +* Add the EPEL repo: + +```shell +sudo yum install epel-release +sudo yum -y update +``` + +* Install Erlang repository: + +```shell +wget -P /tmp/ https://packages.erlang-solutions.com/erlang-solutions-1.0-1.noarch.rpm +sudo rpm -Uvh erlang-solutions-1.0-1.noarch.rpm +``` + +* Install Erlang: + +```shell +sudo yum install erlang erlang-parsetools erlang-xmerl +``` + +* Download [latest Elixir release from Github](https://github.com/elixir-lang/elixir/releases/tag/v1.8.1) (Example for the newest version at the time when this manual was written) + +```shell +wget -P /tmp/ https://github.com/elixir-lang/elixir/releases/download/v1.8.1/Precompiled.zip +``` + +* Create folder where you want to install Elixir, we’ll use: + +```shell +sudo mkdir -p /opt/elixir +``` + +* Unzip downloaded file there: + +```shell +sudo unzip /tmp/Precompiled.zip -d /opt/elixir +``` + +* Create symlinks for the pre-compiled binaries: + +```shell +for e in elixir elixirc iex mix; do sudo ln -s /opt/elixir/bin/${e} /usr/local/bin/${e}; done +``` + +### Install PostgreSQL + +* Add the Postgresql repository: + +```shell +sudo yum install https://download.postgresql.org/pub/repos/yum/11/redhat/rhel-7-x86_64/pgdg-centos11-11-2.noarch.rpm +``` + +* Install the Postgresql server: + +```shell +sudo yum install postgresql11-server postgresql11-contrib +``` + +* Initialize database: + +```shell +sudo /usr/pgsql-11/bin/postgresql-11-setup initdb +``` + +* Open configuration file `/var/lib/pgsql/11/data/pg_hba.conf` and change the following lines from: + +```plain +# IPv4 local connections: +host all all 127.0.0.1/32 ident +# IPv6 local connections: +host all all ::1/128 ident +``` + +to + +```plain +# IPv4 local connections: +host all all 127.0.0.1/32 md5 +# IPv6 local connections: +host all all ::1/128 md5 +``` + +* Enable and start postgresql server: + +```shell +sudo systemctl enable --now postgresql-11.service +``` + +### Install PleromaBE + +* Add a new system user for the Pleroma service: + +```shell +sudo useradd -r -s /bin/false -m -d /var/lib/pleroma -U pleroma +``` + +**Note**: To execute a single command as the Pleroma system user, use `sudo -Hu pleroma command`. You can also switch to a shell by using `sudo -Hu pleroma $SHELL`. If you don’t have and want `sudo` on your system, you can use `su` as root user (UID 0) for a single command by using `su -l pleroma -s $SHELL -c 'command'` and `su -l pleroma -s $SHELL` for starting a shell. + +* Git clone the PleromaBE repository and make the Pleroma user the owner of the directory: + +```shell +sudo mkdir -p /opt/pleroma +sudo chown -R pleroma:pleroma /opt/pleroma +sudo -Hu pleroma git clone https://git.pleroma.social/pleroma/pleroma /opt/pleroma +``` + +* Change to the new directory: + +```shell +cd /opt/pleroma +``` + +* Install the dependencies for Pleroma and answer with `yes` if it asks you to install `Hex`: + +```shell +sudo -Hu pleroma mix deps.get +``` + +* Generate the configuration: `sudo -Hu pleroma mix pleroma.instance gen` + * Answer with `yes` if it asks you to install `rebar3`. + * This may take some time, because parts of pleroma get compiled first. + * After that it will ask you a few questions about your instance and generates a configuration file in `config/generated_config.exs`. + +* Check the configuration and if all looks right, rename it, so Pleroma will load it (`prod.secret.exs` for productive instance, `dev.secret.exs` for development instances): + +```shell +mv config/{generated_config.exs,prod.secret.exs} +``` + +* The previous command creates also the file `config/setup_db.psql`, with which you can create the database: + +```shell +sudo -Hu postgres psql -f config/setup_db.psql +``` + +* Now run the database migration: + +```shell +sudo -Hu pleroma MIX_ENV=prod mix ecto.migrate +``` + +* Now you can start Pleroma already + +```shell +sudo -Hu pleroma MIX_ENV=prod mix phx.server +``` + +### Finalize installation + +If you want to open your newly installed instance to the world, you should run nginx or some other webserver/proxy in front of Pleroma and you should consider to create a systemd service file for Pleroma. + +#### Nginx + +* Install nginx, if not already done: + +```shell +sudo yum install nginx +``` + +* Setup your SSL cert, using your method of choice or certbot. If using certbot, first install it: + +```shell +sudo yum install certbot-nginx +``` + +and then set it up: + +```shell +sudo mkdir -p /var/lib/letsencrypt/ +sudo certbot certonly --email -d --standalone +``` + +If that doesn’t work, make sure, that nginx is not already running. If it still doesn’t work, try setting up nginx first (change ssl “on” to “off” and try again). + +--- + +* Copy the example nginx configuration to the nginx folder + +```shell +sudo cp /opt/pleroma/installation/pleroma.nginx /etc/nginx/conf.d/pleroma.conf +``` + +* Before starting nginx edit the configuration and change it to your needs (e.g. change servername, change cert paths) +* Enable and start nginx: + +```shell +sudo systemctl enable --now nginx +``` + +If you need to renew the certificate in the future, uncomment the relevant location block in the nginx config and run: + +```shell +sudo certbot certonly --email -d --webroot -w /var/lib/letsencrypt/ +``` + +#### Other webserver/proxies + +You can find example configurations for them in `/opt/pleroma/installation/`. + +#### Systemd service + +* Copy example service file + +```shell +sudo cp /opt/pleroma/installation/pleroma.service /etc/systemd/system/pleroma.service +``` + +* Edit the service file and make sure that all paths fit your installation +* Enable and start `pleroma.service`: + +```shell +sudo systemctl enable --now pleroma.service +``` + +#### Create your first user + +If your instance is up and running, you can create your first user with administrative rights with the following task: + +```shell +sudo -Hu pleroma MIX_ENV=prod mix pleroma.user new --admin +``` + +#### Further reading + +* [Admin tasks](Admin tasks) +* [Backup your instance](Backup-your-instance) +* [Configuration tips](General tips for customizing pleroma fe) +* [Hardening your instance](Hardening-your-instance) +* [How to activate mediaproxy](How-to-activate-mediaproxy) +* [Small Pleroma-FE customizations](Small customizations) +* [Updating your instance](Updating-your-instance) + +## Questions + +Questions about the installation or didn’t it work as it should be, ask in [#pleroma:matrix.org](https://matrix.heldscal.la/#/room/#freenode_#pleroma:matrix.org) or IRC Channel **#pleroma** on **Freenode**. diff --git a/docs/installation/debian_based_en.md b/docs/installation/debian_based_en.md new file mode 100644 index 000000000..9613a329b --- /dev/null +++ b/docs/installation/debian_based_en.md @@ -0,0 +1,202 @@ +# Installing on Debian Based Distributions +## Installation + +This guide will assume you are on Debian Stretch. This guide should also work with Ubuntu 16.04 and 18.04. It also assumes that you have administrative rights, either as root or a user with [sudo permissions](https://www.digitalocean.com/community/tutorials/how-to-add-delete-and-grant-sudo-privileges-to-users-on-a-debian-vps). If you want to run this guide with root, ignore the `sudo` at the beginning of the lines, unless it calls a user like `sudo -Hu pleroma`; in this case, use `su -s $SHELL -c 'command'` instead. + +### Required packages + +* `postgresql` (9.6+, Ubuntu 16.04 comes with 9.5, you can get a newer version from [here](https://www.postgresql.org/download/linux/ubuntu/)) +* `postgresql-contrib` (9.6+, same situtation as above) +* `elixir` (1.5+, [install from here, Debian and Ubuntu ship older versions](https://elixir-lang.org/install.html#unix-and-unix-like) or use [asdf](https://github.com/asdf-vm/asdf) as the pleroma user) +* `erlang-dev` +* `erlang-tools` +* `erlang-parsetools` +* `erlang-eldap`, if you want to enable ldap authenticator +* `erlang-xmerl` +* `git` +* `build-essential` + +#### Optional packages used in this guide + +* `nginx` (preferred, example configs for other reverse proxies can be found in the repo) +* `certbot` (or any other ACME client for Let’s Encrypt certificates) + +### Prepare the system + +* First update the system, if not already done: + +```shell +sudo apt update +sudo apt full-upgrade +``` + +* Install some of the above mentioned programs: + +```shell +sudo apt install git build-essential postgresql postgresql-contrib +``` + +### Install Elixir and Erlang + +* Download and add the Erlang repository: + +```shell +wget -P /tmp/ https://packages.erlang-solutions.com/erlang-solutions_1.0_all.deb +sudo dpkg -i /tmp/erlang-solutions_1.0_all.deb +``` + +* Install Elixir and Erlang: + +```shell +sudo apt update +sudo apt install elixir erlang-dev erlang-parsetools erlang-xmerl erlang-tools +``` + +### Install PleromaBE + +* Add a new system user for the Pleroma service: + +```shell +sudo useradd -r -s /bin/false -m -d /var/lib/pleroma -U pleroma +``` + +**Note**: To execute a single command as the Pleroma system user, use `sudo -Hu pleroma command`. You can also switch to a shell by using `sudo -Hu pleroma $SHELL`. If you don’t have and want `sudo` on your system, you can use `su` as root user (UID 0) for a single command by using `su -l pleroma -s $SHELL -c 'command'` and `su -l pleroma -s $SHELL` for starting a shell. + +* Git clone the PleromaBE repository and make the Pleroma user the owner of the directory: + +```shell +sudo mkdir -p /opt/pleroma +sudo chown -R pleroma:pleroma /opt/pleroma +sudo -Hu pleroma git clone https://git.pleroma.social/pleroma/pleroma /opt/pleroma +``` + +* Change to the new directory: + +```shell +cd /opt/pleroma +``` + +* Install the dependencies for Pleroma and answer with `yes` if it asks you to install `Hex`: + +```shell +sudo -Hu pleroma mix deps.get +``` + +* Generate the configuration: `sudo -Hu pleroma mix pleroma.instance gen` + * Answer with `yes` if it asks you to install `rebar3`. + * This may take some time, because parts of pleroma get compiled first. + * After that it will ask you a few questions about your instance and generates a configuration file in `config/generated_config.exs`. + +* Check the configuration and if all looks right, rename it, so Pleroma will load it (`prod.secret.exs` for productive instance, `dev.secret.exs` for development instances): + +```shell +mv config/{generated_config.exs,prod.secret.exs} +``` + +* The previous command creates also the file `config/setup_db.psql`, with which you can create the database: + +```shell +sudo -Hu postgres psql -f config/setup_db.psql +``` + +* Now run the database migration: + +```shell +sudo -Hu pleroma MIX_ENV=prod mix ecto.migrate +``` + +* Now you can start Pleroma already + +```shell +sudo -Hu pleroma MIX_ENV=prod mix phx.server +``` + +### Finalize installation + +If you want to open your newly installed instance to the world, you should run nginx or some other webserver/proxy in front of Pleroma and you should consider to create a systemd service file for Pleroma. + +#### Nginx + +* Install nginx, if not already done: + +```shell +sudo apt install nginx +``` + +* Setup your SSL cert, using your method of choice or certbot. If using certbot, first install it: + +```shell +sudo apt install certbot +``` + +and then set it up: + +```shell +sudo mkdir -p /var/lib/letsencrypt/ +sudo certbot certonly --email -d --standalone +``` + +If that doesn’t work, make sure, that nginx is not already running. If it still doesn’t work, try setting up nginx first (change ssl “on” to “off” and try again). + +--- + +* Copy the example nginx configuration and activate it: + +```shell +sudo cp /opt/pleroma/installation/pleroma.nginx /etc/nginx/sites-available/pleroma.nginx +sudo ln -s /etc/nginx/sites-available/pleroma.nginx /etc/nginx/sites-enabled/pleroma.nginx +``` + +* Before starting nginx edit the configuration and change it to your needs (e.g. change servername, change cert paths) +* Enable and start nginx: + +```shell +sudo systemctl enable --now nginx.service +``` + +If you need to renew the certificate in the future, uncomment the relevant location block in the nginx config and run: + +```shell +sudo certbot certonly --email -d --webroot -w /var/lib/letsencrypt/ +``` + +#### Other webserver/proxies + +You can find example configurations for them in `/opt/pleroma/installation/`. + +#### Systemd service + +* Copy example service file + +```shell +sudo cp /opt/pleroma/installation/pleroma.service /etc/systemd/system/pleroma.service +``` + +* Edit the service file and make sure that all paths fit your installation +* Enable and start `pleroma.service`: + +```shell +sudo systemctl enable --now pleroma.service +``` + +#### Create your first user + +If your instance is up and running, you can create your first user with administrative rights with the following task: + +```shell +sudo -Hu pleroma MIX_ENV=prod mix pleroma.user new --admin +``` + +#### Further reading + +* [Admin tasks](Admin tasks) +* [Backup your instance](Backup-your-instance) +* [Configuration tips](General tips for customizing pleroma fe) +* [Hardening your instance](Hardening-your-instance) +* [How to activate mediaproxy](How-to-activate-mediaproxy) +* [Small Pleroma-FE customizations](Small customizations) +* [Updating your instance](Updating-your-instance) + +## Questions + +Questions about the installation or didn’t it work as it should be, ask in [#pleroma:matrix.org](https://matrix.heldscal.la/#/room/#freenode_#pleroma:matrix.org) or IRC Channel **#pleroma** on **Freenode**. diff --git a/docs/installation/debian_based_jp.md b/docs/installation/debian_based_jp.md new file mode 100644 index 000000000..ac5dcaaee --- /dev/null +++ b/docs/installation/debian_based_jp.md @@ -0,0 +1,191 @@ +# Pleromaの入れ方 +## 日本語訳について + +この記事は [Installing on Debian based distributions](Installing on Debian based distributions) の日本語訳です。何かがおかしいと思ったら、原文を見てください。 + +## インストール + +このガイドはDebian Stretchを仮定しています。Ubuntu 16.04でも可能です。 + +### 必要なソフトウェア + +- PostgreSQL 9.6+ (postgresql-contrib-9.6 または他のバージョンの PSQL をインストールしてください) +- Elixir 1.5 以上 ([Debianのリポジトリからインストールしないこと!!! ここからインストールすること!](https://elixir-lang.org/install.html#unix-and-unix-like))。または [asdf](https://github.com/asdf-vm/asdf) を pleroma ユーザーでインストール。 +- erlang-dev +- erlang-tools +- erlang-parsetools +- erlang-xmerl (Jessieではバックポートからインストールすること!) +- git +- build-essential +- openssh +- openssl +- nginx prefered (Apacheも動くかもしれませんが、誰もテストしていません!) +- certbot (または何らかのACME Let's encryptクライアント) + +### システムを準備する + +* まずシステムをアップデートしてください。 +``` +apt update && apt dist-upgrade +``` + +* 複数のツールとpostgresqlをインストールします。あとで必要になるので。 +``` +apt install git build-essential openssl ssh sudo postgresql-9.6 postgresql-contrib-9.6 +``` +(postgresqlのバージョンは、あなたのディストロにあわせて変えてください。または、バージョン番号がいらないかもしれません。) + +### ElixirとErlangをインストールします + +* Erlangのリポジトリをダウンロードおよびインストールします。 +``` +wget -P /tmp/ https://packages.erlang-solutions.com/erlang-solutions_1.0_all.deb && sudo dpkg -i /tmp/erlang-solutions_1.0_all.deb +``` + +* ElixirとErlangをインストールします、 +``` +apt update && apt install elixir erlang-dev erlang-parsetools erlang-xmerl erlang-tools +``` + +### Pleroma BE (バックエンド) をインストールします + +* 新しいユーザーを作ります。 +``` +adduser pleroma +``` +(Give it any password you want, make it STRONG) + +* 新しいユーザーをsudoグループに入れます。 +``` +usermod -aG sudo pleroma +``` + +* 新しいユーザーに変身し、ホームディレクトリに移動します。 +``` +su pleroma +cd ~ +``` + +* Gitリポジトリをクローンします。 +``` +git clone https://git.pleroma.social/pleroma/pleroma +``` + +* 新しいディレクトリに移動します。 +``` +cd pleroma/ +``` + +* Pleromaが依存するパッケージをインストールします。Hexをインストールしてもよいか聞かれたら、yesを入力してください。 +``` +mix deps.get +``` + +* コンフィギュレーションを生成します。 +``` +mix pleroma.instance gen +``` + * rebar3をインストールしてもよいか聞かれたら、yesを入力してください。 + * この処理には時間がかかります。私もよく分かりませんが、何らかのコンパイルが行われているようです。 + * あなたのインスタンスについて、いくつかの質問があります。その回答は `config/generated_config.exs` というコンフィギュレーションファイルに保存されます。 + +**注意**: メディアプロクシを有効にすると回答して、なおかつ、キャッシュのURLは空欄のままにしている場合は、`generated_config.exs` を編集して、`base_url` で始まる行をコメントアウトまたは削除してください。そして、上にある行の `true` の後にあるコンマを消してください。 + +* コンフィギュレーションを確認して、もし問題なければ、ファイル名を変更してください。 +``` +mv config/{generated_config.exs,prod.secret.exs} +``` + +* これまでのコマンドで、すでに `config/setup_db.psql` というファイルが作られています。このファイルをもとに、データベースを作成します。 +``` +sudo su postgres -c 'psql -f config/setup_db.psql' +``` + +* そして、データベースのミグレーションを実行します。 +``` +MIX_ENV=prod mix ecto.migrate +``` + +* Pleromaを起動できるようになりました。 +``` +MIX_ENV=prod mix phx.server +``` + +### インストールを終わらせる + +あなたの新しいインスタンスを世界に向けて公開するには、nginxまたは何らかのウェブサーバー (プロクシ) を使用する必要があります。また、Pleroma のためにシステムサービスファイルを作成する必要があります。 + +#### Nginx + +* まだインストールしていないなら、nginxをインストールします。 +``` +apt install nginx +``` + +* SSLをセットアップします。他の方法でもよいですが、ここではcertbotを説明します。 +certbotを使うならば、まずそれをインストールします。 +``` +apt install certbot +``` +そしてセットアップします。 +``` +mkdir -p /var/lib/letsencrypt/.well-known +% certbot certonly --email your@emailaddress --webroot -w /var/lib/letsencrypt/ -d yourdomain +``` +もしうまくいかないときは、先にnginxを設定してください。ssl "on" を "off" に変えてから再試行してください。 + +--- + +* nginxコンフィギュレーションの例をnginxフォルダーにコピーします。 +``` +cp /home/pleroma/pleroma/installation/pleroma.nginx /etc/nginx/sites-enabled/pleroma.nginx +``` + +* nginxを起動する前に、コンフィギュレーションを編集してください。例えば、サーバー名、証明書のパスなどを変更する必要があります。 +* nginxを再起動します。 +``` +systemctl reload nginx.service +``` + +#### Systemd サービス + +* サービスファイルの例をコピーします。 +``` +cp /home/pleroma/pleroma/installation/pleroma.service /usr/lib/systemd/system/pleroma.service +``` + +* サービスファイルを変更します。すべてのパスが正しいことを確認してください。また、`[Service]` セクションに以下の行があることを確認してください。 +``` +Environment="MIX_ENV=prod" +``` + +* `pleroma.service` を enable および start してください。 +``` +systemctl enable --now pleroma.service +``` + +#### モデレーターを作る + +新たにユーザーを作ったら、モデレーター権限を与えたいかもしれません。以下のタスクで可能です。 +``` +mix set_moderator username [true|false] +``` + +モデレーターはすべてのポストを消すことができます。将来的には他のことも可能になるかもしれません。 + +#### メディアプロクシを有効にする + +`generate_config` でメディアプロクシを有効にしているなら、すでにメディアプロクシが動作しています。あとから設定を変更したいなら、[How to activate mediaproxy](How-to-activate-mediaproxy) を見てください。 + +#### コンフィギュレーションとカスタマイズ + +* [Configuration tips](General tips for customizing pleroma fe) +* [Small Pleroma-FE customizations](Small customizations) +* [Admin tasks](Admin tasks) + +## 質問ある? + +インストールについて質問がある、もしくは、うまくいかないときは、以下のところで質問できます。 + +* [#pleroma:matrix.org](https://matrix.heldscal.la/#/room/#freenode_#pleroma:matrix.org) +* **Freenode** の **#pleroma** IRCチャンネル diff --git a/docs/installation/netbsd_en.md b/docs/installation/netbsd_en.md new file mode 100644 index 000000000..e0ac98359 --- /dev/null +++ b/docs/installation/netbsd_en.md @@ -0,0 +1,198 @@ +# Installing on NetBSD + +## Required software + +pkgin should have been installed by the NetBSD installer if you selected +the right options. If it isn't installed, install it using pkg_add. + +Note that `postgresql11-contrib` is needed for the Postgres extensions +Pleroma uses. + +The `mksh` shell is needed to run the Elixir `mix` script. + +`# pkgin install acmesh elixir git-base git-docs mksh nginx postgresql11-server postgresql11-client postgresql11-contrib sudo` + +You can also build these packages using pkgsrc: +``` +databases/postgresql11-contrib +databases/postgresql11-client +databases/postgresql11-server +devel/git-base +devel/git-docs +lang/elixir +security/acmesh +security/sudo +shells/mksh +www/nginx +``` + +Copy the rc.d scripts to the right directory: + +``` +# cp /usr/pkg/share/examples/rc.d/nginx /usr/pkg/share/examples/rc.d/pgsql /etc/rc.d +``` + +Add nginx and Postgres to `/etc/rc.conf`: + +``` +nginx=YES +pgsql=YES +``` + +## Configuring postgres + +First, run `# /etc/rc.d/pgsql start`. Then, `$ sudo -Hu pgsql -g pgsql createdb`. + +## Configuring Pleroma + +Create a user for Pleroma: + +``` +# groupadd pleroma +# useradd -d /home/pleroma -m -g pleroma -s /usr/pkg/bin/mksh pleroma +# echo 'export LC_ALL="en_GB.UTF-8"' >> /home/pleroma/.profile +# su -l pleroma -c $SHELL +``` + +Clone the repository: + +``` +$ cd /home/pleroma +$ git clone https://git.pleroma.social/pleroma/pleroma.git +``` + +Configure Pleroma. Note that you need a domain name at this point: + +``` +$ cd /home/pleroma/pleroma +$ mix deps.get +$ mix pleroma.instance gen # You will be asked a few questions here. +``` + +Since Postgres is configured, we can now initialize the database. There should +now be a file in `config/setup_db.psql` that makes this easier. Edit it, and +*change the password* to a password of your choice. Make sure it is secure, since +it'll be protecting your database. Now initialize the database: + +``` +$ sudo -Hu pgsql -g pgsql psql -f config/setup_db.psql +``` + +Postgres allows connections from all users without a password by default. To +fix this, edit `/usr/pkg/pgsql/data/pg_hba.conf`. Change every `trust` to +`password`. + +Once this is done, restart Postgres with `# /etc/rc.d/pgsql restart`. + +Run the database migrations. +You will need to do this whenever you update with `git pull`: + +``` +$ MIX_ENV=prod mix ecto.migrate +``` + +## Configuring nginx + +Install the example configuration file +`/home/pleroma/pleroma/installation/pleroma.nginx` to +`/usr/pkg/etc/nginx.conf`. + +Note that it will need to be wrapped in a `http {}` block. You should add +settings for the nginx daemon outside of the http block, for example: + +``` +user nginx nginx; +error_log /var/log/nginx/error.log; +worker_processes 4; + +events { +} +``` + +Edit the defaults: + +* Change `ssl_certificate` and `ssl_trusted_certificate` to +`/etc/nginx/tls/fullchain`. +* Change `ssl_certificate_key` to `/etc/nginx/tls/key`. +* Change `example.tld` to your instance's domain name. + +## Configuring acme.sh + +We'll be using acme.sh in Stateless Mode for TLS certificate renewal. + +First, get your account fingerprint: + +``` +$ sudo -Hu nginx -g nginx acme.sh --register-account +``` + +You need to add the following to your nginx configuration for the server +running on port 80: + +``` + location ~ ^/\.well-known/acme-challenge/([-_a-zA-Z0-9]+)$ { + default_type text/plain; + return 200 "$1.6fXAG9VyG0IahirPEU2ZerUtItW2DHzDzD9wZaEKpqd"; + } +``` + +Replace the string after after `$1.` with your fingerprint. + +Start nginx: + +``` +# /etc/rc.d/nginx start +``` + +It should now be possible to issue a cert (replace `example.com` +with your domain name): + +``` +$ sudo -Hu nginx -g nginx acme.sh --issue -d example.com --stateless +``` + +Let's add auto-renewal to `/etc/daily.local` +(replace `example.com` with your domain): + +``` +/usr/pkg/bin/sudo -Hu nginx -g nginx \ + /usr/pkg/sbin/acme.sh -r \ + -d example.com \ + --cert-file /etc/nginx/tls/cert \ + --key-file /etc/nginx/tls/key \ + --ca-file /etc/nginx/tls/ca \ + --fullchain-file /etc/nginx/tls/fullchain \ + --stateless +``` + +## Creating a startup script for Pleroma + +Copy the startup script to the correct location and make sure it's executable: + +``` +# cp /home/pleroma/pleroma/installation/netbsd/rc.d/pleroma /etc/rc.d/pleroma +# chmod +x /etc/rc.d/pleroma +``` + +Add the following to `/etc/rc.conf`: + +``` +pleroma=YES +pleroma_home="/home/pleroma" +pleroma_user="pleroma" +``` + +Run `# /etc/rc.d/pleroma start` to start Pleroma. + +## Conclusion + +Restart nginx with `# /etc/rc.d/nginx restart` and you should be up and running. + +If you need further help, contact niaa on freenode. + +Make sure your time is in sync, or other instances will receive your posts with +incorrect timestamps. You should have ntpd running. + +## Instances running NetBSD + +* diff --git a/docs/installation/openbsd_en.md b/docs/installation/openbsd_en.md new file mode 100644 index 000000000..633b08e6c --- /dev/null +++ b/docs/installation/openbsd_en.md @@ -0,0 +1,222 @@ +# Installing on OpenBSD +This guide describes the installation and configuration of pleroma (and the required software to run it) on a single OpenBSD 6.4 server. +For any additional information regarding commands and configuration files mentioned here, check the man pages [online](https://man.openbsd.org/) or directly on your server with the man command. + +#### Required software +The following packages need to be installed: + * elixir + * gmake + * ImageMagick + * git + * postgresql-server + * postgresql-contrib + +To install them, run the following command (with doas or as root): +`pkg_add elixir gmake ImageMagick git postgresql-server postgresql-contrib` + +Pleroma requires a reverse proxy, OpenBSD has relayd in base (and is used in this guide) and packages/ports are available for nginx (www/nginx) and apache (www/apache-httpd). Independently of the reverse proxy, [acme-client(1)](https://man.openbsd.org/acme-client) can be used to get a certificate from Let's Encrypt. + +#### Creating the pleroma user +Pleroma will be run by a dedicated user, \_pleroma. Before creating it, insert the following lines in login.conf: +``` +pleroma:\ + :datasize-max=1536M:\ + :datasize-cur=1536M:\ + :openfiles-max=4096 +``` +This creates a "pleroma" login class and sets higher values than default for datasize and openfiles (see [login.conf(5)](https://man.openbsd.org/login.conf)), this is required to avoid having pleroma crash some time after starting. + +Create the \_pleroma user, assign it the pleroma login class and create its home directory (/home/\_pleroma/): `useradd -m -L pleroma _pleroma` + +#### Clone pleroma's directory +Enter a shell as the \_pleroma user. As root, run `su _pleroma -;cd`. Then clone the repository with `git clone https://git.pleroma.social/pleroma/pleroma.git`. Pleroma is now installed in /home/\_pleroma/pleroma/, it will be configured and started at the end of this guide. + +#### Postgresql +Start a shell as the \_postgresql user (as root run `su _postgresql -` then run the `initdb` command to initialize postgresql: +If you wish to not use the default location for postgresql's data (/var/postgresql/data), add the following switch at the end of the command: `-D ` and modify the `datadir` variable in the /etc/rc.d/postgresql script. + +When this is done, enable postgresql so that it starts on boot and start it. As root, run: +``` +rcctl enable postgresql +rcctl start postgresql +``` +To check that it started properly and didn't fail right after starting, you can run `ps aux | grep postgres`, there should be multiple lines of output. + +#### httpd +httpd will have three fuctions: + * redirect requests trying to reach the instance over http to the https URL + * serve a robots.txt file + * get Let's Encrypt certificates, with acme-client + +Insert the following config in httpd.conf: +``` +# $OpenBSD: httpd.conf,v 1.17 2017/04/16 08:50:49 ajacoutot Exp $ + +ext_inet="" +ext_inet6="" + +server "default" { + listen on $ext_inet port 80 # Comment to disable listening on IPv4 + listen on $ext_inet6 port 80 # Comment to disable listening on IPv6 + listen on 127.0.0.1 port 80 # Do NOT comment this line + + log syslog + directory no index + + location "/.well-known/acme-challenge/*" { + root "/acme" + request strip 2 + } + + location "/robots.txt" { root "/htdocs/local/" } + location "/*" { block return 302 "https://$HTTP_HOST$REQUEST_URI" } +} + +types { + include "/usr/share/misc/mime.types" +} +``` +Do not forget to change *\* to your server's address(es). If httpd should only listen on one protocol family, comment one of the two first *listen* options. + +Create the /var/www/htdocs/local/ folder and write the content of your robots.txt in /var/www/htdocs/local/robots.txt. +Check the configuration with `httpd -n`, if it is OK enable and start httpd (as root): +``` +rcctl enable httpd +rcctl start httpd +``` + +#### acme-client +acme-client is used to get SSL/TLS certificates from Let's Encrypt. +Insert the following configuration in /etc/acme-client.conf: +``` +# +# $OpenBSD: acme-client.conf,v 1.4 2017/03/22 11:14:14 benno Exp $ +# + +authority letsencrypt- { + #agreement url "https://letsencrypt.org/documents/LE-SA-v1.2-November-15-2017.pdf" + api url "https://acme-v01.api.letsencrypt.org/directory" + account key "/etc/acme/letsencrypt-privkey-.pem" +} + +domain { + domain key "/etc/ssl/private/.key" + domain certificate "/etc/ssl/.crt" + domain full chain certificate "/etc/ssl/.fullchain.pem" + sign with letsencrypt- + challengedir "/var/www/acme/" +} +``` +Replace *\* by the domain name you'll use for your instance. As root, run `acme-client -n` to check the config, then `acme-client -ADv ` to create account and domain keys, and request a certificate for the first time. +Make acme-client run everyday by adding it in /etc/daily.local. As root, run the following command: `echo "acme-client " >> /etc/daily.local`. + +Relayd will look for certificates and keys based on the address it listens on (see next part), the easiest way to make them available to relayd is to create a link, as root run: +``` +ln -s /etc/ssl/.fullchain.pem /etc/ssl/.crt +ln -s /etc/ssl/private/.key /etc/ssl/private/.key +``` +This will have to be done for each IPv4 and IPv6 address relayd listens on. + +#### relayd +relayd will be used as the reverse proxy sitting in front of pleroma. +Insert the following configuration in /etc/relayd.conf: +``` +# $OpenBSD: relayd.conf,v 1.4 2018/03/23 09:55:06 claudio Exp $ + +ext_inet="" +ext_inet6="" + +table { 127.0.0.1 } +table { 127.0.0.1 } + +http protocol plerup { # Protocol for upstream pleroma server + #tcp { nodelay, sack, socket buffer 65536, backlog 128 } # Uncomment and adjust as you see fit + tls ciphers "ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-CHACHA20-POLY1305" + tls ecdhe secp384r1 + + # Forward some paths to the local server (as pleroma won't respond to them as you might want) + pass request quick path "/robots.txt" forward to + + # Append a bunch of headers + match request header append "X-Forwarded-For" value "$REMOTE_ADDR" # This two header and the next one are not strictly required by pleroma but adding them won't hurt + match request header append "X-Forwarded-By" value "$SERVER_ADDR:$SERVER_PORT" + + match response header append "X-XSS-Protection" value "1; mode=block" + match response header append "X-Permitted-Cross-Domain-Policies" value "none" + match response header append "X-Frame-Options" value "DENY" + match response header append "X-Content-Type-Options" value "nosniff" + match response header append "Referrer-Policy" value "same-origin" + match response header append "X-Download-Options" value "noopen" + match response header append "Content-Security-Policy" value "default-src 'none'; base-uri 'self'; form-action 'self'; img-src 'self' data: https:; media-src 'self' https:; style-src 'self' 'unsafe-inline'; font-src 'self'; script-src 'self'; connect-src 'self' wss://CHANGEME.tld; upgrade-insecure-requests;" # Modify "CHANGEME.tld" and set your instance's domain here + match request header append "Connection" value "upgrade" + #match response header append "Strict-Transport-Security" value "max-age=31536000; includeSubDomains" # Uncomment this only after you get HTTPS working. + + # If you do not want remote frontends to be able to access your Pleroma backend server, comment these lines + match response header append "Access-Control-Allow-Origin" value "*" + match response header append "Access-Control-Allow-Methods" value "POST, PUT, DELETE, GET, PATCH, OPTIONS" + match response header append "Access-Control-Allow-Headers" value "Authorization, Content-Type, Idempotency-Key" + match response header append "Access-Control-Expose-Headers" value "Link, X-RateLimit-Reset, X-RateLimit-Limit, X-RateLimit-Remaining, X-Request-Id" + # Stop commenting lines here +} + +relay wwwtls { + listen on $ext_inet port https tls # Comment to disable listening on IPv4 + listen on $ext_inet6 port https tls # Comment to disable listening on IPv6 + + protocol plerup + + forward to port 4000 check http "/" code 200 + forward to port 80 check http "/robots.txt" code 200 +} +``` +Again, change *\* to your server's address(es) and comment one of the two *listen* options if needed. Also change *wss://CHANGEME.tld* to *wss://\*. +Check the configuration with `relayd -n`, if it is OK enable and start relayd (as root): +``` +rcctl enable relayd +rcctl start relayd +``` + +#### pf +Enabling and configuring pf is highly recommended. +In /etc/pf.conf, insert the following configuration: +``` +# Macros +if="" +authorized_ssh_clients="any" + +# Skip traffic on loopback interface +set skip on lo + +# Default behavior +set block-policy drop +block in log all +pass out quick + +# Security features +match in all scrub (no-df random-id) +block in log from urpf-failed + +# Rules +pass in quick on $if inet proto icmp to ($if) icmp-type { echoreq unreach paramprob trace } # ICMP +pass in quick on $if inet6 proto icmp6 to ($if) icmp6-type { echoreq unreach paramprob timex toobig } # ICMPv6 +pass in quick on $if proto tcp to ($if) port { http https } # relayd/httpd +pass in quick on $if proto tcp from $authorized_ssh_clients to ($if) port ssh +``` +Replace *\* by your server's network interface name (which you can get with ifconfig). Consider replacing the content of the authorized\_ssh\_clients macro by, for exemple, your home IP address, to avoid SSH connection attempts from bots. + +Check pf's configuration by running `pfctl -nf /etc/pf.conf`, load it with `pfctl -f /etc/pf.conf` and enable pf at boot with `rcctl enable pf`. + +#### Configure and start pleroma +Enter a shell as \_pleroma (as root `su _pleroma -`) and enter pleroma's installation directory (`cd ~/pleroma/`). +Then follow the main installation guide: + * run `mix deps.get` + * run `mix pleroma.instance gen` and enter your instance's information when asked + * copy config/generated\_config.exs to config/prod.secret.exs. The default values should be sufficient but you should edit it and check that everything seems OK. + * exit your current shell back to a root one and run `psql -U postgres -f /home/_pleroma/config/setup_db.psql` to setup the database. + * return to a \_pleroma shell into pleroma's installation directory (`su _pleroma -;cd ~/pleroma`) and run `MIX_ENV=prod mix ecto.migrate` + +As \_pleroma in /home/\_pleroma/pleroma, you can now run `LC_ALL=en_US.UTF-8 MIX_ENV=prod mix phx.server` to start your instance. +In another SSH session/tmux window, check that it is working properly by running `ftp -MVo - http://127.0.0.1:4000/api/v1/instance`, you should get json output. Double-check that *uri*'s value is your instance's domain name. + +##### Starting pleroma at boot +An rc script to automatically start pleroma at boot hasn't been written yet, it can be run in a tmux session (tmux is in base). diff --git a/docs/installation/openbsd_fi.md b/docs/installation/openbsd_fi.md new file mode 100644 index 000000000..fa6faa62d --- /dev/null +++ b/docs/installation/openbsd_fi.md @@ -0,0 +1,110 @@ +# Pleroman asennus OpenBSD:llä + +Tarvitset: +* Oman domainin +* OpenBSD 6.3 -serverin +* Auttavan ymmärryksen unix-järjestelmistä + +Komennot, joiden edessä on '#', tulee ajaa käyttäjänä `root`. Tämä on +suositeltavaa tehdä komennon `doas` avulla, katso `doas (1)` ja `doas.conf (5)`. +Tästä eteenpäin oletuksena on, että domain "esimerkki.com" osoittaa +serverin IP-osoitteeseen. + +Jos asennuksen kanssa on ongelmia, IRC-kanava #pleroma Freenodessa tai +Matrix-kanava #freenode_#pleroma:matrix.org ovat hyviä paikkoja löytää apua +(englanniksi), `/msg eal kukkuu` jos haluat välttämättä puhua härmää. + +Asenna tarvittava ohjelmisto: + +`# pkg_add git elixir gmake postgresql-server-10.3 postgresql-contrib-10.3` + +Luo postgresql-tietokanta: + +`# su - _postgresql` + +`$ mkdir /var/postgresql/data` + +`$ initdb -D /var/postgresql/data -E UTF8` + +`$ createdb` + +Käynnistä tietokanta ja aseta se käynnistymään automaattisesti. + +`# rcctl start postgresql` + +`# rcctl enable postgresql` + +Luo käyttäjä pleromaa varten (kysyy muutaman kysymyksen): + +`# adduser pleroma` + +Vaihda pleroma-käyttäjään ja mene kotihakemistoosi: + +`# su - pleroma` + +Lataa pleroman lähdekoodi: + +`$ git clone https://git.pleroma.social/pleroma/pleroma.git` + +`$ cd pleroma` + +Asenna tarvittavat elixir-kirjastot: + +`$ mix deps.get` + +`$ mix deps.compile` + +Luo tarvittava konfiguraatio: + +`$ mix generate_config` + +`$ cp config/generated_config.exs config/prod.secret.exs` + +Aja luodut tietokantakomennot: + +`# su _postgres -c 'psql -f config/setup_db.psql'` + +`$ MIX_ENV=prod mix ecto.migrate` + +Käynnistä pleroma-prosessi: + +`$ MIX_ENV=prod mix compile` + +`$ MIX_ENV=prod mix phx.server` + +Tässä vaiheessa on hyvä tarkistaa että asetukset ovat oikein. Avaa selaimella, +curlilla tai vastaavalla työkalulla `esimerkki.com:4000/api/v1/instance` ja katso +että kohta "uri" on "https://esimerkki.com". + +Huom! Muista varmistaa että muuttuja MIX_ENV on "prod" mix-komentoja ajaessasi. +Mix lukee oikean konfiguraatiotiedoston sen mukaisesti. + +Ohessa enimmäkseen toimivaksi todettu rc.d-skripti pleroman käynnistämiseen. +Kirjoita se tiedostoon /etc/rc.d/pleroma. Tämän jälkeen aja +`# chmod +x /etc/rc.d/pleroma`, ja voit käynnistää pleroman komennolla +`# /etc/rc.d/pleroma start`. + +``` +#!/bin/ksh +#/etc/rc.d/pleroma + +daemon="cd /home/pleroma/pleroma;MIX_ENV=prod /usr/local/bin/elixir" +daemon_flags="--detached /usr/local/bin/mix phx.server" +daemon_user="pleroma" +rc_reload="NO" +rc_bg="YES" + +pexp="beam" + +. /etc/rc.d/rc.subr + +rc_cmd $1 +``` + +Tämän jälkeen tarvitset enää HTTP-serverin välittämään kutsut pleroma-prosessille. +Tiedostosta `install/pleroma.nginx` löytyy esimerkkikonfiguraatio, ja TLS-sertifikaatit +saat ilmaiseksi esimerkiksi [letsencryptiltä](https://certbot.eff.org/lets-encrypt/opbsd-nginx.html). +Nginx asentuu yksinkertaisesti komennolla `# pkg_add nginx`. + +Kun olet valmis, avaa https://esimerkki.com selaimessasi. Luo käyttäjä ja seuraa kiinnostavia +tyyppejä muilla palvelimilla! diff --git a/docs/introduction.md b/docs/introduction.md new file mode 100644 index 000000000..4af0747fe --- /dev/null +++ b/docs/introduction.md @@ -0,0 +1,55 @@ +# Introduction to Pleroma +## What is Pleroma? +Pleroma is a federated social networking platform, compatible with GNU social, Mastodon and other OStatus and ActivityPub implementations. It is free software licensed under the AGPLv3. +It actually consists of two components: a backend, named simply Pleroma, and a user-facing frontend, named Pleroma-FE. It also includes the Mastodon frontend, if that's your thing. +It's part of what we call the fediverse, a federated network of instances which speak common protocols and can communicate with each other. +One account on a instance is enough to talk to the entire fediverse! + +## How can I use it? + +Pleroma instances are already widely deployed, a list can be found here: +http://distsn.org/pleroma-instances.html + +If you don't feel like joining an existing instance, but instead prefer to deploy your own instance, that's easy too! +Installation instructions can be found here: +[main Pleroma wiki](/) + +## I got an account, now what? +Great! Now you can explore the fediverse! +- Open the login page for your Pleroma instance (for ex. https://pleroma.soykaf.com) and login with your username and password. +(If you don't have one yet, click on Register) :slightly_smiling_face: + +At this point you will have two columns in front of you. + +### Left column +- first block: here you can see your avatar, your nickname a bio, and statistics (Statuses, Following, Followers). +Under that you have a text form which allows you to post new statuses. The icon on the left is for uploading media files and attach them to your post. The number under the text form is a character counter, every instance can have a different character limit (the default is 5000). +If you want to mention someone, type @ + name of the person. A drop-down menu will help you in finding the right person. :slight_smile: +To post your status, simply press Submit. + +- second block: Here you can switch between the different timelines: + - Timeline: all the people that you follow + - Mentions: all the statutes where you are mentioned + - Public Timeline: all the statutes from the local instance + - The Whole Known Network: everything, local and remote! + +- third block: this is the Chat block, where you communicate with people on the same instance in realtime. It is local-only, for now, but we're planning to make it extendable to the entire fediverse! :sweat_smile: + +- fourth block: This is the Notifications block, here you will get notified whenever somebody mentions you, follows you, repeats or favorites one of your statuses. + +### Right column +This is where the interesting stuff happens! :slight_smile: +Depending on the timeline you will see different statuses, but each status has a standard structure: +- Icon + name + link to profile. An optional left-arrow if it's a reply to another status (hovering will reveal the replied-to status). +- A + button on the right allows you to Expand/Collapse an entire discussion thread. It also updates in realtime! +- A binocular icon allows you to open the status on the instance where it's originating from. +- The text of the status, including mentions. If you click on a mention, it will automatically open the profile page of that person. +- Four buttons (left to right): Reply, Repeat, Favorite, Delete. + +## Mastodon interface +If the Pleroma interface isn't your thing, or you're just trying something new but you want to keep using the familiar Mastodon interface, we got that too! :smile: +Just add a "/web" after your instance url (for ex. https://pleroma.soycaf.com/web) and you'll end on the Mastodon web interface, but with a Pleroma backend! MAGIC! :fireworks: +For more information on the Mastodon interface, please look here: +https://github.com/tootsuite/documentation/blob/master/Using-Mastodon/User-guide.md + +Remember, what you see is only the frontend part of Mastodon, the backend is still Pleroma. diff --git a/lib/pleroma/activity.ex b/lib/pleroma/activity.ex index 79dc26b01..bc3f8caba 100644 --- a/lib/pleroma/activity.ex +++ b/lib/pleroma/activity.ex @@ -7,6 +7,7 @@ defmodule Pleroma.Activity do alias Pleroma.Activity alias Pleroma.Notification + alias Pleroma.Object alias Pleroma.Repo import Ecto.Query @@ -22,6 +23,10 @@ defmodule Pleroma.Activity do "Like" => "favourite" } + @mastodon_to_ap_notification_types for {k, v} <- @mastodon_notification_types, + into: %{}, + do: {v, k} + schema "activities" do field(:data, :map) field(:local, :boolean, default: true) @@ -29,9 +34,42 @@ defmodule Pleroma.Activity do field(:recipients, {:array, :string}) has_many(:notifications, Notification, on_delete: :delete_all) + # Attention: this is a fake relation, don't try to preload it blindly and expect it to work! + # The foreign key is embedded in a jsonb field. + # + # To use it, you probably want to do an inner join and a preload: + # + # ``` + # |> join(:inner, [activity], o in Object, + # on: fragment("(?->>'id') = COALESCE((?)->'object'->> 'id', (?)->>'object')", + # o.data, activity.data, activity.data)) + # |> preload([activity, object], [object: object]) + # ``` + # + # As a convenience, Activity.with_preloaded_object() sets up an inner join and preload for the + # typical case. + has_one(:object, Object, on_delete: :nothing, foreign_key: :id) + timestamps() end + def with_preloaded_object(query) do + query + |> join( + :inner, + [activity], + o in Object, + on: + fragment( + "(?->>'id') = COALESCE(?->'object'->>'id', ?->>'object')", + o.data, + activity.data, + activity.data + ) + ) + |> preload([activity, object], object: object) + end + def get_by_ap_id(ap_id) do Repo.one( from( @@ -41,10 +79,44 @@ def get_by_ap_id(ap_id) do ) end + def get_by_ap_id_with_object(ap_id) do + Repo.one( + from( + activity in Activity, + where: fragment("(?)->>'id' = ?", activity.data, ^to_string(ap_id)), + left_join: o in Object, + on: + fragment( + "(?->>'id') = COALESCE(?->'object'->>'id', ?->>'object')", + o.data, + activity.data, + activity.data + ), + preload: [object: o] + ) + ) + end + def get_by_id(id) do Repo.get(Activity, id) end + def get_by_id_with_object(id) do + from(activity in Activity, + where: activity.id == ^id, + inner_join: o in Object, + on: + fragment( + "(?->>'id') = COALESCE(?->'object'->>'id', ?->>'object')", + o.data, + activity.data, + activity.data + ), + preload: [object: o] + ) + |> Repo.one() + end + def by_object_ap_id(ap_id) do from( activity in Activity, @@ -72,7 +144,7 @@ def create_by_object_ap_id(ap_ids) when is_list(ap_ids) do ) end - def create_by_object_ap_id(ap_id) do + def create_by_object_ap_id(ap_id) when is_binary(ap_id) do from( activity in Activity, where: @@ -86,6 +158,8 @@ def create_by_object_ap_id(ap_id) do ) end + def create_by_object_ap_id(_), do: nil + def get_all_create_by_object_ap_id(ap_id) do Repo.all(create_by_object_ap_id(ap_id)) end @@ -97,8 +171,39 @@ def get_create_by_object_ap_id(ap_id) when is_binary(ap_id) do def get_create_by_object_ap_id(_), do: nil - def normalize(obj) when is_map(obj), do: Activity.get_by_ap_id(obj["id"]) - def normalize(ap_id) when is_binary(ap_id), do: Activity.get_by_ap_id(ap_id) + def create_by_object_ap_id_with_object(ap_id) when is_binary(ap_id) do + from( + activity in Activity, + where: + fragment( + "coalesce((?)->'object'->>'id', (?)->>'object') = ?", + activity.data, + activity.data, + ^to_string(ap_id) + ), + where: fragment("(?)->>'type' = 'Create'", activity.data), + inner_join: o in Object, + on: + fragment( + "(?->>'id') = COALESCE(?->'object'->>'id', ?->>'object')", + o.data, + activity.data, + activity.data + ), + preload: [object: o] + ) + end + + def create_by_object_ap_id_with_object(_), do: nil + + def get_create_by_object_ap_id_with_object(ap_id) do + ap_id + |> create_by_object_ap_id_with_object() + |> Repo.one() + end + + def normalize(obj) when is_map(obj), do: get_by_ap_id_with_object(obj["id"]) + def normalize(ap_id) when is_binary(ap_id), do: get_by_ap_id_with_object(ap_id) def normalize(_), do: nil def get_in_reply_to_activity(%Activity{data: %{"object" => %{"inReplyTo" => ap_id}}}) do @@ -109,7 +214,8 @@ def get_in_reply_to_activity(_), do: nil def delete_by_ap_id(id) when is_binary(id) do by_object_ap_id(id) - |> Repo.delete_all(returning: true) + |> select([u], u) + |> Repo.delete_all() |> elem(1) |> Enum.find(fn %{data: %{"type" => "Create", "object" => %{"id" => ap_id}}} -> ap_id == id @@ -126,6 +232,10 @@ def mastodon_notification_type(%Activity{data: %{"type" => unquote(ap_type)}}), def mastodon_notification_type(%Activity{}), do: nil + def from_mastodon_notification_type(type) do + Map.get(@mastodon_to_ap_notification_types, type) + end + def all_by_actor_and_id(actor, status_ids \\ []) def all_by_actor_and_id(_actor, []), do: [] @@ -135,4 +245,50 @@ def all_by_actor_and_id(actor, status_ids) do |> where([s], s.actor == ^actor) |> Repo.all() end + + def increase_replies_count(id) do + Activity + |> where(id: ^id) + |> update([a], + set: [ + data: + fragment( + """ + jsonb_set(?, '{object, repliesCount}', + (coalesce((?->'object'->>'repliesCount')::int, 0) + 1)::varchar::jsonb, true) + """, + a.data, + a.data + ) + ] + ) + |> Repo.update_all([]) + |> case do + {1, [activity]} -> activity + _ -> {:error, "Not found"} + end + end + + def decrease_replies_count(id) do + Activity + |> where(id: ^id) + |> update([a], + set: [ + data: + fragment( + """ + jsonb_set(?, '{object, repliesCount}', + (greatest(0, (?->'object'->>'repliesCount')::int - 1))::varchar::jsonb, true) + """, + a.data, + a.data + ) + ] + ) + |> Repo.update_all([]) + |> case do + {1, [activity]} -> activity + _ -> {:error, "Not found"} + end + end end diff --git a/lib/pleroma/application.ex b/lib/pleroma/application.ex index cc81e1805..782d1d589 100644 --- a/lib/pleroma/application.ex +++ b/lib/pleroma/application.ex @@ -110,7 +110,6 @@ def start(_type, _args) do worker(Pleroma.Web.Federator.RetryQueue, []), worker(Pleroma.Stats, []), worker(Pleroma.Web.Push, []), - worker(Pleroma.Jobs, []), worker(Task, [&Pleroma.Web.Federator.init/0], restart: :temporary) ] ++ streamer_child() ++ diff --git a/lib/pleroma/emails/admin_email.ex b/lib/pleroma/emails/admin_email.ex index 9b20c7e08..afefccec5 100644 --- a/lib/pleroma/emails/admin_email.ex +++ b/lib/pleroma/emails/admin_email.ex @@ -29,9 +29,13 @@ def report(to, reporter, account, statuses, comment) do if length(statuses) > 0 do statuses_list_html = statuses - |> Enum.map(fn %{id: id} -> - status_url = Helpers.o_status_url(Pleroma.Web.Endpoint, :notice, id) - "
  • #{status_url}
  • " + |> Enum.map(fn + %{id: id} -> + status_url = Helpers.o_status_url(Pleroma.Web.Endpoint, :notice, id) + "
  • #{status_url}
  • " + + id when is_binary(id) -> + "
  • #{id}
  • " end) |> Enum.join("\n") diff --git a/lib/pleroma/emails/mailer.ex b/lib/pleroma/emails/mailer.ex index f7e3aa78b..b384e6fec 100644 --- a/lib/pleroma/emails/mailer.ex +++ b/lib/pleroma/emails/mailer.ex @@ -6,7 +6,7 @@ defmodule Pleroma.Mailer do use Swoosh.Mailer, otp_app: :pleroma def deliver_async(email, config \\ []) do - Pleroma.Jobs.enqueue(:mailer, __MODULE__, [:deliver_async, email, config]) + PleromaJobQueue.enqueue(:mailer, __MODULE__, [:deliver_async, email, config]) end def perform(:deliver_async, email, config), do: deliver(email, config) diff --git a/lib/pleroma/formatter.ex b/lib/pleroma/formatter.ex index 1e4ede3f2..e3625383b 100644 --- a/lib/pleroma/formatter.ex +++ b/lib/pleroma/formatter.ex @@ -8,6 +8,7 @@ defmodule Pleroma.Formatter do alias Pleroma.User alias Pleroma.Web.MediaProxy + @safe_mention_regex ~r/^(\s*(?@.+?\s+)+)(?.*)/ @markdown_characters_regex ~r/(`|\*|_|{|}|[|]|\(|\)|#|\+|-|\.|!)/ @link_regex ~r{((?:http(s)?:\/\/)?[\w.-]+(?:\.[\w\.-]+)+[\w\-\._~%:/?#[\]@!\$&'\(\)\*\+,;=.]+)|[0-9a-z+\-\.]+:[0-9a-z$-_.+!*'(),]+}ui # credo:disable-for-previous-line Credo.Check.Readability.MaxLineLength @@ -45,15 +46,28 @@ def hashtag_handler("#" <> tag = tag_text, _buffer, _opts, acc) do @doc """ Parses a text and replace plain text links with HTML. Returns a tuple with a result text, mentions, and hashtags. + + If the 'safe_mention' option is given, only consecutive mentions at the start the post are actually mentioned. """ @spec linkify(String.t(), keyword()) :: {String.t(), [{String.t(), User.t()}], [{String.t(), String.t()}]} def linkify(text, options \\ []) do options = options ++ @auto_linker_config - acc = %{mentions: MapSet.new(), tags: MapSet.new()} - {text, %{mentions: mentions, tags: tags}} = AutoLinker.link_map(text, acc, options) - {text, MapSet.to_list(mentions), MapSet.to_list(tags)} + if options[:safe_mention] && Regex.named_captures(@safe_mention_regex, text) do + %{"mentions" => mentions, "rest" => rest} = Regex.named_captures(@safe_mention_regex, text) + acc = %{mentions: MapSet.new(), tags: MapSet.new()} + + {text_mentions, %{mentions: mentions}} = AutoLinker.link_map(mentions, acc, options) + {text_rest, %{tags: tags}} = AutoLinker.link_map(rest, acc, options) + + {text_mentions <> text_rest, MapSet.to_list(mentions), MapSet.to_list(tags)} + else + acc = %{mentions: MapSet.new(), tags: MapSet.new()} + {text, %{mentions: mentions, tags: tags}} = AutoLinker.link_map(text, acc, options) + + {text, MapSet.to_list(mentions), MapSet.to_list(tags)} + end end def emojify(text) do diff --git a/lib/pleroma/gopher/server.ex b/lib/pleroma/gopher/server.ex index 6baacc566..3b9629d77 100644 --- a/lib/pleroma/gopher/server.ex +++ b/lib/pleroma/gopher/server.ex @@ -66,7 +66,8 @@ def info(text) do def link(name, selector, type \\ 1) do address = Pleroma.Web.Endpoint.host() port = Pleroma.Config.get([:gopher, :port], 1234) - "#{type}#{name}\t#{selector}\t#{address}\t#{port}\r\n" + dstport = Pleroma.Config.get([:gopher, :dstport], port) + "#{type}#{name}\t#{selector}\t#{address}\t#{dstport}\r\n" end def render_activities(activities) do diff --git a/lib/pleroma/html.ex b/lib/pleroma/html.ex index 05253157e..5b152d926 100644 --- a/lib/pleroma/html.ex +++ b/lib/pleroma/html.ex @@ -95,6 +95,13 @@ defmodule Pleroma.HTML.Scrubber.TwitterText do Meta.allow_tag_with_uri_attributes("a", ["href", "data-user", "data-tag"], @valid_schemes) Meta.allow_tag_with_these_attributes("a", ["name", "title", "class"]) + Meta.allow_tag_with_this_attribute_values("a", "rel", [ + "tag", + "nofollow", + "noopener", + "noreferrer" + ]) + # paragraphs and linebreaks Meta.allow_tag_with_these_attributes("br", []) Meta.allow_tag_with_these_attributes("p", []) @@ -137,6 +144,13 @@ defmodule Pleroma.HTML.Scrubber.Default do Meta.allow_tag_with_uri_attributes("a", ["href", "data-user", "data-tag"], @valid_schemes) Meta.allow_tag_with_these_attributes("a", ["name", "title", "class"]) + Meta.allow_tag_with_this_attribute_values("a", "rel", [ + "tag", + "nofollow", + "noopener", + "noreferrer" + ]) + Meta.allow_tag_with_these_attributes("abbr", ["title"]) Meta.allow_tag_with_these_attributes("b", []) diff --git a/lib/pleroma/instances/instance.ex b/lib/pleroma/instances/instance.ex index e92006151..420803a8f 100644 --- a/lib/pleroma/instances/instance.ex +++ b/lib/pleroma/instances/instance.ex @@ -12,7 +12,7 @@ defmodule Pleroma.Instances.Instance do schema "instances" do field(:host, :string) - field(:unreachable_since, :naive_datetime) + field(:unreachable_since, :naive_datetime_usec) timestamps() end diff --git a/lib/pleroma/jobs.ex b/lib/pleroma/jobs.ex deleted file mode 100644 index 24b7e5e46..000000000 --- a/lib/pleroma/jobs.ex +++ /dev/null @@ -1,152 +0,0 @@ -# Pleroma: A lightweight social networking server -# Copyright © 2017-2019 Pleroma Authors -# SPDX-License-Identifier: AGPL-3.0-only - -defmodule Pleroma.Jobs do - @moduledoc """ - A basic job queue - """ - use GenServer - - require Logger - - def init(args) do - {:ok, args} - end - - def start_link do - queues = - Pleroma.Config.get(Pleroma.Jobs) - |> Enum.map(fn {name, _} -> create_queue(name) end) - |> Enum.into(%{}) - - state = %{ - queues: queues, - refs: %{} - } - - GenServer.start_link(__MODULE__, state, name: __MODULE__) - end - - def create_queue(name) do - {name, {:sets.new(), []}} - end - - @doc """ - Enqueues a job. - - Returns `:ok`. - - ## Arguments - - - `queue_name` - a queue name(must be specified in the config). - - `mod` - a worker module (must have `perform` function). - - `args` - a list of arguments for the `perform` function of the worker module. - - `priority` - a job priority (`0` by default). - - ## Examples - - Enqueue `Module.perform/0` with `priority=1`: - - iex> Pleroma.Jobs.enqueue(:example_queue, Module, []) - :ok - - Enqueue `Module.perform(:job_name)` with `priority=5`: - - iex> Pleroma.Jobs.enqueue(:example_queue, Module, [:job_name], 5) - :ok - - Enqueue `Module.perform(:another_job, data)` with `priority=1`: - - iex> data = "foobar" - iex> Pleroma.Jobs.enqueue(:example_queue, Module, [:another_job, data]) - :ok - - Enqueue `Module.perform(:foobar_job, :foo, :bar, 42)` with `priority=1`: - - iex> Pleroma.Jobs.enqueue(:example_queue, Module, [:foobar_job, :foo, :bar, 42]) - :ok - - """ - - def enqueue(queue_name, mod, args, priority \\ 1) - - if Mix.env() == :test do - def enqueue(_queue_name, mod, args, _priority) do - apply(mod, :perform, args) - end - else - @spec enqueue(atom(), atom(), [any()], integer()) :: :ok - def enqueue(queue_name, mod, args, priority) do - GenServer.cast(__MODULE__, {:enqueue, queue_name, mod, args, priority}) - end - end - - def handle_cast({:enqueue, queue_name, mod, args, priority}, state) do - {running_jobs, queue} = state[:queues][queue_name] - - queue = enqueue_sorted(queue, {mod, args}, priority) - - state = - state - |> update_queue(queue_name, {running_jobs, queue}) - |> maybe_start_job(queue_name, running_jobs, queue) - - {:noreply, state} - end - - def handle_info({:DOWN, ref, :process, _pid, _reason}, state) do - queue_name = state.refs[ref] - - {running_jobs, queue} = state[:queues][queue_name] - - running_jobs = :sets.del_element(ref, running_jobs) - - state = - state - |> remove_ref(ref) - |> update_queue(queue_name, {running_jobs, queue}) - |> maybe_start_job(queue_name, running_jobs, queue) - - {:noreply, state} - end - - def maybe_start_job(state, queue_name, running_jobs, queue) do - if :sets.size(running_jobs) < Pleroma.Config.get([__MODULE__, queue_name, :max_jobs]) && - queue != [] do - {{mod, args}, queue} = queue_pop(queue) - {:ok, pid} = Task.start(fn -> apply(mod, :perform, args) end) - mref = Process.monitor(pid) - - state - |> add_ref(queue_name, mref) - |> update_queue(queue_name, {:sets.add_element(mref, running_jobs), queue}) - else - state - end - end - - def enqueue_sorted(queue, element, priority) do - [%{item: element, priority: priority} | queue] - |> Enum.sort_by(fn %{priority: priority} -> priority end) - end - - def queue_pop([%{item: element} | queue]) do - {element, queue} - end - - defp add_ref(state, queue_name, ref) do - refs = Map.put(state[:refs], ref, queue_name) - Map.put(state, :refs, refs) - end - - defp remove_ref(state, ref) do - refs = Map.delete(state[:refs], ref) - Map.put(state, :refs, refs) - end - - defp update_queue(state, queue_name, data) do - queues = Map.put(state[:queues], queue_name, data) - Map.put(state, :queues, queues) - end -end diff --git a/lib/pleroma/notification.ex b/lib/pleroma/notification.ex index 765191275..cac10f24a 100644 --- a/lib/pleroma/notification.ex +++ b/lib/pleroma/notification.ex @@ -7,6 +7,8 @@ defmodule Pleroma.Notification do alias Pleroma.Activity alias Pleroma.Notification + alias Pleroma.Object + alias Pleroma.Pagination alias Pleroma.Repo alias Pleroma.User alias Pleroma.Web.CommonAPI @@ -28,36 +30,25 @@ def changeset(%Notification{} = notification, attrs) do |> cast(attrs, [:seen]) end - # TODO: Make generic and unify (see activity_pub.ex) - defp restrict_max(query, %{"max_id" => max_id}) do - from(activity in query, where: activity.id < ^max_id) + def for_user_query(user) do + Notification + |> where(user_id: ^user.id) + |> join(:inner, [n], activity in assoc(n, :activity)) + |> join(:left, [n, a], object in Object, + on: + fragment( + "(?->>'id') = COALESCE((? -> 'object'::text) ->> 'id'::text)", + object.data, + a.data + ) + ) + |> preload([n, a, o], activity: {a, object: o}) end - defp restrict_max(query, _), do: query - - defp restrict_since(query, %{"since_id" => since_id}) do - from(activity in query, where: activity.id > ^since_id) - end - - defp restrict_since(query, _), do: query - def for_user(user, opts \\ %{}) do - query = - from( - n in Notification, - where: n.user_id == ^user.id, - order_by: [desc: n.id], - join: activity in assoc(n, :activity), - preload: [activity: activity], - limit: 20 - ) - - query = - query - |> restrict_since(opts) - |> restrict_max(opts) - - Repo.all(query) + user + |> for_user_query() + |> Pagination.fetch_paginated(opts) end def set_read_up_to(%{id: user_id} = _user, id) do diff --git a/lib/pleroma/object.ex b/lib/pleroma/object.ex index 58e46ef1d..8a670645d 100644 --- a/lib/pleroma/object.ex +++ b/lib/pleroma/object.ex @@ -14,6 +14,8 @@ defmodule Pleroma.Object do import Ecto.Query import Ecto.Changeset + require Logger + schema "objects" do field(:data, :map) @@ -38,6 +40,33 @@ def get_by_ap_id(ap_id) do Repo.one(from(object in Object, where: fragment("(?)->>'id' = ?", object.data, ^ap_id))) end + # If we pass an Activity to Object.normalize(), we can try to use the preloaded object. + # Use this whenever possible, especially when walking graphs in an O(N) loop! + def normalize(%Activity{object: %Object{} = object}), do: object + + # Catch and log Object.normalize() calls where the Activity's child object is not + # preloaded. + def normalize(%Activity{data: %{"object" => %{"id" => ap_id}}}) do + Logger.debug( + "Object.normalize() called without preloaded object (#{ap_id}). Consider preloading the object!" + ) + + Logger.debug("Backtrace: #{inspect(Process.info(:erlang.self(), :current_stacktrace))}") + + normalize(ap_id) + end + + def normalize(%Activity{data: %{"object" => ap_id}}) do + Logger.debug( + "Object.normalize() called without preloaded object (#{ap_id}). Consider preloading the object!" + ) + + Logger.debug("Backtrace: #{inspect(Process.info(:erlang.self(), :current_stacktrace))}") + + normalize(ap_id) + end + + # Old way, try fetching the object through cache. def normalize(%{"id" => ap_id}), do: normalize(ap_id) def normalize(ap_id) when is_binary(ap_id), do: get_cached_by_ap_id(ap_id) def normalize(_), do: nil @@ -104,4 +133,50 @@ def update_and_set_cache(changeset) do e -> e end end + + def increase_replies_count(ap_id) do + Object + |> where([o], fragment("?->>'id' = ?::text", o.data, ^to_string(ap_id))) + |> update([o], + set: [ + data: + fragment( + """ + jsonb_set(?, '{repliesCount}', + (coalesce((?->>'repliesCount')::int, 0) + 1)::varchar::jsonb, true) + """, + o.data, + o.data + ) + ] + ) + |> Repo.update_all([]) + |> case do + {1, [object]} -> set_cache(object) + _ -> {:error, "Not found"} + end + end + + def decrease_replies_count(ap_id) do + Object + |> where([o], fragment("?->>'id' = ?::text", o.data, ^to_string(ap_id))) + |> update([o], + set: [ + data: + fragment( + """ + jsonb_set(?, '{repliesCount}', + (greatest(0, (?->>'repliesCount')::int - 1))::varchar::jsonb, true) + """, + o.data, + o.data + ) + ] + ) + |> Repo.update_all([]) + |> case do + {1, [object]} -> set_cache(object) + _ -> {:error, "Not found"} + end + end end diff --git a/lib/pleroma/pagination.ex b/lib/pleroma/pagination.ex new file mode 100644 index 000000000..7c864deef --- /dev/null +++ b/lib/pleroma/pagination.ex @@ -0,0 +1,78 @@ +defmodule Pleroma.Pagination do + @moduledoc """ + Implements Mastodon-compatible pagination. + """ + + import Ecto.Query + import Ecto.Changeset + + alias Pleroma.Repo + + @default_limit 20 + + def fetch_paginated(query, params) do + options = cast_params(params) + + query + |> paginate(options) + |> Repo.all() + |> enforce_order(options) + end + + def paginate(query, options) do + query + |> restrict(:min_id, options) + |> restrict(:since_id, options) + |> restrict(:max_id, options) + |> restrict(:order, options) + |> restrict(:limit, options) + end + + defp cast_params(params) do + param_types = %{ + min_id: :string, + since_id: :string, + max_id: :string, + limit: :integer + } + + changeset = cast({%{}, param_types}, params, Map.keys(param_types)) + changeset.changes + end + + defp restrict(query, :min_id, %{min_id: min_id}) do + where(query, [q], q.id > ^min_id) + end + + defp restrict(query, :since_id, %{since_id: since_id}) do + where(query, [q], q.id > ^since_id) + end + + defp restrict(query, :max_id, %{max_id: max_id}) do + where(query, [q], q.id < ^max_id) + end + + defp restrict(query, :order, %{min_id: _}) do + order_by(query, [u], fragment("? asc nulls last", u.id)) + end + + defp restrict(query, :order, _options) do + order_by(query, [u], fragment("? desc nulls last", u.id)) + end + + defp restrict(query, :limit, options) do + limit = Map.get(options, :limit, @default_limit) + + query + |> limit(^limit) + end + + defp restrict(query, _, _), do: query + + defp enforce_order(result, %{min_id: _}) do + result + |> Enum.reverse() + end + + defp enforce_order(result, _), do: result +end diff --git a/lib/pleroma/repo.ex b/lib/pleroma/repo.ex index e6a51b19e..4af1bde56 100644 --- a/lib/pleroma/repo.ex +++ b/lib/pleroma/repo.ex @@ -3,7 +3,10 @@ # SPDX-License-Identifier: AGPL-3.0-only defmodule Pleroma.Repo do - use Ecto.Repo, otp_app: :pleroma + use Ecto.Repo, + otp_app: :pleroma, + adapter: Ecto.Adapters.Postgres, + migration_timestamps: [type: :naive_datetime_usec] @doc """ Dynamically loads the repository url from the diff --git a/lib/pleroma/uploaders/s3.ex b/lib/pleroma/uploaders/s3.ex index e7de3f3e0..521daa93b 100644 --- a/lib/pleroma/uploaders/s3.ex +++ b/lib/pleroma/uploaders/s3.ex @@ -13,10 +13,15 @@ def get_file(file) do bucket = Keyword.fetch!(config, :bucket) bucket_with_namespace = - if namespace = Keyword.get(config, :bucket_namespace) do - namespace <> ":" <> bucket - else - bucket + cond do + truncated_namespace = Keyword.get(config, :truncated_namespace) -> + truncated_namespace + + namespace = Keyword.get(config, :bucket_namespace) -> + namespace <> ":" <> bucket + + true -> + bucket end {:ok, diff --git a/lib/pleroma/user.ex b/lib/pleroma/user.ex index 692ae836c..728b00a56 100644 --- a/lib/pleroma/user.ex +++ b/lib/pleroma/user.ex @@ -50,23 +50,20 @@ defmodule Pleroma.User do field(:local, :boolean, default: true) field(:follower_address, :string) field(:search_rank, :float, virtual: true) + field(:search_type, :integer, virtual: true) field(:tags, {:array, :string}, default: []) field(:bookmarks, {:array, :string}, default: []) - field(:last_refreshed_at, :naive_datetime) + field(:last_refreshed_at, :naive_datetime_usec) has_many(:notifications, Notification) embeds_one(:info, Pleroma.User.Info) timestamps() end - def auth_active?(%User{local: false}), do: true - - def auth_active?(%User{info: %User.Info{confirmation_pending: false}}), do: true - def auth_active?(%User{info: %User.Info{confirmation_pending: true}}), do: !Pleroma.Config.get([:instance, :account_activation_required]) - def auth_active?(_), do: false + def auth_active?(%User{}), do: true def visible_for?(user, for_user \\ nil) @@ -82,17 +79,17 @@ def superuser?(%User{local: true, info: %User.Info{is_admin: true}}), do: true def superuser?(%User{local: true, info: %User.Info{is_moderator: true}}), do: true def superuser?(_), do: false - def avatar_url(user) do + def avatar_url(user, options \\ []) do case user.avatar do %{"url" => [%{"href" => href} | _]} -> href - _ -> "#{Web.base_url()}/images/avi.png" + _ -> !options[:no_default] && "#{Web.base_url()}/images/avi.png" end end - def banner_url(user) do + def banner_url(user, options \\ []) do case user.info.banner do %{"url" => [%{"href" => href} | _]} -> href - _ -> "#{Web.base_url()}/images/banner.png" + _ -> !options[:no_default] && "#{Web.base_url()}/images/banner.png" end end @@ -104,9 +101,8 @@ def ap_id(%User{nickname: nickname}) do "#{Web.base_url()}/users/#{nickname}" end - def ap_followers(%User{} = user) do - "#{ap_id(user)}/followers" - end + def ap_followers(%User{follower_address: fa}) when is_binary(fa), do: fa + def ap_followers(%User{} = user), do: "#{ap_id(user)}/followers" def user_info(%User{} = user) do oneself = if user.local, do: 1, else: 0 @@ -335,10 +331,11 @@ def follow_all(follower, followeds) do ^followed_addresses ) ] - ] + ], + select: u ) - {1, [follower]} = Repo.update_all(q, [], returning: true) + {1, [follower]} = Repo.update_all(q, []) Enum.each(followeds, fn followed -> update_follower_count(followed) @@ -368,10 +365,11 @@ def follow(%User{} = follower, %User{info: info} = followed) do q = from(u in User, where: u.id == ^follower.id, - update: [push: [following: ^ap_followers]] + update: [push: [following: ^ap_followers]], + select: u ) - {1, [follower]} = Repo.update_all(q, [], returning: true) + {1, [follower]} = Repo.update_all(q, []) {:ok, _} = update_follower_count(followed) @@ -386,10 +384,11 @@ def unfollow(%User{} = follower, %User{} = followed) do q = from(u in User, where: u.id == ^follower.id, - update: [pull: [following: ^ap_followers]] + update: [pull: [following: ^ap_followers]], + select: u ) - {1, [follower]} = Repo.update_all(q, [], returning: true) + {1, [follower]} = Repo.update_all(q, []) {:ok, followed} = update_follower_count(followed) @@ -637,7 +636,7 @@ def get_follow_requests(%User{} = user) do users = user |> User.get_follow_requests_query() - |> join(:inner, [a], u in User, a.actor == u.ap_id) + |> join(:inner, [a], u in User, on: a.actor == u.ap_id) |> where([a, u], not fragment("? @> ?", u.following, ^[user.follower_address])) |> group_by([a, u], u.id) |> select([a, u], u) @@ -659,7 +658,8 @@ def increase_note_count(%User{} = user) do ) ] ) - |> Repo.update_all([], returning: true) + |> select([u], u) + |> Repo.update_all([]) |> case do {1, [user]} -> set_cache(user) _ -> {:error, user} @@ -679,7 +679,8 @@ def decrease_note_count(%User{} = user) do ) ] ) - |> Repo.update_all([], returning: true) + |> select([u], u) + |> Repo.update_all([]) |> case do {1, [user]} -> set_cache(user) _ -> {:error, user} @@ -725,7 +726,8 @@ def update_follower_count(%User{} = user) do ) ] ) - |> Repo.update_all([], returning: true) + |> select([u], u) + |> Repo.update_all([]) |> case do {1, [user]} -> set_cache(user) _ -> {:error, user} @@ -766,90 +768,59 @@ def get_recipients_from_activity(%Activity{recipients: to}) do Repo.all(query) end - @spec search_for_admin(%{ - local: boolean(), - page: number(), - page_size: number() - }) :: {:ok, [Pleroma.User.t()], number()} - def search_for_admin(%{query: nil, local: local, page: page, page_size: page_size}) do - query = - from(u in User, order_by: u.id) - |> maybe_local_user_query(local) - - paginated_query = - query - |> paginate(page, page_size) - - count = - query - |> Repo.aggregate(:count, :id) - - {:ok, Repo.all(paginated_query), count} - end - - @spec search_for_admin(%{ - query: binary(), - admin: Pleroma.User.t(), - local: boolean(), - page: number(), - page_size: number() - }) :: {:ok, [Pleroma.User.t()], number()} - def search_for_admin(%{ - query: term, - admin: admin, - local: local, - page: page, - page_size: page_size - }) do - term = String.trim_leading(term, "@") - - local_paginated_query = - User - |> maybe_local_user_query(local) - |> paginate(page, page_size) - - search_query = fts_search_subquery(term, local_paginated_query) - - count = - term - |> fts_search_subquery() - |> maybe_local_user_query(local) - |> Repo.aggregate(:count, :id) - - {:ok, do_search(search_query, admin), count} - end - def search(query, resolve \\ false, for_user \\ nil) do # Strip the beginning @ off if there is a query query = String.trim_leading(query, "@") if resolve, do: get_or_fetch(query) - fts_results = do_search(fts_search_subquery(query), for_user) - - {:ok, trigram_results} = + {:ok, results} = Repo.transaction(fn -> Ecto.Adapters.SQL.query(Repo, "select set_limit(0.25)", []) - do_search(trigram_search_subquery(query), for_user) + Repo.all(search_query(query, for_user)) end) - Enum.uniq_by(fts_results ++ trigram_results, & &1.id) + results end - defp do_search(subquery, for_user, options \\ []) do - q = - from( - s in subquery(subquery), - order_by: [desc: s.search_rank], - limit: ^(options[:limit] || 20) - ) + def search_query(query, for_user) do + fts_subquery = fts_search_subquery(query) + trigram_subquery = trigram_search_subquery(query) + union_query = from(s in trigram_subquery, union_all: ^fts_subquery) + distinct_query = from(s in subquery(union_query), order_by: s.search_type, distinct: s.id) - results = - q - |> Repo.all() - |> Enum.filter(&(&1.search_rank > 0)) + from(s in subquery(boost_search_rank_query(distinct_query, for_user)), + order_by: [desc: s.search_rank], + limit: 20 + ) + end - boost_search_results(results, for_user) + defp boost_search_rank_query(query, nil), do: query + + defp boost_search_rank_query(query, for_user) do + friends_ids = get_friends_ids(for_user) + followers_ids = get_followers_ids(for_user) + + from(u in subquery(query), + select_merge: %{ + search_rank: + fragment( + """ + CASE WHEN (?) THEN (?) * 1.3 + WHEN (?) THEN (?) * 1.2 + WHEN (?) THEN (?) * 1.1 + ELSE (?) END + """, + u.id in ^friends_ids and u.id in ^followers_ids, + u.search_rank, + u.id in ^friends_ids, + u.search_rank, + u.id in ^followers_ids, + u.search_rank, + u.search_rank + ) + } + ) end defp fts_search_subquery(term, query \\ User) do @@ -864,6 +835,7 @@ defp fts_search_subquery(term, query \\ User) do from( u in query, select_merge: %{ + search_type: ^0, search_rank: fragment( """ @@ -896,6 +868,8 @@ defp trigram_search_subquery(term) do from( u in User, select_merge: %{ + # ^1 gives 'Postgrex expected a binary, got 1' for some weird reason + search_type: fragment("?", 1), search_rank: fragment( "similarity(?, trim(? || ' ' || coalesce(?, '')))", @@ -908,33 +882,6 @@ defp trigram_search_subquery(term) do ) end - defp boost_search_results(results, nil), do: results - - defp boost_search_results(results, for_user) do - friends_ids = get_friends_ids(for_user) - followers_ids = get_followers_ids(for_user) - - Enum.map( - results, - fn u -> - search_rank_coef = - cond do - u.id in friends_ids -> - 1.2 - - u.id in followers_ids -> - 1.1 - - true -> - 1 - end - - Map.put(u, :search_rank, u.search_rank * search_rank_coef) - end - ) - |> Enum.sort_by(&(-&1.search_rank)) - end - def blocks_import(%User{} = blocker, blocked_identifiers) when is_list(blocked_identifiers) do Enum.map( blocked_identifiers, @@ -1074,6 +1021,42 @@ def local_user_query(query \\ User) do ) end + def maybe_external_user_query(query, external) do + if external, do: external_user_query(query), else: query + end + + def external_user_query(query \\ User) do + from( + u in query, + where: u.local == false, + where: not is_nil(u.nickname) + ) + end + + def maybe_active_user_query(query, active) do + if active, do: active_user_query(query), else: query + end + + def active_user_query(query \\ User) do + from( + u in query, + where: fragment("not (?->'deactivated' @> 'true')", u.info), + where: not is_nil(u.nickname) + ) + end + + def maybe_deactivated_user_query(query, deactivated) do + if deactivated, do: deactivated_user_query(query), else: query + end + + def deactivated_user_query(query \\ User) do + from( + u in query, + where: fragment("(?->'deactivated' @> 'true')", u.info), + where: not is_nil(u.nickname) + ) + end + def active_local_user_query do from( u in local_user_query(), @@ -1113,13 +1096,15 @@ def delete(%User{} = user) do friends |> Enum.each(fn followed -> User.unfollow(user, followed) end) - query = from(a in Activity, where: a.actor == ^user.ap_id) + query = + from(a in Activity, where: a.actor == ^user.ap_id) + |> Activity.with_preloaded_object() Repo.all(query) |> Enum.each(fn activity -> case activity.data["type"] do "Create" -> - ActivityPub.delete(Object.normalize(activity.data["object"])) + ActivityPub.delete(Object.normalize(activity)) # TODO: Do something with likes, follows, repeats. _ -> @@ -1159,9 +1144,12 @@ def get_or_fetch_by_ap_id(ap_id) do if !is_nil(user) and !User.needs_update?(user) do user else + # Whether to fetch initial posts for the user (if it's a new user & the fetching is enabled) + should_fetch_initial = is_nil(user) and Pleroma.Config.get([:fetch_initial_posts, :enabled]) + user = fetch_by_ap_id(ap_id) - if Pleroma.Config.get([:fetch_initial_posts, :enabled]) do + if should_fetch_initial do with %User{} = user do {:ok, _} = Task.start(__MODULE__, :fetch_initial_posts, [user]) end diff --git a/lib/pleroma/web/activity_pub/activity_pub.ex b/lib/pleroma/web/activity_pub/activity_pub.ex index 2470b4a71..6e1ed7ec9 100644 --- a/lib/pleroma/web/activity_pub/activity_pub.ex +++ b/lib/pleroma/web/activity_pub/activity_pub.ex @@ -89,13 +89,37 @@ def decrease_note_count_if_public(actor, object) do if is_public?(object), do: User.decrease_note_count(actor), else: {:ok, actor} end + def increase_replies_count_if_reply(%{ + "object" => + %{"inReplyTo" => reply_ap_id, "inReplyToStatusId" => reply_status_id} = object, + "type" => "Create" + }) do + if is_public?(object) do + Activity.increase_replies_count(reply_status_id) + Object.increase_replies_count(reply_ap_id) + end + end + + def increase_replies_count_if_reply(_create_data), do: :noop + + def decrease_replies_count_if_reply(%Object{ + data: %{"inReplyTo" => reply_ap_id, "inReplyToStatusId" => reply_status_id} = object + }) do + if is_public?(object) do + Activity.decrease_replies_count(reply_status_id) + Object.decrease_replies_count(reply_ap_id) + end + end + + def decrease_replies_count_if_reply(_object), do: :noop + def insert(map, local \\ true) when is_map(map) do with nil <- Activity.normalize(map), map <- lazy_put_activity_defaults(map), :ok <- check_actor_is_active(map["actor"]), {_, true} <- {:remote_limit_error, check_remote_limit(map)}, {:ok, map} <- MRF.filter(map), - :ok <- insert_full_object(map) do + {:ok, object} <- insert_full_object(map) do {recipients, _, _} = get_recipients(map) {:ok, activity} = @@ -106,6 +130,14 @@ def insert(map, local \\ true) when is_map(map) do recipients: recipients }) + # Splice in the child object if we have one. + activity = + if !is_nil(object) do + Map.put(activity, :object, object) + else + activity + end + Task.start(fn -> Pleroma.Web.RichMedia.Helpers.fetch_data_for_activity(activity) end) @@ -170,6 +202,7 @@ def create(%{to: to, actor: actor, context: context, object: object} = params) d additional ), {:ok, activity} <- insert(create_data, local), + _ <- increase_replies_count_if_reply(create_data), # Changing note count prior to enqueuing federation task in order to avoid # race conditions on updating user.info {:ok, _actor} <- increase_note_count_if_public(actor, activity), @@ -321,6 +354,7 @@ def delete(%Object{data: %{"id" => id, "actor" => actor}} = object, local \\ tru "deleted_activity_id" => activity && activity.id }, {:ok, activity} <- insert(data, local), + _ <- decrease_replies_count_if_reply(object), # Changing note count prior to enqueuing federation task in order to avoid # race conditions on updating user.info {:ok, _actor} <- decrease_note_count_if_public(user, object), @@ -430,6 +464,7 @@ def fetch_activities_for_context(context, opts \\ %{}) do ), order_by: [desc: :id] ) + |> Activity.with_preloaded_object() Repo.all(query) end @@ -702,13 +737,25 @@ defp restrict_muted_reblogs(query, %{"muting_user" => %User{info: info}}) do from( activity in query, - where: fragment("not ?->>'type' = 'Announce'", activity.data), - where: fragment("not ? = ANY(?)", activity.actor, ^muted_reblogs) + where: + fragment( + "not ( ?->>'type' = 'Announce' and ? = ANY(?))", + activity.data, + activity.actor, + ^muted_reblogs + ) ) end defp restrict_muted_reblogs(query, _), do: query + defp maybe_preload_objects(query, %{"skip_preload" => true}), do: query + + defp maybe_preload_objects(query, _) do + query + |> Activity.with_preloaded_object() + end + def fetch_activities_query(recipients, opts \\ %{}) do base_query = from( @@ -718,6 +765,7 @@ def fetch_activities_query(recipients, opts \\ %{}) do ) base_query + |> maybe_preload_objects(opts) |> restrict_recipients(recipients, opts["user"]) |> restrict_tag(opts) |> restrict_tag_reject(opts) @@ -940,7 +988,7 @@ def fetch_object_from_id(id) do }, :ok <- Transmogrifier.contain_origin(id, params), {:ok, activity} <- Transmogrifier.handle_incoming(params) do - {:ok, Object.normalize(activity.data["object"])} + {:ok, Object.normalize(activity)} else {:error, {:reject, nil}} -> {:reject, nil} @@ -952,7 +1000,7 @@ def fetch_object_from_id(id) do Logger.info("Couldn't get object via AP, trying out OStatus fetching...") case OStatus.fetch_activity_from_url(id) do - {:ok, [activity | _]} -> {:ok, Object.normalize(activity.data["object"])} + {:ok, [activity | _]} -> {:ok, Object.normalize(activity)} e -> e end end diff --git a/lib/pleroma/web/activity_pub/mrf/keyword_policy.ex b/lib/pleroma/web/activity_pub/mrf/keyword_policy.ex index 25d5f9cd3..e8dfba672 100644 --- a/lib/pleroma/web/activity_pub/mrf/keyword_policy.ex +++ b/lib/pleroma/web/activity_pub/mrf/keyword_policy.ex @@ -4,6 +4,10 @@ defmodule Pleroma.Web.ActivityPub.MRF.KeywordPolicy do @behaviour Pleroma.Web.ActivityPub.MRF + defp string_matches?(string, _) when not is_binary(string) do + false + end + defp string_matches?(string, pattern) when is_binary(pattern) do String.contains?(string, pattern) end @@ -44,6 +48,20 @@ defp check_ftl_removal( end defp check_replace(%{"object" => %{"content" => content, "summary" => summary}} = message) do + content = + if is_binary(content) do + content + else + "" + end + + summary = + if is_binary(summary) do + summary + else + "" + end + {content, summary} = Enum.reduce( Pleroma.Config.get([:mrf_keyword, :replace]), @@ -60,11 +78,6 @@ defp check_replace(%{"object" => %{"content" => content, "summary" => summary}} |> put_in(["object", "summary"], summary)} end - @impl true - def filter(%{"object" => %{"content" => nil}} = message) do - {:ok, message} - end - @impl true def filter(%{"type" => "Create", "object" => %{"content" => _content}} = message) do with {:ok, message} <- check_reject(message), diff --git a/lib/pleroma/web/activity_pub/relay.ex b/lib/pleroma/web/activity_pub/relay.ex index 01fef71b9..a7a20ca37 100644 --- a/lib/pleroma/web/activity_pub/relay.ex +++ b/lib/pleroma/web/activity_pub/relay.ex @@ -41,7 +41,7 @@ def unfollow(target_instance) do def publish(%Activity{data: %{"type" => "Create"}} = activity) do with %User{} = user <- get_actor(), - %Object{} = object <- Object.normalize(activity.data["object"]["id"]) do + %Object{} = object <- Object.normalize(activity) do ActivityPub.announce(user, object, nil, true, false) else e -> Logger.error("error: #{inspect(e)}") diff --git a/lib/pleroma/web/activity_pub/transmogrifier.ex b/lib/pleroma/web/activity_pub/transmogrifier.ex index 8e4bf7b47..f733ae7e1 100644 --- a/lib/pleroma/web/activity_pub/transmogrifier.ex +++ b/lib/pleroma/web/activity_pub/transmogrifier.ex @@ -86,11 +86,15 @@ def fix_object(object) do end def fix_addressing_list(map, field) do - if is_binary(map[field]) do - map - |> Map.put(field, [map[field]]) - else - map + cond do + is_binary(map[field]) -> + Map.put(map, field, [map[field]]) + + is_nil(map[field]) -> + Map.put(map, field, []) + + true -> + map end end @@ -128,13 +132,42 @@ def fix_explicit_addressing(object) do |> fix_explicit_addressing(explicit_mentions) end + # if as:Public is addressed, then make sure the followers collection is also addressed + # so that the activities will be delivered to local users. + def fix_implicit_addressing(%{"to" => to, "cc" => cc} = object, followers_collection) do + recipients = to ++ cc + + if followers_collection not in recipients do + cond do + "https://www.w3.org/ns/activitystreams#Public" in cc -> + to = to ++ [followers_collection] + Map.put(object, "to", to) + + "https://www.w3.org/ns/activitystreams#Public" in to -> + cc = cc ++ [followers_collection] + Map.put(object, "cc", cc) + + true -> + object + end + else + object + end + end + + def fix_implicit_addressing(object, _), do: object + def fix_addressing(object) do + %User{} = user = User.get_or_fetch_by_ap_id(object["actor"]) + followers_collection = User.ap_followers(user) + object |> fix_addressing_list("to") |> fix_addressing_list("cc") |> fix_addressing_list("bto") |> fix_addressing_list("bcc") |> fix_explicit_addressing + |> fix_implicit_addressing(followers_collection) end def fix_actor(%{"attributedTo" => actor} = object) do @@ -922,7 +955,8 @@ defp strip_internal_tags(%{"tag" => tags} = object) do defp strip_internal_tags(object), do: object defp user_upgrade_task(user) do - old_follower_address = User.ap_followers(user) + # we pass a fake user so that the followers collection is stripped away + old_follower_address = User.ap_followers(%User{nickname: user.nickname}) q = from( diff --git a/lib/pleroma/web/activity_pub/utils.ex b/lib/pleroma/web/activity_pub/utils.ex index af317245f..2e9ffe41c 100644 --- a/lib/pleroma/web/activity_pub/utils.ex +++ b/lib/pleroma/web/activity_pub/utils.ex @@ -209,12 +209,12 @@ def lazy_put_object_defaults(map, activity \\ %{}) do """ def insert_full_object(%{"object" => %{"type" => type} = object_data}) when is_map(object_data) and type in @supported_object_types do - with {:ok, _} <- Object.create(object_data) do - :ok + with {:ok, object} <- Object.create(object_data) do + {:ok, object} end end - def insert_full_object(_), do: :ok + def insert_full_object(_), do: {:ok, nil} def update_object_in_activities(%{data: %{"id" => id}} = object) do # TODO diff --git a/lib/pleroma/web/activity_pub/views/object_view.ex b/lib/pleroma/web/activity_pub/views/object_view.ex index 84fa94e32..6028b773c 100644 --- a/lib/pleroma/web/activity_pub/views/object_view.ex +++ b/lib/pleroma/web/activity_pub/views/object_view.ex @@ -17,7 +17,7 @@ def render("object.json", %{object: %Object{} = object}) do def render("object.json", %{object: %Activity{data: %{"type" => "Create"}} = activity}) do base = Pleroma.Web.ActivityPub.Utils.make_json_ld_header() - object = Object.normalize(activity.data["object"]) + object = Object.normalize(activity) additional = Transmogrifier.prepare_object(activity.data) @@ -28,7 +28,7 @@ def render("object.json", %{object: %Activity{data: %{"type" => "Create"}} = act def render("object.json", %{object: %Activity{} = activity}) do base = Pleroma.Web.ActivityPub.Utils.make_json_ld_header() - object = Object.normalize(activity.data["object"]) + object = Object.normalize(activity) additional = Transmogrifier.prepare_object(activity.data) diff --git a/lib/pleroma/web/activity_pub/views/user_view.ex b/lib/pleroma/web/activity_pub/views/user_view.ex index 3d00dcbf2..5926a3294 100644 --- a/lib/pleroma/web/activity_pub/views/user_view.ex +++ b/lib/pleroma/web/activity_pub/views/user_view.ex @@ -87,16 +87,10 @@ def render("user.json", %{user: user}) do "publicKeyPem" => public_key }, "endpoints" => endpoints, - "icon" => %{ - "type" => "Image", - "url" => User.avatar_url(user) - }, - "image" => %{ - "type" => "Image", - "url" => User.banner_url(user) - }, "tag" => user.info.source_data["tag"] || [] } + |> Map.merge(maybe_make_image(&User.avatar_url/2, "icon", user)) + |> Map.merge(maybe_make_image(&User.banner_url/2, "image", user)) |> Map.merge(Utils.make_json_ld_header()) end @@ -294,4 +288,17 @@ def collection(collection, iri, page, show_items \\ true, total \\ nil) do map end end + + defp maybe_make_image(func, key, user) do + if image = func.(user, no_default: true) do + %{ + key => %{ + "type" => "Image", + "url" => image + } + } + else + %{} + end + end end diff --git a/lib/pleroma/web/admin_api/admin_api_controller.ex b/lib/pleroma/web/admin_api/admin_api_controller.ex index 6d9bf2895..b3a09e49e 100644 --- a/lib/pleroma/web/admin_api/admin_api_controller.ex +++ b/lib/pleroma/web/admin_api/admin_api_controller.ex @@ -3,17 +3,18 @@ # SPDX-License-Identifier: AGPL-3.0-only defmodule Pleroma.Web.AdminAPI.AdminAPIController do - @users_page_size 50 - use Pleroma.Web, :controller alias Pleroma.User alias Pleroma.Web.ActivityPub.Relay alias Pleroma.Web.AdminAPI.AccountView + alias Pleroma.Web.AdminAPI.Search import Pleroma.Web.ControllerHelper, only: [json_response: 3] require Logger + @users_page_size 50 + action_fallback(:errors) def user_delete(conn, %{"nickname" => nickname}) do @@ -44,6 +45,15 @@ def user_create( |> json(user.nickname) end + def user_show(conn, %{"nickname" => nickname}) do + with %User{} = user <- User.get_by_nickname(nickname) do + conn + |> json(AccountView.render("show.json", %{user: user})) + else + _ -> {:error, :not_found} + end + end + def user_toggle_activation(conn, %{"nickname" => nickname}) do user = User.get_by_nickname(nickname) @@ -63,17 +73,17 @@ def untag_users(conn, %{"nicknames" => nicknames, "tags" => tags}) do do: json_response(conn, :no_content, "") end - def list_users(%{assigns: %{user: admin}} = conn, params) do + def list_users(conn, params) do {page, page_size} = page_params(params) + filters = maybe_parse_filters(params["filters"]) - with {:ok, users, count} <- - User.search_for_admin(%{ - query: params["query"], - admin: admin, - local: params["local_only"] == "true", - page: page, - page_size: page_size - }), + search_params = %{ + query: params["query"], + page: page, + page_size: page_size + } + + with {:ok, users, count} <- Search.user(Map.merge(search_params, filters)), do: conn |> json( @@ -85,6 +95,19 @@ def list_users(%{assigns: %{user: admin}} = conn, params) do ) end + @filters ~w(local external active deactivated) + + defp maybe_parse_filters(filters) when is_nil(filters) or filters == "", do: %{} + + @spec maybe_parse_filters(String.t()) :: %{required(String.t()) => true} | %{} + defp maybe_parse_filters(filters) do + filters + |> String.split(",") + |> Enum.filter(&Enum.member?(@filters, &1)) + |> Enum.map(&String.to_atom(&1)) + |> Enum.into(%{}, &{&1, true}) + end + def right_add(conn, %{"permission_group" => permission_group, "nickname" => nickname}) when permission_group in ["moderator", "admin"] do user = User.get_by_nickname(nickname) @@ -217,6 +240,12 @@ def get_password_reset(conn, %{"nickname" => nickname}) do |> json(token.token) end + def errors(conn, {:error, :not_found}) do + conn + |> put_status(404) + |> json("Not found") + end + def errors(conn, {:param_cast, _}) do conn |> put_status(400) diff --git a/lib/pleroma/web/admin_api/search.ex b/lib/pleroma/web/admin_api/search.ex new file mode 100644 index 000000000..9a8e41c2a --- /dev/null +++ b/lib/pleroma/web/admin_api/search.ex @@ -0,0 +1,54 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2019 Pleroma Authors +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Web.AdminAPI.Search do + import Ecto.Query + + alias Pleroma.Repo + alias Pleroma.User + + @page_size 50 + + def user(%{query: term} = params) when is_nil(term) or term == "" do + query = maybe_filtered_query(params) + + paginated_query = + maybe_filtered_query(params) + |> paginate(params[:page] || 1, params[:page_size] || @page_size) + + count = query |> Repo.aggregate(:count, :id) + + results = Repo.all(paginated_query) + + {:ok, results, count} + end + + def user(%{query: term} = params) when is_binary(term) do + search_query = from(u in maybe_filtered_query(params), where: ilike(u.nickname, ^"%#{term}%")) + + count = search_query |> Repo.aggregate(:count, :id) + + results = + search_query + |> paginate(params[:page] || 1, params[:page_size] || @page_size) + |> Repo.all() + + {:ok, results, count} + end + + defp maybe_filtered_query(params) do + from(u in User, order_by: u.nickname) + |> User.maybe_local_user_query(params[:local]) + |> User.maybe_external_user_query(params[:external]) + |> User.maybe_active_user_query(params[:active]) + |> User.maybe_deactivated_user_query(params[:deactivated]) + end + + defp paginate(query, page, page_size) do + from(u in query, + limit: ^page_size, + offset: ^((page - 1) * page_size) + ) + end +end diff --git a/lib/pleroma/web/common_api/common_api.ex b/lib/pleroma/web/common_api/common_api.ex index b5f79c3bf..25b990677 100644 --- a/lib/pleroma/web/common_api/common_api.ex +++ b/lib/pleroma/web/common_api/common_api.ex @@ -6,7 +6,6 @@ defmodule Pleroma.Web.CommonAPI do alias Pleroma.Activity alias Pleroma.Formatter alias Pleroma.Object - alias Pleroma.Repo alias Pleroma.ThreadMute alias Pleroma.User alias Pleroma.Web.ActivityPub.ActivityPub @@ -64,8 +63,9 @@ def reject_follow_request(follower, followed) do end def delete(activity_id, user) do - with %Activity{data: %{"object" => %{"id" => object_id}}} <- Repo.get(Activity, activity_id), - %Object{} = object <- Object.normalize(object_id), + with %Activity{data: %{"object" => _}} = activity <- + Activity.get_by_id_with_object(activity_id), + %Object{} = object <- Object.normalize(activity), true <- User.superuser?(user) || user.ap_id == object.data["actor"], {:ok, _} <- unpin(activity_id, user), {:ok, delete} <- ActivityPub.delete(object) do @@ -75,7 +75,7 @@ def delete(activity_id, user) do def repeat(id_or_ap_id, user) do with %Activity{} = activity <- get_by_id_or_ap_id(id_or_ap_id), - object <- Object.normalize(activity.data["object"]["id"]), + object <- Object.normalize(activity), nil <- Utils.get_existing_announce(user.ap_id, object) do ActivityPub.announce(user, object) else @@ -86,7 +86,7 @@ def repeat(id_or_ap_id, user) do def unrepeat(id_or_ap_id, user) do with %Activity{} = activity <- get_by_id_or_ap_id(id_or_ap_id), - object <- Object.normalize(activity.data["object"]["id"]) do + object <- Object.normalize(activity) do ActivityPub.unannounce(user, object) else _ -> @@ -96,7 +96,7 @@ def unrepeat(id_or_ap_id, user) do def favorite(id_or_ap_id, user) do with %Activity{} = activity <- get_by_id_or_ap_id(id_or_ap_id), - object <- Object.normalize(activity.data["object"]["id"]), + object <- Object.normalize(activity), nil <- Utils.get_existing_like(user.ap_id, object) do ActivityPub.like(user, object) else @@ -107,7 +107,7 @@ def favorite(id_or_ap_id, user) do def unfavorite(id_or_ap_id, user) do with %Activity{} = activity <- get_by_id_or_ap_id(id_or_ap_id), - object <- Object.normalize(activity.data["object"]["id"]) do + object <- Object.normalize(activity) do ActivityPub.unlike(user, object) else _ -> @@ -142,7 +142,8 @@ def post(user, %{"status" => status} = data) do make_content_html( status, attachments, - data + data, + visibility ), {to, cc} <- to_for_user_and_mentions(user, mentions, in_reply_to, visibility), context <- make_context(in_reply_to), diff --git a/lib/pleroma/web/common_api/utils.ex b/lib/pleroma/web/common_api/utils.ex index b7513ef28..f596f703b 100644 --- a/lib/pleroma/web/common_api/utils.ex +++ b/lib/pleroma/web/common_api/utils.ex @@ -17,13 +17,14 @@ defmodule Pleroma.Web.CommonAPI.Utils do # This is a hack for twidere. def get_by_id_or_ap_id(id) do - activity = Repo.get(Activity, id) || Activity.get_create_by_object_ap_id(id) + activity = + Activity.get_by_id_with_object(id) || Activity.get_create_by_object_ap_id_with_object(id) activity && if activity.data["type"] == "Create" do activity else - Activity.get_create_by_object_ap_id(activity.data["object"]) + Activity.get_create_by_object_ap_id_with_object(activity.data["object"]) end end @@ -101,7 +102,8 @@ def to_for_user_and_mentions(_user, mentions, inReplyTo, "direct") do def make_content_html( status, attachments, - data + data, + visibility ) do no_attachment_links = data @@ -110,8 +112,15 @@ def make_content_html( content_type = get_content_type(data["content_type"]) + options = + if visibility == "direct" && Config.get([:instance, :safe_dm_mentions]) do + [safe_mention: true] + else + [] + end + status - |> format_input(content_type) + |> format_input(content_type, options) |> maybe_add_attachments(attachments, no_attachment_links) |> maybe_add_nsfw_tag(data) end @@ -294,10 +303,10 @@ def maybe_notify_to_recipients( def maybe_notify_mentioned_recipients( recipients, - %Activity{data: %{"to" => _to, "type" => type} = data} = _activity + %Activity{data: %{"to" => _to, "type" => type} = data} = activity ) when type == "Create" do - object = Object.normalize(data["object"]) + object = Object.normalize(activity) object_data = cond do @@ -344,4 +353,33 @@ def get_report_statuses(%User{ap_id: actor}, %{"status_ids" => status_ids}) do end def get_report_statuses(_, _), do: {:ok, nil} + + # DEPRECATED mostly, context objects are now created at insertion time. + def context_to_conversation_id(context) do + with %Object{id: id} <- Object.get_cached_by_ap_id(context) do + id + else + _e -> + changeset = Object.context_mapping(context) + + case Repo.insert(changeset) do + {:ok, %{id: id}} -> + id + + # This should be solved by an upsert, but it seems ecto + # has problems accessing the constraint inside the jsonb. + {:error, _} -> + Object.get_cached_by_ap_id(context).id + end + end + end + + def conversation_id_to_context(id) do + with %Object{data: %{"id" => context}} <- Repo.get(Object, id) do + context + else + _e -> + {:error, "No such conversation"} + end + end end diff --git a/lib/pleroma/web/federator/federator.ex b/lib/pleroma/web/federator/federator.ex index 5e690ddb8..c47328e13 100644 --- a/lib/pleroma/web/federator/federator.ex +++ b/lib/pleroma/web/federator/federator.ex @@ -4,7 +4,6 @@ defmodule Pleroma.Web.Federator do alias Pleroma.Activity - alias Pleroma.Jobs alias Pleroma.User alias Pleroma.Web.ActivityPub.ActivityPub alias Pleroma.Web.ActivityPub.Relay @@ -31,39 +30,39 @@ def init do # Client API def incoming_doc(doc) do - Jobs.enqueue(:federator_incoming, __MODULE__, [:incoming_doc, doc]) + PleromaJobQueue.enqueue(:federator_incoming, __MODULE__, [:incoming_doc, doc]) end def incoming_ap_doc(params) do - Jobs.enqueue(:federator_incoming, __MODULE__, [:incoming_ap_doc, params]) + PleromaJobQueue.enqueue(:federator_incoming, __MODULE__, [:incoming_ap_doc, params]) end def publish(activity, priority \\ 1) do - Jobs.enqueue(:federator_outgoing, __MODULE__, [:publish, activity], priority) + PleromaJobQueue.enqueue(:federator_outgoing, __MODULE__, [:publish, activity], priority) end def publish_single_ap(params) do - Jobs.enqueue(:federator_outgoing, __MODULE__, [:publish_single_ap, params]) + PleromaJobQueue.enqueue(:federator_outgoing, __MODULE__, [:publish_single_ap, params]) end def publish_single_websub(websub) do - Jobs.enqueue(:federator_outgoing, __MODULE__, [:publish_single_websub, websub]) + PleromaJobQueue.enqueue(:federator_outgoing, __MODULE__, [:publish_single_websub, websub]) end def verify_websub(websub) do - Jobs.enqueue(:federator_outgoing, __MODULE__, [:verify_websub, websub]) + PleromaJobQueue.enqueue(:federator_outgoing, __MODULE__, [:verify_websub, websub]) end def request_subscription(sub) do - Jobs.enqueue(:federator_outgoing, __MODULE__, [:request_subscription, sub]) + PleromaJobQueue.enqueue(:federator_outgoing, __MODULE__, [:request_subscription, sub]) end def refresh_subscriptions do - Jobs.enqueue(:federator_outgoing, __MODULE__, [:refresh_subscriptions]) + PleromaJobQueue.enqueue(:federator_outgoing, __MODULE__, [:refresh_subscriptions]) end def publish_single_salmon(params) do - Jobs.enqueue(:federator_outgoing, __MODULE__, [:publish_single_salmon, params]) + PleromaJobQueue.enqueue(:federator_outgoing, __MODULE__, [:publish_single_salmon, params]) end # Job Worker Callbacks diff --git a/lib/pleroma/web/mastodon_api/mastodon_api.ex b/lib/pleroma/web/mastodon_api/mastodon_api.ex index 54cb6c97a..08ea5f967 100644 --- a/lib/pleroma/web/mastodon_api/mastodon_api.ex +++ b/lib/pleroma/web/mastodon_api/mastodon_api.ex @@ -2,61 +2,49 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPI do import Ecto.Query import Ecto.Changeset - alias Pleroma.Repo + alias Pleroma.Activity + alias Pleroma.Notification + alias Pleroma.Pagination alias Pleroma.User - @default_limit 20 - def get_followers(user, params \\ %{}) do user |> User.get_followers_query() - |> paginate(params) - |> Repo.all() + |> Pagination.fetch_paginated(params) end def get_friends(user, params \\ %{}) do user |> User.get_friends_query() - |> paginate(params) - |> Repo.all() + |> Pagination.fetch_paginated(params) end - def paginate(query, params \\ %{}) do + def get_notifications(user, params \\ %{}) do options = cast_params(params) - query - |> restrict(:max_id, options) - |> restrict(:since_id, options) - |> restrict(:limit, options) - |> order_by([u], fragment("? desc nulls last", u.id)) + user + |> Notification.for_user_query() + |> restrict(:exclude_types, options) + |> Pagination.fetch_paginated(params) end - def cast_params(params) do + defp cast_params(params) do param_types = %{ - max_id: :string, - since_id: :string, - limit: :integer + exclude_types: {:array, :string} } changeset = cast({%{}, param_types}, params, Map.keys(param_types)) changeset.changes end - defp restrict(query, :max_id, %{max_id: max_id}) do - query - |> where([q], q.id < ^max_id) - end - - defp restrict(query, :since_id, %{since_id: since_id}) do - query - |> where([q], q.id > ^since_id) - end - - defp restrict(query, :limit, options) do - limit = Map.get(options, :limit, @default_limit) + defp restrict(query, :exclude_types, %{exclude_types: mastodon_types = [_ | _]}) do + ap_types = + mastodon_types + |> Enum.map(&Activity.from_mastodon_notification_type/1) + |> Enum.filter(& &1) query - |> limit(^limit) + |> where([q, a], not fragment("? @> ARRAY[?->>'type']::varchar[]", ^ap_types, a.data)) end defp restrict(query, _, _), do: query diff --git a/lib/pleroma/web/mastodon_api/mastodon_api_controller.ex b/lib/pleroma/web/mastodon_api/mastodon_api_controller.ex index 952aa2453..eee4e7678 100644 --- a/lib/pleroma/web/mastodon_api/mastodon_api_controller.ex +++ b/lib/pleroma/web/mastodon_api/mastodon_api_controller.ex @@ -18,6 +18,7 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIController do alias Pleroma.Web.ActivityPub.Visibility alias Pleroma.Web.CommonAPI alias Pleroma.Web.MastodonAPI.AccountView + alias Pleroma.Web.MastodonAPI.AppView alias Pleroma.Web.MastodonAPI.FilterView alias Pleroma.Web.MastodonAPI.ListView alias Pleroma.Web.MastodonAPI.MastodonAPI @@ -51,16 +52,9 @@ def create_app(conn, params) do with cs <- App.register_changeset(%App{}, app_attrs), false <- cs.changes[:client_name] == @local_mastodon_name, {:ok, app} <- Repo.insert(cs) do - res = %{ - id: app.id |> to_string, - name: app.client_name, - client_id: app.client_id, - client_secret: app.client_secret, - redirect_uri: app.redirect_uris, - website: app.website - } - - json(conn, res) + conn + |> put_view(AppView) + |> render("show.json", %{app: app}) end end @@ -132,6 +126,14 @@ def verify_credentials(%{assigns: %{user: user}} = conn, _) do json(conn, account) end + def verify_app_credentials(%{assigns: %{user: _user, token: token}} = conn, _) do + with %Token{app: %App{} = app} <- Repo.preload(token, :app) do + conn + |> put_view(AppView) + |> render("short.json", %{app: app}) + end + end + def user(%{assigns: %{user: for_user}} = conn, %{"id" => nickname_or_id}) do with %User{} = user <- User.get_cached_by_nickname_or_id(nickname_or_id), true <- User.auth_active?(user) || user.id == for_user.id || User.superuser?(for_user) do @@ -161,6 +163,9 @@ def masto_instance(conn, _params) do }, stats: Stats.get_stats(), thumbnail: Web.base_url() <> "/instance/thumbnail.jpeg", + languages: ["en"], + registrations: Pleroma.Config.get([:instance, :registrations_open]), + # Extra (not present in Mastodon): max_toot_chars: Keyword.get(instance, :limit) } @@ -502,7 +507,7 @@ def unmute_conversation(%{assigns: %{user: user}} = conn, %{"id" => id}) do end def notifications(%{assigns: %{user: user}} = conn, params) do - notifications = Notification.for_user(user, params) + notifications = MastodonAPI.get_notifications(user, params) conn |> add_link_headers(:notifications, notifications) @@ -944,12 +949,14 @@ def account_search(%{assigns: %{user: user}} = conn, %{"q" => query} = params) d end def favourites(%{assigns: %{user: user}} = conn, params) do - activities = + params = params |> Map.put("type", "Create") |> Map.put("favorited_by", user.ap_id) |> Map.put("blocking_user", user) - |> ActivityPub.fetch_public_activities() + + activities = + ActivityPub.fetch_activities([], params) |> Enum.reverse() conn diff --git a/lib/pleroma/web/mastodon_api/views/app_view.ex b/lib/pleroma/web/mastodon_api/views/app_view.ex new file mode 100644 index 000000000..f52b693a6 --- /dev/null +++ b/lib/pleroma/web/mastodon_api/views/app_view.ex @@ -0,0 +1,41 @@ +# Pleroma: A lightweight social networking server +# Copyright © 2017-2019 Pleroma Authors +# SPDX-License-Identifier: AGPL-3.0-only + +defmodule Pleroma.Web.MastodonAPI.AppView do + use Pleroma.Web, :view + + alias Pleroma.Web.OAuth.App + + @vapid_key :web_push_encryption + |> Application.get_env(:vapid_details, []) + |> Keyword.get(:public_key) + + def render("show.json", %{app: %App{} = app}) do + %{ + id: app.id |> to_string, + name: app.client_name, + client_id: app.client_id, + client_secret: app.client_secret, + redirect_uri: app.redirect_uris, + website: app.website + } + |> with_vapid_key() + end + + def render("short.json", %{app: %App{website: webiste, client_name: name}}) do + %{ + name: name, + website: webiste + } + |> with_vapid_key() + end + + defp with_vapid_key(data) do + if @vapid_key do + Map.put(data, "vapid_key", @vapid_key) + else + data + end + end +end diff --git a/lib/pleroma/web/mastodon_api/views/status_view.ex b/lib/pleroma/web/mastodon_api/views/status_view.ex index 209119dd5..200bb453d 100644 --- a/lib/pleroma/web/mastodon_api/views/status_view.ex +++ b/lib/pleroma/web/mastodon_api/views/status_view.ex @@ -46,6 +46,14 @@ defp get_user(ap_id) do end end + defp get_context_id(%{data: %{"context_id" => context_id}}) when not is_nil(context_id), + do: context_id + + defp get_context_id(%{data: %{"context" => context}}) when is_binary(context), + do: Utils.context_to_conversation_id(context) + + defp get_context_id(_), do: nil + def render("index.json", opts) do replied_to_activities = get_replied_to_activities(opts.activities) @@ -166,7 +174,7 @@ def render("status.json", %{activity: %{data: %{"object" => object}} = activity} content: content, created_at: created_at, reblogs_count: announcement_count, - replies_count: 0, + replies_count: object["repliesCount"] || 0, favourites_count: like_count, reblogged: present?(repeated), favourited: present?(favorited), @@ -186,7 +194,8 @@ def render("status.json", %{activity: %{data: %{"object" => object}} = activity} language: nil, emojis: build_emojis(activity.data["object"]["emoji"]), pleroma: %{ - local: activity.local + local: activity.local, + conversation_id: get_context_id(activity) } } end diff --git a/lib/pleroma/web/nodeinfo/nodeinfo_controller.ex b/lib/pleroma/web/nodeinfo/nodeinfo_controller.ex index 8c775ce24..216a962bd 100644 --- a/lib/pleroma/web/nodeinfo/nodeinfo_controller.ex +++ b/lib/pleroma/web/nodeinfo/nodeinfo_controller.ex @@ -124,6 +124,9 @@ def raw_nodeinfo do end, if Keyword.get(instance, :allow_relay) do "relay" + end, + if Keyword.get(instance, :safe_dm_mentions) do + "safe_dm_mentions" end ] |> Enum.filter(& &1) diff --git a/lib/pleroma/web/oauth/authorization.ex b/lib/pleroma/web/oauth/authorization.ex index a80543adf..3461f9983 100644 --- a/lib/pleroma/web/oauth/authorization.ex +++ b/lib/pleroma/web/oauth/authorization.ex @@ -16,7 +16,7 @@ defmodule Pleroma.Web.OAuth.Authorization do schema "oauth_authorizations" do field(:token, :string) field(:scopes, {:array, :string}, default: []) - field(:valid_until, :naive_datetime) + field(:valid_until, :naive_datetime_usec) field(:used, :boolean, default: false) belongs_to(:user, Pleroma.User, type: Pleroma.FlakeId) belongs_to(:app, App) diff --git a/lib/pleroma/web/oauth/oauth_controller.ex b/lib/pleroma/web/oauth/oauth_controller.ex index d151efe9e..ebb3dd253 100644 --- a/lib/pleroma/web/oauth/oauth_controller.ex +++ b/lib/pleroma/web/oauth/oauth_controller.ex @@ -83,14 +83,18 @@ def create_authorization(conn, %{ end else {scopes_issue, _} when scopes_issue in [:unsupported_scopes, :missing_scopes] -> + # Per https://github.com/tootsuite/mastodon/blob/ + # 51e154f5e87968d6bb115e053689767ab33e80cd/app/controllers/api/base_controller.rb#L39 conn - |> put_flash(:error, "Permissions not specified.") + |> put_flash(:error, "This action is outside the authorized scopes") |> put_status(:unauthorized) |> authorize(auth_params) {:auth_active, false} -> + # Per https://github.com/tootsuite/mastodon/blob/ + # 51e154f5e87968d6bb115e053689767ab33e80cd/app/controllers/api/base_controller.rb#L76 conn - |> put_flash(:error, "Account confirmation pending.") + |> put_flash(:error, "Your login is missing a confirmed e-mail address") |> put_status(:forbidden) |> authorize(auth_params) @@ -149,9 +153,11 @@ def token_exchange( json(conn, response) else {:auth_active, false} -> + # Per https://github.com/tootsuite/mastodon/blob/ + # 51e154f5e87968d6bb115e053689767ab33e80cd/app/controllers/api/base_controller.rb#L76 conn |> put_status(:forbidden) - |> json(%{error: "Account confirmation pending"}) + |> json(%{error: "Your login is missing a confirmed e-mail address"}) _error -> put_status(conn, 400) diff --git a/lib/pleroma/web/oauth/token.ex b/lib/pleroma/web/oauth/token.ex index 2b074b470..a8b06db36 100644 --- a/lib/pleroma/web/oauth/token.ex +++ b/lib/pleroma/web/oauth/token.ex @@ -17,7 +17,7 @@ defmodule Pleroma.Web.OAuth.Token do field(:token, :string) field(:refresh_token, :string) field(:scopes, {:array, :string}, default: []) - field(:valid_until, :naive_datetime) + field(:valid_until, :naive_datetime_usec) belongs_to(:user, Pleroma.User, type: Pleroma.FlakeId) belongs_to(:app, App) diff --git a/lib/pleroma/web/ostatus/handlers/note_handler.ex b/lib/pleroma/web/ostatus/handlers/note_handler.ex index 770a71a0a..db995ec77 100644 --- a/lib/pleroma/web/ostatus/handlers/note_handler.ex +++ b/lib/pleroma/web/ostatus/handlers/note_handler.ex @@ -106,7 +106,7 @@ def fetch_replied_to_activity(entry, in_reply_to) do # TODO: Clean this up a bit. def handle_note(entry, doc \\ nil) do with id <- XML.string_from_xpath("//id", entry), - activity when is_nil(activity) <- Activity.get_create_by_object_ap_id(id), + activity when is_nil(activity) <- Activity.get_create_by_object_ap_id_with_object(id), [author] <- :xmerl_xpath.string('//author[1]', doc), {:ok, actor} <- OStatus.find_make_or_update_user(author), content_html <- OStatus.get_content(entry), diff --git a/lib/pleroma/web/ostatus/ostatus.ex b/lib/pleroma/web/ostatus/ostatus.ex index 266f86bf4..9a34d7ad5 100644 --- a/lib/pleroma/web/ostatus/ostatus.ex +++ b/lib/pleroma/web/ostatus/ostatus.ex @@ -23,8 +23,8 @@ defmodule Pleroma.Web.OStatus do alias Pleroma.Web.WebFinger alias Pleroma.Web.Websub - def is_representable?(%Activity{data: data}) do - object = Object.normalize(data["object"]) + def is_representable?(%Activity{} = activity) do + object = Object.normalize(activity) cond do is_nil(object) -> @@ -119,7 +119,7 @@ def handle_incoming(xml_string) do def make_share(entry, doc, retweeted_activity) do with {:ok, actor} <- find_make_or_update_user(doc), - %Object{} = object <- Object.normalize(retweeted_activity.data["object"]), + %Object{} = object <- Object.normalize(retweeted_activity), id when not is_nil(id) <- string_from_xpath("/entry/id", entry), {:ok, activity, _object} = ActivityPub.announce(actor, object, id, false) do {:ok, activity} @@ -137,7 +137,7 @@ def handle_share(entry, doc) do def make_favorite(entry, doc, favorited_activity) do with {:ok, actor} <- find_make_or_update_user(doc), - %Object{} = object <- Object.normalize(favorited_activity.data["object"]), + %Object{} = object <- Object.normalize(favorited_activity), id when not is_nil(id) <- string_from_xpath("/entry/id", entry), {:ok, activity, _object} = ActivityPub.like(actor, object, id, false) do {:ok, activity} @@ -159,7 +159,7 @@ def get_or_try_fetching(entry) do Logger.debug("Trying to get entry from db") with id when not is_nil(id) <- string_from_xpath("//activity:object[1]/id", entry), - %Activity{} = activity <- Activity.get_create_by_object_ap_id(id) do + %Activity{} = activity <- Activity.get_create_by_object_ap_id_with_object(id) do {:ok, activity} else _ -> diff --git a/lib/pleroma/web/ostatus/ostatus_controller.ex b/lib/pleroma/web/ostatus/ostatus_controller.ex index 0579a5f3d..2fb6ce41b 100644 --- a/lib/pleroma/web/ostatus/ostatus_controller.ex +++ b/lib/pleroma/web/ostatus/ostatus_controller.ex @@ -102,7 +102,8 @@ def object(conn, %{"uuid" => uuid}) do ActivityPubController.call(conn, :object) else with id <- o_status_url(conn, :object, uuid), - {_, %Activity{} = activity} <- {:activity, Activity.get_create_by_object_ap_id(id)}, + {_, %Activity{} = activity} <- + {:activity, Activity.get_create_by_object_ap_id_with_object(id)}, {_, true} <- {:public?, Visibility.is_public?(activity)}, %User{} = user <- User.get_cached_by_ap_id(activity.data["actor"]) do case get_format(conn) do @@ -148,13 +149,13 @@ def activity(conn, %{"uuid" => uuid}) do end def notice(conn, %{"id" => id}) do - with {_, %Activity{} = activity} <- {:activity, Activity.get_by_id(id)}, + with {_, %Activity{} = activity} <- {:activity, Activity.get_by_id_with_object(id)}, {_, true} <- {:public?, Visibility.is_public?(activity)}, %User{} = user <- User.get_cached_by_ap_id(activity.data["actor"]) do case format = get_format(conn) do "html" -> if activity.data["type"] == "Create" do - %Object{} = object = Object.normalize(activity.data["object"]) + %Object{} = object = Object.normalize(activity) Fallback.RedirectController.redirector_with_meta(conn, %{ activity_id: activity.id, @@ -191,9 +192,9 @@ def notice(conn, %{"id" => id}) do # Returns an HTML embedded
    \n \n {children}\n \n
    \n {this.error && {this.$t('general.generic_error')}}\n {!this.error && this.loading && }\n {!this.error && !this.loading && !this.bottomedOut && {this.$t('general.more')}}\n
    \n
    \n )\n },\n props,\n data () {\n return {\n loading: false,\n bottomedOut: false,\n error: false\n }\n },\n computed: {\n entries () {\n return select(this.$props, this.$store) || []\n }\n },\n created () {\n window.addEventListener('scroll', this.scrollLoad)\n if (this.entries.length === 0) {\n this.fetchEntries()\n }\n },\n destroyed () {\n window.removeEventListener('scroll', this.scrollLoad)\n destroy && destroy(this.$props, this.$store)\n },\n methods: {\n fetchEntries () {\n if (!this.loading) {\n this.loading = true\n this.error = false\n fetch(this.$props, this.$store)\n .then((newEntries) => {\n this.loading = false\n this.bottomedOut = isEmpty(newEntries)\n })\n .catch(() => {\n this.loading = false\n this.error = true\n })\n }\n },\n scrollLoad (e) {\n const bodyBRect = document.body.getBoundingClientRect()\n const height = Math.max(bodyBRect.height, -(bodyBRect.y))\n if (this.loading === false &&\n this.bottomedOut === false &&\n this.$el.offsetHeight > 0 &&\n (window.innerHeight + window.pageYOffset) >= (height - 750)\n ) {\n this.fetchEntries()\n }\n }\n }\n })\n}\n\nexport default withLoadMore\n\n\n\n// WEBPACK FOOTER //\n// ./src/hocs/with_load_more/with_load_more.js","import Vue from 'vue'\nimport isEmpty from 'lodash/isEmpty'\nimport { getComponentProps } from '../../services/component_utils/component_utils'\nimport './with_subscription.scss'\n\nconst withSubscription = ({\n fetch, // function to fetch entries and return a promise\n select, // function to select data from store\n childPropName = 'content', // name of the prop to be passed into the wrapped component\n additionalPropNames = [] // additional prop name list of the wrapper component\n}) => (WrappedComponent) => {\n const originalProps = Object.keys(getComponentProps(WrappedComponent))\n const props = originalProps.filter(v => v !== childPropName).concat(additionalPropNames)\n\n return Vue.component('withSubscription', {\n props: [\n ...props,\n 'refresh' // boolean saying to force-fetch data whenever created\n ],\n render (createElement) {\n if (!this.error && !this.loading) {\n const props = {\n props: {\n ...this.$props,\n [childPropName]: this.fetchedData\n },\n on: this.$listeners,\n scopedSlots: this.$scopedSlots\n }\n const children = Object.entries(this.$slots).map(([key, value]) => createElement('template', { slot: key }, value))\n return (\n
    \n \n {children}\n \n
    \n )\n } else {\n return (\n
    \n {this.error\n ? {this.$t('general.generic_error')}\n : \n }\n
    \n )\n }\n },\n data () {\n return {\n loading: false,\n error: false\n }\n },\n computed: {\n fetchedData () {\n return select(this.$props, this.$store)\n }\n },\n created () {\n if (this.refresh || isEmpty(this.fetchedData)) {\n this.fetchData()\n }\n },\n methods: {\n fetchData () {\n if (!this.loading) {\n this.loading = true\n this.error = false\n fetch(this.$props, this.$store)\n .then(() => {\n this.loading = false\n })\n .catch(() => {\n this.error = true\n this.loading = false\n })\n }\n }\n }\n })\n}\n\nexport default withSubscription\n\n\n\n// WEBPACK FOOTER //\n// ./src/hocs/with_subscription/with_subscription.js","import merge from 'lodash.merge'\nimport objectPath from 'object-path'\nimport localforage from 'localforage'\nimport { each } from 'lodash'\n\nlet loaded = false\n\nconst defaultReducer = (state, paths) => (\n paths.length === 0 ? state : paths.reduce((substate, path) => {\n objectPath.set(substate, path, objectPath.get(state, path))\n return substate\n }, {})\n)\n\nconst saveImmedeatelyActions = [\n 'markNotificationsAsSeen',\n 'clearCurrentUser',\n 'setCurrentUser',\n 'setHighlight',\n 'setOption',\n 'setClientData',\n 'setToken'\n]\n\nconst defaultStorage = (() => {\n return localforage\n})()\n\nexport default function createPersistedState ({\n key = 'vuex-lz',\n paths = [],\n getState = (key, storage) => {\n let value = storage.getItem(key)\n return value\n },\n setState = (key, state, storage) => {\n if (!loaded) {\n console.log('waiting for old state to be loaded...')\n return Promise.resolve()\n } else {\n return storage.setItem(key, state)\n }\n },\n reducer = defaultReducer,\n storage = defaultStorage,\n subscriber = store => handler => store.subscribe(handler)\n} = {}) {\n return getState(key, storage).then((savedState) => {\n return store => {\n try {\n if (savedState !== null && typeof savedState === 'object') {\n // build user cache\n const usersState = savedState.users || {}\n usersState.usersObject = {}\n const users = usersState.users || []\n each(users, (user) => { usersState.usersObject[user.id] = user })\n savedState.users = usersState\n\n store.replaceState(\n merge({}, store.state, savedState)\n )\n }\n if (store.state.config.customTheme) {\n // This is a hack to deal with async loading of config.json and themes\n // See: style_setter.js, setPreset()\n window.themeLoaded = true\n store.dispatch('setOption', {\n name: 'customTheme',\n value: store.state.config.customTheme\n })\n }\n if (store.state.oauth.token) {\n store.dispatch('loginUser', store.state.oauth.token)\n }\n loaded = true\n } catch (e) {\n console.log(\"Couldn't load state\")\n console.error(e)\n loaded = true\n }\n subscriber(store)((mutation, state) => {\n try {\n if (saveImmedeatelyActions.includes(mutation.type)) {\n setState(key, reducer(state, paths), storage)\n .then(success => {\n if (typeof success !== 'undefined') {\n if (mutation.type === 'setOption' || mutation.type === 'setCurrentUser') {\n store.dispatch('settingsSaved', { success })\n }\n }\n }, error => {\n if (mutation.type === 'setOption' || mutation.type === 'setCurrentUser') {\n store.dispatch('settingsSaved', { error })\n }\n })\n }\n } catch (e) {\n console.log(\"Couldn't persist state:\")\n console.log(e)\n }\n })\n }\n })\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/lib/persisted_state.js","export default (store) => {\n store.subscribe((mutation, state) => {\n const vapidPublicKey = state.instance.vapidPublicKey\n const webPushNotification = state.config.webPushNotifications\n const permission = state.interface.notificationPermission === 'granted'\n const user = state.users.currentUser\n\n const isUserMutation = mutation.type === 'setCurrentUser'\n const isVapidMutation = mutation.type === 'setInstanceOption' && mutation.payload.name === 'vapidPublicKey'\n const isPermMutation = mutation.type === 'setNotificationPermission' && mutation.payload === 'granted'\n const isUserConfigMutation = mutation.type === 'setOption' && mutation.payload.name === 'webPushNotifications'\n const isVisibilityMutation = mutation.type === 'setOption' && mutation.payload.name === 'notificationVisibility'\n\n if (isUserMutation || isVapidMutation || isPermMutation || isUserConfigMutation || isVisibilityMutation) {\n if (user && vapidPublicKey && permission && webPushNotification) {\n return store.dispatch('registerPushNotifications')\n } else if (isUserConfigMutation && !webPushNotification) {\n return store.dispatch('unregisterPushNotifications')\n }\n }\n })\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/lib/push_notifications_plugin.js","import backendInteractorService from '../services/backend_interactor_service/backend_interactor_service.js'\nimport { Socket } from 'phoenix'\n\nconst api = {\n state: {\n backendInteractor: backendInteractorService(),\n fetchers: {},\n socket: null,\n chatDisabled: false,\n followRequests: []\n },\n mutations: {\n setBackendInteractor (state, backendInteractor) {\n state.backendInteractor = backendInteractor\n },\n addFetcher (state, {timeline, fetcher}) {\n state.fetchers[timeline] = fetcher\n },\n removeFetcher (state, {timeline}) {\n delete state.fetchers[timeline]\n },\n setWsToken (state, token) {\n state.wsToken = token\n },\n setSocket (state, socket) {\n state.socket = socket\n },\n setChatDisabled (state, value) {\n state.chatDisabled = value\n },\n setFollowRequests (state, value) {\n state.followRequests = value\n }\n },\n actions: {\n startFetching (store, {timeline = 'friends', tag = false, userId = false}) {\n // Don't start fetching if we already are.\n if (store.state.fetchers[timeline]) return\n\n const fetcher = store.state.backendInteractor.startFetching({ timeline, store, userId, tag })\n store.commit('addFetcher', { timeline, fetcher })\n },\n stopFetching (store, timeline) {\n const fetcher = store.state.fetchers[timeline]\n window.clearInterval(fetcher)\n store.commit('removeFetcher', {timeline})\n },\n setWsToken (store, token) {\n store.commit('setWsToken', token)\n },\n initializeSocket (store) {\n // Set up websocket connection\n if (!store.state.chatDisabled) {\n const token = store.state.wsToken\n const socket = new Socket('/socket', {params: {token}})\n socket.connect()\n store.dispatch('initializeChat', socket)\n }\n },\n disableChat (store) {\n store.commit('setChatDisabled', true)\n },\n removeFollowRequest (store, request) {\n let requests = store.state.followRequests.filter((it) => it !== request)\n store.commit('setFollowRequests', requests)\n }\n }\n}\n\nexport default api\n\n\n\n// WEBPACK FOOTER //\n// ./src/modules/api.js","const chat = {\n state: {\n messages: [],\n channel: {state: ''}\n },\n mutations: {\n setChannel (state, channel) {\n state.channel = channel\n },\n addMessage (state, message) {\n state.messages.push(message)\n state.messages = state.messages.slice(-19, 20)\n },\n setMessages (state, messages) {\n state.messages = messages.slice(-19, 20)\n }\n },\n actions: {\n initializeChat (store, socket) {\n const channel = socket.channel('chat:public')\n channel.on('new_msg', (msg) => {\n store.commit('addMessage', msg)\n })\n channel.on('messages', ({messages}) => {\n store.commit('setMessages', messages)\n })\n channel.join()\n store.commit('setChannel', channel)\n }\n }\n}\n\nexport default chat\n\n\n\n// WEBPACK FOOTER //\n// ./src/modules/chat.js","import { set, delete as del } from 'vue'\nimport { setPreset, applyTheme } from '../services/style_setter/style_setter.js'\n\nconst browserLocale = (window.navigator.language || 'en').split('-')[0]\n\nconst defaultState = {\n colors: {},\n collapseMessageWithSubject: undefined, // instance default\n hideAttachments: false,\n hideAttachmentsInConv: false,\n maxThumbnails: 16,\n hideNsfw: true,\n preloadImage: true,\n loopVideo: true,\n loopVideoSilentOnly: true,\n autoLoad: true,\n streaming: false,\n hoverPreview: true,\n pauseOnUnfocused: true,\n stopGifs: false,\n replyVisibility: 'all',\n notificationVisibility: {\n follows: true,\n mentions: true,\n likes: true,\n repeats: true\n },\n webPushNotifications: false,\n muteWords: [],\n highlight: {},\n interfaceLanguage: browserLocale,\n scopeCopy: undefined, // instance default\n subjectLineBehavior: undefined, // instance default\n alwaysShowSubjectInput: undefined, // instance default\n postContentType: undefined // instance default\n}\n\nconst config = {\n state: defaultState,\n mutations: {\n setOption (state, { name, value }) {\n set(state, name, value)\n },\n setHighlight (state, { user, color, type }) {\n const data = this.state.config.highlight[user]\n if (color || type) {\n set(state.highlight, user, { color: color || data.color, type: type || data.type })\n } else {\n del(state.highlight, user)\n }\n }\n },\n actions: {\n setHighlight ({ commit, dispatch }, { user, color, type }) {\n commit('setHighlight', {user, color, type})\n },\n setOption ({ commit, dispatch }, { name, value }) {\n commit('setOption', {name, value})\n switch (name) {\n case 'theme':\n setPreset(value, commit)\n break\n case 'customTheme':\n applyTheme(value, commit)\n }\n }\n }\n}\n\nexport default config\n\n\n\n// WEBPACK FOOTER //\n// ./src/modules/config.js","import { capitalize } from 'lodash'\n\nexport function humanizeErrors (errors) {\n return Object.entries(errors).reduce((errs, [k, val]) => {\n let message = val.reduce((acc, message) => {\n let key = capitalize(k.replace(/_/g, ' '))\n return acc + [key, message].join(' ') + '. '\n }, '')\n return [...errs, message]\n }, [])\n}\n\n\n\n\n// WEBPACK FOOTER //\n// ./src/modules/errors.js","import { set } from 'vue'\nimport { setPreset } from '../services/style_setter/style_setter.js'\n\nconst defaultState = {\n // Stuff from static/config.json and apiConfig\n name: 'Pleroma FE',\n registrationOpen: true,\n textlimit: 5000,\n server: 'http://localhost:4040/',\n theme: 'pleroma-dark',\n background: '/static/aurora_borealis.jpg',\n logo: '/static/logo.png',\n logoMask: true,\n logoMargin: '.2em',\n redirectRootNoLogin: '/main/all',\n redirectRootLogin: '/main/friends',\n showInstanceSpecificPanel: false,\n scopeOptionsEnabled: true,\n formattingOptionsEnabled: false,\n alwaysShowSubjectInput: true,\n collapseMessageWithSubject: false,\n hidePostStats: false,\n hideUserStats: false,\n hideFilteredStatuses: false,\n disableChat: false,\n scopeCopy: true,\n subjectLineBehavior: 'email',\n postContentType: 'text/plain',\n loginMethod: 'password',\n nsfwCensorImage: undefined,\n vapidPublicKey: undefined,\n noAttachmentLinks: false,\n showFeaturesPanel: true,\n\n // Nasty stuff\n pleromaBackend: true,\n emoji: [],\n customEmoji: [],\n restrictedNicknames: [],\n\n // Feature-set, apparently, not everything here is reported...\n mediaProxyAvailable: false,\n chatAvailable: false,\n gopherAvailable: false,\n suggestionsEnabled: false,\n suggestionsWeb: '',\n\n // Html stuff\n instanceSpecificPanelContent: '',\n tos: ''\n}\n\nconst instance = {\n state: defaultState,\n mutations: {\n setInstanceOption (state, { name, value }) {\n if (typeof value !== 'undefined') {\n set(state, name, value)\n }\n }\n },\n actions: {\n setInstanceOption ({ commit, dispatch }, { name, value }) {\n commit('setInstanceOption', {name, value})\n switch (name) {\n case 'name':\n dispatch('setPageTitle')\n break\n }\n },\n setTheme ({ commit }, themeName) {\n commit('setInstanceOption', { name: 'theme', value: themeName })\n return setPreset(themeName, commit)\n }\n }\n}\n\nexport default instance\n\n\n\n// WEBPACK FOOTER //\n// ./src/modules/instance.js","import { set, delete as del } from 'vue'\n\nconst defaultState = {\n settings: {\n currentSaveStateNotice: null,\n noticeClearTimeout: null,\n notificationPermission: null\n },\n browserSupport: {\n cssFilter: window.CSS && window.CSS.supports && (\n window.CSS.supports('filter', 'drop-shadow(0 0)') ||\n window.CSS.supports('-webkit-filter', 'drop-shadow(0 0)')\n )\n }\n}\n\nconst interfaceMod = {\n state: defaultState,\n mutations: {\n settingsSaved (state, { success, error }) {\n if (success) {\n if (state.noticeClearTimeout) {\n clearTimeout(state.noticeClearTimeout)\n }\n set(state.settings, 'currentSaveStateNotice', { error: false, data: success })\n set(state.settings, 'noticeClearTimeout',\n setTimeout(() => del(state.settings, 'currentSaveStateNotice'), 2000))\n } else {\n set(state.settings, 'currentSaveStateNotice', { error: true, errorData: error })\n }\n },\n setNotificationPermission (state, permission) {\n state.notificationPermission = permission\n }\n },\n actions: {\n setPageTitle ({ rootState }, option = '') {\n document.title = `${option} ${rootState.instance.name}`\n },\n settingsSaved ({ commit, dispatch }, { success, error }) {\n commit('settingsSaved', { success, error })\n },\n setNotificationPermission ({ commit }, permission) {\n commit('setNotificationPermission', permission)\n }\n }\n}\n\nexport default interfaceMod\n\n\n\n// WEBPACK FOOTER //\n// ./src/modules/interface.js","import fileTypeService from '../services/file_type/file_type.service.js'\n\nconst mediaViewer = {\n state: {\n media: [],\n currentIndex: 0,\n activated: false\n },\n mutations: {\n setMedia (state, media) {\n state.media = media\n },\n setCurrent (state, index) {\n state.activated = true\n state.currentIndex = index\n },\n close (state) {\n state.activated = false\n }\n },\n actions: {\n setMedia ({ commit }, attachments) {\n const media = attachments.filter(attachment => {\n const type = fileTypeService.fileType(attachment.mimetype)\n return type === 'image' || type === 'video'\n })\n commit('setMedia', media)\n },\n setCurrent ({ commit, state }, current) {\n const index = state.media.indexOf(current)\n commit('setCurrent', index || 0)\n },\n closeMediaViewer ({ commit }) {\n commit('close')\n }\n }\n}\n\nexport default mediaViewer\n\n\n\n// WEBPACK FOOTER //\n// ./src/modules/media_viewer.js","const oauth = {\n state: {\n client_id: false,\n client_secret: false,\n token: false\n },\n mutations: {\n setClientData (state, data) {\n state.client_id = data.client_id\n state.client_secret = data.client_secret\n },\n setToken (state, token) {\n state.token = token\n }\n }\n}\n\nexport default oauth\n\n\n\n// WEBPACK FOOTER //\n// ./src/modules/oauth.js","const oauthTokens = {\n state: {\n tokens: []\n },\n actions: {\n fetchTokens ({rootState, commit}) {\n rootState.api.backendInteractor.fetchOAuthTokens().then((tokens) => {\n commit('swapTokens', tokens)\n })\n },\n revokeToken ({rootState, commit, state}, id) {\n rootState.api.backendInteractor.revokeOAuthToken(id).then((response) => {\n if (response.status === 201) {\n commit('swapTokens', state.tokens.filter(token => token.id !== id))\n }\n })\n }\n },\n mutations: {\n swapTokens (state, tokens) {\n state.tokens = tokens\n }\n }\n}\n\nexport default oauthTokens\n\n\n\n// WEBPACK FOOTER //\n// ./src/modules/oauth_tokens.js","import { remove, slice, each, find, maxBy, minBy, merge, last, isArray } from 'lodash'\nimport apiService from '../services/api/api.service.js'\n// import parse from '../services/status_parser/status_parser.js'\n\nconst emptyTl = (userId = 0) => ({\n statuses: [],\n statusesObject: {},\n faves: [],\n visibleStatuses: [],\n visibleStatusesObject: {},\n newStatusCount: 0,\n maxId: 0,\n minId: 0,\n minVisibleId: 0,\n loading: false,\n followers: [],\n friends: [],\n userId,\n flushMarker: 0\n})\n\nexport const defaultState = {\n allStatuses: [],\n allStatusesObject: {},\n maxId: 0,\n notifications: {\n desktopNotificationSilence: true,\n maxId: 0,\n minId: Number.POSITIVE_INFINITY,\n data: [],\n idStore: {},\n loading: false,\n error: false\n },\n favorites: new Set(),\n error: false,\n timelines: {\n mentions: emptyTl(),\n public: emptyTl(),\n user: emptyTl(),\n favorites: emptyTl(),\n media: emptyTl(),\n publicAndExternal: emptyTl(),\n friends: emptyTl(),\n tag: emptyTl(),\n dms: emptyTl()\n }\n}\n\nexport const prepareStatus = (status) => {\n // Set deleted flag\n status.deleted = false\n\n // To make the array reactive\n status.attachments = status.attachments || []\n\n return status\n}\n\nconst visibleNotificationTypes = (rootState) => {\n return [\n rootState.config.notificationVisibility.likes && 'like',\n rootState.config.notificationVisibility.mentions && 'mention',\n rootState.config.notificationVisibility.repeats && 'repeat',\n rootState.config.notificationVisibility.follows && 'follow'\n ].filter(_ => _)\n}\n\nconst mergeOrAdd = (arr, obj, item) => {\n const oldItem = obj[item.id]\n\n if (oldItem) {\n // We already have this, so only merge the new info.\n merge(oldItem, item)\n // Reactivity fix.\n oldItem.attachments.splice(oldItem.attachments.length)\n return {item: oldItem, new: false}\n } else {\n // This is a new item, prepare it\n prepareStatus(item)\n arr.push(item)\n obj[item.id] = item\n return {item, new: true}\n }\n}\n\nconst sortById = (a, b) => {\n const seqA = Number(a.id)\n const seqB = Number(b.id)\n const isSeqA = !Number.isNaN(seqA)\n const isSeqB = !Number.isNaN(seqB)\n if (isSeqA && isSeqB) {\n return seqA > seqB ? -1 : 1\n } else if (isSeqA && !isSeqB) {\n return 1\n } else if (!isSeqA && isSeqB) {\n return -1\n } else {\n return a.id > b.id ? -1 : 1\n }\n}\n\nconst sortTimeline = (timeline) => {\n timeline.visibleStatuses = timeline.visibleStatuses.sort(sortById)\n timeline.statuses = timeline.statuses.sort(sortById)\n timeline.minVisibleId = (last(timeline.visibleStatuses) || {}).id\n return timeline\n}\n\nconst addNewStatuses = (state, { statuses, showImmediately = false, timeline, user = {}, noIdUpdate = false, userId }) => {\n // Sanity check\n if (!isArray(statuses)) {\n return false\n }\n\n const allStatuses = state.allStatuses\n const allStatusesObject = state.allStatusesObject\n const timelineObject = state.timelines[timeline]\n\n const maxNew = statuses.length > 0 ? maxBy(statuses, 'id').id : 0\n const minNew = statuses.length > 0 ? minBy(statuses, 'id').id : 0\n const newer = timeline && maxNew > timelineObject.maxId && statuses.length > 0\n const older = timeline && (minNew < timelineObject.minId || timelineObject.minId === 0) && statuses.length > 0\n\n if (!noIdUpdate && newer) {\n timelineObject.maxId = maxNew\n }\n if (!noIdUpdate && older) {\n timelineObject.minId = minNew\n }\n\n // This makes sure that user timeline won't get data meant for other\n // user. I.e. opening different user profiles makes request which could\n // return data late after user already viewing different user profile\n if ((timeline === 'user' || timeline === 'media') && timelineObject.userId !== userId) {\n return\n }\n\n const addStatus = (data, showImmediately, addToTimeline = true) => {\n const result = mergeOrAdd(allStatuses, allStatusesObject, data)\n const status = result.item\n\n if (result.new) {\n // We are mentioned in a post\n if (status.type === 'status' && find(status.attentions, { id: user.id })) {\n const mentions = state.timelines.mentions\n\n // Add the mention to the mentions timeline\n if (timelineObject !== mentions) {\n mergeOrAdd(mentions.statuses, mentions.statusesObject, status)\n mentions.newStatusCount += 1\n\n sortTimeline(mentions)\n }\n }\n if (status.visibility === 'direct') {\n const dms = state.timelines.dms\n\n mergeOrAdd(dms.statuses, dms.statusesObject, status)\n dms.newStatusCount += 1\n\n sortTimeline(dms)\n }\n }\n\n // Decide if we should treat the status as new for this timeline.\n let resultForCurrentTimeline\n // Some statuses should only be added to the global status repository.\n if (timeline && addToTimeline) {\n resultForCurrentTimeline = mergeOrAdd(timelineObject.statuses, timelineObject.statusesObject, status)\n }\n\n if (timeline && showImmediately) {\n // Add it directly to the visibleStatuses, don't change\n // newStatusCount\n mergeOrAdd(timelineObject.visibleStatuses, timelineObject.visibleStatusesObject, status)\n } else if (timeline && addToTimeline && resultForCurrentTimeline.new) {\n // Just change newStatuscount\n timelineObject.newStatusCount += 1\n }\n\n return status\n }\n\n const favoriteStatus = (favorite, counter) => {\n const status = find(allStatuses, { id: favorite.in_reply_to_status_id })\n if (status) {\n // This is our favorite, so the relevant bit.\n if (favorite.user.id === user.id) {\n status.favorited = true\n } else {\n status.fave_num += 1\n }\n }\n return status\n }\n\n const processors = {\n 'status': (status) => {\n addStatus(status, showImmediately)\n },\n 'retweet': (status) => {\n // RetweetedStatuses are never shown immediately\n const retweetedStatus = addStatus(status.retweeted_status, false, false)\n\n let retweet\n // If the retweeted status is already there, don't add the retweet\n // to the timeline.\n if (timeline && find(timelineObject.statuses, (s) => {\n if (s.retweeted_status) {\n return s.id === retweetedStatus.id || s.retweeted_status.id === retweetedStatus.id\n } else {\n return s.id === retweetedStatus.id\n }\n })) {\n // Already have it visible (either as the original or another RT), don't add to timeline, don't show.\n retweet = addStatus(status, false, false)\n } else {\n retweet = addStatus(status, showImmediately)\n }\n\n retweet.retweeted_status = retweetedStatus\n },\n 'favorite': (favorite) => {\n // Only update if this is a new favorite.\n // Ignore our own favorites because we get info about likes as response to like request\n if (!state.favorites.has(favorite.id)) {\n state.favorites.add(favorite.id)\n favoriteStatus(favorite)\n }\n },\n 'deletion': (deletion) => {\n const uri = deletion.uri\n\n // Remove possible notification\n const status = find(allStatuses, {uri})\n if (!status) {\n return\n }\n\n remove(state.notifications.data, ({action: {id}}) => id === status.id)\n\n remove(allStatuses, { uri })\n if (timeline) {\n remove(timelineObject.statuses, { uri })\n remove(timelineObject.visibleStatuses, { uri })\n }\n },\n 'follow': (follow) => {\n // NOOP, it is known status but we don't do anything about it for now\n },\n 'default': (unknown) => {\n console.log('unknown status type')\n console.log(unknown)\n }\n }\n\n each(statuses, (status) => {\n const type = status.type\n const processor = processors[type] || processors['default']\n processor(status)\n })\n\n // Keep the visible statuses sorted\n if (timeline) {\n sortTimeline(timelineObject)\n }\n}\n\nconst addNewNotifications = (state, { dispatch, notifications, older, visibleNotificationTypes }) => {\n const allStatuses = state.allStatuses\n const allStatusesObject = state.allStatusesObject\n each(notifications, (notification) => {\n notification.action = mergeOrAdd(allStatuses, allStatusesObject, notification.action).item\n notification.status = notification.status && mergeOrAdd(allStatuses, allStatusesObject, notification.status).item\n\n // Only add a new notification if we don't have one for the same action\n if (!state.notifications.idStore.hasOwnProperty(notification.id)) {\n state.notifications.maxId = notification.id > state.notifications.maxId\n ? notification.id\n : state.notifications.maxId\n state.notifications.minId = notification.id < state.notifications.minId\n ? notification.id\n : state.notifications.minId\n\n state.notifications.data.push(notification)\n state.notifications.idStore[notification.id] = notification\n\n if ('Notification' in window && window.Notification.permission === 'granted') {\n const notifObj = {}\n const action = notification.action\n const title = action.user.name\n notifObj.icon = action.user.profile_image_url\n notifObj.body = action.text // there's a problem that it doesn't put a space before links tho\n\n // Shows first attached non-nsfw image, if any. Should add configuration for this somehow...\n if (action.attachments && action.attachments.length > 0 && !action.nsfw &&\n action.attachments[0].mimetype.startsWith('image/')) {\n notifObj.image = action.attachments[0].url\n }\n\n if (!notification.seen && !state.notifications.desktopNotificationSilence && visibleNotificationTypes.includes(notification.type)) {\n let notification = new window.Notification(title, notifObj)\n // Chrome is known for not closing notifications automatically\n // according to MDN, anyway.\n setTimeout(notification.close.bind(notification), 5000)\n }\n }\n } else if (notification.seen) {\n state.notifications.idStore[notification.id].seen = true\n }\n })\n}\n\nexport const mutations = {\n addNewStatuses,\n addNewNotifications,\n showNewStatuses (state, { timeline }) {\n const oldTimeline = (state.timelines[timeline])\n\n oldTimeline.newStatusCount = 0\n oldTimeline.visibleStatuses = slice(oldTimeline.statuses, 0, 50)\n oldTimeline.minVisibleId = last(oldTimeline.visibleStatuses).id\n oldTimeline.visibleStatusesObject = {}\n each(oldTimeline.visibleStatuses, (status) => { oldTimeline.visibleStatusesObject[status.id] = status })\n },\n clearTimeline (state, { timeline }) {\n state.timelines[timeline] = emptyTl(state.timelines[timeline].userId)\n },\n setFavorited (state, { status, value }) {\n const newStatus = state.allStatusesObject[status.id]\n newStatus.favorited = value\n },\n setFavoritedConfirm (state, { status }) {\n const newStatus = state.allStatusesObject[status.id]\n newStatus.favorited = status.favorited\n newStatus.fave_num = status.fave_num\n },\n setRetweeted (state, { status, value }) {\n const newStatus = state.allStatusesObject[status.id]\n newStatus.repeated = value\n },\n setDeleted (state, { status }) {\n const newStatus = state.allStatusesObject[status.id]\n newStatus.deleted = true\n },\n setLoading (state, { timeline, value }) {\n state.timelines[timeline].loading = value\n },\n setNsfw (state, { id, nsfw }) {\n const newStatus = state.allStatusesObject[id]\n newStatus.nsfw = nsfw\n },\n setError (state, { value }) {\n state.error = value\n },\n setNotificationsLoading (state, { value }) {\n state.notifications.loading = value\n },\n setNotificationsError (state, { value }) {\n state.notifications.error = value\n },\n setNotificationsSilence (state, { value }) {\n state.notifications.desktopNotificationSilence = value\n },\n markNotificationsAsSeen (state) {\n each(state.notifications.data, (notification) => {\n notification.seen = true\n })\n },\n queueFlush (state, { timeline, id }) {\n state.timelines[timeline].flushMarker = id\n }\n}\n\nconst statuses = {\n state: defaultState,\n actions: {\n addNewStatuses ({ rootState, commit }, { statuses, showImmediately = false, timeline = false, noIdUpdate = false, userId }) {\n commit('addNewStatuses', { statuses, showImmediately, timeline, noIdUpdate, user: rootState.users.currentUser, userId })\n },\n addNewNotifications ({ rootState, commit, dispatch }, { notifications, older }) {\n commit('addNewNotifications', { visibleNotificationTypes: visibleNotificationTypes(rootState), dispatch, notifications, older })\n },\n setError ({ rootState, commit }, { value }) {\n commit('setError', { value })\n },\n setNotificationsLoading ({ rootState, commit }, { value }) {\n commit('setNotificationsLoading', { value })\n },\n setNotificationsError ({ rootState, commit }, { value }) {\n commit('setNotificationsError', { value })\n },\n setNotificationsSilence ({ rootState, commit }, { value }) {\n commit('setNotificationsSilence', { value })\n },\n deleteStatus ({ rootState, commit }, status) {\n commit('setDeleted', { status })\n apiService.deleteStatus({ id: status.id, credentials: rootState.users.currentUser.credentials })\n },\n favorite ({ rootState, commit }, status) {\n // Optimistic favoriting...\n commit('setFavorited', { status, value: true })\n apiService.favorite({ id: status.id, credentials: rootState.users.currentUser.credentials })\n .then(response => {\n if (response.ok) {\n return response.json()\n } else {\n return {}\n }\n })\n .then(status => {\n commit('setFavoritedConfirm', { status })\n })\n },\n unfavorite ({ rootState, commit }, status) {\n // Optimistic favoriting...\n commit('setFavorited', { status, value: false })\n apiService.unfavorite({ id: status.id, credentials: rootState.users.currentUser.credentials })\n .then(response => {\n if (response.ok) {\n return response.json()\n } else {\n return {}\n }\n })\n .then(status => {\n commit('setFavoritedConfirm', { status })\n })\n },\n retweet ({ rootState, commit }, status) {\n // Optimistic retweeting...\n commit('setRetweeted', { status, value: true })\n apiService.retweet({ id: status.id, credentials: rootState.users.currentUser.credentials })\n },\n unretweet ({ rootState, commit }, status) {\n commit('setRetweeted', { status, value: false })\n apiService.unretweet({ id: status.id, credentials: rootState.users.currentUser.credentials })\n },\n queueFlush ({ rootState, commit }, { timeline, id }) {\n commit('queueFlush', { timeline, id })\n },\n markNotificationsAsSeen ({ rootState, commit }) {\n commit('markNotificationsAsSeen')\n apiService.markNotificationsAsSeen({\n id: rootState.statuses.notifications.maxId,\n credentials: rootState.users.currentUser.credentials\n })\n }\n },\n mutations\n}\n\nexport default statuses\n\n\n\n// WEBPACK FOOTER //\n// ./src/modules/statuses.js","import backendInteractorService from '../services/backend_interactor_service/backend_interactor_service.js'\nimport { compact, map, each, merge, find } from 'lodash'\nimport { set } from 'vue'\nimport { registerPushNotifications, unregisterPushNotifications } from '../services/push/push.js'\nimport oauthApi from '../services/new_api/oauth'\nimport { humanizeErrors } from './errors'\n\n// TODO: Unify with mergeOrAdd in statuses.js\nexport const mergeOrAdd = (arr, obj, item) => {\n if (!item) { return false }\n const oldItem = obj[item.id]\n if (oldItem) {\n // We already have this, so only merge the new info.\n merge(oldItem, item)\n return { item: oldItem, new: false }\n } else {\n // This is a new item, prepare it\n arr.push(item)\n obj[item.id] = item\n if (item.screen_name && !item.screen_name.includes('@')) {\n obj[item.screen_name] = item\n }\n return { item, new: true }\n }\n}\n\nconst getNotificationPermission = () => {\n const Notification = window.Notification\n\n if (!Notification) return Promise.resolve(null)\n if (Notification.permission === 'default') return Notification.requestPermission()\n return Promise.resolve(Notification.permission)\n}\n\nexport const mutations = {\n setMuted (state, { user: { id }, muted }) {\n const user = state.usersObject[id]\n set(user, 'muted', muted)\n },\n setCurrentUser (state, user) {\n state.lastLoginName = user.screen_name\n state.currentUser = merge(state.currentUser || {}, user)\n },\n clearCurrentUser (state) {\n state.currentUser = false\n state.lastLoginName = false\n },\n beginLogin (state) {\n state.loggingIn = true\n },\n endLogin (state) {\n state.loggingIn = false\n },\n // TODO Clean after ourselves?\n addFriends (state, { id, friends, page }) {\n const user = state.usersObject[id]\n each(friends, friend => {\n if (!find(user.friends, { id: friend.id })) {\n user.friends.push(friend)\n }\n })\n user.friendsPage = page + 1\n },\n addFollowers (state, { id, followers, page }) {\n const user = state.usersObject[id]\n each(followers, follower => {\n if (!find(user.followers, { id: follower.id })) {\n user.followers.push(follower)\n }\n })\n user.followersPage = page + 1\n },\n // Because frontend doesn't have a reason to keep these stuff in memory\n // outside of viewing someones user profile.\n clearFriends (state, userId) {\n const user = state.usersObject[userId]\n if (!user) {\n return\n }\n user.friends = []\n user.friendsPage = 0\n },\n clearFollowers (state, userId) {\n const user = state.usersObject[userId]\n if (!user) {\n return\n }\n user.followers = []\n user.followersPage = 0\n },\n addNewUsers (state, users) {\n each(users, (user) => mergeOrAdd(state.users, state.usersObject, user))\n },\n saveBlocks (state, blockIds) {\n state.currentUser.blockIds = blockIds\n },\n saveMutes (state, muteIds) {\n state.currentUser.muteIds = muteIds\n },\n setUserForStatus (state, status) {\n status.user = state.usersObject[status.user.id]\n },\n setUserForNotification (state, notification) {\n notification.action.user = state.usersObject[notification.action.user.id]\n notification.from_profile = state.usersObject[notification.action.user.id]\n },\n setColor (state, { user: { id }, highlighted }) {\n const user = state.usersObject[id]\n set(user, 'highlight', highlighted)\n },\n signUpPending (state) {\n state.signUpPending = true\n state.signUpErrors = []\n },\n signUpSuccess (state) {\n state.signUpPending = false\n },\n signUpFailure (state, errors) {\n state.signUpPending = false\n state.signUpErrors = errors\n }\n}\n\nexport const getters = {\n userById: state => id =>\n state.users.find(user => user.id === id),\n userByName: state => name =>\n state.users.find(user => user.screen_name &&\n (user.screen_name.toLowerCase() === name.toLowerCase())\n )\n}\n\nexport const defaultState = {\n loggingIn: false,\n lastLoginName: false,\n currentUser: false,\n users: [],\n usersObject: {},\n signUpPending: false,\n signUpErrors: []\n}\n\nconst users = {\n state: defaultState,\n mutations,\n getters,\n actions: {\n fetchUser (store, id) {\n return store.rootState.api.backendInteractor.fetchUser({ id })\n .then((user) => store.commit('addNewUsers', [user]))\n },\n fetchBlocks (store) {\n return store.rootState.api.backendInteractor.fetchBlocks()\n .then((blocks) => {\n store.commit('saveBlocks', map(blocks, 'id'))\n store.commit('addNewUsers', blocks)\n return blocks\n })\n },\n blockUser (store, id) {\n return store.rootState.api.backendInteractor.blockUser(id)\n .then((user) => store.commit('addNewUsers', [user]))\n },\n unblockUser (store, id) {\n return store.rootState.api.backendInteractor.unblockUser(id)\n .then((user) => store.commit('addNewUsers', [user]))\n },\n fetchMutes (store) {\n return store.rootState.api.backendInteractor.fetchMutes()\n .then((mutedUsers) => {\n each(mutedUsers, (user) => { user.muted = true })\n store.commit('addNewUsers', mutedUsers)\n store.commit('saveMutes', map(mutedUsers, 'id'))\n })\n },\n muteUser (store, id) {\n return store.state.api.backendInteractor.setUserMute({ id, muted: true })\n .then((user) => store.commit('addNewUsers', [user]))\n },\n unmuteUser (store, id) {\n return store.state.api.backendInteractor.setUserMute({ id, muted: false })\n .then((user) => store.commit('addNewUsers', [user]))\n },\n addFriends ({ rootState, commit }, fetchBy) {\n return new Promise((resolve, reject) => {\n const user = rootState.users.usersObject[fetchBy]\n const page = user.friendsPage || 1\n rootState.api.backendInteractor.fetchFriends({ id: user.id, page })\n .then((friends) => {\n commit('addFriends', { id: user.id, friends, page })\n resolve(friends)\n }).catch(() => {\n reject()\n })\n })\n },\n addFollowers ({ rootState, commit }, fetchBy) {\n const user = rootState.users.usersObject[fetchBy]\n const page = user.followersPage || 1\n return rootState.api.backendInteractor.fetchFollowers({ id: user.id, page })\n .then((followers) => {\n commit('addFollowers', { id: user.id, followers, page })\n return followers\n })\n },\n clearFriends ({ commit }, userId) {\n commit('clearFriends', userId)\n },\n clearFollowers ({ commit }, userId) {\n commit('clearFollowers', userId)\n },\n registerPushNotifications (store) {\n const token = store.state.currentUser.credentials\n const vapidPublicKey = store.rootState.instance.vapidPublicKey\n const isEnabled = store.rootState.config.webPushNotifications\n const notificationVisibility = store.rootState.config.notificationVisibility\n\n registerPushNotifications(isEnabled, vapidPublicKey, token, notificationVisibility)\n },\n unregisterPushNotifications (store) {\n const token = store.state.currentUser.credentials\n\n unregisterPushNotifications(token)\n },\n addNewStatuses (store, { statuses }) {\n const users = map(statuses, 'user')\n const retweetedUsers = compact(map(statuses, 'retweeted_status.user'))\n store.commit('addNewUsers', users)\n store.commit('addNewUsers', retweetedUsers)\n\n // Reconnect users to statuses\n each(statuses, (status) => {\n store.commit('setUserForStatus', status)\n })\n // Reconnect users to retweets\n each(compact(map(statuses, 'retweeted_status')), (status) => {\n store.commit('setUserForStatus', status)\n })\n },\n addNewNotifications (store, { notifications }) {\n const users = map(notifications, 'from_profile')\n const notificationIds = notifications.map(_ => _.id)\n store.commit('addNewUsers', users)\n\n const notificationsObject = store.rootState.statuses.notifications.idStore\n const relevantNotifications = Object.entries(notificationsObject)\n .filter(([k, val]) => notificationIds.includes(k))\n .map(([k, val]) => val)\n\n // Reconnect users to notifications\n each(relevantNotifications, (notification) => {\n store.commit('setUserForNotification', notification)\n })\n },\n async signUp (store, userInfo) {\n store.commit('signUpPending')\n\n let rootState = store.rootState\n\n let response = await rootState.api.backendInteractor.register(userInfo)\n if (response.ok) {\n const data = {\n oauth: rootState.oauth,\n instance: rootState.instance.server\n }\n let app = await oauthApi.getOrCreateApp(data)\n let result = await oauthApi.getTokenWithCredentials({\n app,\n instance: data.instance,\n username: userInfo.username,\n password: userInfo.password\n })\n store.commit('signUpSuccess')\n store.commit('setToken', result.access_token)\n store.dispatch('loginUser', result.access_token)\n } else {\n const data = await response.json()\n let errors = JSON.parse(data.error)\n // replace ap_id with username\n if (errors.ap_id) {\n errors.username = errors.ap_id\n delete errors.ap_id\n }\n errors = humanizeErrors(errors)\n store.commit('signUpFailure', errors)\n throw Error(errors)\n }\n },\n async getCaptcha (store) {\n return await store.rootState.api.backendInteractor.getCaptcha()\n },\n\n logout (store) {\n store.commit('clearCurrentUser')\n store.commit('setToken', false)\n store.dispatch('stopFetching', 'friends')\n store.commit('setBackendInteractor', backendInteractorService())\n },\n loginUser (store, accessToken) {\n return new Promise((resolve, reject) => {\n const commit = store.commit\n commit('beginLogin')\n store.rootState.api.backendInteractor.verifyCredentials(accessToken)\n .then((data) => {\n if (!data.error) {\n const user = data\n // user.credentials = userCredentials\n user.credentials = accessToken\n user.blockIds = []\n user.muteIds = []\n commit('setCurrentUser', user)\n commit('addNewUsers', [user])\n\n getNotificationPermission()\n .then(permission => commit('setNotificationPermission', permission))\n\n // Set our new backend interactor\n commit('setBackendInteractor', backendInteractorService(accessToken))\n\n if (user.token) {\n store.dispatch('setWsToken', user.token)\n }\n\n // Start getting fresh posts.\n store.dispatch('startFetching', { timeline: 'friends' })\n\n // Get user mutes\n store.dispatch('fetchMutes')\n\n // Fetch our friends\n store.rootState.api.backendInteractor.fetchFriends({ id: user.id })\n .then((friends) => commit('addNewUsers', friends))\n } else {\n const response = data.error\n // Authentication failed\n commit('endLogin')\n if (response.status === 401) {\n reject('Wrong username or password')\n } else {\n reject('An error occurred, please try again')\n }\n }\n commit('endLogin')\n resolve()\n })\n .catch((error) => {\n console.log(error)\n commit('endLogin')\n reject('Failed to connect to server, try again')\n })\n })\n }\n }\n}\n\nexport default users\n\n\n\n// WEBPACK FOOTER //\n// ./src/modules/users.js","import { reduce, find } from 'lodash'\n\nexport const replaceWord = (str, toReplace, replacement) => {\n return str.slice(0, toReplace.start) + replacement + str.slice(toReplace.end)\n}\n\nexport const wordAtPosition = (str, pos) => {\n const words = splitIntoWords(str)\n const wordsWithPosition = addPositionToWords(words)\n\n return find(wordsWithPosition, ({start, end}) => start <= pos && end > pos)\n}\n\nexport const addPositionToWords = (words) => {\n return reduce(words, (result, word) => {\n const data = {\n word,\n start: 0,\n end: word.length\n }\n\n if (result.length > 0) {\n const previous = result.pop()\n\n data.start += previous.end\n data.end += previous.end\n\n result.push(previous)\n }\n\n result.push(data)\n\n return result\n }, [])\n}\n\nexport const splitIntoWords = (str) => {\n // Split at word boundaries\n const regex = /\\b/\n const triggers = /[@#:]+$/\n\n let split = str.split(regex)\n\n // Add trailing @ and # to the following word.\n const words = reduce(split, (result, word) => {\n if (result.length > 0) {\n let previous = result.pop()\n const matches = previous.match(triggers)\n if (matches) {\n previous = previous.replace(triggers, '')\n word = matches[0] + word\n }\n result.push(previous)\n }\n result.push(word)\n\n return result\n }, [])\n\n return words\n}\n\nconst completion = {\n wordAtPosition,\n addPositionToWords,\n splitIntoWords,\n replaceWord\n}\n\nexport default completion\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/completion/completion.js","const qvitterStatusType = (status) => {\n if (status.is_post_verb) {\n return 'status'\n }\n\n if (status.retweeted_status) {\n return 'retweet'\n }\n\n if ((typeof status.uri === 'string' && status.uri.match(/(fave|objectType=Favourite)/)) ||\n (typeof status.text === 'string' && status.text.match(/favorited/))) {\n return 'favorite'\n }\n\n if (status.text.match(/deleted notice {{tag/) || status.qvitter_delete_notice) {\n return 'deletion'\n }\n\n if (status.text.match(/started following/) || status.activity_type === 'follow') {\n return 'follow'\n }\n\n return 'unknown'\n}\n\nexport const parseUser = (data) => {\n const output = {}\n const masto = data.hasOwnProperty('acct')\n // case for users in \"mentions\" property for statuses in MastoAPI\n const mastoShort = masto && !data.hasOwnProperty('avatar')\n\n output.id = String(data.id)\n\n if (masto) {\n output.screen_name = data.acct\n\n // There's nothing else to get\n if (mastoShort) {\n return output\n }\n\n output.name = null // missing\n output.name_html = data.display_name\n\n output.description = null // missing\n output.description_html = data.note\n\n // Utilize avatar_static for gif avatars?\n output.profile_image_url = data.avatar\n output.profile_image_url_original = data.avatar\n\n // Same, utilize header_static?\n output.cover_photo = data.header\n\n output.friends_count = data.following_count\n\n output.bot = data.bot\n\n output.statusnet_profile_url = data.url\n\n if (data.pleroma) {\n const pleroma = data.pleroma\n output.follows_you = pleroma.follows_you\n output.statusnet_blocking = pleroma.statusnet_blocking\n output.muted = pleroma.muted\n }\n\n // Missing, trying to recover\n output.is_local = !output.screen_name.includes('@')\n } else {\n output.screen_name = data.screen_name\n\n output.name = data.name\n output.name_html = data.name_html\n\n output.description = data.description\n output.description_html = data.description_html\n\n output.profile_image_url = data.profile_image_url\n output.profile_image_url_original = data.profile_image_url_original\n\n output.cover_photo = data.cover_photo\n\n output.friends_count = data.friends_count\n\n output.bot = null // missing\n\n output.statusnet_profile_url = data.statusnet_profile_url\n\n output.statusnet_blocking = data.statusnet_blocking\n\n output.is_local = data.is_local\n output.role = data.role\n output.show_role = data.show_role\n\n output.follows_you = data.follows_you\n\n output.muted = data.muted\n\n // QVITTER ONLY FOR NOW\n // Really only applies to logged in user, really.. I THINK\n output.rights = data.rights\n output.no_rich_text = data.no_rich_text\n output.default_scope = data.default_scope\n output.hide_follows = data.hide_follows\n output.hide_followers = data.hide_followers\n output.background_image = data.background_image\n // on mastoapi this info is contained in a \"relationship\"\n output.following = data.following\n // Websocket token\n output.token = data.token\n }\n\n output.created_at = new Date(data.created_at)\n output.locked = data.locked\n output.followers_count = data.followers_count\n output.statuses_count = data.statuses_count\n output.friends = []\n output.followers = []\n if (data.pleroma) {\n output.follow_request_count = data.pleroma.follow_request_count\n }\n\n return output\n}\n\nconst parseAttachment = (data) => {\n const output = {}\n const masto = !data.hasOwnProperty('oembed')\n\n if (masto) {\n // Not exactly same...\n output.mimetype = data.type\n output.meta = data.meta // not present in BE yet\n } else {\n output.mimetype = data.mimetype\n output.meta = null // missing\n }\n\n output.url = data.url\n output.description = data.description\n\n return output\n}\n\nexport const parseStatus = (data) => {\n const output = {}\n const masto = data.hasOwnProperty('account')\n\n if (masto) {\n output.favorited = data.favourited\n output.fave_num = data.favourites_count\n\n output.repeated = data.reblogged\n output.repeat_num = data.reblogs_count\n\n output.type = data.reblog ? 'retweet' : 'status'\n output.nsfw = data.sensitive\n\n output.statusnet_html = data.content\n\n // Not exactly the same but works?\n output.text = data.content\n\n output.in_reply_to_status_id = data.in_reply_to_id\n output.in_reply_to_user_id = data.in_reply_to_account_id\n\n // Missing!! fix in UI?\n output.in_reply_to_screen_name = null\n\n // Not exactly the same but works\n output.statusnet_conversation_id = data.id\n\n if (output.type === 'retweet') {\n output.retweeted_status = parseStatus(data.reblog)\n }\n\n output.summary = data.spoiler_text\n output.summary_html = data.spoiler_text\n output.external_url = data.url\n\n // FIXME missing!!\n output.is_local = false\n } else {\n output.favorited = data.favorited\n output.fave_num = data.fave_num\n\n output.repeated = data.repeated\n output.repeat_num = data.repeat_num\n\n // catchall, temporary\n // Object.assign(output, data)\n\n output.type = qvitterStatusType(data)\n\n if (data.nsfw === undefined) {\n output.nsfw = isNsfw(data)\n if (data.retweeted_status) {\n output.nsfw = data.retweeted_status.nsfw\n }\n } else {\n output.nsfw = data.nsfw\n }\n\n output.statusnet_html = data.statusnet_html\n output.text = data.text\n\n output.in_reply_to_status_id = data.in_reply_to_status_id\n output.in_reply_to_user_id = data.in_reply_to_user_id\n output.in_reply_to_screen_name = data.in_reply_to_screen_name\n\n output.statusnet_conversation_id = data.statusnet_conversation_id\n\n if (output.type === 'retweet') {\n output.retweeted_status = parseStatus(data.retweeted_status)\n }\n\n output.summary = data.summary\n output.summary_html = data.summary_html\n output.external_url = data.external_url\n output.is_local = data.is_local\n }\n\n output.id = String(data.id)\n output.visibility = data.visibility\n output.card = data.card\n output.created_at = new Date(data.created_at)\n\n // Converting to string, the right way.\n output.in_reply_to_status_id = output.in_reply_to_status_id\n ? String(output.in_reply_to_status_id)\n : null\n output.in_reply_to_user_id = output.in_reply_to_user_id\n ? String(output.in_reply_to_user_id)\n : null\n\n output.user = parseUser(masto ? data.account : data.user)\n\n output.attentions = ((masto ? data.mentions : data.attentions) || []).map(parseUser)\n\n output.attachments = ((masto ? data.media_attachments : data.attachments) || [])\n .map(parseAttachment)\n\n const retweetedStatus = masto ? data.reblog : data.retweeted_status\n if (retweetedStatus) {\n output.retweeted_status = parseStatus(retweetedStatus)\n }\n\n return output\n}\n\nexport const parseNotification = (data) => {\n const mastoDict = {\n 'favourite': 'like',\n 'reblog': 'repeat'\n }\n const masto = !data.hasOwnProperty('ntype')\n const output = {}\n\n if (masto) {\n output.type = mastoDict[data.type] || data.type\n output.seen = null // missing\n output.status = parseStatus(data.status)\n output.action = output.status // not sure\n output.from_profile = parseUser(data.account)\n } else {\n const parsedNotice = parseStatus(data.notice)\n output.type = data.ntype\n output.seen = Boolean(data.is_seen)\n output.status = output.type === 'like'\n ? parseStatus(data.notice.favorited_status)\n : parsedNotice\n output.action = parsedNotice\n output.from_profile = parseUser(data.from_profile)\n }\n\n output.created_at = new Date(data.created_at)\n output.id = data.id\n\n return output\n}\n\nconst isNsfw = (status) => {\n const nsfwRegex = /#nsfw/i\n return (status.tags || []).includes('nsfw') || !!status.text.match(nsfwRegex)\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/entity_normalizer/entity_normalizer.service.js","export function StatusCodeError (statusCode, body, options, response) {\n this.name = 'StatusCodeError'\n this.statusCode = statusCode\n this.message = statusCode + ' - ' + (JSON && JSON.stringify ? JSON.stringify(body) : body)\n this.error = body // legacy attribute\n this.options = options\n this.response = response\n\n if (Error.captureStackTrace) { // required for non-V8 environments\n Error.captureStackTrace(this)\n }\n}\nStatusCodeError.prototype = Object.create(Error.prototype)\nStatusCodeError.prototype.constructor = StatusCodeError\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/errors/errors.js","import apiService from '../api/api.service.js'\n\nconst fetchAndUpdate = ({ store, credentials }) => {\n return apiService.fetchFollowRequests({ credentials })\n .then((requests) => {\n store.commit('setFollowRequests', requests)\n }, () => {})\n .catch(() => {})\n}\n\nconst startFetching = ({credentials, store}) => {\n fetchAndUpdate({ credentials, store })\n const boundFetchAndUpdate = () => fetchAndUpdate({ credentials, store })\n return setInterval(boundFetchAndUpdate, 10000)\n}\n\nconst followRequestFetcher = {\n startFetching\n}\n\nexport default followRequestFetcher\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/follow_request_fetcher/follow_request_fetcher.service.js","export const mentionMatchesUrl = (attention, url) => {\n if (url === attention.statusnet_profile_url) {\n return true\n }\n const [namepart, instancepart] = attention.screen_name.split('@')\n const matchstring = new RegExp('://' + instancepart + '/.*' + namepart + '$', 'g')\n\n return !!url.match(matchstring)\n}\n\n/**\n * Extract tag name from pleroma or mastodon url.\n * i.e https://bikeshed.party/tag/photo or https://quey.org/tags/sky\n * @param {string} url\n */\nexport const extractTagFromUrl = (url) => {\n const regex = /tag[s]*\\/(\\w+)$/g\n const result = regex.exec(url)\n if (!result) {\n return false\n }\n return result[1]\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/matcher/matcher.service.js","import utils from './utils.js'\n\nconst search = ({query, store}) => {\n return utils.request({\n store,\n url: '/api/pleroma/search_user',\n params: {\n query\n }\n }).then((data) => data.json())\n}\nconst UserSearch = {\n search\n}\n\nexport default UserSearch\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/new_api/user_search.js","const queryParams = (params) => {\n return Object.keys(params)\n .map(k => encodeURIComponent(k) + '=' + encodeURIComponent(params[k]))\n .join('&')\n}\n\nconst headers = (store) => {\n const accessToken = store.state.oauth.token\n if (accessToken) {\n return {'Authorization': `Bearer ${accessToken}`}\n } else {\n return {}\n }\n}\n\nconst request = ({method = 'GET', url, params, store}) => {\n const instance = store.state.instance.server\n let fullUrl = `${instance}${url}`\n\n if (method === 'GET' && params) {\n fullUrl = fullUrl + `?${queryParams(params)}`\n }\n\n return window.fetch(fullUrl, {\n method,\n headers: headers(store),\n credentials: 'same-origin'\n })\n}\n\nconst utils = {\n queryParams,\n request\n}\n\nexport default utils\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/new_api/utils.js","import apiService from '../api/api.service.js'\n\nconst update = ({store, notifications, older}) => {\n store.dispatch('setNotificationsError', { value: false })\n\n store.dispatch('addNewNotifications', { notifications, older })\n}\n\nconst fetchAndUpdate = ({store, credentials, older = false}) => {\n const args = { credentials }\n const rootState = store.rootState || store.state\n const timelineData = rootState.statuses.notifications\n\n if (older) {\n if (timelineData.minId !== Number.POSITIVE_INFINITY) {\n args['until'] = timelineData.minId\n }\n } else {\n // load unread notifications repeadedly to provide consistency between browser tabs\n const notifications = timelineData.data\n const unread = notifications.filter(n => !n.seen).map(n => n.id)\n if (!unread.length) {\n args['since'] = timelineData.maxId\n } else {\n args['since'] = Math.min(...unread) - 1\n if (timelineData.maxId !== Math.max(...unread)) {\n args['until'] = Math.max(...unread, args['since'] + 20)\n }\n }\n }\n\n args['timeline'] = 'notifications'\n\n return apiService.fetchTimeline(args)\n .then((notifications) => {\n update({store, notifications, older})\n return notifications\n }, () => store.dispatch('setNotificationsError', { value: true }))\n .catch(() => store.dispatch('setNotificationsError', { value: true }))\n}\n\nconst startFetching = ({credentials, store}) => {\n fetchAndUpdate({ credentials, store })\n const boundFetchAndUpdate = () => fetchAndUpdate({ credentials, store })\n // Initially there's set flag to silence all desktop notifications so\n // that there won't spam of them when user just opened up the FE we\n // reset that flag after a while to show new notifications once again.\n setTimeout(() => store.dispatch('setNotificationsSilence', false), 10000)\n return setInterval(boundFetchAndUpdate, 10000)\n}\n\nconst notificationsFetcher = {\n fetchAndUpdate,\n startFetching\n}\n\nexport default notificationsFetcher\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/notifications_fetcher/notifications_fetcher.service.js","import runtime from 'serviceworker-webpack-plugin/lib/runtime'\n\nfunction urlBase64ToUint8Array (base64String) {\n const padding = '='.repeat((4 - base64String.length % 4) % 4)\n const base64 = (base64String + padding)\n .replace(/-/g, '+')\n .replace(/_/g, '/')\n\n const rawData = window.atob(base64)\n return Uint8Array.from([...rawData].map((char) => char.charCodeAt(0)))\n}\n\nfunction isPushSupported () {\n return 'serviceWorker' in navigator && 'PushManager' in window\n}\n\nfunction getOrCreateServiceWorker () {\n return runtime.register()\n .catch((err) => console.error('Unable to get or create a service worker.', err))\n}\n\nfunction subscribePush (registration, isEnabled, vapidPublicKey) {\n if (!isEnabled) return Promise.reject(new Error('Web Push is disabled in config'))\n if (!vapidPublicKey) return Promise.reject(new Error('VAPID public key is not found'))\n\n const subscribeOptions = {\n userVisibleOnly: true,\n applicationServerKey: urlBase64ToUint8Array(vapidPublicKey)\n }\n return registration.pushManager.subscribe(subscribeOptions)\n}\n\nfunction unsubscribePush (registration) {\n return registration.pushManager.getSubscription()\n .then((subscribtion) => {\n if (subscribtion === null) { return }\n return subscribtion.unsubscribe()\n })\n}\n\nfunction deleteSubscriptionFromBackEnd (token) {\n return window.fetch('/api/v1/push/subscription/', {\n method: 'DELETE',\n headers: {\n 'Content-Type': 'application/json',\n 'Authorization': `Bearer ${token}`\n }\n }).then((response) => {\n if (!response.ok) throw new Error('Bad status code from server.')\n return response\n })\n}\n\nfunction sendSubscriptionToBackEnd (subscription, token, notificationVisibility) {\n return window.fetch('/api/v1/push/subscription/', {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n 'Authorization': `Bearer ${token}`\n },\n body: JSON.stringify({\n subscription,\n data: {\n alerts: {\n follow: notificationVisibility.follows,\n favourite: notificationVisibility.likes,\n mention: notificationVisibility.mentions,\n reblog: notificationVisibility.repeats\n }\n }\n })\n }).then((response) => {\n if (!response.ok) throw new Error('Bad status code from server.')\n return response.json()\n }).then((responseData) => {\n if (!responseData.id) throw new Error('Bad response from server.')\n return responseData\n })\n}\n\nexport function registerPushNotifications (isEnabled, vapidPublicKey, token, notificationVisibility) {\n if (isPushSupported()) {\n getOrCreateServiceWorker()\n .then((registration) => subscribePush(registration, isEnabled, vapidPublicKey))\n .then((subscription) => sendSubscriptionToBackEnd(subscription, token, notificationVisibility))\n .catch((e) => console.warn(`Failed to setup Web Push Notifications: ${e.message}`))\n }\n}\n\nexport function unregisterPushNotifications (token) {\n if (isPushSupported()) {\n Promise.all([\n deleteSubscriptionFromBackEnd(token),\n getOrCreateServiceWorker()\n .then((registration) => {\n return unsubscribePush(registration).then((result) => [registration, result])\n })\n .then(([registration, unsubResult]) => {\n if (!unsubResult) {\n console.warn('Push subscription cancellation wasn\\'t successful, killing SW anyway...')\n }\n return registration.unregister().then((result) => {\n if (!result) {\n console.warn('Failed to kill SW')\n }\n })\n })\n ]).catch((e) => console.warn(`Failed to disable Web Push Notifications: ${e.message}`))\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/push/push.js","\n\n\n\n\n\n\n\n// WEBPACK FOOTER //\n// color_input.vue?77e7e595","\n\n\n\n\n\n\n\n// WEBPACK FOOTER //\n// contrast_ratio.vue?3da6379e","\n\n\n\n\n\n\n\n// WEBPACK FOOTER //\n// export_import.vue?3c652c60","\n\n\n\n\n\n// WEBPACK FOOTER //\n// interface_language_switcher.vue?71c943eb","\n\n\n\n\n\n// WEBPACK FOOTER //\n// opacity_input.vue?aea9ac64","\n\n\n\n\n\n// WEBPACK FOOTER //\n// range_input.vue?63c72290","import UserPanel from './components/user_panel/user_panel.vue'\nimport NavPanel from './components/nav_panel/nav_panel.vue'\nimport Notifications from './components/notifications/notifications.vue'\nimport UserFinder from './components/user_finder/user_finder.vue'\nimport InstanceSpecificPanel from './components/instance_specific_panel/instance_specific_panel.vue'\nimport FeaturesPanel from './components/features_panel/features_panel.vue'\nimport WhoToFollowPanel from './components/who_to_follow_panel/who_to_follow_panel.vue'\nimport ChatPanel from './components/chat_panel/chat_panel.vue'\nimport MediaModal from './components/media_modal/media_modal.vue'\nimport SideDrawer from './components/side_drawer/side_drawer.vue'\nimport { unseenNotificationsFromStore } from './services/notification_utils/notification_utils'\n\nexport default {\n name: 'app',\n components: {\n UserPanel,\n NavPanel,\n Notifications,\n UserFinder,\n InstanceSpecificPanel,\n FeaturesPanel,\n WhoToFollowPanel,\n ChatPanel,\n MediaModal,\n SideDrawer\n },\n data: () => ({\n mobileActivePanel: 'timeline',\n finderHidden: true,\n supportsMask: window.CSS && window.CSS.supports && (\n window.CSS.supports('mask-size', 'contain') ||\n window.CSS.supports('-webkit-mask-size', 'contain') ||\n window.CSS.supports('-moz-mask-size', 'contain') ||\n window.CSS.supports('-ms-mask-size', 'contain') ||\n window.CSS.supports('-o-mask-size', 'contain')\n )\n }),\n created () {\n // Load the locale from the storage\n this.$i18n.locale = this.$store.state.config.interfaceLanguage\n },\n computed: {\n currentUser () { return this.$store.state.users.currentUser },\n background () {\n return this.currentUser.background_image || this.$store.state.instance.background\n },\n enableMask () { return this.supportsMask && this.$store.state.instance.logoMask },\n logoStyle () {\n return {\n 'visibility': this.enableMask ? 'hidden' : 'visible'\n }\n },\n logoMaskStyle () {\n return this.enableMask ? {\n 'mask-image': `url(${this.$store.state.instance.logo})`\n } : {\n 'background-color': this.enableMask ? '' : 'transparent'\n }\n },\n logoBgStyle () {\n return Object.assign({\n 'margin': `${this.$store.state.instance.logoMargin} 0`,\n opacity: this.finderHidden ? 1 : 0\n }, this.enableMask ? {} : {\n 'background-color': this.enableMask ? '' : 'transparent'\n })\n },\n logo () { return this.$store.state.instance.logo },\n bgStyle () {\n return {\n 'background-image': `url(${this.background})`\n }\n },\n bgAppStyle () {\n return {\n '--body-background-image': `url(${this.background})`\n }\n },\n sitename () { return this.$store.state.instance.name },\n chat () { return this.$store.state.chat.channel.state === 'joined' },\n suggestionsEnabled () { return this.$store.state.instance.suggestionsEnabled },\n showInstanceSpecificPanel () { return this.$store.state.instance.showInstanceSpecificPanel },\n unseenNotifications () {\n return unseenNotificationsFromStore(this.$store)\n },\n unseenNotificationsCount () {\n return this.unseenNotifications.length\n },\n showFeaturesPanel () { return this.$store.state.instance.showFeaturesPanel }\n },\n methods: {\n scrollToTop () {\n window.scrollTo(0, 0)\n },\n logout () {\n this.$router.replace('/main/public')\n this.$store.dispatch('logout')\n },\n onFinderToggled (hidden) {\n this.finderHidden = hidden\n },\n toggleMobileSidebar () {\n this.$refs.sideDrawer.toggleDrawer()\n }\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/App.js","import InstanceSpecificPanel from '../instance_specific_panel/instance_specific_panel.vue'\nimport FeaturesPanel from '../features_panel/features_panel.vue'\nimport TermsOfServicePanel from '../terms_of_service_panel/terms_of_service_panel.vue'\n\nconst About = {\n components: {\n InstanceSpecificPanel,\n FeaturesPanel,\n TermsOfServicePanel\n },\n computed: {\n showFeaturesPanel () { return this.$store.state.instance.showFeaturesPanel }\n }\n}\n\nexport default About\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/about/about.js","import StillImage from '../still-image/still-image.vue'\nimport VideoAttachment from '../video_attachment/video_attachment.vue'\nimport nsfwImage from '../../assets/nsfw.png'\nimport fileTypeService from '../../services/file_type/file_type.service.js'\n\nconst Attachment = {\n props: [\n 'attachment',\n 'nsfw',\n 'statusId',\n 'size',\n 'allowPlay',\n 'setMedia'\n ],\n data () {\n return {\n nsfwImage: this.$store.state.instance.nsfwCensorImage || nsfwImage,\n hideNsfwLocal: this.$store.state.config.hideNsfw,\n preloadImage: this.$store.state.config.preloadImage,\n loading: false,\n img: fileTypeService.fileType(this.attachment.mimetype) === 'image' && document.createElement('img'),\n modalOpen: false,\n showHidden: false\n }\n },\n components: {\n StillImage,\n VideoAttachment\n },\n computed: {\n usePlaceHolder () {\n return this.size === 'hide' || this.type === 'unknown'\n },\n referrerpolicy () {\n return this.$store.state.instance.mediaProxyAvailable ? '' : 'no-referrer'\n },\n type () {\n return fileTypeService.fileType(this.attachment.mimetype)\n },\n hidden () {\n return this.nsfw && this.hideNsfwLocal && !this.showHidden\n },\n isEmpty () {\n return (this.type === 'html' && !this.attachment.oembed) || this.type === 'unknown'\n },\n isSmall () {\n return this.size === 'small'\n },\n fullwidth () {\n return this.type === 'html' || this.type === 'audio'\n }\n },\n methods: {\n linkClicked ({target}) {\n if (target.tagName === 'A') {\n window.open(target.href, '_blank')\n }\n },\n openModal (event) {\n const modalTypes = this.$store.state.config.playVideosInModal\n ? ['image', 'video']\n : ['image']\n if (fileTypeService.fileMatchesSomeType(modalTypes, this.attachment) ||\n this.usePlaceHolder\n ) {\n event.stopPropagation()\n event.preventDefault()\n this.setMedia()\n this.$store.dispatch('setCurrent', this.attachment)\n }\n },\n toggleHidden (event) {\n if (this.$store.state.config.useOneClickNsfw && !this.showHidden) {\n this.openModal(event)\n return\n }\n if (this.img && !this.preloadImage) {\n if (this.img.onload) {\n this.img.onload()\n } else {\n this.loading = true\n this.img.src = this.attachment.url\n this.img.onload = () => {\n this.loading = false\n this.showHidden = !this.showHidden\n }\n }\n } else {\n this.showHidden = !this.showHidden\n }\n }\n }\n}\n\nexport default Attachment\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/attachment/attachment.js","import UserCardContent from '../user_card_content/user_card_content.vue'\nimport UserAvatar from '../user_avatar/user_avatar.vue'\nimport generateProfileLink from 'src/services/user_profile_link_generator/user_profile_link_generator'\n\nconst BasicUserCard = {\n props: [\n 'user'\n ],\n data () {\n return {\n userExpanded: false\n }\n },\n components: {\n UserCardContent,\n UserAvatar\n },\n methods: {\n toggleUserExpanded () {\n this.userExpanded = !this.userExpanded\n },\n userProfileLink (user) {\n return generateProfileLink(user.id, user.screen_name, this.$store.state.instance.restrictedNicknames)\n }\n }\n}\n\nexport default BasicUserCard\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/basic_user_card/basic_user_card.js","import BasicUserCard from '../basic_user_card/basic_user_card.vue'\n\nconst BlockCard = {\n props: ['userId'],\n data () {\n return {\n progress: false\n }\n },\n computed: {\n user () {\n return this.$store.getters.userById(this.userId)\n },\n blocked () {\n return this.user.statusnet_blocking\n }\n },\n components: {\n BasicUserCard\n },\n methods: {\n unblockUser () {\n this.progress = true\n this.$store.dispatch('unblockUser', this.user.id).then(() => {\n this.progress = false\n })\n },\n blockUser () {\n this.progress = true\n this.$store.dispatch('blockUser', this.user.id).then(() => {\n this.progress = false\n })\n }\n }\n}\n\nexport default BlockCard\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/block_card/block_card.js","import generateProfileLink from 'src/services/user_profile_link_generator/user_profile_link_generator'\n\nconst chatPanel = {\n props: [ 'floating' ],\n data () {\n return {\n currentMessage: '',\n channel: null,\n collapsed: true\n }\n },\n computed: {\n messages () {\n return this.$store.state.chat.messages\n }\n },\n methods: {\n submit (message) {\n this.$store.state.chat.channel.push('new_msg', {text: message}, 10000)\n this.currentMessage = ''\n },\n togglePanel () {\n this.collapsed = !this.collapsed\n },\n userProfileLink (user) {\n return generateProfileLink(user.id, user.username, this.$store.state.instance.restrictedNicknames)\n }\n }\n}\n\nexport default chatPanel\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/chat_panel/chat_panel.js","import Conversation from '../conversation/conversation.vue'\nimport { find } from 'lodash'\n\nconst conversationPage = {\n components: {\n Conversation\n },\n computed: {\n statusoid () {\n const id = this.$route.params.id\n const statuses = this.$store.state.statuses.allStatuses\n const status = find(statuses, {id})\n\n return status\n }\n }\n}\n\nexport default conversationPage\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/conversation-page/conversation-page.js","import { reduce, filter } from 'lodash'\nimport Status from '../status/status.vue'\n\nconst sortById = (a, b) => {\n const seqA = Number(a.id)\n const seqB = Number(b.id)\n const isSeqA = !Number.isNaN(seqA)\n const isSeqB = !Number.isNaN(seqB)\n if (isSeqA && isSeqB) {\n return seqA < seqB ? -1 : 1\n } else if (isSeqA && !isSeqB) {\n return -1\n } else if (!isSeqA && isSeqB) {\n return 1\n } else {\n return a.id < b.id ? -1 : 1\n }\n}\n\nconst sortAndFilterConversation = (conversation) => {\n conversation = filter(conversation, (status) => status.type !== 'retweet')\n return conversation.filter(_ => _).sort(sortById)\n}\n\nconst conversation = {\n data () {\n return {\n highlight: null\n }\n },\n props: [\n 'statusoid',\n 'collapsable'\n ],\n computed: {\n status () {\n return this.statusoid\n },\n statusId () {\n if (this.statusoid.retweeted_status) {\n return this.statusoid.retweeted_status.id\n } else {\n return this.statusoid.id\n }\n },\n conversation () {\n if (!this.status) {\n return []\n }\n\n const conversationId = this.status.statusnet_conversation_id\n const statuses = this.$store.state.statuses.allStatuses\n const conversation = filter(statuses, { statusnet_conversation_id: conversationId })\n return sortAndFilterConversation(conversation)\n },\n replies () {\n let i = 1\n return reduce(this.conversation, (result, {id, in_reply_to_status_id}) => {\n /* eslint-disable camelcase */\n const irid = in_reply_to_status_id\n /* eslint-enable camelcase */\n if (irid) {\n result[irid] = result[irid] || []\n result[irid].push({\n name: `#${i}`,\n id: id\n })\n }\n i++\n return result\n }, {})\n }\n },\n components: {\n Status\n },\n created () {\n this.fetchConversation()\n },\n watch: {\n '$route': 'fetchConversation'\n },\n methods: {\n fetchConversation () {\n if (this.status) {\n const conversationId = this.status.statusnet_conversation_id\n this.$store.state.api.backendInteractor.fetchConversation({id: conversationId})\n .then((statuses) => this.$store.dispatch('addNewStatuses', { statuses }))\n .then(() => this.setHighlight(this.statusId))\n } else {\n const id = this.$route.params.id\n this.$store.state.api.backendInteractor.fetchStatus({id})\n .then((status) => this.$store.dispatch('addNewStatuses', { statuses: [status] }))\n .then(() => this.fetchConversation())\n }\n },\n getReplies (id) {\n return this.replies[id] || []\n },\n focused (id) {\n return id === this.statusId\n },\n setHighlight (id) {\n this.highlight = id\n }\n }\n}\n\nexport default conversation\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/conversation/conversation.js","const DeleteButton = {\n props: [ 'status' ],\n methods: {\n deleteStatus () {\n const confirmed = window.confirm('Do you really want to delete this status?')\n if (confirmed) {\n this.$store.dispatch('deleteStatus', { id: this.status.id })\n }\n }\n },\n computed: {\n currentUser () { return this.$store.state.users.currentUser },\n canDelete () { return this.currentUser && this.currentUser.rights.delete_others_notice || this.status.user.id === this.currentUser.id }\n }\n}\n\nexport default DeleteButton\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/delete_button/delete_button.js","import Timeline from '../timeline/timeline.vue'\n\nconst DMs = {\n computed: {\n timeline () {\n return this.$store.state.statuses.timelines.dms\n }\n },\n components: {\n Timeline\n }\n}\n\nexport default DMs\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/dm_timeline/dm_timeline.js","const FavoriteButton = {\n props: ['status', 'loggedIn'],\n data () {\n return {\n hidePostStatsLocal: typeof this.$store.state.config.hidePostStats === 'undefined'\n ? this.$store.state.instance.hidePostStats\n : this.$store.state.config.hidePostStats,\n animated: false\n }\n },\n methods: {\n favorite () {\n if (!this.status.favorited) {\n this.$store.dispatch('favorite', {id: this.status.id})\n } else {\n this.$store.dispatch('unfavorite', {id: this.status.id})\n }\n this.animated = true\n setTimeout(() => {\n this.animated = false\n }, 500)\n }\n },\n computed: {\n classes () {\n return {\n 'icon-star-empty': !this.status.favorited,\n 'icon-star': this.status.favorited,\n 'animate-spin': this.animated\n }\n }\n }\n}\n\nexport default FavoriteButton\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/favorite_button/favorite_button.js","const FeaturesPanel = {\n computed: {\n chat: function () {\n return this.$store.state.instance.chatAvailable && (!this.$store.state.chatDisabled)\n },\n gopher: function () { return this.$store.state.instance.gopherAvailable },\n whoToFollow: function () { return this.$store.state.instance.suggestionsEnabled },\n mediaProxy: function () { return this.$store.state.instance.mediaProxyAvailable },\n scopeOptions: function () { return this.$store.state.instance.scopeOptionsEnabled },\n textlimit: function () { return this.$store.state.instance.textlimit }\n }\n}\n\nexport default FeaturesPanel\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/features_panel/features_panel.js","import BasicUserCard from '../basic_user_card/basic_user_card.vue'\nimport { requestFollow, requestUnfollow } from '../../services/follow_manipulate/follow_manipulate'\n\nconst FollowCard = {\n props: [\n 'user',\n 'noFollowsYou'\n ],\n data () {\n return {\n inProgress: false,\n requestSent: false,\n updated: false\n }\n },\n components: {\n BasicUserCard\n },\n computed: {\n isMe () { return this.$store.state.users.currentUser.id === this.user.id },\n following () { return this.updated ? this.updated.following : this.user.following },\n showFollow () {\n return !this.following || this.updated && !this.updated.following\n }\n },\n methods: {\n followUser () {\n this.inProgress = true\n requestFollow(this.user, this.$store).then(({ sent, updated }) => {\n this.inProgress = false\n this.requestSent = sent\n this.updated = updated\n })\n },\n unfollowUser () {\n this.inProgress = true\n requestUnfollow(this.user, this.$store).then(({ updated }) => {\n this.inProgress = false\n this.updated = updated\n })\n }\n }\n}\n\nexport default FollowCard\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/follow_card/follow_card.js","import BasicUserCard from '../basic_user_card/basic_user_card.vue'\n\nconst FollowRequestCard = {\n props: ['user'],\n components: {\n BasicUserCard\n },\n methods: {\n approveUser () {\n this.$store.state.api.backendInteractor.approveUser(this.user.id)\n this.$store.dispatch('removeFollowRequest', this.user)\n },\n denyUser () {\n this.$store.state.api.backendInteractor.denyUser(this.user.id)\n this.$store.dispatch('removeFollowRequest', this.user)\n }\n }\n}\n\nexport default FollowRequestCard\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/follow_request_card/follow_request_card.js","import FollowRequestCard from '../follow_request_card/follow_request_card.vue'\n\nconst FollowRequests = {\n components: {\n FollowRequestCard\n },\n computed: {\n requests () {\n return this.$store.state.api.followRequests\n }\n }\n}\n\nexport default FollowRequests\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/follow_requests/follow_requests.js","import { set } from 'vue'\n\nexport default {\n props: [\n 'name', 'label', 'value', 'fallback', 'options', 'no-inherit'\n ],\n data () {\n return {\n lValue: this.value,\n availableOptions: [\n this.noInherit ? '' : 'inherit',\n 'custom',\n ...(this.options || []),\n 'serif',\n 'monospace',\n 'sans-serif'\n ].filter(_ => _)\n }\n },\n beforeUpdate () {\n this.lValue = this.value\n },\n computed: {\n present () {\n return typeof this.lValue !== 'undefined'\n },\n dValue () {\n return this.lValue || this.fallback || {}\n },\n family: {\n get () {\n return this.dValue.family\n },\n set (v) {\n set(this.lValue, 'family', v)\n this.$emit('input', this.lValue)\n }\n },\n isCustom () {\n return this.preset === 'custom'\n },\n preset: {\n get () {\n if (this.family === 'serif' ||\n this.family === 'sans-serif' ||\n this.family === 'monospace' ||\n this.family === 'inherit') {\n return this.family\n } else {\n return 'custom'\n }\n },\n set (v) {\n this.family = v === 'custom' ? '' : v\n }\n }\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/font_control/font_control.js","import Timeline from '../timeline/timeline.vue'\nconst FriendsTimeline = {\n components: {\n Timeline\n },\n computed: {\n timeline () { return this.$store.state.statuses.timelines.friends }\n }\n}\n\nexport default FriendsTimeline\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/friends_timeline/friends_timeline.js","import Attachment from '../attachment/attachment.vue'\nimport { chunk, last, dropRight } from 'lodash'\n\nconst Gallery = {\n data: () => ({\n width: 500\n }),\n props: [\n 'attachments',\n 'nsfw',\n 'setMedia'\n ],\n components: { Attachment },\n mounted () {\n this.resize()\n window.addEventListener('resize', this.resize)\n },\n destroyed () {\n window.removeEventListener('resize', this.resize)\n },\n computed: {\n rows () {\n if (!this.attachments) {\n return []\n }\n const rows = chunk(this.attachments, 3)\n if (last(rows).length === 1 && rows.length > 1) {\n // if 1 attachment on last row -> add it to the previous row instead\n const lastAttachment = last(rows)[0]\n const allButLastRow = dropRight(rows)\n last(allButLastRow).push(lastAttachment)\n return allButLastRow\n }\n return rows\n },\n rowHeight () {\n return itemsPerRow => ({ 'height': `${(this.width / (itemsPerRow + 0.6))}px` })\n },\n useContainFit () {\n return this.$store.state.config.useContainFit\n }\n },\n methods: {\n resize () {\n // Quick optimization to make resizing not always trigger state change,\n // only update attachment size in 10px steps\n const width = Math.floor(this.$el.getBoundingClientRect().width / 10) * 10\n if (this.width !== width) {\n this.width = width\n }\n }\n }\n}\n\nexport default Gallery\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/gallery/gallery.js","import Cropper from 'cropperjs'\nimport 'cropperjs/dist/cropper.css'\n\nconst ImageCropper = {\n props: {\n trigger: {\n type: [String, window.Element],\n required: true\n },\n submitHandler: {\n type: Function,\n required: true\n },\n cropperOptions: {\n type: Object,\n default () {\n return {\n aspectRatio: 1,\n autoCropArea: 1,\n viewMode: 1,\n movable: false,\n zoomable: false,\n guides: false\n }\n }\n },\n mimes: {\n type: String,\n default: 'image/png, image/gif, image/jpeg, image/bmp, image/x-icon'\n },\n saveButtonLabel: {\n type: String\n },\n cancelButtonLabel: {\n type: String\n }\n },\n data () {\n return {\n cropper: undefined,\n dataUrl: undefined,\n filename: undefined,\n submitting: false,\n submitError: null\n }\n },\n computed: {\n saveText () {\n return this.saveButtonLabel || this.$t('image_cropper.save')\n },\n cancelText () {\n return this.cancelButtonLabel || this.$t('image_cropper.cancel')\n },\n submitErrorMsg () {\n return this.submitError && this.submitError instanceof Error ? this.submitError.toString() : this.submitError\n }\n },\n methods: {\n destroy () {\n if (this.cropper) {\n this.cropper.destroy()\n }\n this.$refs.input.value = ''\n this.dataUrl = undefined\n this.$emit('close')\n },\n submit () {\n this.submitting = true\n this.avatarUploadError = null\n this.submitHandler(this.cropper, this.file)\n .then(() => this.destroy())\n .catch((err) => {\n this.submitError = err\n })\n .finally(() => {\n this.submitting = false\n })\n },\n pickImage () {\n this.$refs.input.click()\n },\n createCropper () {\n this.cropper = new Cropper(this.$refs.img, this.cropperOptions)\n },\n getTriggerDOM () {\n return typeof this.trigger === 'object' ? this.trigger : document.querySelector(this.trigger)\n },\n readFile () {\n const fileInput = this.$refs.input\n if (fileInput.files != null && fileInput.files[0] != null) {\n this.file = fileInput.files[0]\n let reader = new window.FileReader()\n reader.onload = (e) => {\n this.dataUrl = e.target.result\n this.$emit('open')\n }\n reader.readAsDataURL(this.file)\n this.$emit('changed', this.file, reader)\n }\n },\n clearError () {\n this.submitError = null\n }\n },\n mounted () {\n // listen for click event on trigger\n const trigger = this.getTriggerDOM()\n if (!trigger) {\n this.$emit('error', 'No image make trigger found.', 'user')\n } else {\n trigger.addEventListener('click', this.pickImage)\n }\n // listen for input file changes\n const fileInput = this.$refs.input\n fileInput.addEventListener('change', this.readFile)\n },\n beforeDestroy: function () {\n // remove the event listeners\n const trigger = this.getTriggerDOM()\n if (trigger) {\n trigger.removeEventListener('click', this.pickImage)\n }\n const fileInput = this.$refs.input\n fileInput.removeEventListener('change', this.readFile)\n }\n}\n\nexport default ImageCropper\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/image_cropper/image_cropper.js","const InstanceSpecificPanel = {\n computed: {\n instanceSpecificPanelContent () {\n return this.$store.state.instance.instanceSpecificPanelContent\n },\n show () {\n return !this.$store.state.config.hideISP\n }\n }\n}\n\nexport default InstanceSpecificPanel\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/instance_specific_panel/instance_specific_panel.js","const LinkPreview = {\n name: 'LinkPreview',\n props: [\n 'card',\n 'size',\n 'nsfw'\n ],\n computed: {\n useImage () {\n // Currently BE shoudn't give cards if tagged NSFW, this is a bit paranoid\n // as it makes sure to hide the image if somehow NSFW tagged preview can\n // exist.\n return this.card.image && !this.nsfw && this.size !== 'hide'\n },\n useDescription () {\n return this.card.description && /\\S/.test(this.card.description)\n }\n }\n}\n\nexport default LinkPreview\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/link-preview/link-preview.js","import oauthApi from '../../services/new_api/oauth.js'\nconst LoginForm = {\n data: () => ({\n user: {},\n authError: false\n }),\n computed: {\n loginMethod () { return this.$store.state.instance.loginMethod },\n loggingIn () { return this.$store.state.users.loggingIn },\n registrationOpen () { return this.$store.state.instance.registrationOpen }\n },\n methods: {\n oAuthLogin () {\n oauthApi.login({\n oauth: this.$store.state.oauth,\n instance: this.$store.state.instance.server,\n commit: this.$store.commit\n })\n },\n submit () {\n const data = {\n oauth: this.$store.state.oauth,\n instance: this.$store.state.instance.server\n }\n this.clearError()\n oauthApi.getOrCreateApp(data).then((app) => {\n oauthApi.getTokenWithCredentials(\n {\n app,\n instance: data.instance,\n username: this.user.username,\n password: this.user.password\n }\n ).then((result) => {\n if (result.error) {\n this.authError = result.error\n this.user.password = ''\n return\n }\n this.$store.commit('setToken', result.access_token)\n this.$store.dispatch('loginUser', result.access_token)\n this.$router.push({name: 'friends'})\n })\n })\n },\n clearError () {\n this.authError = false\n }\n }\n}\n\nexport default LoginForm\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/login_form/login_form.js","import StillImage from '../still-image/still-image.vue'\nimport VideoAttachment from '../video_attachment/video_attachment.vue'\nimport fileTypeService from '../../services/file_type/file_type.service.js'\n\nconst MediaModal = {\n components: {\n StillImage,\n VideoAttachment\n },\n computed: {\n showing () {\n return this.$store.state.mediaViewer.activated\n },\n media () {\n return this.$store.state.mediaViewer.media\n },\n currentIndex () {\n return this.$store.state.mediaViewer.currentIndex\n },\n currentMedia () {\n return this.media[this.currentIndex]\n },\n canNavigate () {\n return this.media.length > 1\n },\n type () {\n return this.currentMedia ? fileTypeService.fileType(this.currentMedia.mimetype) : null\n }\n },\n methods: {\n hide () {\n this.$store.dispatch('closeMediaViewer')\n },\n goPrev () {\n if (this.canNavigate) {\n const prevIndex = this.currentIndex === 0 ? this.media.length - 1 : (this.currentIndex - 1)\n this.$store.dispatch('setCurrent', this.media[prevIndex])\n }\n },\n goNext () {\n if (this.canNavigate) {\n const nextIndex = this.currentIndex === this.media.length - 1 ? 0 : (this.currentIndex + 1)\n this.$store.dispatch('setCurrent', this.media[nextIndex])\n }\n },\n handleKeyupEvent (e) {\n if (this.showing && e.keyCode === 27) { // escape\n this.hide()\n }\n },\n handleKeydownEvent (e) {\n if (!this.showing) {\n return\n }\n\n if (e.keyCode === 39) { // arrow right\n this.goNext()\n } else if (e.keyCode === 37) { // arrow left\n this.goPrev()\n }\n }\n },\n mounted () {\n document.addEventListener('keyup', this.handleKeyupEvent)\n document.addEventListener('keydown', this.handleKeydownEvent)\n },\n destroyed () {\n document.removeEventListener('keyup', this.handleKeyupEvent)\n document.removeEventListener('keydown', this.handleKeydownEvent)\n }\n}\n\nexport default MediaModal\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/media_modal/media_modal.js","/* eslint-env browser */\nimport statusPosterService from '../../services/status_poster/status_poster.service.js'\nimport fileSizeFormatService from '../../services/file_size_format/file_size_format.js'\n\nconst mediaUpload = {\n data () {\n return {\n uploading: false,\n uploadReady: true\n }\n },\n methods: {\n uploadFile (file) {\n const self = this\n const store = this.$store\n if (file.size > store.state.instance.uploadlimit) {\n const filesize = fileSizeFormatService.fileSizeFormat(file.size)\n const allowedsize = fileSizeFormatService.fileSizeFormat(store.state.instance.uploadlimit)\n self.$emit('upload-failed', 'file_too_big', {filesize: filesize.num, filesizeunit: filesize.unit, allowedsize: allowedsize.num, allowedsizeunit: allowedsize.unit})\n return\n }\n const formData = new FormData()\n formData.append('media', file)\n\n self.$emit('uploading')\n self.uploading = true\n\n statusPosterService.uploadMedia({ store, formData })\n .then((fileData) => {\n self.$emit('uploaded', fileData)\n self.uploading = false\n }, (error) => { // eslint-disable-line handle-callback-err\n self.$emit('upload-failed', 'default')\n self.uploading = false\n })\n },\n fileDrop (e) {\n if (e.dataTransfer.files.length > 0) {\n e.preventDefault() // allow dropping text like before\n this.uploadFile(e.dataTransfer.files[0])\n }\n },\n fileDrag (e) {\n let types = e.dataTransfer.types\n if (types.contains('Files')) {\n e.dataTransfer.dropEffect = 'copy'\n } else {\n e.dataTransfer.dropEffect = 'none'\n }\n },\n clearFile () {\n this.uploadReady = false\n this.$nextTick(() => {\n this.uploadReady = true\n })\n },\n change ({target}) {\n for (var i = 0; i < target.files.length; i++) {\n let file = target.files[i]\n this.uploadFile(file)\n }\n }\n },\n props: [\n 'dropFiles'\n ],\n watch: {\n 'dropFiles': function (fileInfos) {\n if (!this.uploading) {\n this.uploadFile(fileInfos[0])\n }\n }\n }\n}\n\nexport default mediaUpload\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/media_upload/media_upload.js","import Timeline from '../timeline/timeline.vue'\n\nconst Mentions = {\n computed: {\n timeline () {\n return this.$store.state.statuses.timelines.mentions\n }\n },\n components: {\n Timeline\n }\n}\n\nexport default Mentions\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/mentions/mentions.js","import BasicUserCard from '../basic_user_card/basic_user_card.vue'\n\nconst MuteCard = {\n props: ['userId'],\n data () {\n return {\n progress: false\n }\n },\n computed: {\n user () {\n return this.$store.getters.userById(this.userId)\n },\n muted () {\n return this.user.muted\n }\n },\n components: {\n BasicUserCard\n },\n methods: {\n unmuteUser () {\n this.progress = true\n this.$store.dispatch('unmuteUser', this.user.id).then(() => {\n this.progress = false\n })\n },\n muteUser () {\n this.progress = true\n this.$store.dispatch('muteUser', this.user.id).then(() => {\n this.progress = false\n })\n }\n }\n}\n\nexport default MuteCard\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/mute_card/mute_card.js","import followRequestFetcher from '../../services/follow_request_fetcher/follow_request_fetcher.service'\n\nconst NavPanel = {\n created () {\n if (this.currentUser && this.currentUser.locked) {\n const store = this.$store\n const credentials = store.state.users.currentUser.credentials\n\n followRequestFetcher.startFetching({ store, credentials })\n }\n },\n computed: {\n currentUser () {\n return this.$store.state.users.currentUser\n },\n chat () {\n return this.$store.state.chat.channel\n },\n followRequestCount () {\n return this.$store.state.api.followRequests.length\n }\n }\n}\n\nexport default NavPanel\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/nav_panel/nav_panel.js","import Status from '../status/status.vue'\nimport UserAvatar from '../user_avatar/user_avatar.vue'\nimport UserCardContent from '../user_card_content/user_card_content.vue'\nimport { highlightClass, highlightStyle } from '../../services/user_highlighter/user_highlighter.js'\nimport generateProfileLink from 'src/services/user_profile_link_generator/user_profile_link_generator'\n\nconst Notification = {\n data () {\n return {\n userExpanded: false,\n betterShadow: this.$store.state.interface.browserSupport.cssFilter\n }\n },\n props: [ 'notification' ],\n components: {\n Status, UserAvatar, UserCardContent\n },\n methods: {\n toggleUserExpanded () {\n this.userExpanded = !this.userExpanded\n },\n userProfileLink (user) {\n return generateProfileLink(user.id, user.screen_name, this.$store.state.instance.restrictedNicknames)\n }\n },\n computed: {\n userClass () {\n return highlightClass(this.notification.action.user)\n },\n userStyle () {\n const highlight = this.$store.state.config.highlight\n const user = this.notification.action.user\n return highlightStyle(highlight[user.screen_name])\n }\n }\n}\n\nexport default Notification\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/notification/notification.js","import Notification from '../notification/notification.vue'\nimport notificationsFetcher from '../../services/notifications_fetcher/notifications_fetcher.service.js'\nimport {\n notificationsFromStore,\n visibleNotificationsFromStore,\n unseenNotificationsFromStore\n} from '../../services/notification_utils/notification_utils.js'\n\nconst Notifications = {\n created () {\n const store = this.$store\n const credentials = store.state.users.currentUser.credentials\n\n notificationsFetcher.startFetching({ store, credentials })\n },\n data () {\n return {\n bottomedOut: false\n }\n },\n computed: {\n notifications () {\n return notificationsFromStore(this.$store)\n },\n error () {\n return this.$store.state.statuses.notifications.error\n },\n unseenNotifications () {\n return unseenNotificationsFromStore(this.$store)\n },\n visibleNotifications () {\n return visibleNotificationsFromStore(this.$store)\n },\n unseenCount () {\n return this.unseenNotifications.length\n },\n loading () {\n return this.$store.state.statuses.notifications.loading\n }\n },\n components: {\n Notification\n },\n watch: {\n unseenCount (count) {\n if (count > 0) {\n this.$store.dispatch('setPageTitle', `(${count})`)\n } else {\n this.$store.dispatch('setPageTitle', '')\n }\n }\n },\n methods: {\n markAsSeen () {\n this.$store.dispatch('markNotificationsAsSeen', this.visibleNotifications)\n },\n fetchOlderNotifications () {\n const store = this.$store\n const credentials = store.state.users.currentUser.credentials\n store.commit('setNotificationsLoading', { value: true })\n notificationsFetcher.fetchAndUpdate({\n store,\n credentials,\n older: true\n }).then(notifs => {\n store.commit('setNotificationsLoading', { value: false })\n if (notifs.length === 0) {\n this.bottomedOut = true\n }\n })\n }\n }\n}\n\nexport default Notifications\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/notifications/notifications.js","import oauth from '../../services/new_api/oauth.js'\n\nconst oac = {\n props: ['code'],\n mounted () {\n if (this.code) {\n oauth.getToken({\n app: this.$store.state.oauth,\n instance: this.$store.state.instance.server,\n code: this.code\n }).then((result) => {\n this.$store.commit('setToken', result.access_token)\n this.$store.dispatch('loginUser', result.access_token)\n this.$router.push({name: 'friends'})\n })\n }\n }\n}\n\nexport default oac\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/oauth_callback/oauth_callback.js","import statusPoster from '../../services/status_poster/status_poster.service.js'\nimport MediaUpload from '../media_upload/media_upload.vue'\nimport fileTypeService from '../../services/file_type/file_type.service.js'\nimport Completion from '../../services/completion/completion.js'\nimport { take, filter, reject, map, uniqBy } from 'lodash'\n\nconst buildMentionsString = ({user, attentions}, currentUser) => {\n let allAttentions = [...attentions]\n\n allAttentions.unshift(user)\n\n allAttentions = uniqBy(allAttentions, 'id')\n allAttentions = reject(allAttentions, {id: currentUser.id})\n\n let mentions = map(allAttentions, (attention) => {\n return `@${attention.screen_name}`\n })\n\n return mentions.length > 0 ? mentions.join(' ') + ' ' : ''\n}\n\nconst PostStatusForm = {\n props: [\n 'replyTo',\n 'repliedUser',\n 'attentions',\n 'copyMessageScope',\n 'subject'\n ],\n components: {\n MediaUpload\n },\n mounted () {\n this.resize(this.$refs.textarea)\n const textLength = this.$refs.textarea.value.length\n this.$refs.textarea.setSelectionRange(textLength, textLength)\n\n if (this.replyTo) {\n this.$refs.textarea.focus()\n }\n },\n data () {\n const preset = this.$route.query.message\n let statusText = preset || ''\n\n const scopeCopy = typeof this.$store.state.config.scopeCopy === 'undefined'\n ? this.$store.state.instance.scopeCopy\n : this.$store.state.config.scopeCopy\n\n if (this.replyTo) {\n const currentUser = this.$store.state.users.currentUser\n statusText = buildMentionsString({ user: this.repliedUser, attentions: this.attentions }, currentUser)\n }\n\n const scope = (this.copyMessageScope && scopeCopy || this.copyMessageScope === 'direct')\n ? this.copyMessageScope\n : this.$store.state.users.currentUser.default_scope\n\n const contentType = typeof this.$store.state.config.postContentType === 'undefined'\n ? this.$store.state.instance.postContentType\n : this.$store.state.config.postContentType\n\n return {\n dropFiles: [],\n submitDisabled: false,\n error: null,\n posting: false,\n highlighted: 0,\n newStatus: {\n spoilerText: this.subject || '',\n status: statusText,\n nsfw: false,\n files: [],\n visibility: scope,\n contentType\n },\n caret: 0\n }\n },\n computed: {\n vis () {\n return {\n public: { selected: this.newStatus.visibility === 'public' },\n unlisted: { selected: this.newStatus.visibility === 'unlisted' },\n private: { selected: this.newStatus.visibility === 'private' },\n direct: { selected: this.newStatus.visibility === 'direct' }\n }\n },\n candidates () {\n const firstchar = this.textAtCaret.charAt(0)\n if (firstchar === '@') {\n const query = this.textAtCaret.slice(1).toUpperCase()\n const matchedUsers = filter(this.users, (user) => {\n return user.screen_name.toUpperCase().startsWith(query) ||\n user.name && user.name.toUpperCase().startsWith(query)\n })\n if (matchedUsers.length <= 0) {\n return false\n }\n // eslint-disable-next-line camelcase\n return map(take(matchedUsers, 5), ({screen_name, name, profile_image_url_original}, index) => ({\n // eslint-disable-next-line camelcase\n screen_name: `@${screen_name}`,\n name: name,\n img: profile_image_url_original,\n highlighted: index === this.highlighted\n }))\n } else if (firstchar === ':') {\n if (this.textAtCaret === ':') { return }\n const matchedEmoji = filter(this.emoji.concat(this.customEmoji), (emoji) => emoji.shortcode.startsWith(this.textAtCaret.slice(1)))\n if (matchedEmoji.length <= 0) {\n return false\n }\n return map(take(matchedEmoji, 5), ({shortcode, image_url, utf}, index) => ({\n screen_name: `:${shortcode}:`,\n name: '',\n utf: utf || '',\n // eslint-disable-next-line camelcase\n img: utf ? '' : this.$store.state.instance.server + image_url,\n highlighted: index === this.highlighted\n }))\n } else {\n return false\n }\n },\n textAtCaret () {\n return (this.wordAtCaret || {}).word || ''\n },\n wordAtCaret () {\n const word = Completion.wordAtPosition(this.newStatus.status, this.caret - 1) || {}\n return word\n },\n users () {\n return this.$store.state.users.users\n },\n emoji () {\n return this.$store.state.instance.emoji || []\n },\n customEmoji () {\n return this.$store.state.instance.customEmoji || []\n },\n statusLength () {\n return this.newStatus.status.length\n },\n spoilerTextLength () {\n return this.newStatus.spoilerText.length\n },\n statusLengthLimit () {\n return this.$store.state.instance.textlimit\n },\n hasStatusLengthLimit () {\n return this.statusLengthLimit > 0\n },\n charactersLeft () {\n return this.statusLengthLimit - (this.statusLength + this.spoilerTextLength)\n },\n isOverLengthLimit () {\n return this.hasStatusLengthLimit && (this.charactersLeft < 0)\n },\n scopeOptionsEnabled () {\n return this.$store.state.instance.scopeOptionsEnabled\n },\n alwaysShowSubject () {\n if (typeof this.$store.state.config.alwaysShowSubjectInput !== 'undefined') {\n return this.$store.state.config.alwaysShowSubjectInput\n } else if (typeof this.$store.state.instance.alwaysShowSubjectInput !== 'undefined') {\n return this.$store.state.instance.alwaysShowSubjectInput\n } else {\n return this.$store.state.instance.scopeOptionsEnabled\n }\n },\n formattingOptionsEnabled () {\n return this.$store.state.instance.formattingOptionsEnabled\n }\n },\n methods: {\n replace (replacement) {\n this.newStatus.status = Completion.replaceWord(this.newStatus.status, this.wordAtCaret, replacement)\n const el = this.$el.querySelector('textarea')\n el.focus()\n this.caret = 0\n },\n replaceCandidate (e) {\n const len = this.candidates.length || 0\n if (this.textAtCaret === ':' || e.ctrlKey) { return }\n if (len > 0) {\n e.preventDefault()\n const candidate = this.candidates[this.highlighted]\n const replacement = candidate.utf || (candidate.screen_name + ' ')\n this.newStatus.status = Completion.replaceWord(this.newStatus.status, this.wordAtCaret, replacement)\n const el = this.$el.querySelector('textarea')\n el.focus()\n this.caret = 0\n this.highlighted = 0\n }\n },\n cycleBackward (e) {\n const len = this.candidates.length || 0\n if (len > 0) {\n e.preventDefault()\n this.highlighted -= 1\n if (this.highlighted < 0) {\n this.highlighted = this.candidates.length - 1\n }\n } else {\n this.highlighted = 0\n }\n },\n cycleForward (e) {\n const len = this.candidates.length || 0\n if (len > 0) {\n if (e.shiftKey) { return }\n e.preventDefault()\n this.highlighted += 1\n if (this.highlighted >= len) {\n this.highlighted = 0\n }\n } else {\n this.highlighted = 0\n }\n },\n setCaret ({target: {selectionStart}}) {\n this.caret = selectionStart\n },\n postStatus (newStatus) {\n if (this.posting) { return }\n if (this.submitDisabled) { return }\n\n if (this.newStatus.status === '') {\n if (this.newStatus.files.length > 0) {\n this.newStatus.status = '\\u200b' // hack\n } else {\n this.error = 'Cannot post an empty status with no files'\n return\n }\n }\n\n this.posting = true\n statusPoster.postStatus({\n status: newStatus.status,\n spoilerText: newStatus.spoilerText || null,\n visibility: newStatus.visibility,\n sensitive: newStatus.nsfw,\n media: newStatus.files,\n store: this.$store,\n inReplyToStatusId: this.replyTo,\n contentType: newStatus.contentType\n }).then((data) => {\n if (!data.error) {\n this.newStatus = {\n status: '',\n spoilerText: '',\n files: [],\n visibility: newStatus.visibility,\n contentType: newStatus.contentType\n }\n this.$refs.mediaUpload.clearFile()\n this.$emit('posted')\n let el = this.$el.querySelector('textarea')\n el.style.height = 'auto'\n el.style.height = undefined\n this.error = null\n } else {\n this.error = data.error\n }\n this.posting = false\n })\n },\n addMediaFile (fileInfo) {\n this.newStatus.files.push(fileInfo)\n this.enableSubmit()\n },\n removeMediaFile (fileInfo) {\n let index = this.newStatus.files.indexOf(fileInfo)\n this.newStatus.files.splice(index, 1)\n },\n uploadFailed (errString, templateArgs) {\n templateArgs = templateArgs || {}\n this.error = this.$t('upload.error.base') + ' ' + this.$t('upload.error.' + errString, templateArgs)\n this.enableSubmit()\n },\n disableSubmit () {\n this.submitDisabled = true\n },\n enableSubmit () {\n this.submitDisabled = false\n },\n type (fileInfo) {\n return fileTypeService.fileType(fileInfo.mimetype)\n },\n paste (e) {\n if (e.clipboardData.files.length > 0) {\n // Strangely, files property gets emptied after event propagation\n // Trying to wrap it in array doesn't work. Plus I doubt it's possible\n // to hold more than one file in clipboard.\n this.dropFiles = [e.clipboardData.files[0]]\n }\n },\n fileDrop (e) {\n if (e.dataTransfer.files.length > 0) {\n e.preventDefault() // allow dropping text like before\n this.dropFiles = e.dataTransfer.files\n }\n },\n fileDrag (e) {\n e.dataTransfer.dropEffect = 'copy'\n },\n resize (e) {\n const target = e.target || e\n if (!(target instanceof window.Element)) { return }\n const vertPadding = Number(window.getComputedStyle(target)['padding-top'].substr(0, 1)) +\n Number(window.getComputedStyle(target)['padding-bottom'].substr(0, 1))\n // Auto is needed to make textbox shrink when removing lines\n target.style.height = 'auto'\n target.style.height = `${target.scrollHeight - vertPadding}px`\n if (target.value === '') {\n target.style.height = null\n }\n },\n clearError () {\n this.error = null\n },\n changeVis (visibility) {\n this.newStatus.visibility = visibility\n }\n }\n}\n\nexport default PostStatusForm\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/post_status_form/post_status_form.js","import Timeline from '../timeline/timeline.vue'\nconst PublicAndExternalTimeline = {\n components: {\n Timeline\n },\n computed: {\n timeline () { return this.$store.state.statuses.timelines.publicAndExternal }\n },\n created () {\n this.$store.dispatch('startFetching', { timeline: 'publicAndExternal' })\n },\n destroyed () {\n this.$store.dispatch('stopFetching', 'publicAndExternal')\n }\n}\n\nexport default PublicAndExternalTimeline\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/public_and_external_timeline/public_and_external_timeline.js","import Timeline from '../timeline/timeline.vue'\nconst PublicTimeline = {\n components: {\n Timeline\n },\n computed: {\n timeline () { return this.$store.state.statuses.timelines.public }\n },\n created () {\n this.$store.dispatch('startFetching', { timeline: 'public' })\n },\n destroyed () {\n this.$store.dispatch('stopFetching', 'public')\n }\n\n}\n\nexport default PublicTimeline\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/public_timeline/public_timeline.js","import { validationMixin } from 'vuelidate'\nimport { required, sameAs } from 'vuelidate/lib/validators'\nimport { mapActions, mapState } from 'vuex'\n\nconst registration = {\n mixins: [validationMixin],\n data: () => ({\n user: {\n email: '',\n fullname: '',\n username: '',\n password: '',\n confirm: ''\n },\n captcha: {}\n }),\n validations: {\n user: {\n email: { required },\n username: { required },\n fullname: { required },\n password: { required },\n confirm: {\n required,\n sameAsPassword: sameAs('password')\n }\n }\n },\n created () {\n if ((!this.registrationOpen && !this.token) || this.signedIn) {\n this.$router.push({name: 'root'})\n }\n\n this.setCaptcha()\n },\n computed: {\n token () { return this.$route.params.token },\n ...mapState({\n registrationOpen: (state) => state.instance.registrationOpen,\n signedIn: (state) => !!state.users.currentUser,\n isPending: (state) => state.users.signUpPending,\n serverValidationErrors: (state) => state.users.signUpErrors,\n termsOfService: (state) => state.instance.tos\n })\n },\n methods: {\n ...mapActions(['signUp', 'getCaptcha']),\n async submit () {\n this.user.nickname = this.user.username\n this.user.token = this.token\n\n this.user.captcha_solution = this.captcha.solution\n this.user.captcha_token = this.captcha.token\n this.user.captcha_answer_data = this.captcha.answer_data\n\n this.$v.$touch()\n\n if (!this.$v.$invalid) {\n try {\n await this.signUp(this.user)\n this.$router.push({name: 'friends'})\n } catch (error) {\n console.warn('Registration failed: ' + error)\n }\n }\n },\n setCaptcha () {\n this.getCaptcha().then(cpt => { this.captcha = cpt })\n }\n }\n}\n\nexport default registration\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/registration/registration.js","const RetweetButton = {\n props: ['status', 'loggedIn', 'visibility'],\n data () {\n return {\n hidePostStatsLocal: typeof this.$store.state.config.hidePostStats === 'undefined'\n ? this.$store.state.instance.hidePostStats\n : this.$store.state.config.hidePostStats,\n animated: false\n }\n },\n methods: {\n retweet () {\n if (!this.status.repeated) {\n this.$store.dispatch('retweet', {id: this.status.id})\n } else {\n this.$store.dispatch('unretweet', {id: this.status.id})\n }\n this.animated = true\n setTimeout(() => {\n this.animated = false\n }, 500)\n }\n },\n computed: {\n classes () {\n return {\n 'retweeted': this.status.repeated,\n 'retweeted-empty': !this.status.repeated,\n 'animate-spin': this.animated\n }\n }\n }\n}\n\nexport default RetweetButton\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/retweet_button/retweet_button.js","/* eslint-env browser */\nimport TabSwitcher from '../tab_switcher/tab_switcher.js'\nimport StyleSwitcher from '../style_switcher/style_switcher.vue'\nimport InterfaceLanguageSwitcher from '../interface_language_switcher/interface_language_switcher.vue'\nimport { filter, trim } from 'lodash'\n\nconst settings = {\n data () {\n const user = this.$store.state.config\n const instance = this.$store.state.instance\n\n return {\n hideAttachmentsLocal: user.hideAttachments,\n hideAttachmentsInConvLocal: user.hideAttachmentsInConv,\n maxThumbnails: user.maxThumbnails,\n hideNsfwLocal: user.hideNsfw,\n useOneClickNsfw: user.useOneClickNsfw,\n hideISPLocal: user.hideISP,\n preloadImage: user.preloadImage,\n\n hidePostStatsLocal: typeof user.hidePostStats === 'undefined'\n ? instance.hidePostStats\n : user.hidePostStats,\n hidePostStatsDefault: this.$t('settings.values.' + instance.hidePostStats),\n\n hideUserStatsLocal: typeof user.hideUserStats === 'undefined'\n ? instance.hideUserStats\n : user.hideUserStats,\n hideUserStatsDefault: this.$t('settings.values.' + instance.hideUserStats),\n\n hideFilteredStatusesLocal: typeof user.hideFilteredStatuses === 'undefined'\n ? instance.hideFilteredStatuses\n : user.hideFilteredStatuses,\n hideFilteredStatusesDefault: this.$t('settings.values.' + instance.hideFilteredStatuses),\n\n notificationVisibilityLocal: user.notificationVisibility,\n replyVisibilityLocal: user.replyVisibility,\n loopVideoLocal: user.loopVideo,\n muteWordsString: user.muteWords.join('\\n'),\n autoLoadLocal: user.autoLoad,\n streamingLocal: user.streaming,\n pauseOnUnfocusedLocal: user.pauseOnUnfocused,\n hoverPreviewLocal: user.hoverPreview,\n\n collapseMessageWithSubjectLocal: typeof user.collapseMessageWithSubject === 'undefined'\n ? instance.collapseMessageWithSubject\n : user.collapseMessageWithSubject,\n collapseMessageWithSubjectDefault: this.$t('settings.values.' + instance.collapseMessageWithSubject),\n\n subjectLineBehaviorLocal: typeof user.subjectLineBehavior === 'undefined'\n ? instance.subjectLineBehavior\n : user.subjectLineBehavior,\n subjectLineBehaviorDefault: instance.subjectLineBehavior,\n\n postContentTypeLocal: typeof user.postContentType === 'undefined'\n ? instance.postContentType\n : user.postContentType,\n postContentTypeDefault: instance.postContentType,\n\n alwaysShowSubjectInputLocal: typeof user.alwaysShowSubjectInput === 'undefined'\n ? instance.alwaysShowSubjectInput\n : user.alwaysShowSubjectInput,\n alwaysShowSubjectInputDefault: instance.alwaysShowSubjectInput,\n\n scopeCopyLocal: typeof user.scopeCopy === 'undefined'\n ? instance.scopeCopy\n : user.scopeCopy,\n scopeCopyDefault: this.$t('settings.values.' + instance.scopeCopy),\n\n stopGifs: user.stopGifs,\n webPushNotificationsLocal: user.webPushNotifications,\n loopVideoSilentOnlyLocal: user.loopVideosSilentOnly,\n loopSilentAvailable:\n // Firefox\n Object.getOwnPropertyDescriptor(HTMLVideoElement.prototype, 'mozHasAudio') ||\n // Chrome-likes\n Object.getOwnPropertyDescriptor(HTMLMediaElement.prototype, 'webkitAudioDecodedByteCount') ||\n // Future spec, still not supported in Nightly 63 as of 08/2018\n Object.getOwnPropertyDescriptor(HTMLMediaElement.prototype, 'audioTracks'),\n playVideosInModal: user.playVideosInModal,\n useContainFit: user.useContainFit\n }\n },\n components: {\n TabSwitcher,\n StyleSwitcher,\n InterfaceLanguageSwitcher\n },\n computed: {\n user () {\n return this.$store.state.users.currentUser\n },\n currentSaveStateNotice () {\n return this.$store.state.interface.settings.currentSaveStateNotice\n },\n instanceSpecificPanelPresent () { return this.$store.state.instance.showInstanceSpecificPanel }\n },\n watch: {\n hideAttachmentsLocal (value) {\n this.$store.dispatch('setOption', { name: 'hideAttachments', value })\n },\n hideAttachmentsInConvLocal (value) {\n this.$store.dispatch('setOption', { name: 'hideAttachmentsInConv', value })\n },\n hidePostStatsLocal (value) {\n this.$store.dispatch('setOption', { name: 'hidePostStats', value })\n },\n hideUserStatsLocal (value) {\n this.$store.dispatch('setOption', { name: 'hideUserStats', value })\n },\n hideFilteredStatusesLocal (value) {\n this.$store.dispatch('setOption', { name: 'hideFilteredStatuses', value })\n },\n hideNsfwLocal (value) {\n this.$store.dispatch('setOption', { name: 'hideNsfw', value })\n },\n useOneClickNsfw (value) {\n this.$store.dispatch('setOption', { name: 'useOneClickNsfw', value })\n },\n preloadImage (value) {\n this.$store.dispatch('setOption', { name: 'preloadImage', value })\n },\n hideISPLocal (value) {\n this.$store.dispatch('setOption', { name: 'hideISP', value })\n },\n 'notificationVisibilityLocal.likes' (value) {\n this.$store.dispatch('setOption', { name: 'notificationVisibility', value: this.$store.state.config.notificationVisibility })\n },\n 'notificationVisibilityLocal.follows' (value) {\n this.$store.dispatch('setOption', { name: 'notificationVisibility', value: this.$store.state.config.notificationVisibility })\n },\n 'notificationVisibilityLocal.repeats' (value) {\n this.$store.dispatch('setOption', { name: 'notificationVisibility', value: this.$store.state.config.notificationVisibility })\n },\n 'notificationVisibilityLocal.mentions' (value) {\n this.$store.dispatch('setOption', { name: 'notificationVisibility', value: this.$store.state.config.notificationVisibility })\n },\n replyVisibilityLocal (value) {\n this.$store.dispatch('setOption', { name: 'replyVisibility', value })\n },\n loopVideoLocal (value) {\n this.$store.dispatch('setOption', { name: 'loopVideo', value })\n },\n loopVideoSilentOnlyLocal (value) {\n this.$store.dispatch('setOption', { name: 'loopVideoSilentOnly', value })\n },\n autoLoadLocal (value) {\n this.$store.dispatch('setOption', { name: 'autoLoad', value })\n },\n streamingLocal (value) {\n this.$store.dispatch('setOption', { name: 'streaming', value })\n },\n pauseOnUnfocusedLocal (value) {\n this.$store.dispatch('setOption', { name: 'pauseOnUnfocused', value })\n },\n hoverPreviewLocal (value) {\n this.$store.dispatch('setOption', { name: 'hoverPreview', value })\n },\n muteWordsString (value) {\n value = filter(value.split('\\n'), (word) => trim(word).length > 0)\n this.$store.dispatch('setOption', { name: 'muteWords', value })\n },\n collapseMessageWithSubjectLocal (value) {\n this.$store.dispatch('setOption', { name: 'collapseMessageWithSubject', value })\n },\n scopeCopyLocal (value) {\n this.$store.dispatch('setOption', { name: 'scopeCopy', value })\n },\n alwaysShowSubjectInputLocal (value) {\n this.$store.dispatch('setOption', { name: 'alwaysShowSubjectInput', value })\n },\n subjectLineBehaviorLocal (value) {\n this.$store.dispatch('setOption', { name: 'subjectLineBehavior', value })\n },\n postContentTypeLocal (value) {\n this.$store.dispatch('setOption', { name: 'postContentType', value })\n },\n stopGifs (value) {\n this.$store.dispatch('setOption', { name: 'stopGifs', value })\n },\n webPushNotificationsLocal (value) {\n this.$store.dispatch('setOption', { name: 'webPushNotifications', value })\n if (value) this.$store.dispatch('registerPushNotifications')\n },\n playVideosInModal (value) {\n this.$store.dispatch('setOption', { name: 'playVideosInModal', value })\n },\n useContainFit (value) {\n this.$store.dispatch('setOption', { name: 'useContainFit', value })\n },\n maxThumbnails (value) {\n value = this.maxThumbnails = Math.floor(Math.max(value, 0))\n this.$store.dispatch('setOption', { name: 'maxThumbnails', value })\n }\n }\n}\n\nexport default settings\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/settings/settings.js","import ColorInput from '../color_input/color_input.vue'\nimport OpacityInput from '../opacity_input/opacity_input.vue'\nimport { getCssShadow } from '../../services/style_setter/style_setter.js'\nimport { hex2rgb } from '../../services/color_convert/color_convert.js'\n\nexport default {\n // 'Value' and 'Fallback' can be undefined, but if they are\n // initially vue won't detect it when they become something else\n // therefore i'm using \"ready\" which should be passed as true when\n // data becomes available\n props: [\n 'value', 'fallback', 'ready'\n ],\n data () {\n return {\n selectedId: 0,\n // TODO there are some bugs regarding display of array (it's not getting updated when deleting for some reason)\n cValue: this.value || this.fallback || []\n }\n },\n components: {\n ColorInput,\n OpacityInput\n },\n methods: {\n add () {\n this.cValue.push(Object.assign({}, this.selected))\n this.selectedId = this.cValue.length - 1\n },\n del () {\n this.cValue.splice(this.selectedId, 1)\n this.selectedId = this.cValue.length === 0 ? undefined : this.selectedId - 1\n },\n moveUp () {\n const movable = this.cValue.splice(this.selectedId, 1)[0]\n this.cValue.splice(this.selectedId - 1, 0, movable)\n this.selectedId -= 1\n },\n moveDn () {\n const movable = this.cValue.splice(this.selectedId, 1)[0]\n this.cValue.splice(this.selectedId + 1, 0, movable)\n this.selectedId += 1\n }\n },\n beforeUpdate () {\n this.cValue = this.value || this.fallback\n },\n computed: {\n selected () {\n if (this.ready && this.cValue.length > 0) {\n return this.cValue[this.selectedId]\n } else {\n return {\n x: 0,\n y: 0,\n blur: 0,\n spread: 0,\n inset: false,\n color: '#000000',\n alpha: 1\n }\n }\n },\n moveUpValid () {\n return this.ready && this.selectedId > 0\n },\n moveDnValid () {\n return this.ready && this.selectedId < this.cValue.length - 1\n },\n present () {\n return this.ready &&\n typeof this.cValue[this.selectedId] !== 'undefined' &&\n !this.usingFallback\n },\n usingFallback () {\n return typeof this.value === 'undefined'\n },\n rgb () {\n return hex2rgb(this.selected.color)\n },\n style () {\n return this.ready ? {\n boxShadow: getCssShadow(this.cValue)\n } : {}\n }\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/shadow_control/shadow_control.js","import UserCardContent from '../user_card_content/user_card_content.vue'\nimport { unseenNotificationsFromStore } from '../../services/notification_utils/notification_utils'\n\n// TODO: separate touch gesture stuff into their own utils if more components want them\nconst deltaCoord = (oldCoord, newCoord) => [newCoord[0] - oldCoord[0], newCoord[1] - oldCoord[1]]\n\nconst touchEventCoord = e => ([e.touches[0].screenX, e.touches[0].screenY])\n\nconst SideDrawer = {\n props: [ 'logout' ],\n data: () => ({\n closed: true,\n touchCoord: [0, 0]\n }),\n components: { UserCardContent },\n computed: {\n currentUser () {\n return this.$store.state.users.currentUser\n },\n chat () { return this.$store.state.chat.channel.state === 'joined' },\n unseenNotifications () {\n return unseenNotificationsFromStore(this.$store)\n },\n unseenNotificationsCount () {\n return this.unseenNotifications.length\n },\n suggestionsEnabled () {\n return this.$store.state.instance.suggestionsEnabled\n },\n logo () {\n return this.$store.state.instance.logo\n },\n sitename () {\n return this.$store.state.instance.name\n },\n followRequestCount () {\n return this.$store.state.api.followRequests.length\n }\n },\n methods: {\n toggleDrawer () {\n this.closed = !this.closed\n },\n doLogout () {\n this.logout()\n this.toggleDrawer()\n },\n touchStart (e) {\n this.touchCoord = touchEventCoord(e)\n },\n touchMove (e) {\n const delta = deltaCoord(this.touchCoord, touchEventCoord(e))\n if (delta[0] < -30 && Math.abs(delta[1]) < Math.abs(delta[0]) && !this.closed) {\n this.toggleDrawer()\n }\n }\n }\n}\n\nexport default SideDrawer\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/side_drawer/side_drawer.js","import Attachment from '../attachment/attachment.vue'\nimport FavoriteButton from '../favorite_button/favorite_button.vue'\nimport RetweetButton from '../retweet_button/retweet_button.vue'\nimport DeleteButton from '../delete_button/delete_button.vue'\nimport PostStatusForm from '../post_status_form/post_status_form.vue'\nimport UserCardContent from '../user_card_content/user_card_content.vue'\nimport UserAvatar from '../user_avatar/user_avatar.vue'\nimport Gallery from '../gallery/gallery.vue'\nimport LinkPreview from '../link-preview/link-preview.vue'\nimport generateProfileLink from 'src/services/user_profile_link_generator/user_profile_link_generator'\nimport fileType from 'src/services/file_type/file_type.service'\nimport { highlightClass, highlightStyle } from '../../services/user_highlighter/user_highlighter.js'\nimport { mentionMatchesUrl, extractTagFromUrl } from 'src/services/matcher/matcher.service.js'\nimport { filter, find, unescape } from 'lodash'\n\nconst Status = {\n name: 'Status',\n props: [\n 'statusoid',\n 'expandable',\n 'inConversation',\n 'focused',\n 'highlight',\n 'compact',\n 'replies',\n 'isPreview',\n 'noHeading',\n 'inlineExpanded'\n ],\n data () {\n return {\n replying: false,\n expanded: false,\n unmuted: false,\n userExpanded: false,\n preview: null,\n showPreview: false,\n showingTall: this.inConversation && this.focused,\n showingLongSubject: false,\n expandingSubject: typeof this.$store.state.config.collapseMessageWithSubject === 'undefined'\n ? !this.$store.state.instance.collapseMessageWithSubject\n : !this.$store.state.config.collapseMessageWithSubject,\n betterShadow: this.$store.state.interface.browserSupport.cssFilter\n }\n },\n computed: {\n localCollapseSubjectDefault () {\n return typeof this.$store.state.config.collapseMessageWithSubject === 'undefined'\n ? this.$store.state.instance.collapseMessageWithSubject\n : this.$store.state.config.collapseMessageWithSubject\n },\n muteWords () {\n return this.$store.state.config.muteWords\n },\n repeaterClass () {\n const user = this.statusoid.user\n return highlightClass(user)\n },\n userClass () {\n const user = this.retweet ? (this.statusoid.retweeted_status.user) : this.statusoid.user\n return highlightClass(user)\n },\n deleted () {\n return this.statusoid.deleted\n },\n repeaterStyle () {\n const user = this.statusoid.user\n const highlight = this.$store.state.config.highlight\n return highlightStyle(highlight[user.screen_name])\n },\n userStyle () {\n if (this.noHeading) return\n const user = this.retweet ? (this.statusoid.retweeted_status.user) : this.statusoid.user\n const highlight = this.$store.state.config.highlight\n return highlightStyle(highlight[user.screen_name])\n },\n hideAttachments () {\n return (this.$store.state.config.hideAttachments && !this.inConversation) ||\n (this.$store.state.config.hideAttachmentsInConv && this.inConversation)\n },\n userProfileLink () {\n return this.generateUserProfileLink(this.status.user.id, this.status.user.screen_name)\n },\n replyProfileLink () {\n if (this.isReply) {\n return this.generateUserProfileLink(this.status.in_reply_to_user_id, this.replyToName)\n }\n },\n retweet () { return !!this.statusoid.retweeted_status },\n retweeter () { return this.statusoid.user.name || this.statusoid.user.screen_name },\n retweeterHtml () { return this.statusoid.user.name_html },\n retweeterProfileLink () { return this.generateUserProfileLink(this.statusoid.user.id, this.statusoid.user.screen_name) },\n status () {\n if (this.retweet) {\n return this.statusoid.retweeted_status\n } else {\n return this.statusoid\n }\n },\n loggedIn () {\n return !!this.$store.state.users.currentUser\n },\n muteWordHits () {\n const statusText = this.status.text.toLowerCase()\n const hits = filter(this.muteWords, (muteWord) => {\n return statusText.includes(muteWord.toLowerCase())\n })\n\n return hits\n },\n muted () { return !this.unmuted && (this.status.user.muted || this.muteWordHits.length > 0) },\n hideFilteredStatuses () {\n return typeof this.$store.state.config.hideFilteredStatuses === 'undefined'\n ? this.$store.state.instance.hideFilteredStatuses\n : this.$store.state.config.hideFilteredStatuses\n },\n hideStatus () {\n return (this.hideReply || this.deleted) || (this.muted && this.hideFilteredStatuses)\n },\n isFocused () {\n // retweet or root of an expanded conversation\n if (this.focused) {\n return true\n } else if (!this.inConversation) {\n return false\n }\n // use conversation highlight only when in conversation\n return this.status.id === this.highlight\n },\n // This is a bit hacky, but we want to approximate post height before rendering\n // so we count newlines (masto uses

    for paragraphs, GS uses
    between them)\n // as well as approximate line count by counting characters and approximating ~80\n // per line.\n //\n // Using max-height + overflow: auto for status components resulted in false positives\n // very often with japanese characters, and it was very annoying.\n tallStatus () {\n const lengthScore = this.status.statusnet_html.split(/ 20\n },\n longSubject () {\n return this.status.summary.length > 900\n },\n isReply () {\n return !!(this.status.in_reply_to_status_id && this.status.in_reply_to_user_id)\n },\n replyToName () {\n const user = this.$store.state.users.usersObject[this.status.in_reply_to_user_id]\n if (user) {\n return user.screen_name\n } else {\n return this.status.in_reply_to_screen_name\n }\n },\n hideReply () {\n if (this.$store.state.config.replyVisibility === 'all') {\n return false\n }\n if (this.inlineExpanded || this.expanded || this.inConversation || !this.isReply) {\n return false\n }\n if (this.status.user.id === this.$store.state.users.currentUser.id) {\n return false\n }\n if (this.status.type === 'retweet') {\n return false\n }\n var checkFollowing = this.$store.state.config.replyVisibility === 'following'\n for (var i = 0; i < this.status.attentions.length; ++i) {\n if (this.status.user.id === this.status.attentions[i].id) {\n continue\n }\n if (checkFollowing && this.status.attentions[i].following) {\n return false\n }\n if (this.status.attentions[i].id === this.$store.state.users.currentUser.id) {\n return false\n }\n }\n return this.status.attentions.length > 0\n },\n hideSubjectStatus () {\n if (this.tallStatus && !this.localCollapseSubjectDefault) {\n return false\n }\n return !this.expandingSubject && this.status.summary\n },\n hideTallStatus () {\n if (this.status.summary && this.localCollapseSubjectDefault) {\n return false\n }\n if (this.showingTall) {\n return false\n }\n return this.tallStatus\n },\n showingMore () {\n return (this.tallStatus && this.showingTall) || (this.status.summary && this.expandingSubject)\n },\n nsfwClickthrough () {\n if (!this.status.nsfw) {\n return false\n }\n if (this.status.summary && this.localCollapseSubjectDefault) {\n return false\n }\n return true\n },\n replySubject () {\n if (!this.status.summary) return ''\n const decodedSummary = unescape(this.status.summary)\n const behavior = typeof this.$store.state.config.subjectLineBehavior === 'undefined'\n ? this.$store.state.instance.subjectLineBehavior\n : this.$store.state.config.subjectLineBehavior\n const startsWithRe = decodedSummary.match(/^re[: ]/i)\n if (behavior !== 'noop' && startsWithRe || behavior === 'masto') {\n return decodedSummary\n } else if (behavior === 'email') {\n return 're: '.concat(decodedSummary)\n } else if (behavior === 'noop') {\n return ''\n }\n },\n attachmentSize () {\n if ((this.$store.state.config.hideAttachments && !this.inConversation) ||\n (this.$store.state.config.hideAttachmentsInConv && this.inConversation) ||\n (this.status.attachments.length > this.maxThumbnails)) {\n return 'hide'\n } else if (this.compact) {\n return 'small'\n }\n return 'normal'\n },\n galleryTypes () {\n if (this.attachmentSize === 'hide') {\n return []\n }\n return this.$store.state.config.playVideosInModal\n ? ['image', 'video']\n : ['image']\n },\n galleryAttachments () {\n return this.status.attachments.filter(\n file => fileType.fileMatchesSomeType(this.galleryTypes, file)\n )\n },\n nonGalleryAttachments () {\n return this.status.attachments.filter(\n file => !fileType.fileMatchesSomeType(this.galleryTypes, file)\n )\n },\n maxThumbnails () {\n return this.$store.state.config.maxThumbnails\n }\n },\n components: {\n Attachment,\n FavoriteButton,\n RetweetButton,\n DeleteButton,\n PostStatusForm,\n UserCardContent,\n UserAvatar,\n Gallery,\n LinkPreview\n },\n methods: {\n visibilityIcon (visibility) {\n switch (visibility) {\n case 'private':\n return 'icon-lock'\n case 'unlisted':\n return 'icon-lock-open-alt'\n case 'direct':\n return 'icon-mail-alt'\n default:\n return 'icon-globe'\n }\n },\n linkClicked (event) {\n let { target } = event\n if (target.tagName === 'SPAN') {\n target = target.parentNode\n }\n if (target.tagName === 'A') {\n if (target.className.match(/mention/)) {\n const href = target.href\n const attn = this.status.attentions.find(attn => mentionMatchesUrl(attn, href))\n if (attn) {\n event.stopPropagation()\n event.preventDefault()\n const link = this.generateUserProfileLink(attn.id, attn.screen_name)\n this.$router.push(link)\n return\n }\n }\n if (target.className.match(/hashtag/)) {\n // Extract tag name from link url\n const tag = extractTagFromUrl(target.href)\n if (tag) {\n const link = this.generateTagLink(tag)\n this.$router.push(link)\n return\n }\n }\n window.open(target.href, '_blank')\n }\n },\n toggleReplying () {\n this.replying = !this.replying\n },\n gotoOriginal (id) {\n // only handled by conversation, not status_or_conversation\n if (this.inConversation) {\n this.$emit('goto', id)\n }\n },\n toggleExpanded () {\n this.$emit('toggleExpanded')\n },\n toggleMute () {\n this.unmuted = !this.unmuted\n },\n toggleUserExpanded () {\n this.userExpanded = !this.userExpanded\n },\n toggleShowMore () {\n if (this.showingTall) {\n this.showingTall = false\n } else if (this.expandingSubject && this.status.summary) {\n this.expandingSubject = false\n } else if (this.hideTallStatus) {\n this.showingTall = true\n } else if (this.hideSubjectStatus && this.status.summary) {\n this.expandingSubject = true\n }\n },\n replyEnter (id, event) {\n this.showPreview = true\n const targetId = id\n const statuses = this.$store.state.statuses.allStatuses\n\n if (!this.preview) {\n // if we have the status somewhere already\n this.preview = find(statuses, { 'id': targetId })\n // or if we have to fetch it\n if (!this.preview) {\n this.$store.state.api.backendInteractor.fetchStatus({id}).then((status) => {\n this.preview = status\n })\n }\n } else if (this.preview.id !== targetId) {\n this.preview = find(statuses, { 'id': targetId })\n }\n },\n replyLeave () {\n this.showPreview = false\n },\n generateUserProfileLink (id, name) {\n return generateProfileLink(id, name, this.$store.state.instance.restrictedNicknames)\n },\n generateTagLink (tag) {\n return `/tag/${tag}`\n },\n setMedia () {\n const attachments = this.attachmentSize === 'hide' ? this.status.attachments : this.galleryAttachments\n return () => this.$store.dispatch('setMedia', attachments)\n }\n },\n watch: {\n 'highlight': function (id) {\n if (this.status.id === id) {\n let rect = this.$el.getBoundingClientRect()\n if (rect.top < 100) {\n // Post is above screen, match its top to screen top\n window.scrollBy(0, rect.top - 100)\n } else if (rect.height >= (window.innerHeight - 50)) {\n // Post we want to see is taller than screen so match its top to screen top\n window.scrollBy(0, rect.top - 100)\n } else if (rect.bottom > window.innerHeight - 50) {\n // Post is below screen, match its bottom to screen bottom\n window.scrollBy(0, rect.bottom - window.innerHeight + 50)\n }\n }\n }\n },\n filters: {\n capitalize: function (str) {\n return str.charAt(0).toUpperCase() + str.slice(1)\n }\n }\n}\n\nexport default Status\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/status/status.js","import Status from '../status/status.vue'\nimport Conversation from '../conversation/conversation.vue'\n\nconst statusOrConversation = {\n props: ['statusoid'],\n data () {\n return {\n expanded: false\n }\n },\n components: {\n Status,\n Conversation\n },\n methods: {\n toggleExpanded () {\n this.expanded = !this.expanded\n }\n }\n}\n\nexport default statusOrConversation\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/status_or_conversation/status_or_conversation.js","const StillImage = {\n props: [\n 'src',\n 'referrerpolicy',\n 'mimetype',\n 'imageLoadError'\n ],\n data () {\n return {\n stopGifs: this.$store.state.config.stopGifs\n }\n },\n computed: {\n animated () {\n return this.stopGifs && (this.mimetype === 'image/gif' || this.src.endsWith('.gif'))\n }\n },\n methods: {\n onLoad () {\n const canvas = this.$refs.canvas\n if (!canvas) return\n const width = this.$refs.src.naturalWidth\n const height = this.$refs.src.naturalHeight\n canvas.width = width\n canvas.height = height\n canvas.getContext('2d').drawImage(this.$refs.src, 0, 0, width, height)\n },\n onError () {\n this.imageLoadError && this.imageLoadError()\n }\n }\n}\n\nexport default StillImage\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/still-image/still-image.js","import { rgb2hex, hex2rgb, getContrastRatio, alphaBlend } from '../../services/color_convert/color_convert.js'\nimport { set, delete as del } from 'vue'\nimport { generateColors, generateShadows, generateRadii, generateFonts, composePreset, getThemes } from '../../services/style_setter/style_setter.js'\nimport ColorInput from '../color_input/color_input.vue'\nimport RangeInput from '../range_input/range_input.vue'\nimport OpacityInput from '../opacity_input/opacity_input.vue'\nimport ShadowControl from '../shadow_control/shadow_control.vue'\nimport FontControl from '../font_control/font_control.vue'\nimport ContrastRatio from '../contrast_ratio/contrast_ratio.vue'\nimport TabSwitcher from '../tab_switcher/tab_switcher.js'\nimport Preview from './preview.vue'\nimport ExportImport from '../export_import/export_import.vue'\n\n// List of color values used in v1\nconst v1OnlyNames = [\n 'bg',\n 'fg',\n 'text',\n 'link',\n 'cRed',\n 'cGreen',\n 'cBlue',\n 'cOrange'\n].map(_ => _ + 'ColorLocal')\n\nexport default {\n data () {\n return {\n availableStyles: [],\n selected: this.$store.state.config.theme,\n\n previewShadows: {},\n previewColors: {},\n previewRadii: {},\n previewFonts: {},\n\n shadowsInvalid: true,\n colorsInvalid: true,\n radiiInvalid: true,\n\n keepColor: false,\n keepShadows: false,\n keepOpacity: false,\n keepRoundness: false,\n keepFonts: false,\n\n textColorLocal: '',\n linkColorLocal: '',\n\n bgColorLocal: '',\n bgOpacityLocal: undefined,\n\n fgColorLocal: '',\n fgTextColorLocal: undefined,\n fgLinkColorLocal: undefined,\n\n btnColorLocal: undefined,\n btnTextColorLocal: undefined,\n btnOpacityLocal: undefined,\n\n inputColorLocal: undefined,\n inputTextColorLocal: undefined,\n inputOpacityLocal: undefined,\n\n panelColorLocal: undefined,\n panelTextColorLocal: undefined,\n panelLinkColorLocal: undefined,\n panelFaintColorLocal: undefined,\n panelOpacityLocal: undefined,\n\n topBarColorLocal: undefined,\n topBarTextColorLocal: undefined,\n topBarLinkColorLocal: undefined,\n\n alertErrorColorLocal: undefined,\n\n badgeOpacityLocal: undefined,\n badgeNotificationColorLocal: undefined,\n\n borderColorLocal: undefined,\n borderOpacityLocal: undefined,\n\n faintColorLocal: undefined,\n faintOpacityLocal: undefined,\n faintLinkColorLocal: undefined,\n\n cRedColorLocal: '',\n cBlueColorLocal: '',\n cGreenColorLocal: '',\n cOrangeColorLocal: '',\n\n shadowSelected: undefined,\n shadowsLocal: {},\n fontsLocal: {},\n\n btnRadiusLocal: '',\n inputRadiusLocal: '',\n checkboxRadiusLocal: '',\n panelRadiusLocal: '',\n avatarRadiusLocal: '',\n avatarAltRadiusLocal: '',\n attachmentRadiusLocal: '',\n tooltipRadiusLocal: ''\n }\n },\n created () {\n const self = this\n\n getThemes().then((themesComplete) => {\n self.availableStyles = themesComplete\n })\n },\n mounted () {\n this.normalizeLocalState(this.$store.state.config.customTheme)\n if (typeof this.shadowSelected === 'undefined') {\n this.shadowSelected = this.shadowsAvailable[0]\n }\n },\n computed: {\n selectedVersion () {\n return Array.isArray(this.selected) ? 1 : 2\n },\n currentColors () {\n return {\n bg: this.bgColorLocal,\n text: this.textColorLocal,\n link: this.linkColorLocal,\n\n fg: this.fgColorLocal,\n fgText: this.fgTextColorLocal,\n fgLink: this.fgLinkColorLocal,\n\n panel: this.panelColorLocal,\n panelText: this.panelTextColorLocal,\n panelLink: this.panelLinkColorLocal,\n panelFaint: this.panelFaintColorLocal,\n\n input: this.inputColorLocal,\n inputText: this.inputTextColorLocal,\n\n topBar: this.topBarColorLocal,\n topBarText: this.topBarTextColorLocal,\n topBarLink: this.topBarLinkColorLocal,\n\n btn: this.btnColorLocal,\n btnText: this.btnTextColorLocal,\n\n alertError: this.alertErrorColorLocal,\n badgeNotification: this.badgeNotificationColorLocal,\n\n faint: this.faintColorLocal,\n faintLink: this.faintLinkColorLocal,\n border: this.borderColorLocal,\n\n cRed: this.cRedColorLocal,\n cBlue: this.cBlueColorLocal,\n cGreen: this.cGreenColorLocal,\n cOrange: this.cOrangeColorLocal\n }\n },\n currentOpacity () {\n return {\n bg: this.bgOpacityLocal,\n btn: this.btnOpacityLocal,\n input: this.inputOpacityLocal,\n panel: this.panelOpacityLocal,\n topBar: this.topBarOpacityLocal,\n border: this.borderOpacityLocal,\n faint: this.faintOpacityLocal\n }\n },\n currentRadii () {\n return {\n btn: this.btnRadiusLocal,\n input: this.inputRadiusLocal,\n checkbox: this.checkboxRadiusLocal,\n panel: this.panelRadiusLocal,\n avatar: this.avatarRadiusLocal,\n avatarAlt: this.avatarAltRadiusLocal,\n tooltip: this.tooltipRadiusLocal,\n attachment: this.attachmentRadiusLocal\n }\n },\n preview () {\n return composePreset(this.previewColors, this.previewRadii, this.previewShadows, this.previewFonts)\n },\n previewTheme () {\n if (!this.preview.theme.colors) return { colors: {}, opacity: {}, radii: {}, shadows: {}, fonts: {} }\n return this.preview.theme\n },\n // This needs optimization maybe\n previewContrast () {\n if (!this.previewTheme.colors.bg) return {}\n const colors = this.previewTheme.colors\n const opacity = this.previewTheme.opacity\n if (!colors.bg) return {}\n const hints = (ratio) => ({\n text: ratio.toPrecision(3) + ':1',\n // AA level, AAA level\n aa: ratio >= 4.5,\n aaa: ratio >= 7,\n // same but for 18pt+ texts\n laa: ratio >= 3,\n laaa: ratio >= 4.5\n })\n\n // fgsfds :DDDD\n const fgs = {\n text: hex2rgb(colors.text),\n panelText: hex2rgb(colors.panelText),\n panelLink: hex2rgb(colors.panelLink),\n btnText: hex2rgb(colors.btnText),\n topBarText: hex2rgb(colors.topBarText),\n inputText: hex2rgb(colors.inputText),\n\n link: hex2rgb(colors.link),\n topBarLink: hex2rgb(colors.topBarLink),\n\n red: hex2rgb(colors.cRed),\n green: hex2rgb(colors.cGreen),\n blue: hex2rgb(colors.cBlue),\n orange: hex2rgb(colors.cOrange)\n }\n\n const bgs = {\n bg: hex2rgb(colors.bg),\n btn: hex2rgb(colors.btn),\n panel: hex2rgb(colors.panel),\n topBar: hex2rgb(colors.topBar),\n input: hex2rgb(colors.input),\n alertError: hex2rgb(colors.alertError),\n badgeNotification: hex2rgb(colors.badgeNotification)\n }\n\n /* This is a bit confusing because \"bottom layer\" used is text color\n * This is done to get worst case scenario when background below transparent\n * layer matches text color, making it harder to read the lower alpha is.\n */\n const ratios = {\n bgText: getContrastRatio(alphaBlend(bgs.bg, opacity.bg, fgs.text), fgs.text),\n bgLink: getContrastRatio(alphaBlend(bgs.bg, opacity.bg, fgs.link), fgs.link),\n bgRed: getContrastRatio(alphaBlend(bgs.bg, opacity.bg, fgs.red), fgs.red),\n bgGreen: getContrastRatio(alphaBlend(bgs.bg, opacity.bg, fgs.green), fgs.green),\n bgBlue: getContrastRatio(alphaBlend(bgs.bg, opacity.bg, fgs.blue), fgs.blue),\n bgOrange: getContrastRatio(alphaBlend(bgs.bg, opacity.bg, fgs.orange), fgs.orange),\n\n tintText: getContrastRatio(alphaBlend(bgs.bg, 0.5, fgs.panelText), fgs.text),\n\n panelText: getContrastRatio(alphaBlend(bgs.panel, opacity.panel, fgs.panelText), fgs.panelText),\n panelLink: getContrastRatio(alphaBlend(bgs.panel, opacity.panel, fgs.panelLink), fgs.panelLink),\n\n btnText: getContrastRatio(alphaBlend(bgs.btn, opacity.btn, fgs.btnText), fgs.btnText),\n\n inputText: getContrastRatio(alphaBlend(bgs.input, opacity.input, fgs.inputText), fgs.inputText),\n\n topBarText: getContrastRatio(alphaBlend(bgs.topBar, opacity.topBar, fgs.topBarText), fgs.topBarText),\n topBarLink: getContrastRatio(alphaBlend(bgs.topBar, opacity.topBar, fgs.topBarLink), fgs.topBarLink)\n }\n\n return Object.entries(ratios).reduce((acc, [k, v]) => { acc[k] = hints(v); return acc }, {})\n },\n previewRules () {\n if (!this.preview.rules) return ''\n return [\n ...Object.values(this.preview.rules),\n 'color: var(--text)',\n 'font-family: var(--interfaceFont, sans-serif)'\n ].join(';')\n },\n shadowsAvailable () {\n return Object.keys(this.previewTheme.shadows).sort()\n },\n currentShadowOverriden: {\n get () {\n return !!this.currentShadow\n },\n set (val) {\n if (val) {\n set(this.shadowsLocal, this.shadowSelected, this.currentShadowFallback.map(_ => Object.assign({}, _)))\n } else {\n del(this.shadowsLocal, this.shadowSelected)\n }\n }\n },\n currentShadowFallback () {\n return this.previewTheme.shadows[this.shadowSelected]\n },\n currentShadow: {\n get () {\n return this.shadowsLocal[this.shadowSelected]\n },\n set (v) {\n set(this.shadowsLocal, this.shadowSelected, v)\n }\n },\n themeValid () {\n return !this.shadowsInvalid && !this.colorsInvalid && !this.radiiInvalid\n },\n exportedTheme () {\n const saveEverything = (\n !this.keepFonts &&\n !this.keepShadows &&\n !this.keepOpacity &&\n !this.keepRoundness &&\n !this.keepColor\n )\n\n const theme = {}\n\n if (this.keepFonts || saveEverything) {\n theme.fonts = this.fontsLocal\n }\n if (this.keepShadows || saveEverything) {\n theme.shadows = this.shadowsLocal\n }\n if (this.keepOpacity || saveEverything) {\n theme.opacity = this.currentOpacity\n }\n if (this.keepColor || saveEverything) {\n theme.colors = this.currentColors\n }\n if (this.keepRoundness || saveEverything) {\n theme.radii = this.currentRadii\n }\n\n return {\n // To separate from other random JSON files and possible future theme formats\n _pleroma_theme_version: 2, theme\n }\n }\n },\n components: {\n ColorInput,\n OpacityInput,\n RangeInput,\n ContrastRatio,\n ShadowControl,\n FontControl,\n TabSwitcher,\n Preview,\n ExportImport\n },\n methods: {\n setCustomTheme () {\n this.$store.dispatch('setOption', {\n name: 'customTheme',\n value: {\n shadows: this.shadowsLocal,\n fonts: this.fontsLocal,\n opacity: this.currentOpacity,\n colors: this.currentColors,\n radii: this.currentRadii\n }\n })\n },\n onImport (parsed) {\n if (parsed._pleroma_theme_version === 1) {\n this.normalizeLocalState(parsed, 1)\n } else if (parsed._pleroma_theme_version === 2) {\n this.normalizeLocalState(parsed.theme, 2)\n }\n },\n importValidator (parsed) {\n const version = parsed._pleroma_theme_version\n return version >= 1 || version <= 2\n },\n clearAll () {\n const state = this.$store.state.config.customTheme\n const version = state.colors ? 2 : 'l1'\n this.normalizeLocalState(this.$store.state.config.customTheme, version)\n },\n\n // Clears all the extra stuff when loading V1 theme\n clearV1 () {\n Object.keys(this.$data)\n .filter(_ => _.endsWith('ColorLocal') || _.endsWith('OpacityLocal'))\n .filter(_ => !v1OnlyNames.includes(_))\n .forEach(key => {\n set(this.$data, key, undefined)\n })\n },\n\n clearRoundness () {\n Object.keys(this.$data)\n .filter(_ => _.endsWith('RadiusLocal'))\n .forEach(key => {\n set(this.$data, key, undefined)\n })\n },\n\n clearOpacity () {\n Object.keys(this.$data)\n .filter(_ => _.endsWith('OpacityLocal'))\n .forEach(key => {\n set(this.$data, key, undefined)\n })\n },\n\n clearShadows () {\n this.shadowsLocal = {}\n },\n\n clearFonts () {\n this.fontsLocal = {}\n },\n\n /**\n * This applies stored theme data onto form. Supports three versions of data:\n * v2 (version = 2) - newer version of themes.\n * v1 (version = 1) - older version of themes (import from file)\n * v1l (version = l1) - older version of theme (load from local storage)\n * v1 and v1l differ because of way themes were stored/exported.\n * @param {Object} input - input data\n * @param {Number} version - version of data. 0 means try to guess based on data. \"l1\" means v1, locastorage type\n */\n normalizeLocalState (input, version = 0) {\n const colors = input.colors || input\n const radii = input.radii || input\n const opacity = input.opacity\n const shadows = input.shadows || {}\n const fonts = input.fonts || {}\n\n if (version === 0) {\n if (input.version) version = input.version\n // Old v1 naming: fg is text, btn is foreground\n if (typeof colors.text === 'undefined' && typeof colors.fg !== 'undefined') {\n version = 1\n }\n // New v2 naming: text is text, fg is foreground\n if (typeof colors.text !== 'undefined' && typeof colors.fg !== 'undefined') {\n version = 2\n }\n }\n\n // Stuff that differs between V1 and V2\n if (version === 1) {\n this.fgColorLocal = rgb2hex(colors.btn)\n this.textColorLocal = rgb2hex(colors.fg)\n }\n\n if (!this.keepColor) {\n this.clearV1()\n const keys = new Set(version !== 1 ? Object.keys(colors) : [])\n if (version === 1 || version === 'l1') {\n keys\n .add('bg')\n .add('link')\n .add('cRed')\n .add('cBlue')\n .add('cGreen')\n .add('cOrange')\n }\n\n keys.forEach(key => {\n this[key + 'ColorLocal'] = rgb2hex(colors[key])\n })\n }\n\n if (!this.keepRoundness) {\n this.clearRoundness()\n Object.entries(radii).forEach(([k, v]) => {\n // 'Radius' is kept mostly for v1->v2 localstorage transition\n const key = k.endsWith('Radius') ? k.split('Radius')[0] : k\n this[key + 'RadiusLocal'] = v\n })\n }\n\n if (!this.keepShadows) {\n this.clearShadows()\n this.shadowsLocal = shadows\n this.shadowSelected = this.shadowsAvailable[0]\n }\n\n if (!this.keepFonts) {\n this.clearFonts()\n this.fontsLocal = fonts\n }\n\n if (opacity && !this.keepOpacity) {\n this.clearOpacity()\n Object.entries(opacity).forEach(([k, v]) => {\n if (typeof v === 'undefined' || v === null || Number.isNaN(v)) return\n this[k + 'OpacityLocal'] = v\n })\n }\n }\n },\n watch: {\n currentRadii () {\n try {\n this.previewRadii = generateRadii({ radii: this.currentRadii })\n this.radiiInvalid = false\n } catch (e) {\n this.radiiInvalid = true\n console.warn(e)\n }\n },\n shadowsLocal: {\n handler () {\n try {\n this.previewShadows = generateShadows({ shadows: this.shadowsLocal })\n this.shadowsInvalid = false\n } catch (e) {\n this.shadowsInvalid = true\n console.warn(e)\n }\n },\n deep: true\n },\n fontsLocal: {\n handler () {\n try {\n this.previewFonts = generateFonts({ fonts: this.fontsLocal })\n this.fontsInvalid = false\n } catch (e) {\n this.fontsInvalid = true\n console.warn(e)\n }\n },\n deep: true\n },\n currentColors () {\n try {\n this.previewColors = generateColors({\n opacity: this.currentOpacity,\n colors: this.currentColors\n })\n this.colorsInvalid = false\n } catch (e) {\n this.colorsInvalid = true\n console.warn(e)\n }\n },\n currentOpacity () {\n try {\n this.previewColors = generateColors({\n opacity: this.currentOpacity,\n colors: this.currentColors\n })\n } catch (e) {\n console.warn(e)\n }\n },\n selected () {\n if (this.selectedVersion === 1) {\n if (!this.keepRoundness) {\n this.clearRoundness()\n }\n\n if (!this.keepShadows) {\n this.clearShadows()\n }\n\n if (!this.keepOpacity) {\n this.clearOpacity()\n }\n\n if (!this.keepColor) {\n this.clearV1()\n\n this.bgColorLocal = this.selected[1]\n this.fgColorLocal = this.selected[2]\n this.textColorLocal = this.selected[3]\n this.linkColorLocal = this.selected[4]\n this.cRedColorLocal = this.selected[5]\n this.cGreenColorLocal = this.selected[6]\n this.cBlueColorLocal = this.selected[7]\n this.cOrangeColorLocal = this.selected[8]\n }\n } else if (this.selectedVersion >= 2) {\n this.normalizeLocalState(this.selected.theme, 2)\n }\n }\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/style_switcher/style_switcher.js","import Timeline from '../timeline/timeline.vue'\n\nconst TagTimeline = {\n created () {\n this.$store.commit('clearTimeline', { timeline: 'tag' })\n this.$store.dispatch('startFetching', { timeline: 'tag', tag: this.tag })\n },\n components: {\n Timeline\n },\n computed: {\n tag () { return this.$route.params.tag },\n timeline () { return this.$store.state.statuses.timelines.tag }\n },\n watch: {\n tag () {\n this.$store.commit('clearTimeline', { timeline: 'tag' })\n this.$store.dispatch('startFetching', { timeline: 'tag', tag: this.tag })\n }\n },\n destroyed () {\n this.$store.dispatch('stopFetching', 'tag')\n }\n}\n\nexport default TagTimeline\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/tag_timeline/tag_timeline.js","const TermsOfServicePanel = {\n computed: {\n content () {\n return this.$store.state.instance.tos\n }\n }\n}\n\nexport default TermsOfServicePanel\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/terms_of_service_panel/terms_of_service_panel.js","import Status from '../status/status.vue'\nimport timelineFetcher from '../../services/timeline_fetcher/timeline_fetcher.service.js'\nimport StatusOrConversation from '../status_or_conversation/status_or_conversation.vue'\nimport { throttle } from 'lodash'\n\nconst Timeline = {\n props: [\n 'timeline',\n 'timelineName',\n 'title',\n 'userId',\n 'tag',\n 'embedded',\n 'count'\n ],\n data () {\n return {\n paused: false,\n unfocused: false,\n bottomedOut: false\n }\n },\n computed: {\n timelineError () { return this.$store.state.statuses.error },\n newStatusCount () {\n return this.timeline.newStatusCount\n },\n newStatusCountStr () {\n if (this.timeline.flushMarker !== 0) {\n return ''\n } else {\n return ` (${this.newStatusCount})`\n }\n },\n classes () {\n return {\n root: ['timeline'].concat(!this.embedded ? ['panel', 'panel-default'] : []),\n header: ['timeline-heading'].concat(!this.embedded ? ['panel-heading'] : []),\n body: ['timeline-body'].concat(!this.embedded ? ['panel-body'] : []),\n footer: ['timeline-footer'].concat(!this.embedded ? ['panel-footer'] : [])\n }\n }\n },\n components: {\n Status,\n StatusOrConversation\n },\n created () {\n const store = this.$store\n const credentials = store.state.users.currentUser.credentials\n const showImmediately = this.timeline.visibleStatuses.length === 0\n\n window.addEventListener('scroll', this.scrollLoad)\n\n if (this.timelineName === 'friends' && !credentials) { return false }\n\n timelineFetcher.fetchAndUpdate({\n store,\n credentials,\n timeline: this.timelineName,\n showImmediately,\n userId: this.userId,\n tag: this.tag\n })\n },\n mounted () {\n if (typeof document.hidden !== 'undefined') {\n document.addEventListener('visibilitychange', this.handleVisibilityChange, false)\n this.unfocused = document.hidden\n }\n window.addEventListener('keydown', this.handleShortKey)\n },\n destroyed () {\n window.removeEventListener('scroll', this.scrollLoad)\n window.removeEventListener('keydown', this.handleShortKey)\n if (typeof document.hidden !== 'undefined') document.removeEventListener('visibilitychange', this.handleVisibilityChange, false)\n this.$store.commit('setLoading', { timeline: this.timelineName, value: false })\n },\n methods: {\n handleShortKey (e) {\n if (e.key === '.') this.showNewStatuses()\n },\n showNewStatuses () {\n if (this.newStatusCount === 0) return\n\n if (this.timeline.flushMarker !== 0) {\n this.$store.commit('clearTimeline', { timeline: this.timelineName })\n this.$store.commit('queueFlush', { timeline: this.timelineName, id: 0 })\n this.fetchOlderStatuses()\n } else {\n this.$store.commit('showNewStatuses', { timeline: this.timelineName })\n this.paused = false\n }\n },\n fetchOlderStatuses: throttle(function () {\n const store = this.$store\n const credentials = store.state.users.currentUser.credentials\n store.commit('setLoading', { timeline: this.timelineName, value: true })\n timelineFetcher.fetchAndUpdate({\n store,\n credentials,\n timeline: this.timelineName,\n older: true,\n showImmediately: true,\n userId: this.userId,\n tag: this.tag\n }).then(statuses => {\n store.commit('setLoading', { timeline: this.timelineName, value: false })\n if (statuses && statuses.length === 0) {\n this.bottomedOut = true\n }\n })\n }, 1000, this),\n scrollLoad (e) {\n const bodyBRect = document.body.getBoundingClientRect()\n const height = Math.max(bodyBRect.height, -(bodyBRect.y))\n if (this.timeline.loading === false &&\n this.$store.state.config.autoLoad &&\n this.$el.offsetHeight > 0 &&\n (window.innerHeight + window.pageYOffset) >= (height - 750)) {\n this.fetchOlderStatuses()\n }\n },\n handleVisibilityChange () {\n this.unfocused = document.hidden\n }\n },\n watch: {\n newStatusCount (count) {\n if (!this.$store.state.config.streaming) {\n return\n }\n if (count > 0) {\n // only 'stream' them when you're scrolled to the top\n if (window.pageYOffset < 15 &&\n !this.paused &&\n !(this.unfocused && this.$store.state.config.pauseOnUnfocused)\n ) {\n this.showNewStatuses()\n } else {\n this.paused = true\n }\n }\n }\n }\n}\n\nexport default Timeline\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/timeline/timeline.js","import StillImage from '../still-image/still-image.vue'\n\nconst UserAvatar = {\n props: [\n 'src',\n 'betterShadow',\n 'compact'\n ],\n data () {\n return {\n showPlaceholder: false\n }\n },\n components: {\n StillImage\n },\n computed: {\n imgSrc () {\n return this.showPlaceholder ? '/images/avi.png' : this.src\n }\n },\n methods: {\n imageLoadError () {\n this.showPlaceholder = true\n }\n }\n}\n\nexport default UserAvatar\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/user_avatar/user_avatar.js","import UserAvatar from '../user_avatar/user_avatar.vue'\nimport { hex2rgb } from '../../services/color_convert/color_convert.js'\nimport { requestFollow, requestUnfollow } from '../../services/follow_manipulate/follow_manipulate'\nimport generateProfileLink from 'src/services/user_profile_link_generator/user_profile_link_generator'\n\nexport default {\n props: [ 'user', 'switcher', 'selected', 'hideBio' ],\n data () {\n return {\n followRequestInProgress: false,\n followRequestSent: false,\n hideUserStatsLocal: typeof this.$store.state.config.hideUserStats === 'undefined'\n ? this.$store.state.instance.hideUserStats\n : this.$store.state.config.hideUserStats,\n betterShadow: this.$store.state.interface.browserSupport.cssFilter\n }\n },\n computed: {\n headingStyle () {\n const color = this.$store.state.config.customTheme.colors\n ? this.$store.state.config.customTheme.colors.bg // v2\n : this.$store.state.config.colors.bg // v1\n\n if (color) {\n const rgb = (typeof color === 'string') ? hex2rgb(color) : color\n const tintColor = `rgba(${Math.floor(rgb.r)}, ${Math.floor(rgb.g)}, ${Math.floor(rgb.b)}, .5)`\n\n const gradient = [\n [tintColor, this.hideBio ? '60%' : ''],\n this.hideBio ? [\n color, '100%'\n ] : [\n tintColor, ''\n ]\n ].map(_ => _.join(' ')).join(', ')\n\n return {\n backgroundColor: `rgb(${Math.floor(rgb.r * 0.53)}, ${Math.floor(rgb.g * 0.56)}, ${Math.floor(rgb.b * 0.59)})`,\n backgroundImage: [\n `linear-gradient(to bottom, ${gradient})`,\n `url(${this.user.cover_photo})`\n ].join(', ')\n }\n }\n },\n isOtherUser () {\n return this.user.id !== this.$store.state.users.currentUser.id\n },\n subscribeUrl () {\n // eslint-disable-next-line no-undef\n const serverUrl = new URL(this.user.statusnet_profile_url)\n return `${serverUrl.protocol}//${serverUrl.host}/main/ostatus`\n },\n loggedIn () {\n return this.$store.state.users.currentUser\n },\n dailyAvg () {\n const days = Math.ceil((new Date() - new Date(this.user.created_at)) / (60 * 60 * 24 * 1000))\n return Math.round(this.user.statuses_count / days)\n },\n userHighlightType: {\n get () {\n const data = this.$store.state.config.highlight[this.user.screen_name]\n return data && data.type || 'disabled'\n },\n set (type) {\n const data = this.$store.state.config.highlight[this.user.screen_name]\n if (type !== 'disabled') {\n this.$store.dispatch('setHighlight', { user: this.user.screen_name, color: data && data.color || '#FFFFFF', type })\n } else {\n this.$store.dispatch('setHighlight', { user: this.user.screen_name, color: undefined })\n }\n }\n },\n userHighlightColor: {\n get () {\n const data = this.$store.state.config.highlight[this.user.screen_name]\n return data && data.color\n },\n set (color) {\n this.$store.dispatch('setHighlight', { user: this.user.screen_name, color })\n }\n },\n visibleRole () {\n const validRole = (this.user.role === 'admin' || this.user.role === 'moderator')\n const showRole = this.isOtherUser || this.user.show_role\n\n return validRole && showRole && this.user.role\n }\n },\n components: {\n UserAvatar\n },\n methods: {\n followUser () {\n this.followRequestInProgress = true\n requestFollow(this.user, this.$store).then(({sent}) => {\n this.followRequestInProgress = false\n this.followRequestSent = sent\n })\n },\n unfollowUser () {\n this.followRequestInProgress = true\n requestUnfollow(this.user, this.$store).then(() => {\n this.followRequestInProgress = false\n })\n },\n blockUser () {\n const store = this.$store\n store.state.api.backendInteractor.blockUser(this.user.id)\n .then((blockedUser) => store.commit('addNewUsers', [blockedUser]))\n },\n unblockUser () {\n const store = this.$store\n store.state.api.backendInteractor.unblockUser(this.user.id)\n .then((unblockedUser) => store.commit('addNewUsers', [unblockedUser]))\n },\n toggleMute () {\n const store = this.$store\n store.commit('setMuted', {user: this.user, muted: !this.user.muted})\n store.state.api.backendInteractor.setUserMute(this.user)\n },\n setProfileView (v) {\n if (this.switcher) {\n const store = this.$store\n store.commit('setProfileView', { v })\n }\n },\n linkClicked ({target}) {\n if (target.tagName === 'SPAN') {\n target = target.parentNode\n }\n if (target.tagName === 'A') {\n window.open(target.href, '_blank')\n }\n },\n userProfileLink (user) {\n return generateProfileLink(user.id, user.screen_name, this.$store.state.instance.restrictedNicknames)\n }\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/user_card_content/user_card_content.js","const UserFinder = {\n data: () => ({\n username: undefined,\n hidden: true,\n error: false,\n loading: false\n }),\n methods: {\n findUser (username) {\n this.$router.push({ name: 'user-search', query: { query: username } })\n this.$refs.userSearchInput.focus()\n },\n toggleHidden () {\n this.hidden = !this.hidden\n this.$emit('toggled', this.hidden)\n }\n }\n}\n\nexport default UserFinder\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/user_finder/user_finder.js","import LoginForm from '../login_form/login_form.vue'\nimport PostStatusForm from '../post_status_form/post_status_form.vue'\nimport UserCardContent from '../user_card_content/user_card_content.vue'\n\nconst UserPanel = {\n computed: {\n user () { return this.$store.state.users.currentUser }\n },\n components: {\n LoginForm,\n PostStatusForm,\n UserCardContent\n }\n}\n\nexport default UserPanel\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/user_panel/user_panel.js","import { compose } from 'vue-compose'\nimport get from 'lodash/get'\nimport UserCardContent from '../user_card_content/user_card_content.vue'\nimport FollowCard from '../follow_card/follow_card.vue'\nimport Timeline from '../timeline/timeline.vue'\nimport withLoadMore from '../../hocs/with_load_more/with_load_more'\nimport withList from '../../hocs/with_list/with_list'\n\nconst FollowerList = compose(\n withLoadMore({\n fetch: (props, $store) => $store.dispatch('addFollowers', props.userId),\n select: (props, $store) => get($store.getters.userById(props.userId), 'followers', []),\n destory: (props, $store) => $store.dispatch('clearFollowers', props.userId),\n childPropName: 'entries',\n additionalPropNames: ['userId']\n }),\n withList({ getEntryProps: user => ({ user }) })\n)(FollowCard)\n\nconst FriendList = compose(\n withLoadMore({\n fetch: (props, $store) => $store.dispatch('addFriends', props.userId),\n select: (props, $store) => get($store.getters.userById(props.userId), 'friends', []),\n destory: (props, $store) => $store.dispatch('clearFriends', props.userId),\n childPropName: 'entries',\n additionalPropNames: ['userId']\n }),\n withList({ getEntryProps: user => ({ user }) })\n)(FollowCard)\n\nconst UserProfile = {\n data () {\n return {\n error: false\n }\n },\n created () {\n this.$store.commit('clearTimeline', { timeline: 'user' })\n this.$store.commit('clearTimeline', { timeline: 'favorites' })\n this.$store.commit('clearTimeline', { timeline: 'media' })\n this.$store.dispatch('startFetching', { timeline: 'user', userId: this.fetchBy })\n this.$store.dispatch('startFetching', { timeline: 'media', userId: this.fetchBy })\n this.startFetchFavorites()\n if (!this.user.id) {\n this.$store.dispatch('fetchUser', this.fetchBy)\n .catch((reason) => {\n const errorMessage = get(reason, 'error.error')\n if (errorMessage === 'No user with such user_id') { // Known error\n this.error = this.$t('user_profile.profile_does_not_exist')\n } else if (errorMessage) {\n this.error = errorMessage\n } else {\n this.error = this.$t('user_profile.profile_loading_error')\n }\n })\n }\n },\n destroyed () {\n this.cleanUp()\n },\n computed: {\n timeline () {\n return this.$store.state.statuses.timelines.user\n },\n favorites () {\n return this.$store.state.statuses.timelines.favorites\n },\n media () {\n return this.$store.state.statuses.timelines.media\n },\n userId () {\n return this.$route.params.id || this.user.id\n },\n userName () {\n return this.$route.params.name || this.user.screen_name\n },\n isUs () {\n return this.userId && this.$store.state.users.currentUser.id &&\n this.userId === this.$store.state.users.currentUser.id\n },\n userInStore () {\n if (this.isExternal) {\n return this.$store.getters.userById(this.userId)\n }\n return this.$store.getters.userByName(this.userName)\n },\n user () {\n if (this.timeline.statuses[0]) {\n return this.timeline.statuses[0].user\n }\n if (this.userInStore) {\n return this.userInStore\n }\n return {}\n },\n fetchBy () {\n return this.isExternal ? this.userId : this.userName\n },\n isExternal () {\n return this.$route.name === 'external-user-profile'\n },\n followsTabVisible () {\n return this.isUs || !this.user.hide_follows\n },\n followersTabVisible () {\n return this.isUs || !this.user.hide_followers\n }\n },\n methods: {\n startFetchFavorites () {\n if (this.isUs) {\n this.$store.dispatch('startFetching', { timeline: 'favorites', userId: this.fetchBy })\n }\n },\n startUp () {\n this.$store.dispatch('startFetching', { timeline: 'user', userId: this.fetchBy })\n this.$store.dispatch('startFetching', { timeline: 'media', userId: this.fetchBy })\n\n this.startFetchFavorites()\n },\n cleanUp () {\n this.$store.dispatch('stopFetching', 'user')\n this.$store.dispatch('stopFetching', 'favorites')\n this.$store.dispatch('stopFetching', 'media')\n this.$store.commit('clearTimeline', { timeline: 'user' })\n this.$store.commit('clearTimeline', { timeline: 'favorites' })\n this.$store.commit('clearTimeline', { timeline: 'media' })\n }\n },\n watch: {\n userName () {\n if (this.isExternal) {\n return\n }\n this.cleanUp()\n this.startUp()\n },\n userId () {\n if (!this.isExternal) {\n return\n }\n this.cleanUp()\n this.startUp()\n },\n $route () {\n this.$refs.tabSwitcher.activateTab(0)()\n }\n },\n components: {\n UserCardContent,\n Timeline,\n FollowerList,\n FriendList\n }\n}\n\nexport default UserProfile\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/user_profile/user_profile.js","import FollowCard from '../follow_card/follow_card.vue'\nimport userSearchApi from '../../services/new_api/user_search.js'\nconst userSearch = {\n components: {\n FollowCard\n },\n props: [\n 'query'\n ],\n data () {\n return {\n username: '',\n users: [],\n loading: false\n }\n },\n mounted () {\n this.search(this.query)\n },\n watch: {\n query (newV) {\n this.search(newV)\n }\n },\n methods: {\n newQuery (query) {\n this.$router.push({ name: 'user-search', query: { query } })\n this.$refs.userSearchInput.focus()\n },\n search (query) {\n if (!query) {\n this.users = []\n return\n }\n this.loading = true\n userSearchApi.search({query, store: this.$store})\n .then((res) => {\n this.loading = false\n this.users = res\n })\n }\n }\n}\n\nexport default userSearch\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/user_search/user_search.js","import { compose } from 'vue-compose'\nimport unescape from 'lodash/unescape'\nimport get from 'lodash/get'\nimport TabSwitcher from '../tab_switcher/tab_switcher.js'\nimport ImageCropper from '../image_cropper/image_cropper.vue'\nimport StyleSwitcher from '../style_switcher/style_switcher.vue'\nimport fileSizeFormatService from '../../services/file_size_format/file_size_format.js'\nimport BlockCard from '../block_card/block_card.vue'\nimport MuteCard from '../mute_card/mute_card.vue'\nimport withSubscription from '../../hocs/with_subscription/with_subscription'\nimport withList from '../../hocs/with_list/with_list'\n\nconst BlockList = compose(\n withSubscription({\n fetch: (props, $store) => $store.dispatch('fetchBlocks'),\n select: (props, $store) => get($store.state.users.currentUser, 'blockIds', []),\n childPropName: 'entries'\n }),\n withList({ getEntryProps: userId => ({ userId }) })\n)(BlockCard)\n\nconst MuteList = compose(\n withSubscription({\n fetch: (props, $store) => $store.dispatch('fetchMutes'),\n select: (props, $store) => get($store.state.users.currentUser, 'muteIds', []),\n childPropName: 'entries'\n }),\n withList({ getEntryProps: userId => ({ userId }) })\n)(MuteCard)\n\nconst UserSettings = {\n data () {\n return {\n newName: this.$store.state.users.currentUser.name,\n newBio: unescape(this.$store.state.users.currentUser.description),\n newLocked: this.$store.state.users.currentUser.locked,\n newNoRichText: this.$store.state.users.currentUser.no_rich_text,\n newDefaultScope: this.$store.state.users.currentUser.default_scope,\n hideFollows: this.$store.state.users.currentUser.hide_follows,\n hideFollowers: this.$store.state.users.currentUser.hide_followers,\n showRole: this.$store.state.users.currentUser.show_role,\n role: this.$store.state.users.currentUser.role,\n followList: null,\n followImportError: false,\n followsImported: false,\n enableFollowsExport: true,\n pickAvatarBtnVisible: true,\n bannerUploading: false,\n backgroundUploading: false,\n followListUploading: false,\n bannerPreview: null,\n backgroundPreview: null,\n bannerUploadError: null,\n backgroundUploadError: null,\n deletingAccount: false,\n deleteAccountConfirmPasswordInput: '',\n deleteAccountError: false,\n changePasswordInputs: [ '', '', '' ],\n changedPassword: false,\n changePasswordError: false,\n activeTab: 'profile'\n }\n },\n created () {\n this.$store.dispatch('fetchTokens')\n },\n components: {\n StyleSwitcher,\n TabSwitcher,\n ImageCropper,\n BlockList,\n MuteList\n },\n computed: {\n user () {\n return this.$store.state.users.currentUser\n },\n pleromaBackend () {\n return this.$store.state.instance.pleromaBackend\n },\n scopeOptionsEnabled () {\n return this.$store.state.instance.scopeOptionsEnabled\n },\n vis () {\n return {\n public: { selected: this.newDefaultScope === 'public' },\n unlisted: { selected: this.newDefaultScope === 'unlisted' },\n private: { selected: this.newDefaultScope === 'private' },\n direct: { selected: this.newDefaultScope === 'direct' }\n }\n },\n currentSaveStateNotice () {\n return this.$store.state.interface.settings.currentSaveStateNotice\n },\n oauthTokens () {\n return this.$store.state.oauthTokens.tokens.map(oauthToken => {\n return {\n id: oauthToken.id,\n appName: oauthToken.app_name,\n validUntil: new Date(oauthToken.valid_until).toLocaleDateString()\n }\n })\n }\n },\n methods: {\n updateProfile () {\n const name = this.newName\n const description = this.newBio\n const locked = this.newLocked\n // Backend notation.\n /* eslint-disable camelcase */\n const default_scope = this.newDefaultScope\n const no_rich_text = this.newNoRichText\n const hide_follows = this.hideFollows\n const hide_followers = this.hideFollowers\n const show_role = this.showRole\n\n /* eslint-enable camelcase */\n this.$store.state.api.backendInteractor\n .updateProfile({\n params: {\n name,\n description,\n locked,\n // Backend notation.\n /* eslint-disable camelcase */\n default_scope,\n no_rich_text,\n hide_follows,\n hide_followers,\n show_role\n /* eslint-enable camelcase */\n }}).then((user) => {\n if (!user.error) {\n this.$store.commit('addNewUsers', [user])\n this.$store.commit('setCurrentUser', user)\n }\n })\n },\n changeVis (visibility) {\n this.newDefaultScope = visibility\n },\n uploadFile (slot, e) {\n const file = e.target.files[0]\n if (!file) { return }\n if (file.size > this.$store.state.instance[slot + 'limit']) {\n const filesize = fileSizeFormatService.fileSizeFormat(file.size)\n const allowedsize = fileSizeFormatService.fileSizeFormat(this.$store.state.instance[slot + 'limit'])\n this[slot + 'UploadError'] = this.$t('upload.error.base') + ' ' + this.$t('upload.error.file_too_big', {filesize: filesize.num, filesizeunit: filesize.unit, allowedsize: allowedsize.num, allowedsizeunit: allowedsize.unit})\n return\n }\n // eslint-disable-next-line no-undef\n const reader = new FileReader()\n reader.onload = ({target}) => {\n const img = target.result\n this[slot + 'Preview'] = img\n }\n reader.readAsDataURL(file)\n },\n submitAvatar (cropper, file) {\n const img = cropper.getCroppedCanvas().toDataURL(file.type)\n return this.$store.state.api.backendInteractor.updateAvatar({ params: { img } }).then((user) => {\n if (!user.error) {\n this.$store.commit('addNewUsers', [user])\n this.$store.commit('setCurrentUser', user)\n } else {\n throw new Error(this.$t('upload.error.base') + user.error)\n }\n })\n },\n clearUploadError (slot) {\n this[slot + 'UploadError'] = null\n },\n submitBanner () {\n if (!this.bannerPreview) { return }\n\n let banner = this.bannerPreview\n // eslint-disable-next-line no-undef\n let imginfo = new Image()\n /* eslint-disable camelcase */\n let offset_top, offset_left, width, height\n imginfo.src = banner\n width = imginfo.width\n height = imginfo.height\n offset_top = 0\n offset_left = 0\n this.bannerUploading = true\n this.$store.state.api.backendInteractor.updateBanner({params: {banner, offset_top, offset_left, width, height}}).then((data) => {\n if (!data.error) {\n let clone = JSON.parse(JSON.stringify(this.$store.state.users.currentUser))\n clone.cover_photo = data.url\n this.$store.commit('addNewUsers', [clone])\n this.$store.commit('setCurrentUser', clone)\n this.bannerPreview = null\n } else {\n this.bannerUploadError = this.$t('upload.error.base') + data.error\n }\n this.bannerUploading = false\n })\n /* eslint-enable camelcase */\n },\n submitBg () {\n if (!this.backgroundPreview) { return }\n let img = this.backgroundPreview\n // eslint-disable-next-line no-undef\n let imginfo = new Image()\n let cropX, cropY, cropW, cropH\n imginfo.src = img\n cropX = 0\n cropY = 0\n cropW = imginfo.width\n cropH = imginfo.width\n this.backgroundUploading = true\n this.$store.state.api.backendInteractor.updateBg({params: {img, cropX, cropY, cropW, cropH}}).then((data) => {\n if (!data.error) {\n let clone = JSON.parse(JSON.stringify(this.$store.state.users.currentUser))\n clone.background_image = data.url\n this.$store.commit('addNewUsers', [clone])\n this.$store.commit('setCurrentUser', clone)\n this.backgroundPreview = null\n } else {\n this.backgroundUploadError = this.$t('upload.error.base') + data.error\n }\n this.backgroundUploading = false\n })\n },\n importFollows () {\n this.followListUploading = true\n const followList = this.followList\n this.$store.state.api.backendInteractor.followImport({params: followList})\n .then((status) => {\n if (status) {\n this.followsImported = true\n } else {\n this.followImportError = true\n }\n this.followListUploading = false\n })\n },\n /* This function takes an Array of Users\n * and outputs a file with all the addresses for the user to download\n */\n exportPeople (users, filename) {\n // Get all the friends addresses\n var UserAddresses = users.map(function (user) {\n // check is it's a local user\n if (user && user.is_local) {\n // append the instance address\n // eslint-disable-next-line no-undef\n user.screen_name += '@' + location.hostname\n }\n return user.screen_name\n }).join('\\n')\n // Make the user download the file\n var fileToDownload = document.createElement('a')\n fileToDownload.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(UserAddresses))\n fileToDownload.setAttribute('download', filename)\n fileToDownload.style.display = 'none'\n document.body.appendChild(fileToDownload)\n fileToDownload.click()\n document.body.removeChild(fileToDownload)\n },\n exportFollows () {\n this.enableFollowsExport = false\n this.$store.state.api.backendInteractor\n .exportFriends({\n id: this.$store.state.users.currentUser.id\n })\n .then((friendList) => {\n this.exportPeople(friendList, 'friends.csv')\n setTimeout(() => { this.enableFollowsExport = true }, 2000)\n })\n },\n followListChange () {\n // eslint-disable-next-line no-undef\n let formData = new FormData()\n formData.append('list', this.$refs.followlist.files[0])\n this.followList = formData\n },\n dismissImported () {\n this.followsImported = false\n this.followImportError = false\n },\n confirmDelete () {\n this.deletingAccount = true\n },\n deleteAccount () {\n this.$store.state.api.backendInteractor.deleteAccount({password: this.deleteAccountConfirmPasswordInput})\n .then((res) => {\n if (res.status === 'success') {\n this.$store.dispatch('logout')\n this.$router.push({name: 'root'})\n } else {\n this.deleteAccountError = res.error\n }\n })\n },\n changePassword () {\n const params = {\n password: this.changePasswordInputs[0],\n newPassword: this.changePasswordInputs[1],\n newPasswordConfirmation: this.changePasswordInputs[2]\n }\n this.$store.state.api.backendInteractor.changePassword(params)\n .then((res) => {\n if (res.status === 'success') {\n this.changedPassword = true\n this.changePasswordError = false\n this.logout()\n } else {\n this.changedPassword = false\n this.changePasswordError = res.error\n }\n })\n },\n activateTab (tabName) {\n this.activeTab = tabName\n },\n logout () {\n this.$store.dispatch('logout')\n this.$router.replace('/')\n },\n revokeToken (id) {\n if (window.confirm(`${this.$i18n.t('settings.revoke_token')}?`)) {\n this.$store.dispatch('revokeToken', id)\n }\n }\n }\n}\n\nexport default UserSettings\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/user_settings/user_settings.js","\nconst VideoAttachment = {\n props: ['attachment', 'controls'],\n data () {\n return {\n loopVideo: this.$store.state.config.loopVideo\n }\n },\n methods: {\n onVideoDataLoad (e) {\n const target = e.srcElement || e.target\n if (typeof target.webkitAudioDecodedByteCount !== 'undefined') {\n // non-zero if video has audio track\n if (target.webkitAudioDecodedByteCount > 0) {\n this.loopVideo = this.loopVideo && !this.$store.state.config.loopVideoSilentOnly\n }\n } else if (typeof target.mozHasAudio !== 'undefined') {\n // true if video has audio track\n if (target.mozHasAudio) {\n this.loopVideo = this.loopVideo && !this.$store.state.config.loopVideoSilentOnly\n }\n } else if (typeof target.audioTracks !== 'undefined') {\n if (target.audioTracks.length > 0) {\n this.loopVideo = this.loopVideo && !this.$store.state.config.loopVideoSilentOnly\n }\n }\n }\n }\n}\n\nexport default VideoAttachment\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/video_attachment/video_attachment.js","import apiService from '../../services/api/api.service.js'\nimport FollowCard from '../follow_card/follow_card.vue'\n\nconst WhoToFollow = {\n components: {\n FollowCard\n },\n data () {\n return {\n users: []\n }\n },\n mounted () {\n this.getWhoToFollow()\n },\n methods: {\n showWhoToFollow (reply) {\n reply.forEach((i, index) => {\n const user = {\n id: 0,\n name: i.display_name,\n screen_name: i.acct,\n profile_image_url: i.avatar || '/images/avi.png'\n }\n this.users.push(user)\n\n this.$store.state.api.backendInteractor.externalProfile(user.screen_name)\n .then((externalUser) => {\n if (!externalUser.error) {\n this.$store.commit('addNewUsers', [externalUser])\n user.id = externalUser.id\n }\n })\n })\n },\n getWhoToFollow () {\n const credentials = this.$store.state.users.currentUser.credentials\n if (credentials) {\n apiService.suggestions({credentials: credentials})\n .then((reply) => {\n this.showWhoToFollow(reply)\n })\n }\n }\n }\n}\n\nexport default WhoToFollow\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/who_to_follow/who_to_follow.js","import apiService from '../../services/api/api.service.js'\nimport generateProfileLink from 'src/services/user_profile_link_generator/user_profile_link_generator'\nimport { shuffle } from 'lodash'\n\nfunction showWhoToFollow (panel, reply) {\n const shuffled = shuffle(reply)\n\n panel.usersToFollow.forEach((toFollow, index) => {\n let user = shuffled[index]\n let img = user.avatar || '/images/avi.png'\n let name = user.acct\n\n toFollow.img = img\n toFollow.name = name\n\n panel.$store.state.api.backendInteractor.externalProfile(name)\n .then((externalUser) => {\n if (!externalUser.error) {\n panel.$store.commit('addNewUsers', [externalUser])\n toFollow.id = externalUser.id\n }\n })\n })\n}\n\nfunction getWhoToFollow (panel) {\n var credentials = panel.$store.state.users.currentUser.credentials\n if (credentials) {\n panel.usersToFollow.forEach(toFollow => {\n toFollow.name = 'Loading...'\n })\n apiService.suggestions({credentials: credentials})\n .then((reply) => {\n showWhoToFollow(panel, reply)\n })\n }\n}\n\nconst WhoToFollowPanel = {\n data: () => ({\n usersToFollow: new Array(3).fill().map(x => (\n {\n img: '/images/avi.png',\n name: '',\n id: 0\n }\n ))\n }),\n computed: {\n user: function () {\n return this.$store.state.users.currentUser.screen_name\n },\n suggestionsEnabled () {\n return this.$store.state.instance.suggestionsEnabled\n }\n },\n methods: {\n userProfileLink (id, name) {\n return generateProfileLink(id, name, this.$store.state.instance.restrictedNicknames)\n }\n },\n watch: {\n user: function (user, oldUser) {\n if (this.suggestionsEnabled) {\n getWhoToFollow(this)\n }\n }\n },\n mounted:\n function () {\n if (this.suggestionsEnabled) {\n getWhoToFollow(this)\n }\n }\n}\n\nexport default WhoToFollowPanel\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/who_to_follow_panel/who_to_follow_panel.js","module.exports = {\"chat\":{\"title\":\"الدردشة\"},\"features_panel\":{\"chat\":\"الدردشة\",\"gopher\":\"غوفر\",\"media_proxy\":\"بروكسي الوسائط\",\"scope_options\":\"\",\"text_limit\":\"الحد الأقصى للنص\",\"title\":\"الميّزات\",\"who_to_follow\":\"للمتابعة\"},\"finder\":{\"error_fetching_user\":\"خطأ أثناء جلب صفحة المستخدم\",\"find_user\":\"البحث عن مستخدِم\"},\"general\":{\"apply\":\"تطبيق\",\"submit\":\"إرسال\"},\"login\":{\"login\":\"تسجيل الدخول\",\"logout\":\"الخروج\",\"password\":\"الكلمة السرية\",\"placeholder\":\"مثال lain\",\"register\":\"انشاء حساب\",\"username\":\"إسم المستخدم\"},\"nav\":{\"chat\":\"الدردشة المحلية\",\"friend_requests\":\"طلبات المتابَعة\",\"mentions\":\"الإشارات\",\"public_tl\":\"الخيط الزمني العام\",\"timeline\":\"الخيط الزمني\",\"twkn\":\"كافة الشبكة المعروفة\"},\"notifications\":{\"broken_favorite\":\"منشور مجهول، جارٍ البحث عنه…\",\"favorited_you\":\"أعجِب بمنشورك\",\"followed_you\":\"يُتابعك\",\"load_older\":\"تحميل الإشعارات الأقدم\",\"notifications\":\"الإخطارات\",\"read\":\"مقروء!\",\"repeated_you\":\"شارَك منشورك\"},\"post_status\":{\"account_not_locked_warning\":\"\",\"account_not_locked_warning_link\":\"مقفل\",\"attachments_sensitive\":\"اعتبر المرفقات كلها كمحتوى حساس\",\"content_type\":{\"plain_text\":\"نص صافٍ\"},\"content_warning\":\"الموضوع (اختياري)\",\"default\":\"وصلت للتوّ إلى لوس أنجلس.\",\"direct_warning\":\"\",\"posting\":\"النشر\",\"scope\":{\"direct\":\"\",\"private\":\"\",\"public\":\"علني - يُنشر على الخيوط الزمنية العمومية\",\"unlisted\":\"غير مُدرَج - لا يُنشَر على الخيوط الزمنية العمومية\"}},\"registration\":{\"bio\":\"السيرة الذاتية\",\"email\":\"عنوان البريد الإلكتروني\",\"fullname\":\"الإسم المعروض\",\"password_confirm\":\"تأكيد الكلمة السرية\",\"registration\":\"التسجيل\",\"token\":\"رمز الدعوة\"},\"settings\":{\"attachmentRadius\":\"المُرفَقات\",\"attachments\":\"المُرفَقات\",\"autoload\":\"\",\"avatar\":\"الصورة الرمزية\",\"avatarAltRadius\":\"الصور الرمزية (الإشعارات)\",\"avatarRadius\":\"الصور الرمزية\",\"background\":\"الخلفية\",\"bio\":\"السيرة الذاتية\",\"btnRadius\":\"الأزرار\",\"cBlue\":\"أزرق (الرد، المتابَعة)\",\"cGreen\":\"أخضر (إعادة النشر)\",\"cOrange\":\"برتقالي (مفضلة)\",\"cRed\":\"أحمر (إلغاء)\",\"change_password\":\"تغيير كلمة السر\",\"change_password_error\":\"وقع هناك خلل أثناء تعديل كلمتك السرية.\",\"changed_password\":\"تم تغيير كلمة المرور بنجاح!\",\"collapse_subject\":\"\",\"confirm_new_password\":\"تأكيد كلمة السر الجديدة\",\"current_avatar\":\"صورتك الرمزية الحالية\",\"current_password\":\"كلمة السر الحالية\",\"current_profile_banner\":\"الرأسية الحالية لصفحتك الشخصية\",\"data_import_export_tab\":\"تصدير واستيراد البيانات\",\"default_vis\":\"أسلوب العرض الافتراضي\",\"delete_account\":\"حذف الحساب\",\"delete_account_description\":\"حذف حسابك و كافة منشوراتك نهائيًا.\",\"delete_account_error\":\"\",\"delete_account_instructions\":\"يُرجى إدخال كلمتك السرية أدناه لتأكيد عملية حذف الحساب.\",\"export_theme\":\"حفظ النموذج\",\"filtering\":\"التصفية\",\"filtering_explanation\":\"سيتم إخفاء كافة المنشورات التي تحتوي على هذه الكلمات، كلمة واحدة في كل سطر\",\"follow_export\":\"تصدير الاشتراكات\",\"follow_export_button\":\"تصدير الاشتراكات كملف csv\",\"follow_export_processing\":\"التصدير جارٍ، سوف يُطلَب منك تنزيل ملفك بعد حين\",\"follow_import\":\"استيراد الاشتراكات\",\"follow_import_error\":\"خطأ أثناء استيراد المتابِعين\",\"follows_imported\":\"\",\"foreground\":\"الأمامية\",\"general\":\"الإعدادات العامة\",\"hide_attachments_in_convo\":\"إخفاء المرفقات على المحادثات\",\"hide_attachments_in_tl\":\"إخفاء المرفقات على الخيط الزمني\",\"hide_post_stats\":\"\",\"hide_user_stats\":\"\",\"import_followers_from_a_csv_file\":\"\",\"import_theme\":\"تحميل نموذج\",\"inputRadius\":\"\",\"instance_default\":\"\",\"interfaceLanguage\":\"لغة الواجهة\",\"invalid_theme_imported\":\"\",\"limited_availability\":\"غير متوفر على متصفحك\",\"links\":\"الروابط\",\"lock_account_description\":\"\",\"loop_video\":\"\",\"loop_video_silent_only\":\"\",\"name\":\"الاسم\",\"name_bio\":\"الاسم والسيرة الذاتية\",\"new_password\":\"كلمة السر الجديدة\",\"no_rich_text_description\":\"\",\"notification_visibility\":\"نوع الإشعارات التي تريد عرضها\",\"notification_visibility_follows\":\"يتابع\",\"notification_visibility_likes\":\"الإعجابات\",\"notification_visibility_mentions\":\"الإشارات\",\"notification_visibility_repeats\":\"\",\"nsfw_clickthrough\":\"\",\"oauth_tokens\":\"رموز OAuth\",\"token\":\"رمز\",\"refresh_token\":\"رمز التحديث\",\"valid_until\":\"صالح حتى\",\"revoke_token\":\"سحب\",\"panelRadius\":\"\",\"pause_on_unfocused\":\"\",\"presets\":\"النماذج\",\"profile_background\":\"خلفية الصفحة الشخصية\",\"profile_banner\":\"رأسية الصفحة الشخصية\",\"profile_tab\":\"الملف الشخصي\",\"radii_help\":\"\",\"replies_in_timeline\":\"الردود على الخيط الزمني\",\"reply_link_preview\":\"\",\"reply_visibility_all\":\"عرض كافة الردود\",\"reply_visibility_following\":\"\",\"reply_visibility_self\":\"\",\"saving_err\":\"خطأ أثناء حفظ الإعدادات\",\"saving_ok\":\"تم حفظ الإعدادات\",\"security_tab\":\"الأمان\",\"set_new_avatar\":\"اختيار صورة رمزية جديدة\",\"set_new_profile_background\":\"اختيار خلفية جديدة للملف الشخصي\",\"set_new_profile_banner\":\"اختيار رأسية جديدة للصفحة الشخصية\",\"settings\":\"الإعدادات\",\"stop_gifs\":\"\",\"streaming\":\"\",\"text\":\"النص\",\"theme\":\"المظهر\",\"theme_help\":\"\",\"tooltipRadius\":\"\",\"user_settings\":\"إعدادات المستخدم\",\"values\":{\"false\":\"لا\",\"true\":\"نعم\"}},\"timeline\":{\"collapse\":\"\",\"conversation\":\"محادثة\",\"error_fetching\":\"خطأ أثناء جلب التحديثات\",\"load_older\":\"تحميل المنشورات القديمة\",\"no_retweet_hint\":\"\",\"repeated\":\"\",\"show_new\":\"عرض الجديد\",\"up_to_date\":\"تم تحديثه\"},\"user_card\":{\"approve\":\"قبول\",\"block\":\"حظر\",\"blocked\":\"تم حظره!\",\"deny\":\"رفض\",\"follow\":\"اتبع\",\"followees\":\"\",\"followers\":\"مُتابِعون\",\"following\":\"\",\"follows_you\":\"يتابعك!\",\"mute\":\"كتم\",\"muted\":\"تم كتمه\",\"per_day\":\"في اليوم\",\"remote_follow\":\"مُتابَعة عن بُعد\",\"statuses\":\"المنشورات\"},\"user_profile\":{\"timeline_title\":\"الخيط الزمني للمستخدم\"},\"who_to_follow\":{\"more\":\"المزيد\",\"who_to_follow\":\"للمتابعة\"}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/ar.json\n// module id = 432\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Xat\"},\"features_panel\":{\"chat\":\"Xat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Proxy per multimèdia\",\"scope_options\":\"Opcions d'abast i visibilitat\",\"text_limit\":\"Límit de text\",\"title\":\"Funcionalitats\",\"who_to_follow\":\"A qui seguir\"},\"finder\":{\"error_fetching_user\":\"No s'ha pogut carregar l'usuari/a\",\"find_user\":\"Find user\"},\"general\":{\"apply\":\"Aplica\",\"submit\":\"Desa\"},\"login\":{\"login\":\"Inicia sessió\",\"logout\":\"Tanca la sessió\",\"password\":\"Contrasenya\",\"placeholder\":\"p.ex.: Maria\",\"register\":\"Registra't\",\"username\":\"Nom d'usuari/a\"},\"nav\":{\"chat\":\"Xat local públic\",\"friend_requests\":\"Soŀlicituds de connexió\",\"mentions\":\"Mencions\",\"public_tl\":\"Flux públic del node\",\"timeline\":\"Flux personal\",\"twkn\":\"Flux de la xarxa coneguda\"},\"notifications\":{\"broken_favorite\":\"No es coneix aquest estat. S'està cercant.\",\"favorited_you\":\"ha marcat un estat teu\",\"followed_you\":\"ha començat a seguir-te\",\"load_older\":\"Carrega més notificacions\",\"notifications\":\"Notificacions\",\"read\":\"Read!\",\"repeated_you\":\"ha repetit el teu estat\"},\"post_status\":{\"account_not_locked_warning\":\"El teu compte no està {0}. Qualsevol persona pot seguir-te per llegir les teves entrades reservades només a seguidores.\",\"account_not_locked_warning_link\":\"bloquejat\",\"attachments_sensitive\":\"Marca l'adjunt com a delicat\",\"content_type\":{\"plain_text\":\"Text pla\"},\"content_warning\":\"Assumpte (opcional)\",\"default\":\"Em sento…\",\"direct_warning\":\"Aquesta entrada només serà visible per les usuràries que etiquetis\",\"posting\":\"Publicació\",\"scope\":{\"direct\":\"Directa - Publica només per les usuàries etiquetades\",\"private\":\"Només seguidors/es - Publica només per comptes que et segueixin\",\"public\":\"Pública - Publica als fluxos públics\",\"unlisted\":\"Silenciosa - No la mostris en fluxos públics\"}},\"registration\":{\"bio\":\"Presentació\",\"email\":\"Correu\",\"fullname\":\"Nom per mostrar\",\"password_confirm\":\"Confirma la contrasenya\",\"registration\":\"Registra't\",\"token\":\"Codi d'invitació\"},\"settings\":{\"attachmentRadius\":\"Adjunts\",\"attachments\":\"Adjunts\",\"autoload\":\"Recarrega automàticament en arribar a sota de tot.\",\"avatar\":\"Avatar\",\"avatarAltRadius\":\"Avatars en les notificacions\",\"avatarRadius\":\"Avatars\",\"background\":\"Fons de pantalla\",\"bio\":\"Presentació\",\"btnRadius\":\"Botons\",\"cBlue\":\"Blau (respon, segueix)\",\"cGreen\":\"Verd (republica)\",\"cOrange\":\"Taronja (marca com a preferit)\",\"cRed\":\"Vermell (canceŀla)\",\"change_password\":\"Canvia la contrasenya\",\"change_password_error\":\"No s'ha pogut canviar la contrasenya\",\"changed_password\":\"S'ha canviat la contrasenya\",\"collapse_subject\":\"Replega les entrades amb títol\",\"confirm_new_password\":\"Confirma la nova contrasenya\",\"current_avatar\":\"L'avatar actual\",\"current_password\":\"La contrasenya actual\",\"current_profile_banner\":\"El fons de perfil actual\",\"data_import_export_tab\":\"Importa o exporta dades\",\"default_vis\":\"Abast per defecte de les entrades\",\"delete_account\":\"Esborra el compte\",\"delete_account_description\":\"Esborra permanentment el teu compte i tots els missatges\",\"delete_account_error\":\"No s'ha pogut esborrar el compte. Si continua el problema, contacta amb l'administració del node\",\"delete_account_instructions\":\"Confirma que vols esborrar el compte escrivint la teva contrasenya aquí sota\",\"export_theme\":\"Desa el tema\",\"filtering\":\"Filtres\",\"filtering_explanation\":\"Es silenciaran totes les entrades que continguin aquestes paraules. Separa-les per línies\",\"follow_export\":\"Exporta la llista de contactes\",\"follow_export_button\":\"Exporta tots els comptes que segueixes a un fitxer CSV\",\"follow_export_processing\":\"S'està processant la petició. Aviat podràs descarregar el fitxer\",\"follow_import\":\"Importa els contactes\",\"follow_import_error\":\"No s'ha pogut importar els contactes\",\"follows_imported\":\"S'han importat els contactes. Trigaran una estoneta en ser processats.\",\"foreground\":\"Primer pla\",\"general\":\"General\",\"hide_attachments_in_convo\":\"Amaga els adjunts en les converses\",\"hide_attachments_in_tl\":\"Amaga els adjunts en el flux d'entrades\",\"import_followers_from_a_csv_file\":\"Importa els contactes des d'un fitxer CSV\",\"import_theme\":\"Carrega un tema\",\"inputRadius\":\"Caixes d'entrada de text\",\"instance_default\":\"(default: {value})\",\"interfaceLanguage\":\"Llengua de la interfície\",\"invalid_theme_imported\":\"No s'ha entès l'arxiu carregat perquè no és un tema vàlid de Pleroma. No s'ha fet cap canvi als temes actuals.\",\"limited_availability\":\"No està disponible en aquest navegador\",\"links\":\"Enllaços\",\"lock_account_description\":\"Restringeix el teu compte només a seguidores aprovades.\",\"loop_video\":\"Reprodueix els vídeos en bucle\",\"loop_video_silent_only\":\"Reprodueix en bucles només els vídeos sense so (com els \\\"GIF\\\" de Mastodon)\",\"name\":\"Nom\",\"name_bio\":\"Nom i presentació\",\"new_password\":\"Contrasenya nova\",\"notification_visibility\":\"Notifica'm quan algú\",\"notification_visibility_follows\":\"Comença a seguir-me\",\"notification_visibility_likes\":\"Marca com a preferida una entrada meva\",\"notification_visibility_mentions\":\"Em menciona\",\"notification_visibility_repeats\":\"Republica una entrada meva\",\"no_rich_text_description\":\"Neteja el formatat de text de totes les entrades\",\"nsfw_clickthrough\":\"Amaga el contingut NSFW darrer d'una imatge clicable\",\"oauth_tokens\":\"Llistats OAuth\",\"token\":\"Token\",\"refresh_token\":\"Actualitza el token\",\"valid_until\":\"Vàlid fins\",\"revoke_token\":\"Revocar\",\"panelRadius\":\"Panells\",\"pause_on_unfocused\":\"Pausa la reproducció en continu quan la pestanya perdi el focus\",\"presets\":\"Temes\",\"profile_background\":\"Fons de pantalla\",\"profile_banner\":\"Fons de perfil\",\"profile_tab\":\"Perfil\",\"radii_help\":\"Configura l'arrodoniment de les vores (en píxels)\",\"replies_in_timeline\":\"Replies in timeline\",\"reply_link_preview\":\"Mostra el missatge citat en passar el ratolí per sobre de l'enllaç de resposta\",\"reply_visibility_all\":\"Mostra totes les respostes\",\"reply_visibility_following\":\"Mostra només les respostes a entrades meves o d'usuàries que jo segueixo\",\"reply_visibility_self\":\"Mostra només les respostes a entrades meves\",\"saving_err\":\"No s'ha pogut desar la configuració\",\"saving_ok\":\"S'ha desat la configuració\",\"security_tab\":\"Seguretat\",\"set_new_avatar\":\"Canvia l'avatar\",\"set_new_profile_background\":\"Canvia el fons de pantalla\",\"set_new_profile_banner\":\"Canvia el fons del perfil\",\"settings\":\"Configuració\",\"stop_gifs\":\"Anima els GIF només en passar-hi el ratolí per sobre\",\"streaming\":\"Carrega automàticament entrades noves quan estigui a dalt de tot\",\"text\":\"Text\",\"theme\":\"Tema\",\"theme_help\":\"Personalitza els colors del tema. Escriu-los en format RGB hexadecimal (#rrggbb)\",\"tooltipRadius\":\"Missatges sobreposats\",\"user_settings\":\"Configuració personal\",\"values\":{\"false\":\"no\",\"true\":\"sí\"}},\"timeline\":{\"collapse\":\"Replega\",\"conversation\":\"Conversa\",\"error_fetching\":\"S'ha produït un error en carregar les entrades\",\"load_older\":\"Carrega entrades anteriors\",\"no_retweet_hint\":\"L'entrada és només per a seguidores o és \\\"directa\\\", i per tant no es pot republicar\",\"repeated\":\"republicat\",\"show_new\":\"Mostra els nous\",\"up_to_date\":\"Actualitzat\"},\"user_card\":{\"approve\":\"Aprova\",\"block\":\"Bloqueja\",\"blocked\":\"Bloquejat!\",\"deny\":\"Denega\",\"follow\":\"Segueix\",\"followees\":\"Segueixo\",\"followers\":\"Seguidors/es\",\"following\":\"Seguint!\",\"follows_you\":\"Et segueix!\",\"mute\":\"Silencia\",\"muted\":\"Silenciat\",\"per_day\":\"per dia\",\"remote_follow\":\"Seguiment remot\",\"statuses\":\"Estats\"},\"user_profile\":{\"timeline_title\":\"Flux personal\"},\"who_to_follow\":{\"more\":\"More\",\"who_to_follow\":\"A qui seguir\"}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/ca.json\n// module id = 433\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Chat\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Mediální proxy\",\"scope_options\":\"Možnosti rozsahů\",\"text_limit\":\"Textový limit\",\"title\":\"Vlastnosti\",\"who_to_follow\":\"Koho sledovat\"},\"finder\":{\"error_fetching_user\":\"Chyba při načítání uživatele\",\"find_user\":\"Najít uživatele\"},\"general\":{\"apply\":\"Použít\",\"submit\":\"Odeslat\",\"more\":\"Více\",\"generic_error\":\"Vyskytla se chyba\",\"optional\":\"volitelné\"},\"image_cropper\":{\"crop_picture\":\"Oříznout obrázek\",\"save\":\"Uložit\",\"cancel\":\"Zrušit\"},\"login\":{\"login\":\"Přihlásit\",\"description\":\"Přihlásit pomocí OAuth\",\"logout\":\"Odhlásit\",\"password\":\"Heslo\",\"placeholder\":\"např. lain\",\"register\":\"Registrovat\",\"username\":\"Uživatelské jméno\",\"hint\":\"Chcete-li se přidat do diskuze, přihlaste se\"},\"media_modal\":{\"previous\":\"Předchozí\",\"next\":\"Další\"},\"nav\":{\"about\":\"O instanci\",\"back\":\"Zpět\",\"chat\":\"Místní chat\",\"friend_requests\":\"Požadavky o sledování\",\"mentions\":\"Zmínky\",\"dms\":\"Přímé zprávy\",\"public_tl\":\"Veřejná časová osa\",\"timeline\":\"Časová osa\",\"twkn\":\"Celá známá síť\",\"user_search\":\"Hledání uživatelů\",\"who_to_follow\":\"Koho sledovat\",\"preferences\":\"Předvolby\"},\"notifications\":{\"broken_favorite\":\"Neznámý příspěvek, hledám jej…\",\"favorited_you\":\"si oblíbil/a váš příspěvek\",\"followed_you\":\"vás nyní sleduje\",\"load_older\":\"Načíst starší oznámení\",\"notifications\":\"Oznámení\",\"read\":\"Číst!\",\"repeated_you\":\"zopakoval/a váš příspěvek\",\"no_more_notifications\":\"Žádná další oznámení\"},\"post_status\":{\"new_status\":\"Napsat nový příspěvek\",\"account_not_locked_warning\":\"Váš účet není {0}. Kdokoliv vás může sledovat a vidět vaše příspěvky pouze pro sledující.\",\"account_not_locked_warning_link\":\"uzamčen\",\"attachments_sensitive\":\"Označovat přílohy jako citlivé\",\"content_type\":{\"plain_text\":\"Prostý text\"},\"content_warning\":\"Předmět (volitelný)\",\"default\":\"Právě jsem přistál v L.A.\",\"direct_warning\":\"Tento příspěvek uvidí pouze všichni zmínění uživatelé.\",\"posting\":\"Přispívání\",\"scope\":{\"direct\":\"Přímý - Poslat pouze zmíněným uživatelům\",\"private\":\"Pouze pro sledující - Poslat pouze sledujícím\",\"public\":\"Veřejný - Poslat na veřejné časové osy\",\"unlisted\":\"Neuvedený - Neposlat na veřejné časové osy\"}},\"registration\":{\"bio\":\"O vás\",\"email\":\"E-mail\",\"fullname\":\"Zobrazované jméno\",\"password_confirm\":\"Potvrzení hesla\",\"registration\":\"Registrace\",\"token\":\"Token pozvánky\",\"captcha\":\"CAPTCHA\",\"new_captcha\":\"Kliknutím na obrázek získáte novou CAPTCHA\",\"username_placeholder\":\"např. lain\",\"fullname_placeholder\":\"např. Lain Iwakura\",\"bio_placeholder\":\"např.\\nNazdar, jsem Lain\\nJsem anime dívka a žiji v příměstském Japonsku. Možná mě znáte z Wired.\",\"validations\":{\"username_required\":\"nemůže být prázdné\",\"fullname_required\":\"nemůže být prázdné\",\"email_required\":\"nemůže být prázdný\",\"password_required\":\"nemůže být prázdné\",\"password_confirmation_required\":\"nemůže být prázdné\",\"password_confirmation_match\":\"musí být stejné jako heslo\"}},\"settings\":{\"app_name\":\"Název aplikace\",\"attachmentRadius\":\"Přílohy\",\"attachments\":\"Přílohy\",\"autoload\":\"Povolit automatické načítání při rolování dolů\",\"avatar\":\"Avatar\",\"avatarAltRadius\":\"Avatary (oznámení)\",\"avatarRadius\":\"Avatary\",\"background\":\"Pozadí\",\"bio\":\"O vás\",\"blocks_tab\":\"Blokování\",\"btnRadius\":\"Tlačítka\",\"cBlue\":\"Modrá (Odpovědět, sledovat)\",\"cGreen\":\"Zelená (Zopakovat)\",\"cOrange\":\"Oranžová (Oblíbit)\",\"cRed\":\"Červená (Zrušit)\",\"change_password\":\"Změnit heslo\",\"change_password_error\":\"Při změně vašeho hesla se vyskytla chyba.\",\"changed_password\":\"Heslo bylo úspěšně změněno!\",\"collapse_subject\":\"Zabalit příspěvky s předměty\",\"composing\":\"Komponování\",\"confirm_new_password\":\"Potvrďte nové heslo\",\"current_avatar\":\"Váš současný avatar\",\"current_password\":\"Současné heslo\",\"current_profile_banner\":\"Váš současný profilový banner\",\"data_import_export_tab\":\"Import/export dat\",\"default_vis\":\"Výchozí rozsah viditelnosti\",\"delete_account\":\"Smazat účet\",\"delete_account_description\":\"Trvale smaže váš účet a všechny vaše příspěvky.\",\"delete_account_error\":\"Při mazání vašeho účtu nastala chyba. Pokud tato chyba bude trvat, kontaktujte prosím admministrátora vaší instance.\",\"delete_account_instructions\":\"Pro potvrzení smazání účtu napište své heslo do pole níže.\",\"avatar_size_instruction\":\"Doporučená minimální velikost pro avatarové obrázky je 150x150 pixelů.\",\"export_theme\":\"Uložit přednastavení\",\"filtering\":\"Filtrování\",\"filtering_explanation\":\"Všechny příspěvky obsahující tato slova budou skryty. Napište jedno slovo na každý řádek\",\"follow_export\":\"Export sledovaných\",\"follow_export_button\":\"Exportovat vaše sledované do souboru CSV\",\"follow_export_processing\":\"Zpracovávám, brzy si budete moci stáhnout váš soubor\",\"follow_import\":\"Import sledovaných\",\"follow_import_error\":\"Chyba při importování sledovaných\",\"follows_imported\":\"Sledovaní importováni! Jejich zpracování bude chvilku trvat.\",\"foreground\":\"Popředí\",\"general\":\"Obecné\",\"hide_attachments_in_convo\":\"Skrývat přílohy v konverzacích\",\"hide_attachments_in_tl\":\"Skrývat přílohy v časové ose\",\"max_thumbnails\":\"Maximální počet miniatur na příspěvek\",\"hide_isp\":\"Skrýt panel specifický pro instanci\",\"preload_images\":\"Přednačítat obrázky\",\"use_one_click_nsfw\":\"Otevírat citlivé přílohy pouze jedním kliknutím\",\"hide_post_stats\":\"Skrývat statistiky příspěvků (např. počet oblíbení)\",\"hide_user_stats\":\"Skrývat statistiky uživatelů (např. počet sledujících)\",\"hide_filtered_statuses\":\"Skrývat filtrované příspěvky\",\"import_followers_from_a_csv_file\":\"Importovat sledované ze souboru CSV\",\"import_theme\":\"Načíst přednastavení\",\"inputRadius\":\"Vstupní pole\",\"checkboxRadius\":\"Zaškrtávací pole\",\"instance_default\":\"(výchozí: {value})\",\"instance_default_simple\":\"(výchozí)\",\"interface\":\"Rozhraní\",\"interfaceLanguage\":\"Jazyk rozhraní\",\"invalid_theme_imported\":\"Zvolený soubor není podporovaný motiv Pleroma. Nebyly provedeny žádné změny s vaším motivem.\",\"limited_availability\":\"Nedostupné ve vašem prohlížeči\",\"links\":\"Odkazy\",\"lock_account_description\":\"Omezit váš účet pouze na schválené sledující\",\"loop_video\":\"Opakovat videa\",\"loop_video_silent_only\":\"Opakovat pouze videa beze zvuku (t.j. „GIFy“ na Mastodonu)\",\"mutes_tab\":\"Ignorování\",\"play_videos_in_modal\":\"Přehrávat videa přímo v prohlížeči médií\",\"use_contain_fit\":\"Neořezávat přílohu v miniaturách\",\"name\":\"Jméno\",\"name_bio\":\"Jméno a popis\",\"new_password\":\"Nové heslo\",\"notification_visibility\":\"Typy oznámení k zobrazení\",\"notification_visibility_follows\":\"Sledující\",\"notification_visibility_likes\":\"Oblíbení\",\"notification_visibility_mentions\":\"Zmínky\",\"notification_visibility_repeats\":\"Zopakování\",\"no_rich_text_description\":\"Odstranit ze všech příspěvků formátování textu\",\"no_blocks\":\"Žádná blokování\",\"no_mutes\":\"Žádná ignorování\",\"hide_follows_description\":\"Nezobrazovat, koho sleduji\",\"hide_followers_description\":\"Nezobrazovat, kdo mě sleduje\",\"show_admin_badge\":\"Zobrazovat v mém profilu odznak administrátora\",\"show_moderator_badge\":\"Zobrazovat v mém profilu odznak moderátora\",\"nsfw_clickthrough\":\"Povolit prokliknutelné skrývání citlivých příloh\",\"oauth_tokens\":\"Tokeny OAuth\",\"token\":\"Token\",\"refresh_token\":\"Obnovit token\",\"valid_until\":\"Platný do\",\"revoke_token\":\"Odvolat\",\"panelRadius\":\"Panely\",\"pause_on_unfocused\":\"Pozastavit streamování, pokud není záložka prohlížeče v soustředění\",\"presets\":\"Přednastavení\",\"profile_background\":\"Profilové pozadí\",\"profile_banner\":\"Profilový banner\",\"profile_tab\":\"Profil\",\"radii_help\":\"Nastavit zakulacení rohů rozhraní (v pixelech)\",\"replies_in_timeline\":\"Odpovědi v časové ose\",\"reply_link_preview\":\"Povolit náhledy odkazu pro odpověď při přejetí myši\",\"reply_visibility_all\":\"Zobrazit všechny odpovědiShow all replies\",\"reply_visibility_following\":\"Zobrazit pouze odpovědi směřované na mě nebo uživatele, které sleduji\",\"reply_visibility_self\":\"Zobrazit pouze odpovědi směřované na mě\",\"saving_err\":\"Chyba při ukládání nastavení\",\"saving_ok\":\"Nastavení uložena\",\"security_tab\":\"Bezpečnost\",\"scope_copy\":\"Kopírovat rozsah při odpovídání (přímé zprávy jsou vždy kopírovány)\",\"set_new_avatar\":\"Nastavit nový avatar\",\"set_new_profile_background\":\"Nastavit nové profilové pozadí\",\"set_new_profile_banner\":\"Nastavit nový profilový banner\",\"settings\":\"Nastavení\",\"subject_input_always_show\":\"Vždy zobrazit pole pro předmět\",\"subject_line_behavior\":\"Kopírovat předmět při odpovídání\",\"subject_line_email\":\"Jako u e-mailu: „re: předmět“\",\"subject_line_mastodon\":\"Jako u Mastodonu: zkopírovat tak, jak je\",\"subject_line_noop\":\"Nekopírovat\",\"post_status_content_type\":\"Publikovat typ obsahu příspěvku\",\"status_content_type_plain\":\"Prostý text\",\"stop_gifs\":\"Přehrávat GIFy při přejetí myši\",\"streaming\":\"Povolit automatické streamování nových příspěvků při rolování nahoru\",\"text\":\"Text\",\"theme\":\"Motiv\",\"theme_help\":\"Použijte hexadecimální barevné kódy (#rrggbb) pro přizpůsobení vašeho barevného motivu.\",\"theme_help_v2_1\":\"Zaškrtnutím pole můžete také přepsat barvy a průhlednost některých komponentů, pro smazání všech přednastavení použijte tlačítko „Smazat vše“.\",\"theme_help_v2_2\":\"Ikony pod některými položkami jsou indikátory kontrastu pozadí/textu, pro detailní informace nad nimi přejeďte myší. Prosím berte na vědomí, že při používání kontrastu průhlednosti ukazují indikátory nejhorší možný případ.\",\"tooltipRadius\":\"Popisky/upozornění\",\"upload_a_photo\":\"Nahrát fotku\",\"user_settings\":\"Uživatelská nastavení\",\"values\":{\"false\":\"ne\",\"true\":\"ano\"},\"notifications\":\"Oznámení\",\"enable_web_push_notifications\":\"Povolit webová push oznámení\",\"style\":{\"switcher\":{\"keep_color\":\"Ponechat barvy\",\"keep_shadows\":\"Ponechat stíny\",\"keep_opacity\":\"Ponechat průhlednost\",\"keep_roundness\":\"Ponechat kulatost\",\"keep_fonts\":\"Keep fonts\",\"save_load_hint\":\"Možnosti „Ponechat“ dočasně ponechávají aktuálně nastavené možností při volení či nahrávání motivů, také tyto možnosti ukládají při exportování motivu. Pokud není žádné pole zaškrtnuto, uloží export motivu všechno.\",\"reset\":\"Resetovat\",\"clear_all\":\"Vymazat vše\",\"clear_opacity\":\"Vymazat průhlednost\"},\"common\":{\"color\":\"Barva\",\"opacity\":\"Průhlednost\",\"contrast\":{\"hint\":\"Poměr kontrastu je {ratio}, {level} {context}\",\"level\":{\"aa\":\"splňuje směrnici úrovně AA (minimální)\",\"aaa\":\"splňuje směrnici úrovně AAA (doporučováno)\",\"bad\":\"nesplňuje žádné směrnice přístupnosti\"},\"context\":{\"18pt\":\"pro velký (18+ bodů) text\",\"text\":\"pro text\"}}},\"common_colors\":{\"_tab_label\":\"Obvyklé\",\"main\":\"Obvyklé barvy\",\"foreground_hint\":\"Pro detailnější kontrolu viz záložka „Pokročilé“\",\"rgbo\":\"Ikony, odstíny, odznaky\"},\"advanced_colors\":{\"_tab_label\":\"Pokročilé\",\"alert\":\"Pozadí upozornění\",\"alert_error\":\"Chyba\",\"badge\":\"Pozadí odznaků\",\"badge_notification\":\"Oznámení\",\"panel_header\":\"Záhlaví panelu\",\"top_bar\":\"Vrchní pruh\",\"borders\":\"Okraje\",\"buttons\":\"Tlačítka\",\"inputs\":\"Vstupní pole\",\"faint_text\":\"Vybledlý text\"},\"radii\":{\"_tab_label\":\"Kulatost\"},\"shadows\":{\"_tab_label\":\"Stín a osvětlení\",\"component\":\"Komponent\",\"override\":\"Přepsat\",\"shadow_id\":\"Stín #{value}\",\"blur\":\"Rozmazání\",\"spread\":\"Rozsah\",\"inset\":\"Vsazení\",\"hint\":\"Pro stíny můžete také použít --variable jako hodnotu barvy pro použití proměnných CSS3. Prosím berte na vědomí, že nastavení průhlednosti v tomto případě nebude fungovat.\",\"filter_hint\":{\"always_drop_shadow\":\"Varování, tento stín vždy používá {0}, když to prohlížeč podporuje.\",\"drop_shadow_syntax\":\"{0} nepodporuje parametr {1} a klíčové slovo {2}.\",\"avatar_inset\":\"Prosím berte na vědomí, že kombinování vsazených i nevsazených stínů u avatarů může u průhledných avatarů dát neočekávané výsledky.\",\"spread_zero\":\"Stíny s rozsahem > 0 se zobrazí, jako kdyby byl rozsah nastaven na nulu\",\"inset_classic\":\"Vsazené stíny budou používat {0}\"},\"components\":{\"panel\":\"Panel\",\"panelHeader\":\"Záhlaví panelu\",\"topBar\":\"Vrchní pruh\",\"avatar\":\"Avatar uživatele (v zobrazení profilu)\",\"avatarStatus\":\"Avatar uživatele (v zobrazení příspěvku)\",\"popup\":\"Vyskakovací okna a popisky\",\"button\":\"Tlačítko\",\"buttonHover\":\"Tlačítko (přejetí myši)\",\"buttonPressed\":\"Tlačítko (stisknuto)\",\"buttonPressedHover\":\"Button (stisknuto+přejetí myši)\",\"input\":\"Vstupní pole\"}},\"fonts\":{\"_tab_label\":\"Písma\",\"help\":\"Zvolte písmo, které bude použito pro prvky rozhraní. U možnosti „vlastní“ musíte zadat přesný název písma tak, jak se zobrazuje v systému.\",\"components\":{\"interface\":\"Rozhraní\",\"input\":\"Vstupní pole\",\"post\":\"Text příspěvků\",\"postCode\":\"Neproporcionální text v příspěvku (formátovaný text)\"},\"family\":\"Název písma\",\"size\":\"Velikost (v pixelech)\",\"weight\":\"Tloušťka\",\"custom\":\"Vlastní\"},\"preview\":{\"header\":\"Náhled\",\"content\":\"Obsah\",\"error\":\"Příklad chyby\",\"button\":\"Tlačítko\",\"text\":\"Spousta dalšího {0} a {1}\",\"mono\":\"obsahu\",\"input\":\"Just landed in L.A.\",\"faint_link\":\"pomocný manuál\",\"fine_print\":\"Přečtěte si náš {0} a nenaučte se nic užitečného!\",\"header_faint\":\"Tohle je v pohodě\",\"checkbox\":\"Pročetl/a jsem podmínky používání\",\"link\":\"hezký malý odkaz\"}}},\"timeline\":{\"collapse\":\"Zabalit\",\"conversation\":\"Konverzace\",\"error_fetching\":\"Chyba při načítání aktualizací\",\"load_older\":\"Načíst starší příspěvky\",\"no_retweet_hint\":\"Příspěvek je označen jako pouze pro sledující či přímý a nemůže být zopakován\",\"repeated\":\"zopakoval/a\",\"show_new\":\"Zobrazit nové\",\"up_to_date\":\"Aktuální\",\"no_more_statuses\":\"Žádné další příspěvky\",\"no_statuses\":\"Žádné příspěvky\"},\"status\":{\"reply_to\":\"Odpovědět uživateli\",\"replies_list\":\"Odpovědi:\"},\"user_card\":{\"approve\":\"Schválit\",\"block\":\"Blokovat\",\"blocked\":\"Blokován/a!\",\"deny\":\"Zamítnout\",\"favorites\":\"Oblíbené\",\"follow\":\"Sledovat\",\"follow_sent\":\"Požadavek odeslán!\",\"follow_progress\":\"Odeslílám požadavek…\",\"follow_again\":\"Odeslat požadavek znovu?\",\"follow_unfollow\":\"Přestat sledovat\",\"followees\":\"Sledovaní\",\"followers\":\"Sledující\",\"following\":\"Sledujete!\",\"follows_you\":\"Sleduje vás!\",\"its_you\":\"Jste to vy!\",\"media\":\"Média\",\"mute\":\"Ignorovat\",\"muted\":\"Ignorován/a\",\"per_day\":\"za den\",\"remote_follow\":\"Vzdálené sledování\",\"statuses\":\"Příspěvky\",\"unblock\":\"Odblokovat\",\"unblock_progress\":\"Odblokuji…\",\"block_progress\":\"Blokuji…\",\"unmute\":\"Přestat ignorovat\",\"unmute_progress\":\"Ruším ignorování…\",\"mute_progress\":\"Ignoruji…\"},\"user_profile\":{\"timeline_title\":\"Uživatelská časová osa\",\"profile_does_not_exist\":\"Omlouváme se, tento profil neexistuje.\",\"profile_loading_error\":\"Omlouváme se, při načítání tohoto profilu se vyskytla chyba.\"},\"who_to_follow\":{\"more\":\"Více\",\"who_to_follow\":\"Koho sledovat\"},\"tool_tip\":{\"media_upload\":\"Nahrát média\",\"repeat\":\"Zopakovat\",\"reply\":\"Odpovědět\",\"favorite\":\"Oblíbit\",\"user_settings\":\"Uživatelské nastavení\"},\"upload\":{\"error\":{\"base\":\"Nahrávání selhalo.\",\"file_too_big\":\"Soubor je úříliš velký [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"Zkuste to znovu později\"},\"file_size_units\":{\"B\":\"B\",\"KiB\":\"KiB\",\"MiB\":\"MiB\",\"GiB\":\"GiB\",\"TiB\":\"TiB\"}}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/cs.json\n// module id = 434\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Chat\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Media Proxy\",\"scope_options\":\"Reichweitenoptionen\",\"text_limit\":\"Textlimit\",\"title\":\"Features\",\"who_to_follow\":\"Who to follow\"},\"finder\":{\"error_fetching_user\":\"Fehler beim Suchen des Benutzers\",\"find_user\":\"Finde Benutzer\"},\"general\":{\"apply\":\"Anwenden\",\"submit\":\"Absenden\"},\"login\":{\"login\":\"Anmelden\",\"description\":\"Mit OAuth anmelden\",\"logout\":\"Abmelden\",\"password\":\"Passwort\",\"placeholder\":\"z.B. lain\",\"register\":\"Registrieren\",\"username\":\"Benutzername\"},\"nav\":{\"back\":\"Zurück\",\"chat\":\"Lokaler Chat\",\"friend_requests\":\"Followanfragen\",\"mentions\":\"Erwähnungen\",\"dms\":\"Direktnachrichten\",\"public_tl\":\"Öffentliche Zeitleiste\",\"timeline\":\"Zeitleiste\",\"twkn\":\"Das gesamte bekannte Netzwerk\",\"user_search\":\"Benutzersuche\",\"preferences\":\"Voreinstellungen\"},\"notifications\":{\"broken_favorite\":\"Unbekannte Nachricht, suche danach...\",\"favorited_you\":\"favorisierte deine Nachricht\",\"followed_you\":\"folgt dir\",\"load_older\":\"Ältere Benachrichtigungen laden\",\"notifications\":\"Benachrichtigungen\",\"read\":\"Gelesen!\",\"repeated_you\":\"wiederholte deine Nachricht\"},\"post_status\":{\"new_status\":\"Neuen Status veröffentlichen\",\"account_not_locked_warning\":\"Dein Profil ist nicht {0}. Wer dir folgen will, kann das jederzeit tun und dann auch deine privaten Beiträge sehen.\",\"account_not_locked_warning_link\":\"gesperrt\",\"attachments_sensitive\":\"Anhänge als heikel markieren\",\"content_type\":{\"plain_text\":\"Nur Text\"},\"content_warning\":\"Betreff (optional)\",\"default\":\"Sitze gerade im Hofbräuhaus.\",\"direct_warning\":\"Dieser Beitrag wird nur für die erwähnten Nutzer sichtbar sein.\",\"posting\":\"Veröffentlichen\",\"scope\":{\"direct\":\"Direkt - Beitrag nur an erwähnte Profile\",\"private\":\"Nur Follower - Beitrag nur für Follower sichtbar\",\"public\":\"Öffentlich - Beitrag an öffentliche Zeitleisten\",\"unlisted\":\"Nicht gelistet - Nicht in öffentlichen Zeitleisten anzeigen\"}},\"registration\":{\"bio\":\"Bio\",\"email\":\"Email\",\"fullname\":\"Angezeigter Name\",\"password_confirm\":\"Passwort bestätigen\",\"registration\":\"Registrierung\",\"token\":\"Einladungsschlüssel\",\"captcha\":\"CAPTCHA\",\"new_captcha\":\"Zum Erstellen eines neuen Captcha auf das Bild klicken.\",\"validations\":{\"username_required\":\"darf nicht leer sein\",\"fullname_required\":\"darf nicht leer sein\",\"email_required\":\"darf nicht leer sein\",\"password_required\":\"darf nicht leer sein\",\"password_confirmation_required\":\"darf nicht leer sein\",\"password_confirmation_match\":\"sollte mit dem Passwort identisch sein.\"}},\"settings\":{\"attachmentRadius\":\"Anhänge\",\"attachments\":\"Anhänge\",\"autoload\":\"Aktiviere automatisches Laden von älteren Beiträgen beim scrollen\",\"avatar\":\"Avatar\",\"avatarAltRadius\":\"Avatare (Benachrichtigungen)\",\"avatarRadius\":\"Avatare\",\"background\":\"Hintergrund\",\"bio\":\"Bio\",\"btnRadius\":\"Buttons\",\"cBlue\":\"Blau (Antworten, Folgt dir)\",\"cGreen\":\"Grün (Retweet)\",\"cOrange\":\"Orange (Favorisieren)\",\"cRed\":\"Rot (Abbrechen)\",\"change_password\":\"Passwort ändern\",\"change_password_error\":\"Es gab ein Problem bei der Änderung des Passworts.\",\"changed_password\":\"Passwort erfolgreich geändert!\",\"collapse_subject\":\"Beiträge mit Betreff einklappen\",\"composing\":\"Verfassen\",\"confirm_new_password\":\"Neues Passwort bestätigen\",\"current_avatar\":\"Dein derzeitiger Avatar\",\"current_password\":\"Aktuelles Passwort\",\"current_profile_banner\":\"Der derzeitige Banner deines Profils\",\"data_import_export_tab\":\"Datenimport/-export\",\"default_vis\":\"Standard-Sichtbarkeitsumfang\",\"delete_account\":\"Account löschen\",\"delete_account_description\":\"Lösche deinen Account und alle deine Nachrichten unwiderruflich.\",\"delete_account_error\":\"Es ist ein Fehler beim Löschen deines Accounts aufgetreten. Tritt dies weiterhin auf, wende dich an den Administrator der Instanz.\",\"delete_account_instructions\":\"Tippe dein Passwort unten in das Feld ein, um die Löschung deines Accounts zu bestätigen.\",\"export_theme\":\"Farbschema speichern\",\"filtering\":\"Filtern\",\"filtering_explanation\":\"Alle Beiträge die diese Wörter enthalten werden ausgeblendet. Ein Wort pro Zeile.\",\"follow_export\":\"Follower exportieren\",\"follow_export_button\":\"Exportiere deine Follows in eine csv-Datei\",\"follow_export_processing\":\"In Bearbeitung. Die Liste steht gleich zum herunterladen bereit.\",\"follow_import\":\"Followers importieren\",\"follow_import_error\":\"Fehler beim importieren der Follower\",\"follows_imported\":\"Followers importiert! Die Bearbeitung kann eine Zeit lang dauern.\",\"foreground\":\"Vordergrund\",\"general\":\"Allgemein\",\"hide_attachments_in_convo\":\"Anhänge in Unterhaltungen ausblenden\",\"hide_attachments_in_tl\":\"Anhänge in der Zeitleiste ausblenden\",\"hide_isp\":\"Instanz-spezifisches Panel ausblenden\",\"preload_images\":\"Bilder vorausladen\",\"hide_post_stats\":\"Beitragsstatistiken verbergen (z.B. die Anzahl der Favoriten)\",\"hide_user_stats\":\"Benutzerstatistiken verbergen (z.B. die Anzahl der Follower)\",\"hide_filtered_statuses\":\"Gefilterte Beiträge verbergen\",\"import_followers_from_a_csv_file\":\"Importiere Follower, denen du folgen möchtest, aus einer CSV-Datei\",\"import_theme\":\"Farbschema laden\",\"inputRadius\":\"Eingabefelder\",\"checkboxRadius\":\"Auswahlfelder\",\"instance_default\":\"(Standard: {value})\",\"instance_default_simple\":\"(Standard)\",\"interface\":\"Oberfläche\",\"interfaceLanguage\":\"Sprache der Oberfläche\",\"invalid_theme_imported\":\"Die ausgewählte Datei ist kein unterstütztes Pleroma-Theme. Keine Änderungen wurden vorgenommen.\",\"limited_availability\":\"In deinem Browser nicht verfügbar\",\"links\":\"Links\",\"lock_account_description\":\"Sperre deinen Account, um neue Follower zu genehmigen oder abzulehnen\",\"loop_video\":\"Videos wiederholen\",\"loop_video_silent_only\":\"Nur Videos ohne Ton wiederholen (z.B. Mastodons \\\"gifs\\\")\",\"name\":\"Name\",\"name_bio\":\"Name & Bio\",\"new_password\":\"Neues Passwort\",\"notification_visibility\":\"Benachrichtigungstypen, die angezeigt werden sollen\",\"notification_visibility_follows\":\"Follows\",\"notification_visibility_likes\":\"Favoriten\",\"notification_visibility_mentions\":\"Erwähnungen\",\"notification_visibility_repeats\":\"Wiederholungen\",\"no_rich_text_description\":\"Rich-Text Formatierungen von allen Beiträgen entfernen\",\"hide_follows_description\":\"Zeige nicht, wem ich folge\",\"hide_followers_description\":\"Zeige nicht, wer mir folgt\",\"nsfw_clickthrough\":\"Aktiviere ausblendbares Overlay für Anhänge, die als NSFW markiert sind\",\"oauth_tokens\":\"OAuth-Token\",\"token\":\"Zeichen\",\"refresh_token\":\"Token aktualisieren\",\"valid_until\":\"Gültig bis\",\"revoke_token\":\"Widerrufen\",\"panelRadius\":\"Panel\",\"pause_on_unfocused\":\"Streaming pausieren, wenn das Tab nicht fokussiert ist\",\"presets\":\"Voreinstellungen\",\"profile_background\":\"Profilhintergrund\",\"profile_banner\":\"Profilbanner\",\"profile_tab\":\"Profil\",\"radii_help\":\"Kantenrundung (in Pixel) der Oberfläche anpassen\",\"replies_in_timeline\":\"Antworten in der Zeitleiste\",\"reply_link_preview\":\"Antwortlink-Vorschau beim Überfahren mit der Maus aktivieren\",\"reply_visibility_all\":\"Alle Antworten zeigen\",\"reply_visibility_following\":\"Zeige nur Antworten an mich oder an Benutzer, denen ich folge\",\"reply_visibility_self\":\"Nur Antworten an mich anzeigen\",\"saving_err\":\"Fehler beim Speichern der Einstellungen\",\"saving_ok\":\"Einstellungen gespeichert\",\"security_tab\":\"Sicherheit\",\"scope_copy\":\"Reichweite beim Antworten übernehmen (Direktnachrichten werden immer kopiert)\",\"set_new_avatar\":\"Setze einen neuen Avatar\",\"set_new_profile_background\":\"Setze einen neuen Hintergrund für dein Profil\",\"set_new_profile_banner\":\"Setze einen neuen Banner für dein Profil\",\"settings\":\"Einstellungen\",\"subject_input_always_show\":\"Betreff-Feld immer anzeigen\",\"subject_line_behavior\":\"Betreff beim Antworten kopieren\",\"subject_line_email\":\"Wie Email: \\\"re: Betreff\\\"\",\"subject_line_mastodon\":\"Wie Mastodon: unverändert kopieren\",\"subject_line_noop\":\"Nicht kopieren\",\"stop_gifs\":\"Play-on-hover GIFs\",\"streaming\":\"Aktiviere automatisches Laden (Streaming) von neuen Beiträgen\",\"text\":\"Text\",\"theme\":\"Farbschema\",\"theme_help\":\"Benutze HTML-Farbcodes (#rrggbb) um dein Farbschema anzupassen\",\"theme_help_v2_1\":\"Du kannst auch die Farben und die Deckkraft bestimmter Komponenten überschreiben, indem du das Kontrollkästchen umschaltest. Verwende die Schaltfläche \\\"Alle löschen\\\", um alle Überschreibungen zurückzusetzen.\",\"theme_help_v2_2\":\"Unter einigen Einträgen befinden sich Symbole für Hintergrund-/Textkontrastindikatoren, für detaillierte Informationen fahre mit der Maus darüber. Bitte beachte, dass bei der Verwendung von Transparenz Kontrastindikatoren den schlechtest möglichen Fall darstellen.\",\"tooltipRadius\":\"Tooltips/Warnungen\",\"user_settings\":\"Benutzereinstellungen\",\"values\":{\"false\":\"nein\",\"true\":\"Ja\"},\"notifications\":\"Benachrichtigungen\",\"enable_web_push_notifications\":\"Web-Pushbenachrichtigungen aktivieren\",\"style\":{\"switcher\":{\"keep_color\":\"Farben beibehalten\",\"keep_shadows\":\"Schatten beibehalten\",\"keep_opacity\":\"Deckkraft beibehalten\",\"keep_roundness\":\"Abrundungen beibehalten\",\"keep_fonts\":\"Schriften beibehalten\",\"save_load_hint\":\"Die \\\"Beibehalten\\\"-Optionen behalten die aktuell eingestellten Optionen beim Auswählen oder Laden von Designs bei, sie speichern diese Optionen auch beim Exportieren eines Designs. Wenn alle Kontrollkästchen deaktiviert sind, wird beim Exportieren des Designs alles gespeichert.\",\"reset\":\"Zurücksetzen\",\"clear_all\":\"Alles leeren\",\"clear_opacity\":\"Deckkraft leeren\"},\"common\":{\"color\":\"Farbe\",\"opacity\":\"Deckkraft\",\"contrast\":{\"hint\":\"Das Kontrastverhältnis ist {ratio}, es {level} {context}\",\"level\":{\"aa\":\"entspricht Level AA Richtlinie (minimum)\",\"aaa\":\"entspricht Level AAA Richtlinie (empfohlen)\",\"bad\":\"entspricht keiner Richtlinien zur Barrierefreiheit\"},\"context\":{\"18pt\":\"für großen (18pt+) Text\",\"text\":\"für Text\"}}},\"common_colors\":{\"_tab_label\":\"Allgemein\",\"main\":\"Allgemeine Farben\",\"foreground_hint\":\"Siehe Reiter \\\"Erweitert\\\" für eine detailliertere Einstellungen\",\"rgbo\":\"Symbole, Betonungen, Kennzeichnungen\"},\"advanced_colors\":{\"_tab_label\":\"Erweitert\",\"alert\":\"Warnhinweis-Hintergrund\",\"alert_error\":\"Fehler\",\"badge\":\"Kennzeichnungs-Hintergrund\",\"badge_notification\":\"Benachrichtigung\",\"panel_header\":\"Panel-Kopf\",\"top_bar\":\"Obere Leiste\",\"borders\":\"Rahmen\",\"buttons\":\"Schaltflächen\",\"inputs\":\"Eingabefelder\",\"faint_text\":\"Verblasster Text\"},\"radii\":{\"_tab_label\":\"Abrundungen\"},\"shadows\":{\"_tab_label\":\"Schatten und Beleuchtung\",\"component\":\"Komponente\",\"override\":\"Überschreiben\",\"shadow_id\":\"Schatten #{value}\",\"blur\":\"Unschärfe\",\"spread\":\"Streuung\",\"inset\":\"Einsatz\",\"hint\":\"Für Schatten kannst du auch --variable als Farbwert verwenden, um CSS3-Variablen zu verwenden. Bitte beachte, dass die Einstellung der Deckkraft in diesem Fall nicht funktioniert.\",\"filter_hint\":{\"always_drop_shadow\":\"Achtung, dieser Schatten verwendet immer {0}, wenn der Browser dies unterstützt.\",\"drop_shadow_syntax\":\"{0} unterstützt Parameter {1} und Schlüsselwort {2} nicht.\",\"avatar_inset\":\"Bitte beachte, dass die Kombination von eingesetzten und nicht eingesetzten Schatten auf Avataren zu unerwarteten Ergebnissen bei transparenten Avataren führen kann.\",\"spread_zero\":\"Schatten mit einer Streuung > 0 erscheinen so, als ob sie auf Null gesetzt wären.\",\"inset_classic\":\"Eingesetzte Schatten werden mit {0} verwendet\"},\"components\":{\"panel\":\"Panel\",\"panelHeader\":\"Panel-Kopf\",\"topBar\":\"Obere Leiste\",\"avatar\":\"Benutzer-Avatar (in der Profilansicht)\",\"avatarStatus\":\"Benutzer-Avatar (in der Beitragsanzeige)\",\"popup\":\"Dialogfenster und Hinweistexte\",\"button\":\"Schaltfläche\",\"buttonHover\":\"Schaltfläche (hover)\",\"buttonPressed\":\"Schaltfläche (gedrückt)\",\"buttonPressedHover\":\"Schaltfläche (gedrückt+hover)\",\"input\":\"Input field\"}},\"fonts\":{\"_tab_label\":\"Schriften\",\"help\":\"Wähl die Schriftart, die für Elemente der Benutzeroberfläche verwendet werden soll. Für \\\" Benutzerdefiniert\\\" musst du den genauen Schriftnamen eingeben, wie er im System angezeigt wird.\",\"components\":{\"interface\":\"Oberfläche\",\"input\":\"Eingabefelder\",\"post\":\"Beitragstext\",\"postCode\":\"Dicktengleicher Text in einem Beitrag (Rich-Text)\"},\"family\":\"Schriftname\",\"size\":\"Größe (in px)\",\"weight\":\"Gewicht (Dicke)\",\"custom\":\"Benutzerdefiniert\"},\"preview\":{\"header\":\"Vorschau\",\"content\":\"Inhalt\",\"error\":\"Beispielfehler\",\"button\":\"Schaltfläche\",\"text\":\"Ein Haufen mehr von {0} und {1}\",\"mono\":\"Inhalt\",\"input\":\"Sitze gerade im Hofbräuhaus.\",\"faint_link\":\"Hilfreiche Anleitung\",\"fine_print\":\"Lies unser {0}, um nichts Nützliches zu lernen!\",\"header_faint\":\"Das ist in Ordnung\",\"checkbox\":\"Ich habe die Allgemeinen Geschäftsbedingungen überflogen\",\"link\":\"ein netter kleiner Link\"}}},\"timeline\":{\"collapse\":\"Einklappen\",\"conversation\":\"Unterhaltung\",\"error_fetching\":\"Fehler beim Laden\",\"load_older\":\"Lade ältere Beiträge\",\"no_retweet_hint\":\"Der Beitrag ist als nur-für-Follower oder als Direktnachricht markiert und kann nicht wiederholt werden.\",\"repeated\":\"wiederholte\",\"show_new\":\"Zeige Neuere\",\"up_to_date\":\"Aktuell\"},\"user_card\":{\"approve\":\"Genehmigen\",\"block\":\"Blockieren\",\"blocked\":\"Blockiert!\",\"deny\":\"Ablehnen\",\"follow\":\"Folgen\",\"follow_sent\":\"Anfrage gesendet!\",\"follow_progress\":\"Anfragen…\",\"follow_again\":\"Anfrage erneut senden?\",\"follow_unfollow\":\"Folgen beenden\",\"followees\":\"Folgt\",\"followers\":\"Followers\",\"following\":\"Folgst du!\",\"follows_you\":\"Folgt dir!\",\"its_you\":\"Das bist du!\",\"mute\":\"Stummschalten\",\"muted\":\"Stummgeschaltet\",\"per_day\":\"pro Tag\",\"remote_follow\":\"Folgen\",\"statuses\":\"Beiträge\"},\"user_profile\":{\"timeline_title\":\"Beiträge\"},\"who_to_follow\":{\"more\":\"Mehr\",\"who_to_follow\":\"Wem soll ich folgen\"},\"tool_tip\":{\"media_upload\":\"Medien hochladen\",\"repeat\":\"Wiederholen\",\"reply\":\"Antworten\",\"favorite\":\"Favorisieren\",\"user_settings\":\"Benutzereinstellungen\"},\"upload\":{\"error\":{\"base\":\"Hochladen fehlgeschlagen.\",\"file_too_big\":\"Datei ist zu groß [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"Bitte versuche es später erneut\"},\"file_size_units\":{\"B\":\"B\",\"KiB\":\"KiB\",\"MiB\":\"MiB\",\"GiB\":\"GiB\",\"TiB\":\"TiB\"}}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/de.json\n// module id = 435\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Chat\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Media proxy\",\"scope_options\":\"Scope options\",\"text_limit\":\"Text limit\",\"title\":\"Features\",\"who_to_follow\":\"Who to follow\"},\"finder\":{\"error_fetching_user\":\"Error fetching user\",\"find_user\":\"Find user\"},\"general\":{\"apply\":\"Apply\",\"submit\":\"Submit\",\"more\":\"More\",\"generic_error\":\"An error occured\",\"optional\":\"optional\"},\"image_cropper\":{\"crop_picture\":\"Crop picture\",\"save\":\"Save\",\"cancel\":\"Cancel\"},\"login\":{\"login\":\"Log in\",\"description\":\"Log in with OAuth\",\"logout\":\"Log out\",\"password\":\"Password\",\"placeholder\":\"e.g. lain\",\"register\":\"Register\",\"username\":\"Username\",\"hint\":\"Log in to join the discussion\"},\"media_modal\":{\"previous\":\"Previous\",\"next\":\"Next\"},\"nav\":{\"about\":\"About\",\"back\":\"Back\",\"chat\":\"Local Chat\",\"friend_requests\":\"Follow Requests\",\"mentions\":\"Mentions\",\"dms\":\"Direct Messages\",\"public_tl\":\"Public Timeline\",\"timeline\":\"Timeline\",\"twkn\":\"The Whole Known Network\",\"user_search\":\"User Search\",\"who_to_follow\":\"Who to follow\",\"preferences\":\"Preferences\"},\"notifications\":{\"broken_favorite\":\"Unknown status, searching for it...\",\"favorited_you\":\"favorited your status\",\"followed_you\":\"followed you\",\"load_older\":\"Load older notifications\",\"notifications\":\"Notifications\",\"read\":\"Read!\",\"repeated_you\":\"repeated your status\",\"no_more_notifications\":\"No more notifications\"},\"post_status\":{\"new_status\":\"Post new status\",\"account_not_locked_warning\":\"Your account is not {0}. Anyone can follow you to view your follower-only posts.\",\"account_not_locked_warning_link\":\"locked\",\"attachments_sensitive\":\"Mark attachments as sensitive\",\"content_type\":{\"plain_text\":\"Plain text\"},\"content_warning\":\"Subject (optional)\",\"default\":\"Just landed in L.A.\",\"direct_warning\":\"This post will only be visible to all the mentioned users.\",\"posting\":\"Posting\",\"scope\":{\"direct\":\"Direct - Post to mentioned users only\",\"private\":\"Followers-only - Post to followers only\",\"public\":\"Public - Post to public timelines\",\"unlisted\":\"Unlisted - Do not post to public timelines\"}},\"registration\":{\"bio\":\"Bio\",\"email\":\"Email\",\"fullname\":\"Display name\",\"password_confirm\":\"Password confirmation\",\"registration\":\"Registration\",\"token\":\"Invite token\",\"captcha\":\"CAPTCHA\",\"new_captcha\":\"Click the image to get a new captcha\",\"username_placeholder\":\"e.g. lain\",\"fullname_placeholder\":\"e.g. Lain Iwakura\",\"bio_placeholder\":\"e.g.\\nHi, I'm Lain\\nI’m an anime girl living in suburban Japan. You may know me from the Wired.\",\"validations\":{\"username_required\":\"cannot be left blank\",\"fullname_required\":\"cannot be left blank\",\"email_required\":\"cannot be left blank\",\"password_required\":\"cannot be left blank\",\"password_confirmation_required\":\"cannot be left blank\",\"password_confirmation_match\":\"should be the same as password\"}},\"settings\":{\"app_name\":\"App name\",\"attachmentRadius\":\"Attachments\",\"attachments\":\"Attachments\",\"autoload\":\"Enable automatic loading when scrolled to the bottom\",\"avatar\":\"Avatar\",\"avatarAltRadius\":\"Avatars (Notifications)\",\"avatarRadius\":\"Avatars\",\"background\":\"Background\",\"bio\":\"Bio\",\"blocks_tab\":\"Blocks\",\"btnRadius\":\"Buttons\",\"cBlue\":\"Blue (Reply, follow)\",\"cGreen\":\"Green (Retweet)\",\"cOrange\":\"Orange (Favorite)\",\"cRed\":\"Red (Cancel)\",\"change_password\":\"Change Password\",\"change_password_error\":\"There was an issue changing your password.\",\"changed_password\":\"Password changed successfully!\",\"collapse_subject\":\"Collapse posts with subjects\",\"composing\":\"Composing\",\"confirm_new_password\":\"Confirm new password\",\"current_avatar\":\"Your current avatar\",\"current_password\":\"Current password\",\"current_profile_banner\":\"Your current profile banner\",\"data_import_export_tab\":\"Data Import / Export\",\"default_vis\":\"Default visibility scope\",\"delete_account\":\"Delete Account\",\"delete_account_description\":\"Permanently delete your account and all your messages.\",\"delete_account_error\":\"There was an issue deleting your account. If this persists please contact your instance administrator.\",\"delete_account_instructions\":\"Type your password in the input below to confirm account deletion.\",\"avatar_size_instruction\":\"The recommended minimum size for avatar images is 150x150 pixels.\",\"export_theme\":\"Save preset\",\"filtering\":\"Filtering\",\"filtering_explanation\":\"All statuses containing these words will be muted, one per line\",\"follow_export\":\"Follow export\",\"follow_export_button\":\"Export your follows to a csv file\",\"follow_export_processing\":\"Processing, you'll soon be asked to download your file\",\"follow_import\":\"Follow import\",\"follow_import_error\":\"Error importing followers\",\"follows_imported\":\"Follows imported! Processing them will take a while.\",\"foreground\":\"Foreground\",\"general\":\"General\",\"hide_attachments_in_convo\":\"Hide attachments in conversations\",\"hide_attachments_in_tl\":\"Hide attachments in timeline\",\"max_thumbnails\":\"Maximum amount of thumbnails per post\",\"hide_isp\":\"Hide instance-specific panel\",\"preload_images\":\"Preload images\",\"use_one_click_nsfw\":\"Open NSFW attachments with just one click\",\"hide_post_stats\":\"Hide post statistics (e.g. the number of favorites)\",\"hide_user_stats\":\"Hide user statistics (e.g. the number of followers)\",\"hide_filtered_statuses\":\"Hide filtered statuses\",\"import_followers_from_a_csv_file\":\"Import follows from a csv file\",\"import_theme\":\"Load preset\",\"inputRadius\":\"Input fields\",\"checkboxRadius\":\"Checkboxes\",\"instance_default\":\"(default: {value})\",\"instance_default_simple\":\"(default)\",\"interface\":\"Interface\",\"interfaceLanguage\":\"Interface language\",\"invalid_theme_imported\":\"The selected file is not a supported Pleroma theme. No changes to your theme were made.\",\"limited_availability\":\"Unavailable in your browser\",\"links\":\"Links\",\"lock_account_description\":\"Restrict your account to approved followers only\",\"loop_video\":\"Loop videos\",\"loop_video_silent_only\":\"Loop only videos without sound (i.e. Mastodon's \\\"gifs\\\")\",\"mutes_tab\":\"Mutes\",\"play_videos_in_modal\":\"Play videos directly in the media viewer\",\"use_contain_fit\":\"Don't crop the attachment in thumbnails\",\"name\":\"Name\",\"name_bio\":\"Name & Bio\",\"new_password\":\"New password\",\"notification_visibility\":\"Types of notifications to show\",\"notification_visibility_follows\":\"Follows\",\"notification_visibility_likes\":\"Likes\",\"notification_visibility_mentions\":\"Mentions\",\"notification_visibility_repeats\":\"Repeats\",\"no_rich_text_description\":\"Strip rich text formatting from all posts\",\"no_blocks\":\"No blocks\",\"no_mutes\":\"No mutes\",\"hide_follows_description\":\"Don't show who I'm following\",\"hide_followers_description\":\"Don't show who's following me\",\"show_admin_badge\":\"Show Admin badge in my profile\",\"show_moderator_badge\":\"Show Moderator badge in my profile\",\"nsfw_clickthrough\":\"Enable clickthrough NSFW attachment hiding\",\"oauth_tokens\":\"OAuth tokens\",\"token\":\"Token\",\"refresh_token\":\"Refresh Token\",\"valid_until\":\"Valid Until\",\"revoke_token\":\"Revoke\",\"panelRadius\":\"Panels\",\"pause_on_unfocused\":\"Pause streaming when tab is not focused\",\"presets\":\"Presets\",\"profile_background\":\"Profile Background\",\"profile_banner\":\"Profile Banner\",\"profile_tab\":\"Profile\",\"radii_help\":\"Set up interface edge rounding (in pixels)\",\"replies_in_timeline\":\"Replies in timeline\",\"reply_link_preview\":\"Enable reply-link preview on mouse hover\",\"reply_visibility_all\":\"Show all replies\",\"reply_visibility_following\":\"Only show replies directed at me or users I'm following\",\"reply_visibility_self\":\"Only show replies directed at me\",\"saving_err\":\"Error saving settings\",\"saving_ok\":\"Settings saved\",\"security_tab\":\"Security\",\"scope_copy\":\"Copy scope when replying (DMs are always copied)\",\"set_new_avatar\":\"Set new avatar\",\"set_new_profile_background\":\"Set new profile background\",\"set_new_profile_banner\":\"Set new profile banner\",\"settings\":\"Settings\",\"subject_input_always_show\":\"Always show subject field\",\"subject_line_behavior\":\"Copy subject when replying\",\"subject_line_email\":\"Like email: \\\"re: subject\\\"\",\"subject_line_mastodon\":\"Like mastodon: copy as is\",\"subject_line_noop\":\"Do not copy\",\"post_status_content_type\":\"Post status content type\",\"status_content_type_plain\":\"Plain text\",\"stop_gifs\":\"Play-on-hover GIFs\",\"streaming\":\"Enable automatic streaming of new posts when scrolled to the top\",\"text\":\"Text\",\"theme\":\"Theme\",\"theme_help\":\"Use hex color codes (#rrggbb) to customize your color theme.\",\"theme_help_v2_1\":\"You can also override certain component's colors and opacity by toggling the checkbox, use \\\"Clear all\\\" button to clear all overrides.\",\"theme_help_v2_2\":\"Icons underneath some entries are background/text contrast indicators, hover over for detailed info. Please keep in mind that when using transparency contrast indicators show the worst possible case.\",\"tooltipRadius\":\"Tooltips/alerts\",\"upload_a_photo\":\"Upload a photo\",\"user_settings\":\"User Settings\",\"values\":{\"false\":\"no\",\"true\":\"yes\"},\"notifications\":\"Notifications\",\"enable_web_push_notifications\":\"Enable web push notifications\",\"style\":{\"switcher\":{\"keep_color\":\"Keep colors\",\"keep_shadows\":\"Keep shadows\",\"keep_opacity\":\"Keep opacity\",\"keep_roundness\":\"Keep roundness\",\"keep_fonts\":\"Keep fonts\",\"save_load_hint\":\"\\\"Keep\\\" options preserve currently set options when selecting or loading themes, it also stores said options when exporting a theme. When all checkboxes unset, exporting theme will save everything.\",\"reset\":\"Reset\",\"clear_all\":\"Clear all\",\"clear_opacity\":\"Clear opacity\"},\"common\":{\"color\":\"Color\",\"opacity\":\"Opacity\",\"contrast\":{\"hint\":\"Contrast ratio is {ratio}, it {level} {context}\",\"level\":{\"aa\":\"meets Level AA guideline (minimal)\",\"aaa\":\"meets Level AAA guideline (recommended)\",\"bad\":\"doesn't meet any accessibility guidelines\"},\"context\":{\"18pt\":\"for large (18pt+) text\",\"text\":\"for text\"}}},\"common_colors\":{\"_tab_label\":\"Common\",\"main\":\"Common colors\",\"foreground_hint\":\"See \\\"Advanced\\\" tab for more detailed control\",\"rgbo\":\"Icons, accents, badges\"},\"advanced_colors\":{\"_tab_label\":\"Advanced\",\"alert\":\"Alert background\",\"alert_error\":\"Error\",\"badge\":\"Badge background\",\"badge_notification\":\"Notification\",\"panel_header\":\"Panel header\",\"top_bar\":\"Top bar\",\"borders\":\"Borders\",\"buttons\":\"Buttons\",\"inputs\":\"Input fields\",\"faint_text\":\"Faded text\"},\"radii\":{\"_tab_label\":\"Roundness\"},\"shadows\":{\"_tab_label\":\"Shadow and lighting\",\"component\":\"Component\",\"override\":\"Override\",\"shadow_id\":\"Shadow #{value}\",\"blur\":\"Blur\",\"spread\":\"Spread\",\"inset\":\"Inset\",\"hint\":\"For shadows you can also use --variable as a color value to use CSS3 variables. Please note that setting opacity won't work in this case.\",\"filter_hint\":{\"always_drop_shadow\":\"Warning, this shadow always uses {0} when browser supports it.\",\"drop_shadow_syntax\":\"{0} does not support {1} parameter and {2} keyword.\",\"avatar_inset\":\"Please note that combining both inset and non-inset shadows on avatars might give unexpected results with transparent avatars.\",\"spread_zero\":\"Shadows with spread > 0 will appear as if it was set to zero\",\"inset_classic\":\"Inset shadows will be using {0}\"},\"components\":{\"panel\":\"Panel\",\"panelHeader\":\"Panel header\",\"topBar\":\"Top bar\",\"avatar\":\"User avatar (in profile view)\",\"avatarStatus\":\"User avatar (in post display)\",\"popup\":\"Popups and tooltips\",\"button\":\"Button\",\"buttonHover\":\"Button (hover)\",\"buttonPressed\":\"Button (pressed)\",\"buttonPressedHover\":\"Button (pressed+hover)\",\"input\":\"Input field\"}},\"fonts\":{\"_tab_label\":\"Fonts\",\"help\":\"Select font to use for elements of UI. For \\\"custom\\\" you have to enter exact font name as it appears in system.\",\"components\":{\"interface\":\"Interface\",\"input\":\"Input fields\",\"post\":\"Post text\",\"postCode\":\"Monospaced text in a post (rich text)\"},\"family\":\"Font name\",\"size\":\"Size (in px)\",\"weight\":\"Weight (boldness)\",\"custom\":\"Custom\"},\"preview\":{\"header\":\"Preview\",\"content\":\"Content\",\"error\":\"Example error\",\"button\":\"Button\",\"text\":\"A bunch of more {0} and {1}\",\"mono\":\"content\",\"input\":\"Just landed in L.A.\",\"faint_link\":\"helpful manual\",\"fine_print\":\"Read our {0} to learn nothing useful!\",\"header_faint\":\"This is fine\",\"checkbox\":\"I have skimmed over terms and conditions\",\"link\":\"a nice lil' link\"}}},\"timeline\":{\"collapse\":\"Collapse\",\"conversation\":\"Conversation\",\"error_fetching\":\"Error fetching updates\",\"load_older\":\"Load older statuses\",\"no_retweet_hint\":\"Post is marked as followers-only or direct and cannot be repeated\",\"repeated\":\"repeated\",\"show_new\":\"Show new\",\"up_to_date\":\"Up-to-date\",\"no_more_statuses\":\"No more statuses\",\"no_statuses\":\"No statuses\"},\"status\":{\"reply_to\":\"Reply to\",\"replies_list\":\"Replies:\"},\"user_card\":{\"approve\":\"Approve\",\"block\":\"Block\",\"blocked\":\"Blocked!\",\"deny\":\"Deny\",\"favorites\":\"Favorites\",\"follow\":\"Follow\",\"follow_sent\":\"Request sent!\",\"follow_progress\":\"Requesting…\",\"follow_again\":\"Send request again?\",\"follow_unfollow\":\"Unfollow\",\"followees\":\"Following\",\"followers\":\"Followers\",\"following\":\"Following!\",\"follows_you\":\"Follows you!\",\"its_you\":\"It's you!\",\"media\":\"Media\",\"mute\":\"Mute\",\"muted\":\"Muted\",\"per_day\":\"per day\",\"remote_follow\":\"Remote follow\",\"statuses\":\"Statuses\",\"unblock\":\"Unblock\",\"unblock_progress\":\"Unblocking...\",\"block_progress\":\"Blocking...\",\"unmute\":\"Unmute\",\"unmute_progress\":\"Unmuting...\",\"mute_progress\":\"Muting...\"},\"user_profile\":{\"timeline_title\":\"User Timeline\",\"profile_does_not_exist\":\"Sorry, this profile does not exist.\",\"profile_loading_error\":\"Sorry, there was an error loading this profile.\"},\"who_to_follow\":{\"more\":\"More\",\"who_to_follow\":\"Who to follow\"},\"tool_tip\":{\"media_upload\":\"Upload Media\",\"repeat\":\"Repeat\",\"reply\":\"Reply\",\"favorite\":\"Favorite\",\"user_settings\":\"User Settings\"},\"upload\":{\"error\":{\"base\":\"Upload failed.\",\"file_too_big\":\"File too big [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"Try again later\"},\"file_size_units\":{\"B\":\"B\",\"KiB\":\"KiB\",\"MiB\":\"MiB\",\"GiB\":\"GiB\",\"TiB\":\"TiB\"}}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/en.json\n// module id = 436\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Babilejo\"},\"features_panel\":{\"chat\":\"Babilejo\",\"gopher\":\"Gopher\",\"media_proxy\":\"Aŭdvidaĵa prokurilo\",\"scope_options\":\"Agordoj de amplekso\",\"text_limit\":\"Teksta limo\",\"title\":\"Funkcioj\",\"who_to_follow\":\"Kiun aboni\"},\"finder\":{\"error_fetching_user\":\"Eraro alportante uzanton\",\"find_user\":\"Trovi uzanton\"},\"general\":{\"apply\":\"Apliki\",\"submit\":\"Sendi\",\"more\":\"Pli\",\"generic_error\":\"Eraro okazis\",\"optional\":\"Malnepra\"},\"image_cropper\":{\"crop_picture\":\"Tondi bildon\",\"save\":\"Konservi\",\"cancel\":\"Nuligi\"},\"login\":{\"login\":\"Saluti\",\"description\":\"Saluti per OAuth\",\"logout\":\"Adiaŭi\",\"password\":\"Pasvorto\",\"placeholder\":\"ekz. lain\",\"register\":\"Registriĝi\",\"username\":\"Salutnomo\",\"hint\":\"Salutu por partopreni la diskutadon\"},\"media_modal\":{\"previous\":\"Antaŭa\",\"next\":\"Sekva\"},\"nav\":{\"about\":\"Pri\",\"back\":\"Reen\",\"chat\":\"Loka babilejo\",\"friend_requests\":\"Abonaj petoj\",\"mentions\":\"Mencioj\",\"dms\":\"Rektaj mesaĝoj\",\"public_tl\":\"Publika tempolinio\",\"timeline\":\"Tempolinio\",\"twkn\":\"La tuta konata reto\",\"user_search\":\"Serĉi uzantojn\",\"who_to_follow\":\"Kiun aboni\",\"preferences\":\"Agordoj\"},\"notifications\":{\"broken_favorite\":\"Nekonata stato, serĉante ĝin…\",\"favorited_you\":\"ŝatis vian staton\",\"followed_you\":\"ekabonis vin\",\"load_older\":\"Enlegi pli malnovajn sciigojn\",\"notifications\":\"Sciigoj\",\"read\":\"Legite!\",\"repeated_you\":\"ripetis vian staton\",\"no_more_notifications\":\"Neniuj pliaj sciigoj\"},\"post_status\":{\"new_status\":\"Afiŝi novan staton\",\"account_not_locked_warning\":\"Via konto ne estas {0}. Iu ajn povas vin aboni por vidi viajn afiŝoj nur por abonantoj.\",\"account_not_locked_warning_link\":\"ŝlosita\",\"attachments_sensitive\":\"Marki kunsendaĵojn kiel konsternajn\",\"content_type\":{\"plain_text\":\"Plata teksto\"},\"content_warning\":\"Temo (malnepra)\",\"default\":\"Ĵus alvenis al la Universala Kongreso!\",\"direct_warning\":\"Ĉi tiu afiŝo estos videbla nur por ĉiuj menciitaj uzantoj.\",\"posting\":\"Afiŝante\",\"scope\":{\"direct\":\"Rekta – Afiŝi nur al menciitaj uzantoj\",\"private\":\"Nur abonantoj – Afiŝi nur al abonantoj\",\"public\":\"Publika – Afiŝi al publikaj tempolinioj\",\"unlisted\":\"Nelistigita – Ne afiŝi al publikaj tempolinioj\"}},\"registration\":{\"bio\":\"Priskribo\",\"email\":\"Retpoŝtadreso\",\"fullname\":\"Vidiga nomo\",\"password_confirm\":\"Konfirmo de pasvorto\",\"registration\":\"Registriĝo\",\"token\":\"Invita ĵetono\",\"captcha\":\"TESTO DE HOMECO\",\"new_captcha\":\"Alklaku la bildon por akiri novan teston\",\"username_placeholder\":\"ekz. lain\",\"fullname_placeholder\":\"ekz. Lain Iwakura\",\"bio_placeholder\":\"ekz.\\nSaluton, mi estas Lain\\nMi estas animea knabino vivante en Japanujo. Eble vi konas min de la retejo « Wired ».\",\"validations\":{\"username_required\":\"ne povas resti malplena\",\"fullname_required\":\"ne povas resti malplena\",\"email_required\":\"ne povas resti malplena\",\"password_required\":\"ne povas resti malplena\",\"password_confirmation_required\":\"ne povas resti malplena\",\"password_confirmation_match\":\"samu la pasvorton\"}},\"settings\":{\"app_name\":\"Nomo de aplikaĵo\",\"attachmentRadius\":\"Kunsendaĵoj\",\"attachments\":\"Kunsendaĵoj\",\"autoload\":\"Ŝalti memfaran enlegadon ĉe subo de paĝo\",\"avatar\":\"Profilbildo\",\"avatarAltRadius\":\"Profilbildoj (sciigoj)\",\"avatarRadius\":\"Profilbildoj\",\"background\":\"Fono\",\"bio\":\"Priskribo\",\"blocks_tab\":\"Baroj\",\"btnRadius\":\"Butonoj\",\"cBlue\":\"Blua (Respondo, abono)\",\"cGreen\":\"Verda (Kunhavigo)\",\"cOrange\":\"Oranĝa (Ŝato)\",\"cRed\":\"Ruĝa (Nuligo)\",\"change_password\":\"Ŝanĝi pasvorton\",\"change_password_error\":\"Okazis eraro dum ŝanĝo de via pasvorto.\",\"changed_password\":\"Pasvorto sukcese ŝanĝiĝis!\",\"collapse_subject\":\"Maletendi afiŝojn kun temoj\",\"composing\":\"Verkante\",\"confirm_new_password\":\"Konfirmu novan pasvorton\",\"current_avatar\":\"Via nuna profilbildo\",\"current_password\":\"Nuna pasvorto\",\"current_profile_banner\":\"Via nuna profila rubando\",\"data_import_export_tab\":\"Enporto / Elporto de datenoj\",\"default_vis\":\"Implicita videbleca amplekso\",\"delete_account\":\"Forigi konton\",\"delete_account_description\":\"Por ĉiam forigi vian konton kaj ĉiujn viajn mesaĝojn\",\"delete_account_error\":\"Okazis eraro dum forigo de via kanto. Se tio daŭre okazados, bonvolu kontakti la administranton de via nodo.\",\"delete_account_instructions\":\"Entajpu sube vian pasvorton por konfirmi forigon de konto.\",\"avatar_size_instruction\":\"La rekomendata malpleja grando de profilbildoj estas 150×150 bilderoj.\",\"export_theme\":\"Konservi antaŭagordon\",\"filtering\":\"Filtrado\",\"filtering_explanation\":\"Ĉiuj statoj kun tiuj ĉi vortoj silentiĝos, po unu linio\",\"follow_export\":\"Abona elporto\",\"follow_export_button\":\"Elporti viajn abonojn al CSV-dosiero\",\"follow_export_processing\":\"Traktante; baldaŭ vi ricevos peton elŝuti la dosieron\",\"follow_import\":\"Abona enporto\",\"follow_import_error\":\"Eraro enportante abonojn\",\"follows_imported\":\"Abonoj enportiĝis! Traktado daŭros iom.\",\"foreground\":\"Malfono\",\"general\":\"Ĝenerala\",\"hide_attachments_in_convo\":\"Kaŝi kunsendaĵojn en interparoloj\",\"hide_attachments_in_tl\":\"Kaŝi kunsendaĵojn en tempolinio\",\"max_thumbnails\":\"Plej multa nombro da bildetoj po afiŝo\",\"hide_isp\":\"Kaŝi nodo-propran breton\",\"preload_images\":\"Antaŭ-enlegi bildojn\",\"use_one_click_nsfw\":\"Malfermi konsternajn kunsendaĵojn per nur unu klako\",\"hide_post_stats\":\"Kaŝi statistikon de afiŝoj (ekz. nombron da ŝatoj)\",\"hide_user_stats\":\"Kaŝi statistikon de uzantoj (ekz. nombron da abonantoj)\",\"hide_filtered_statuses\":\"Kaŝi filtritajn statojn\",\"import_followers_from_a_csv_file\":\"Enporti abonojn el CSV-dosiero\",\"import_theme\":\"Enlegi antaŭagordojn\",\"inputRadius\":\"Enigaj kampoj\",\"checkboxRadius\":\"Markbutonoj\",\"instance_default\":\"(implicita: {value})\",\"instance_default_simple\":\"(implicita)\",\"interface\":\"Fasado\",\"interfaceLanguage\":\"Lingvo de fasado\",\"invalid_theme_imported\":\"La elektita dosiero ne estas subtenata haŭto de Pleromo. Neniuj ŝanĝoj al via haŭto okazis.\",\"limited_availability\":\"Nehavebla en via foliumilo\",\"links\":\"Ligiloj\",\"lock_account_description\":\"Limigi vian konton al nur abonantoj aprobitaj\",\"loop_video\":\"Ripetadi filmojn\",\"loop_video_silent_only\":\"Ripetadi nur filmojn sen sono (ekz. la \\\"GIF-ojn\\\" de Mastodon)\",\"mutes_tab\":\"Silentigoj\",\"play_videos_in_modal\":\"Ludi filmojn rekte en la aŭdvidaĵa spektilo\",\"use_contain_fit\":\"Ne tondi la kunsendaĵon en bildetoj\",\"name\":\"Nomo\",\"name_bio\":\"Nomo kaj priskribo\",\"new_password\":\"Nova pasvorto\",\"notification_visibility\":\"Montrotaj specoj de sciigoj\",\"notification_visibility_follows\":\"Abonoj\",\"notification_visibility_likes\":\"Ŝatoj\",\"notification_visibility_mentions\":\"Mencioj\",\"notification_visibility_repeats\":\"Ripetoj\",\"no_rich_text_description\":\"Forigi riĉtekstajn formojn de ĉiuj afiŝoj\",\"no_blocks\":\"Neniuj baroj\",\"no_mutes\":\"Neniuj silentigoj\",\"hide_follows_description\":\"Ne montri kiun mi sekvas\",\"hide_followers_description\":\"Ne montri kiu min sekvas\",\"show_admin_badge\":\"Montri la insignon de administranto en mia profilo\",\"show_moderator_badge\":\"Montri la insignon de kontrolanto en mia profilo\",\"nsfw_clickthrough\":\"Ŝalti traklakan kaŝon de konsternaj kunsendaĵoj\",\"oauth_tokens\":\"Ĵetonoj de OAuth\",\"token\":\"Ĵetono\",\"refresh_token\":\"Ĵetono de novigo\",\"valid_until\":\"Valida ĝis\",\"revoke_token\":\"Senvalidigi\",\"panelRadius\":\"Bretoj\",\"pause_on_unfocused\":\"Paŭzigi elsendfluon kiam langeto ne estas fokusata\",\"presets\":\"Antaŭagordoj\",\"profile_background\":\"Profila fono\",\"profile_banner\":\"Profila rubando\",\"profile_tab\":\"Profilo\",\"radii_help\":\"Agordi fasadan rondigon de randoj (bildere)\",\"replies_in_timeline\":\"Respondoj en tempolinio\",\"reply_link_preview\":\"Ŝalti respond-ligilan antaŭvidon dum musa ŝvebo\",\"reply_visibility_all\":\"Montri ĉiujn respondojn\",\"reply_visibility_following\":\"Montri nur respondojn por mi aŭ miaj abonatoj\",\"reply_visibility_self\":\"Montri nur respondojn por mi\",\"saving_err\":\"Eraro dum konservo de agordoj\",\"saving_ok\":\"Agordoj konserviĝis\",\"security_tab\":\"Sekureco\",\"scope_copy\":\"Kopii amplekson por respondo (rektaj mesaĝoj ĉiam kopiiĝas)\",\"set_new_avatar\":\"Agordi novan profilbildon\",\"set_new_profile_background\":\"Agordi novan profilan fonon\",\"set_new_profile_banner\":\"Agordi novan profilan rubandon\",\"settings\":\"Agordoj\",\"subject_input_always_show\":\"Ĉiam montri teman kampon\",\"subject_line_behavior\":\"Kopii temon por respondo\",\"subject_line_email\":\"Kiel retpoŝto: \\\"re: temo\\\"\",\"subject_line_mastodon\":\"Kiel Mastodon: kopii senŝanĝe\",\"subject_line_noop\":\"Ne kopii\",\"post_status_content_type\":\"Afiŝi specon de la enhavo de la stato\",\"status_content_type_plain\":\"Plata teksto\",\"stop_gifs\":\"Movi GIF-bildojn dum musa ŝvebo\",\"streaming\":\"Ŝalti memfaran fluigon de novaj afiŝoj ĉe la supro de la paĝo\",\"text\":\"Teksto\",\"theme\":\"Haŭto\",\"theme_help\":\"Uzu deksesumajn kolorkodojn (#rrvvbb) por adapti vian koloran haŭton.\",\"theme_help_v2_1\":\"Vi ankaŭ povas superagordi la kolorojn kaj travideblecon de kelkaj eroj per marko de la markbutono; uzu la butonon \\\"Vakigi ĉion\\\" por forigi ĉîujn superagordojn.\",\"theme_help_v2_2\":\"Bildsimboloj sub kelkaj eroj estas indikiloj de kontrasto inter fono kaj teksto; muse ŝvebu por detalaj informoj. Bonvolu memori, ke la indikilo montras la plej malbonan okazeblon dum sia uzo.\",\"tooltipRadius\":\"Ŝpruchelpiloj/avertoj\",\"upload_a_photo\":\"Alŝuti foton\",\"user_settings\":\"Agordoj de uzanto\",\"values\":{\"false\":\"ne\",\"true\":\"jes\"},\"notifications\":\"Sciigoj\",\"enable_web_push_notifications\":\"Ŝalti retajn puŝajn sciigojn\",\"style\":{\"switcher\":{\"keep_color\":\"Konservi kolorojn\",\"keep_shadows\":\"Konservi ombrojn\",\"keep_opacity\":\"Konservi maltravideblecon\",\"keep_roundness\":\"Konservi rondecon\",\"keep_fonts\":\"Konservi tiparojn\",\"save_load_hint\":\"Elektebloj de \\\"konservi\\\" konservas la nuntempajn agordojn dum elektado aŭ enlegado de haŭtoj. Ĝi ankaŭ konservas tiujn agordojn dum elportado de haŭto. Kun ĉiuj markbutonoj nemarkitaj, elporto de la haŭto ĉion konservos.\",\"reset\":\"Restarigi\",\"clear_all\":\"Vakigi ĉion\",\"clear_opacity\":\"Vakigi maltravideblecon\"},\"common\":{\"color\":\"Koloro\",\"opacity\":\"Maltravidebleco\",\"contrast\":{\"hint\":\"Proporcio de kontrasto estas {ratio}, ĝi {level} {context}\",\"level\":{\"aa\":\"plenumas la gvidilon je nivelo AA (malpleja)\",\"aaa\":\"plenumas la gvidilon je nivela AAA (rekomendita)\",\"bad\":\"plenumas neniujn faciluzajn gvidilojn\"},\"context\":{\"18pt\":\"por granda (18pt+) teksto\",\"text\":\"por teksto\"}}},\"common_colors\":{\"_tab_label\":\"Komunaj\",\"main\":\"Komunaj koloroj\",\"foreground_hint\":\"Vidu langeton \\\"Specialaj\\\" por pli detalaj agordoj\",\"rgbo\":\"Bildsimboloj, emfazoj, insignoj\"},\"advanced_colors\":{\"_tab_label\":\"Specialaj\",\"alert\":\"Averta fono\",\"alert_error\":\"Eraro\",\"badge\":\"Insigna fono\",\"badge_notification\":\"Sciigo\",\"panel_header\":\"Kapo de breto\",\"top_bar\":\"Supra breto\",\"borders\":\"Limoj\",\"buttons\":\"Butonoj\",\"inputs\":\"Enigaj kampoj\",\"faint_text\":\"Malvigla teksto\"},\"radii\":{\"_tab_label\":\"Rondeco\"},\"shadows\":{\"_tab_label\":\"Ombro kaj lumo\",\"component\":\"Ero\",\"override\":\"Transpasi\",\"shadow_id\":\"Ombro #{value}\",\"blur\":\"Malklarigo\",\"spread\":\"Vastigo\",\"inset\":\"Internigo\",\"hint\":\"Por ombroj vi ankaŭ povas uzi --variable kiel koloran valoron, por uzi variantojn de CSS3. Bonvolu rimarki, ke tiuokaze agordoj de maltravidebleco ne funkcios.\",\"filter_hint\":{\"always_drop_shadow\":\"Averto: ĉi tiu ombro ĉiam uzas {0} kiam la foliumilo ĝin subtenas.\",\"drop_shadow_syntax\":\"{0} ne subtenas parametron {1} kaj ŝlosilvorton {2}.\",\"avatar_inset\":\"Bonvolu rimarki, ke agordi ambaŭ internajn kaj eksterajn ombrojn por profilbildoj povas redoni neatenditajn rezultojn ĉe profilbildoj travideblaj.\",\"spread_zero\":\"Ombroj kun vastigo > 0 aperos kvazaŭ ĝi estus fakte nulo\",\"inset_classic\":\"Internaj ombroj uzos {0}\"},\"components\":{\"panel\":\"Breto\",\"panelHeader\":\"Kapo de breto\",\"topBar\":\"Supra breto\",\"avatar\":\"Profilbildo de uzanto (en profila vido)\",\"avatarStatus\":\"Profilbildo de uzanto (en afiŝa vido)\",\"popup\":\"Ŝprucaĵoj\",\"button\":\"Butono\",\"buttonHover\":\"Butono (je ŝvebo)\",\"buttonPressed\":\"Butono (premita)\",\"buttonPressedHover\":\"Butono (premita je ŝvebo)\",\"input\":\"Eniga kampo\"}},\"fonts\":{\"_tab_label\":\"Tiparoj\",\"help\":\"Elektu tiparon uzotan por eroj de la fasado. Por \\\"propra\\\" vi devas enigi la precizan nomon de tiparo tiel, kiel ĝi aperas en la sistemo\",\"components\":{\"interface\":\"Fasado\",\"input\":\"Enigaj kampoj\",\"post\":\"Teksto de afiŝo\",\"postCode\":\"Egallarĝa teksto en afiŝo (riĉteksto)\"},\"family\":\"Nomo de tiparo\",\"size\":\"Grando (en bilderoj)\",\"weight\":\"Pezo (graseco)\",\"custom\":\"Propra\"},\"preview\":{\"header\":\"Antaŭrigardo\",\"content\":\"Enhavo\",\"error\":\"Ekzempla eraro\",\"button\":\"Butono\",\"text\":\"Kelko da pliaj {0} kaj {1}\",\"mono\":\"enhavo\",\"input\":\"Ĵus alvenis al la Universala Kongreso!\",\"faint_link\":\"helpan manlibron\",\"fine_print\":\"Legu nian {0} por nenion utilan ekscii!\",\"header_faint\":\"Tio estas en ordo\",\"checkbox\":\"Mi legetis la kondiĉojn de uzado\",\"link\":\"bela eta ligil’\"}}},\"timeline\":{\"collapse\":\"Maletendi\",\"conversation\":\"Interparolo\",\"error_fetching\":\"Eraro dum ĝisdatigo\",\"load_older\":\"Montri pli malnovajn statojn\",\"no_retweet_hint\":\"Afiŝo estas markita kiel rekta aŭ nur por abonantoj, kaj ne eblas ĝin ripeti\",\"repeated\":\"ripetita\",\"show_new\":\"Montri novajn\",\"up_to_date\":\"Ĝisdata\",\"no_more_statuses\":\"Neniuj pliaj statoj\",\"no_statuses\":\"Neniuj statoj\"},\"user_card\":{\"approve\":\"Aprobi\",\"block\":\"Bari\",\"blocked\":\"Barita!\",\"deny\":\"Rifuzi\",\"favorites\":\"Ŝatataj\",\"follow\":\"Aboni\",\"follow_sent\":\"Peto sendiĝis!\",\"follow_progress\":\"Petanta…\",\"follow_again\":\"Ĉu sendi peton denove?\",\"follow_unfollow\":\"Malaboni\",\"followees\":\"Abonatoj\",\"followers\":\"Abonantoj\",\"following\":\"Abonanta!\",\"follows_you\":\"Abonas vin!\",\"its_you\":\"Tio estas vi!\",\"media\":\"Aŭdvidaĵoj\",\"mute\":\"Silentigi\",\"muted\":\"Silentigitaj\",\"per_day\":\"tage\",\"remote_follow\":\"Fore aboni\",\"statuses\":\"Statoj\",\"unblock\":\"Malbari\",\"unblock_progress\":\"Malbaranta…\",\"block_progress\":\"Baranta…\",\"unmute\":\"Malsilentigi\",\"unmute_progress\":\"Malsilentiganta…\",\"mute_progress\":\"Silentiganta…\"},\"user_profile\":{\"timeline_title\":\"Uzanta tempolinio\",\"profile_does_not_exist\":\"Pardonu, ĉi tiu profilo ne ekzistas.\",\"profile_loading_error\":\"Pardonu, eraro okazis dum enlegado de ĉi tiu profilo.\"},\"who_to_follow\":{\"more\":\"Pli\",\"who_to_follow\":\"Kiun aboni\"},\"tool_tip\":{\"media_upload\":\"Alŝuti aŭdvidaĵon\",\"repeat\":\"Ripeti\",\"reply\":\"Respondi\",\"favorite\":\"Ŝati\",\"user_settings\":\"Agordoj de uzanto\"},\"upload\":{\"error\":{\"base\":\"Alŝuto malsukcesis.\",\"file_too_big\":\"Dosiero estas tro granda [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"Reprovu pli poste\"},\"file_size_units\":{\"B\":\"B\",\"KiB\":\"KiB\",\"MiB\":\"MiB\",\"GiB\":\"GiB\",\"TiB\":\"TiB\"}}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/eo.json\n// module id = 437\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Chat\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Media proxy\",\"scope_options\":\"Opciones del alcance de la visibilidad\",\"text_limit\":\"Límite de carácteres\",\"title\":\"Características\",\"who_to_follow\":\"A quién seguir\"},\"finder\":{\"error_fetching_user\":\"Error al buscar usuario\",\"find_user\":\"Encontrar usuario\"},\"general\":{\"apply\":\"Aplicar\",\"submit\":\"Enviar\",\"more\":\"Más\",\"generic_error\":\"Ha ocurrido un error\"},\"login\":{\"login\":\"Identificación\",\"description\":\"Identificación con OAuth\",\"logout\":\"Salir\",\"password\":\"Contraseña\",\"placeholder\":\"p.ej. lain\",\"register\":\"Registrar\",\"username\":\"Usuario\",\"hint\":\"Inicia sesión para unirte a la discusión\"},\"nav\":{\"about\":\"Sobre\",\"back\":\"Volver\",\"chat\":\"Chat Local\",\"friend_requests\":\"Solicitudes de amistad\",\"mentions\":\"Menciones\",\"dms\":\"Mensajes Directo\",\"public_tl\":\"Línea Temporal Pública\",\"timeline\":\"Línea Temporal\",\"twkn\":\"Toda La Red Conocida\",\"user_search\":\"Búsqueda de Usuarios\",\"who_to_follow\":\"A quién seguir\",\"preferences\":\"Preferencias\"},\"notifications\":{\"broken_favorite\":\"Estado desconocido, buscándolo...\",\"favorited_you\":\"le gusta tu estado\",\"followed_you\":\"empezó a seguirte\",\"load_older\":\"Cargar notificaciones antiguas\",\"notifications\":\"Notificaciones\",\"read\":\"¡Leído!\",\"repeated_you\":\"repite tu estado\",\"no_more_notifications\":\"No hay más notificaciones\"},\"post_status\":{\"new_status\":\"Publicar un nuevo estado\",\"account_not_locked_warning\":\"Tu cuenta no está {0}. Cualquiera puede seguirte y leer las entradas para Solo-Seguidores.\",\"account_not_locked_warning_link\":\"bloqueada\",\"attachments_sensitive\":\"Contenido sensible\",\"content_type\":{\"plain_text\":\"Texto Plano\"},\"content_warning\":\"Tema (opcional)\",\"default\":\"Acabo de aterrizar en L.A.\",\"direct_warning\":\"Esta entrada solo será visible para los usuarios mencionados.\",\"posting\":\"Publicando\",\"scope\":{\"direct\":\"Directo - Solo para los usuarios mencionados.\",\"private\":\"Solo-Seguidores - Solo tus seguidores leeran la entrada\",\"public\":\"Público - Entradas visibles en las Líneas Temporales Públicas\",\"unlisted\":\"Sin Listar - Entradas no visibles en las Líneas Temporales Públicas\"}},\"registration\":{\"bio\":\"Biografía\",\"email\":\"Correo electrónico\",\"fullname\":\"Nombre a mostrar\",\"password_confirm\":\"Confirmación de contraseña\",\"registration\":\"Registro\",\"token\":\"Token de invitación\",\"captcha\":\"CAPTCHA\",\"new_captcha\":\"Click en la imagen para obtener un nuevo captca\",\"validations\":{\"username_required\":\"no puede estar vacío\",\"fullname_required\":\"no puede estar vacío\",\"email_required\":\"no puede estar vacío\",\"password_required\":\"no puede estar vacío\",\"password_confirmation_required\":\"no puede estar vacío\",\"password_confirmation_match\":\"la contraseña no coincide\"}},\"settings\":{\"attachmentRadius\":\"Adjuntos\",\"attachments\":\"Adjuntos\",\"autoload\":\"Activar carga automática al llegar al final de la página\",\"avatar\":\"Avatar\",\"avatarAltRadius\":\"Avatares (Notificaciones)\",\"avatarRadius\":\"Avatares\",\"background\":\"Fondo\",\"bio\":\"Biografía\",\"btnRadius\":\"Botones\",\"cBlue\":\"Azul (Responder, seguir)\",\"cGreen\":\"Verde (Retweet)\",\"cOrange\":\"Naranja (Favorito)\",\"cRed\":\"Rojo (Cancelar)\",\"change_password\":\"Cambiar contraseña\",\"change_password_error\":\"Hubo un problema cambiando la contraseña.\",\"changed_password\":\"Contraseña cambiada correctamente!\",\"collapse_subject\":\"Colapsar entradas con tema\",\"composing\":\"Redactando\",\"confirm_new_password\":\"Confirmar la nueva contraseña\",\"current_avatar\":\"Tu avatar actual\",\"current_password\":\"Contraseña actual\",\"current_profile_banner\":\"Tu cabecera actual\",\"data_import_export_tab\":\"Importar / Exportar Datos\",\"default_vis\":\"Alcance de visibilidad por defecto\",\"delete_account\":\"Eliminar la cuenta\",\"delete_account_description\":\"Eliminar para siempre la cuenta y todos los mensajes.\",\"delete_account_error\":\"Hubo un error al eliminar tu cuenta. Si el fallo persiste, ponte en contacto con el administrador de tu instancia.\",\"delete_account_instructions\":\"Escribe tu contraseña para confirmar la eliminación de tu cuenta.\",\"avatar_size_instruction\":\"El tamaño mínimo recomendado para el avatar es de 150X150 píxeles.\",\"export_theme\":\"Exportar tema\",\"filtering\":\"Filtros\",\"filtering_explanation\":\"Todos los estados que contengan estas palabras serán silenciados, una por línea\",\"follow_export\":\"Exportar personas que tú sigues\",\"follow_export_button\":\"Exporta tus seguidores a un archivo csv\",\"follow_export_processing\":\"Procesando, en breve se te preguntará para guardar el archivo\",\"follow_import\":\"Importar personas que tú sigues\",\"follow_import_error\":\"Error al importal el archivo\",\"follows_imported\":\"¡Importado! Procesarlos llevará tiempo.\",\"foreground\":\"Primer plano\",\"general\":\"General\",\"hide_attachments_in_convo\":\"Ocultar adjuntos en las conversaciones\",\"hide_attachments_in_tl\":\"Ocultar adjuntos en la línea temporal\",\"hide_isp\":\"Ocultar el panel específico de la instancia\",\"preload_images\":\"Precargar las imágenes\",\"use_one_click_nsfw\":\"Abrir los adjuntos NSFW con un solo click.\",\"hide_post_stats\":\"Ocultar las estadísticas de las entradas (p.ej. el número de favoritos)\",\"hide_user_stats\":\"Ocultar las estadísticas del usuario (p.ej. el número de seguidores)\",\"hide_filtered_statuses\":\"Ocultar estados filtrados\",\"import_followers_from_a_csv_file\":\"Importar personas que tú sigues a partir de un archivo csv\",\"import_theme\":\"Importar tema\",\"inputRadius\":\"Campos de entrada\",\"checkboxRadius\":\"Casillas de verificación\",\"instance_default\":\"(por defecto: {value})\",\"instance_default_simple\":\"(por defecto)\",\"interface\":\"Interfaz\",\"interfaceLanguage\":\"Idioma\",\"invalid_theme_imported\":\"El archivo importado no es un tema válido de Pleroma. No se han realizado cambios.\",\"limited_availability\":\"No disponible en tu navegador\",\"links\":\"Enlaces\",\"lock_account_description\":\"Restringir el acceso a tu cuenta solo a seguidores admitidos\",\"loop_video\":\"Vídeos en bucle\",\"loop_video_silent_only\":\"Bucle solo en vídeos sin sonido (p.ej. \\\"gifs\\\" de Mastodon)\",\"play_videos_in_modal\":\"Reproducir los vídeos directamente en el visor de medios\",\"use_contain_fit\":\"No recortar los adjuntos en miniaturas\",\"name\":\"Nombre\",\"name_bio\":\"Nombre y Biografía\",\"new_password\":\"Nueva contraseña\",\"notification_visibility\":\"Tipos de notificaciones a mostrar\",\"notification_visibility_follows\":\"Nuevos seguidores\",\"notification_visibility_likes\":\"Me gustan (Likes)\",\"notification_visibility_mentions\":\"Menciones\",\"notification_visibility_repeats\":\"Repeticiones (Repeats)\",\"no_rich_text_description\":\"Eliminar el formato de texto enriquecido de todas las entradas\",\"hide_follows_description\":\"No mostrar a quién sigo\",\"hide_followers_description\":\"No mostrar quién me sigue\",\"show_admin_badge\":\"Mostrar la placa de administrador en mi perfil\",\"show_moderator_badge\":\"Mostrar la placa de moderador en mi perfil\",\"nsfw_clickthrough\":\"Activar el clic para ocultar los adjuntos NSFW\",\"oauth_tokens\":\"Tokens de OAuth\",\"token\":\"Token\",\"refresh_token\":\"Actualizar el token\",\"valid_until\":\"Válido hasta\",\"revoke_token\":\"Revocar\",\"panelRadius\":\"Paneles\",\"pause_on_unfocused\":\"Parar la transmisión cuando no estés en foco.\",\"presets\":\"Por defecto\",\"profile_background\":\"Fondo del Perfil\",\"profile_banner\":\"Cabecera del Perfil\",\"profile_tab\":\"Perfil\",\"radii_help\":\"Estable el redondeo de las esquinas del interfaz (en píxeles)\",\"replies_in_timeline\":\"Réplicas en la línea temporal\",\"reply_link_preview\":\"Activar la previsualización del enlace de responder al pasar el ratón por encim\",\"reply_visibility_all\":\"Mostrar todas las réplicas\",\"reply_visibility_following\":\"Solo mostrar réplicas para mí o usuarios a los que sigo\",\"reply_visibility_self\":\"Solo mostrar réplicas para mí\",\"saving_err\":\"Error al guardar los ajustes\",\"saving_ok\":\"Ajustes guardados\",\"security_tab\":\"Seguridad\",\"scope_copy\":\"Copiar la visibilidad cuando contestamos (En los mensajes directos (MDs) siempre se copia)\",\"set_new_avatar\":\"Cambiar avatar\",\"set_new_profile_background\":\"Cambiar fondo del perfil\",\"set_new_profile_banner\":\"Cambiar cabecera del perfil\",\"settings\":\"Ajustes\",\"subject_input_always_show\":\"Mostrar siempre el campo del tema\",\"subject_line_behavior\":\"Copiar el tema en las contestaciones\",\"subject_line_email\":\"Tipo email: \\\"re: tema\\\"\",\"subject_line_mastodon\":\"Tipo mastodon: copiar como es\",\"subject_line_noop\":\"No copiar\",\"post_status_content_type\":\"Formato de publicación\",\"status_content_type_plain\":\"Texto plano\",\"stop_gifs\":\"Iniciar GIFs al pasar el ratón\",\"streaming\":\"Habilite la transmisión automática de nuevas publicaciones cuando se desplaza hacia la parte superior\",\"text\":\"Texto\",\"theme\":\"Tema\",\"theme_help\":\"Use códigos de color hexadecimales (#rrggbb) para personalizar su tema de colores.\",\"theme_help_v2_1\":\"También puede invalidar los colores y la opacidad de ciertos componentes si activa la casilla de verificación, use el botón \\\"Borrar todo\\\" para deshacer los cambios.\",\"theme_help_v2_2\":\"Los iconos debajo de algunas entradas son indicadores de contraste de fondo/texto, desplace el ratón para obtener información detallada. Tenga en cuenta que cuando se utilizan indicadores de contraste de transparencia se muestra el peor caso posible.\",\"tooltipRadius\":\"Información/alertas\",\"user_settings\":\"Ajustes de Usuario\",\"values\":{\"false\":\"no\",\"true\":\"sí\"},\"notifications\":\"Notificaciones\",\"enable_web_push_notifications\":\"Habilitar las notificiaciones en el navegador\",\"style\":{\"switcher\":{\"keep_color\":\"Mantener colores\",\"keep_shadows\":\"Mantener sombras\",\"keep_opacity\":\"Mantener opacidad\",\"keep_roundness\":\"Mantener redondeces\",\"keep_fonts\":\"Mantener fuentes\",\"save_load_hint\":\"Las opciones \\\"Mantener\\\" conservan las opciones configuradas actualmente al seleccionar o cargar temas, también almacena dichas opciones al exportar un tema. Cuando se desactiven todas las casillas de verificación, el tema de exportación lo guardará todo.\",\"reset\":\"Reiniciar\",\"clear_all\":\"Limpiar todo\",\"clear_opacity\":\"Limpiar opacidad\"},\"common\":{\"color\":\"Color\",\"opacity\":\"Opacidad\",\"contrast\":{\"hint\":\"El ratio de contraste es {ratio}. {level} {context}\",\"level\":{\"aa\":\"Cumple con la pauta de nivel AA (mínimo)\",\"aaa\":\"Cumple con la pauta de nivel AAA (recomendado)\",\"bad\":\"No cumple con las pautas de accesibilidad\"},\"context\":{\"18pt\":\"para textos grandes (+18pt)\",\"text\":\"para textos\"}}},\"common_colors\":{\"_tab_label\":\"Común\",\"main\":\"Colores comunes\",\"foreground_hint\":\"Vea la pestaña \\\"Avanzado\\\" para un control más detallado\",\"rgbo\":\"Iconos, acentos, insignias\"},\"advanced_colors\":{\"_tab_label\":\"Avanzado\",\"alert\":\"Fondo de Alertas\",\"alert_error\":\"Error\",\"badge\":\"Fondo de Insignias\",\"badge_notification\":\"Notificaciones\",\"panel_header\":\"Cabecera del panel\",\"top_bar\":\"Barra superior\",\"borders\":\"Bordes\",\"buttons\":\"Botones\",\"inputs\":\"Campos de entrada\",\"faint_text\":\"Texto desvanecido\"},\"radii\":{\"_tab_label\":\"Redondez\"},\"shadows\":{\"_tab_label\":\"Sombra e iluminación\",\"component\":\"Componente\",\"override\":\"Sobreescribir\",\"shadow_id\":\"Sombra #{value}\",\"blur\":\"Difuminar\",\"spread\":\"Cantidad\",\"inset\":\"Insertada\",\"hint\":\"Para las sombras, también puede usar --variable como un valor de color para usar las variables CSS3. Tenga en cuenta que establecer la opacidad no funcionará en este caso.\",\"filter_hint\":{\"always_drop_shadow\":\"Advertencia, esta sombra siempre usa {0} cuando el navegador lo soporta.\",\"drop_shadow_syntax\":\"{0} no soporta el parámetro {1} y la palabra clave {2}.\",\"avatar_inset\":\"Tenga en cuenta que la combinación de sombras insertadas como no-insertadas en los avatares, puede dar resultados inesperados con los avatares transparentes.\",\"spread_zero\":\"Sombras con una cantidad > 0 aparecerá como si estuviera puesto a cero\",\"inset_classic\":\"Las sombras insertadas estarán usando {0}\"},\"components\":{\"panel\":\"Panel\",\"panelHeader\":\"Cabecera del panel\",\"topBar\":\"Barra superior\",\"avatar\":\"Avatar del usuario (en la vista del perfil)\",\"avatarStatus\":\"Avatar del usuario (en la vista de la entrada)\",\"popup\":\"Ventanas y textos emergentes (popups & tooltips)\",\"button\":\"Botones\",\"buttonHover\":\"Botón (encima)\",\"buttonPressed\":\"Botón (presionado)\",\"buttonPressedHover\":\"Botón (presionado+encima)\",\"input\":\"Campo de entrada\"}},\"fonts\":{\"_tab_label\":\"Fuentes\",\"help\":\"Seleccione la fuente para utilizar para los elementos de la interfaz de usuario. Para \\\"personalizado\\\", debe ingresar el nombre exacto de la fuente tal como aparece en el sistema.\",\"components\":{\"interface\":\"Interfaz\",\"input\":\"Campos de entrada\",\"post\":\"Texto de publicaciones\",\"postCode\":\"Texto monoespaciado en publicación (texto enriquecido)\"},\"family\":\"Nombre de la fuente\",\"size\":\"Tamaño (en px)\",\"weight\":\"Peso (negrita)\",\"custom\":\"Personalizado\"},\"preview\":{\"header\":\"Vista previa\",\"content\":\"Contenido\",\"error\":\"Ejemplo de error\",\"button\":\"Botón\",\"text\":\"Un montón de {0} y {1}\",\"mono\":\"contenido\",\"input\":\"Acaba de aterrizar en L.A.\",\"faint_link\":\"manual útil\",\"fine_print\":\"¡Lea nuestro {0} para aprender nada útil!\",\"header_faint\":\"Esto está bien\",\"checkbox\":\"He revisado los términos y condiciones\",\"link\":\"un bonito enlace\"}}},\"timeline\":{\"collapse\":\"Colapsar\",\"conversation\":\"Conversación\",\"error_fetching\":\"Error al cargar las actualizaciones\",\"load_older\":\"Cargar actualizaciones anteriores\",\"no_retweet_hint\":\"La publicación está marcada como solo para seguidores o directa y no se puede repetir\",\"repeated\":\"repetida\",\"show_new\":\"Mostrar lo nuevo\",\"up_to_date\":\"Actualizado\",\"no_more_statuses\":\"No hay más estados\"},\"user_card\":{\"approve\":\"Aprovar\",\"block\":\"Bloquear\",\"blocked\":\"¡Bloqueado!\",\"deny\":\"Denegar\",\"favorites\":\"Favoritos\",\"follow\":\"Seguir\",\"follow_sent\":\"¡Solicitud enviada!\",\"follow_progress\":\"Solicitando…\",\"follow_again\":\"¿Enviar solicitud de nuevo?\",\"follow_unfollow\":\"Dejar de seguir\",\"followees\":\"Siguiendo\",\"followers\":\"Seguidores\",\"following\":\"¡Siguiendo!\",\"follows_you\":\"¡Te sigue!\",\"its_you\":\"¡Eres tú!\",\"media\":\"Media\",\"mute\":\"Silenciar\",\"muted\":\"Silenciado\",\"per_day\":\"por día\",\"remote_follow\":\"Seguir\",\"statuses\":\"Estados\"},\"user_profile\":{\"timeline_title\":\"Linea temporal del usuario\"},\"who_to_follow\":{\"more\":\"Más\",\"who_to_follow\":\"A quién seguir\"},\"tool_tip\":{\"media_upload\":\"Subir Medios\",\"repeat\":\"Repetir\",\"reply\":\"Contestar\",\"favorite\":\"Favorito\",\"user_settings\":\"Ajustes de usuario\"},\"upload\":{\"error\":{\"base\":\"Subida fallida.\",\"file_too_big\":\"Archivo demasiado grande [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"Inténtalo más tarde\"},\"file_size_units\":{\"B\":\"B\",\"KiB\":\"KiB\",\"MiB\":\"MiB\",\"GiB\":\"GiB\",\"TiB\":\"TiB\"}}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/es.json\n// module id = 438\n// module chunks = 2","module.exports = {\"finder\":{\"error_fetching_user\":\"Viga kasutaja leidmisel\",\"find_user\":\"Otsi kasutajaid\"},\"general\":{\"submit\":\"Postita\"},\"login\":{\"login\":\"Logi sisse\",\"logout\":\"Logi välja\",\"password\":\"Parool\",\"placeholder\":\"nt lain\",\"register\":\"Registreeru\",\"username\":\"Kasutajanimi\"},\"nav\":{\"mentions\":\"Mainimised\",\"public_tl\":\"Avalik Ajajoon\",\"timeline\":\"Ajajoon\",\"twkn\":\"Kogu Teadaolev Võrgustik\"},\"notifications\":{\"followed_you\":\"alustas sinu jälgimist\",\"notifications\":\"Teavitused\",\"read\":\"Loe!\"},\"post_status\":{\"default\":\"Just sõitsin elektrirongiga Tallinnast Pääskülla.\",\"posting\":\"Postitan\"},\"registration\":{\"bio\":\"Bio\",\"email\":\"E-post\",\"fullname\":\"Kuvatav nimi\",\"password_confirm\":\"Parooli kinnitamine\",\"registration\":\"Registreerimine\"},\"settings\":{\"attachments\":\"Manused\",\"autoload\":\"Luba ajajoone automaatne uuendamine kui ajajoon on põhja keritud\",\"avatar\":\"Profiilipilt\",\"bio\":\"Bio\",\"current_avatar\":\"Sinu praegune profiilipilt\",\"current_profile_banner\":\"Praegune profiilibänner\",\"filtering\":\"Sisu filtreerimine\",\"filtering_explanation\":\"Kõiki staatuseid, mis sisaldavad neid sõnu, ei kuvata. Üks sõna reale.\",\"hide_attachments_in_convo\":\"Peida manused vastlustes\",\"hide_attachments_in_tl\":\"Peida manused ajajoonel\",\"name\":\"Nimi\",\"name_bio\":\"Nimi ja Bio\",\"nsfw_clickthrough\":\"Peida tööks-mittesobivad(NSFW) manuste hiireklõpsu taha\",\"profile_background\":\"Profiilitaust\",\"profile_banner\":\"Profiilibänner\",\"reply_link_preview\":\"Luba algpostituse kuvamine vastustes\",\"set_new_avatar\":\"Vali uus profiilipilt\",\"set_new_profile_background\":\"Vali uus profiilitaust\",\"set_new_profile_banner\":\"Vali uus profiilibänner\",\"settings\":\"Sätted\",\"theme\":\"Teema\",\"user_settings\":\"Kasutaja sätted\"},\"timeline\":{\"conversation\":\"Vestlus\",\"error_fetching\":\"Viga uuenduste laadimisel\",\"load_older\":\"Kuva vanemaid staatuseid\",\"show_new\":\"Näita uusi\",\"up_to_date\":\"Uuendatud\"},\"user_card\":{\"block\":\"Blokeeri\",\"blocked\":\"Blokeeritud!\",\"follow\":\"Jälgi\",\"followees\":\"Jälgitavaid\",\"followers\":\"Jälgijaid\",\"following\":\"Jälgin!\",\"follows_you\":\"Jälgib sind!\",\"mute\":\"Vaigista\",\"muted\":\"Vaigistatud\",\"per_day\":\"päevas\",\"statuses\":\"Staatuseid\"}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/et.json\n// module id = 439\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Chat\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Media-välityspalvelin\",\"scope_options\":\"Näkyvyyden rajaus\",\"text_limit\":\"Tekstin pituusraja\",\"title\":\"Ominaisuudet\",\"who_to_follow\":\"Seurausehdotukset\"},\"finder\":{\"error_fetching_user\":\"Virhe hakiessa käyttäjää\",\"find_user\":\"Hae käyttäjä\"},\"general\":{\"apply\":\"Aseta\",\"submit\":\"Lähetä\",\"more\":\"Lisää\",\"generic_error\":\"Virhe tapahtui\"},\"login\":{\"login\":\"Kirjaudu sisään\",\"description\":\"Kirjaudu sisään OAuthilla\",\"logout\":\"Kirjaudu ulos\",\"password\":\"Salasana\",\"placeholder\":\"esim. Seppo\",\"register\":\"Rekisteröidy\",\"username\":\"Käyttäjänimi\"},\"nav\":{\"about\":\"Tietoja\",\"back\":\"Takaisin\",\"chat\":\"Paikallinen Chat\",\"friend_requests\":\"Seurauspyynnöt\",\"mentions\":\"Maininnat\",\"dms\":\"Yksityisviestit\",\"public_tl\":\"Julkinen Aikajana\",\"timeline\":\"Aikajana\",\"twkn\":\"Koko Tunnettu Verkosto\",\"user_search\":\"Käyttäjähaku\",\"who_to_follow\":\"Seurausehdotukset\",\"preferences\":\"Asetukset\"},\"notifications\":{\"broken_favorite\":\"Viestiä ei löydetty...\",\"favorited_you\":\"tykkäsi viestistäsi\",\"followed_you\":\"seuraa sinua\",\"load_older\":\"Lataa vanhempia ilmoituksia\",\"notifications\":\"Ilmoitukset\",\"read\":\"Lue!\",\"repeated_you\":\"toisti viestisi\",\"no_more_notifications\":\"Ei enempää ilmoituksia\"},\"post_status\":{\"new_status\":\"Uusi viesti\",\"account_not_locked_warning\":\"Tilisi ei ole {0}. Kuka vain voi seurata sinua nähdäksesi 'vain-seuraajille' -viestisi\",\"account_not_locked_warning_link\":\"lukittu\",\"attachments_sensitive\":\"Merkkaa liitteet arkaluonteisiksi\",\"content_type\":{\"plain_text\":\"Tavallinen teksti\"},\"content_warning\":\"Aihe (valinnainen)\",\"default\":\"Tulin juuri saunasta.\",\"direct_warning\":\"Tämä viesti näkyy vain mainituille käyttäjille.\",\"posting\":\"Lähetetään\",\"scope\":{\"direct\":\"Yksityisviesti - Näkyy vain mainituille käyttäjille\",\"private\":\"Vain-seuraajille - Näkyy vain seuraajillesi\",\"public\":\"Julkinen - Näkyy julkisilla aikajanoilla\",\"unlisted\":\"Listaamaton - Ei näy julkisilla aikajanoilla\"}},\"registration\":{\"bio\":\"Kuvaus\",\"email\":\"Sähköposti\",\"fullname\":\"Koko nimi\",\"password_confirm\":\"Salasanan vahvistaminen\",\"registration\":\"Rekisteröityminen\",\"token\":\"Kutsuvaltuus\",\"captcha\":\"Varmenne\",\"new_captcha\":\"Paina kuvaa saadaksesi uuden varmenteen\",\"validations\":{\"username_required\":\"ei voi olla tyhjä\",\"fullname_required\":\"ei voi olla tyhjä\",\"email_required\":\"ei voi olla tyhjä\",\"password_required\":\"ei voi olla tyhjä\",\"password_confirmation_required\":\"ei voi olla tyhjä\",\"password_confirmation_match\":\"pitää vastata salasanaa\"}},\"settings\":{\"attachmentRadius\":\"Liitteet\",\"attachments\":\"Liitteet\",\"autoload\":\"Lataa vanhempia viestejä automaattisesti ruudun pohjalla\",\"avatar\":\"Profiilikuva\",\"avatarAltRadius\":\"Profiilikuvat (ilmoitukset)\",\"avatarRadius\":\"Profiilikuvat\",\"background\":\"Tausta\",\"bio\":\"Kuvaus\",\"btnRadius\":\"Napit\",\"cBlue\":\"Sininen (Vastaukset, seuraukset)\",\"cGreen\":\"Vihreä (Toistot)\",\"cOrange\":\"Oranssi (Tykkäykset)\",\"cRed\":\"Punainen (Peruminen)\",\"change_password\":\"Vaihda salasana\",\"change_password_error\":\"Virhe vaihtaessa salasanaa.\",\"changed_password\":\"Salasana vaihdettu!\",\"collapse_subject\":\"Minimoi viestit, joille on asetettu aihe\",\"composing\":\"Viestien laatiminen\",\"confirm_new_password\":\"Vahvista uusi salasana\",\"current_avatar\":\"Nykyinen profiilikuvasi\",\"current_password\":\"Nykyinen salasana\",\"current_profile_banner\":\"Nykyinen julisteesi\",\"data_import_export_tab\":\"Tietojen tuonti / vienti\",\"default_vis\":\"Oletusnäkyvyysrajaus\",\"delete_account\":\"Poista tili\",\"delete_account_description\":\"Poista tilisi ja viestisi pysyvästi.\",\"delete_account_error\":\"Virhe poistaessa tiliäsi. Jos virhe jatkuu, ota yhteyttä palvelimesi ylläpitoon.\",\"delete_account_instructions\":\"Syötä salasanasi vahvistaaksesi tilin poiston.\",\"export_theme\":\"Tallenna teema\",\"filtering\":\"Suodatus\",\"filtering_explanation\":\"Kaikki viestit, jotka sisältävät näitä sanoja, suodatetaan. Yksi sana per rivi.\",\"follow_export\":\"Seurausten vienti\",\"follow_export_button\":\"Vie seurauksesi CSV-tiedostoon\",\"follow_export_processing\":\"Käsitellään, sinua pyydetään lataamaan tiedosto hetken päästä\",\"follow_import\":\"Seurausten tuonti\",\"follow_import_error\":\"Virhe tuodessa seuraksia\",\"follows_imported\":\"Seuraukset tuotu! Niiden käsittely vie hetken.\",\"foreground\":\"Korostus\",\"general\":\"Yleinen\",\"hide_attachments_in_convo\":\"Piilota liitteet keskusteluissa\",\"hide_attachments_in_tl\":\"Piilota liitteet aikajanalla\",\"max_thumbnails\":\"Suurin sallittu määrä liitteitä esikatselussa\",\"hide_isp\":\"Piilota palvelimenkohtainen ruutu\",\"preload_images\":\"Esilataa kuvat\",\"use_one_click_nsfw\":\"Avaa NSFW-liitteet yhdellä painalluksella\",\"hide_post_stats\":\"Piilota viestien statistiikka (esim. tykkäysten määrä)\",\"hide_user_stats\":\"Piilota käyttäjien statistiikka (esim. seuraajien määrä)\",\"import_followers_from_a_csv_file\":\"Tuo seuraukset CSV-tiedostosta\",\"import_theme\":\"Tuo tallennettu teema\",\"inputRadius\":\"Syöttökentät\",\"checkboxRadius\":\"Valintalaatikot\",\"instance_default\":\"(oletus: {value})\",\"instance_default_simple\":\"(oletus)\",\"interface\":\"Käyttöliittymä\",\"interfaceLanguage\":\"Käyttöliittymän kieli\",\"invalid_theme_imported\":\"Tuotu tallennettu teema on epäkelpo, muutoksia ei tehty nykyiseen teemaasi.\",\"limited_availability\":\"Ei saatavilla selaimessasi\",\"links\":\"Linkit\",\"lock_account_description\":\"Vain erikseen hyväksytyt käyttäjät voivat seurata tiliäsi\",\"loop_video\":\"Uudelleentoista videot\",\"loop_video_silent_only\":\"Uudelleentoista ainoastaan äänettömät videot (Video-\\\"giffit\\\")\",\"play_videos_in_modal\":\"Toista videot modaalissa\",\"use_contain_fit\":\"Älä rajaa liitteitä esikatselussa\",\"name\":\"Nimi\",\"name_bio\":\"Nimi ja kuvaus\",\"new_password\":\"Uusi salasana\",\"notification_visibility\":\"Ilmoitusten näkyvyys\",\"notification_visibility_follows\":\"Seuraukset\",\"notification_visibility_likes\":\"Tykkäykset\",\"notification_visibility_mentions\":\"Maininnat\",\"notification_visibility_repeats\":\"Toistot\",\"no_rich_text_description\":\"Älä näytä tekstin muotoilua.\",\"hide_network_description\":\"Älä näytä seurauksiani tai seuraajiani\",\"nsfw_clickthrough\":\"Piilota NSFW liitteet klikkauksen taakse\",\"oauth_tokens\":\"OAuth-merkit\",\"token\":\"Token\",\"refresh_token\":\"Päivitä token\",\"valid_until\":\"Voimassa asti\",\"revoke_token\":\"Peruuttaa\",\"panelRadius\":\"Ruudut\",\"pause_on_unfocused\":\"Pysäytä automaattinen viestien näyttö välilehden ollessa pois fokuksesta\",\"presets\":\"Valmiit teemat\",\"profile_background\":\"Taustakuva\",\"profile_banner\":\"Juliste\",\"profile_tab\":\"Profiili\",\"radii_help\":\"Aseta reunojen pyöristys (pikseleinä)\",\"replies_in_timeline\":\"Keskustelut aikajanalla\",\"reply_link_preview\":\"Keskusteluiden vastauslinkkien esikatselu\",\"reply_visibility_all\":\"Näytä kaikki vastaukset\",\"reply_visibility_following\":\"Näytä vain vastaukset minulle tai seuraamilleni käyttäjille\",\"reply_visibility_self\":\"Näytä vain vastaukset minulle\",\"saving_err\":\"Virhe tallentaessa asetuksia\",\"saving_ok\":\"Asetukset tallennettu\",\"security_tab\":\"Tietoturva\",\"scope_copy\":\"Kopioi näkyvyysrajaus vastatessa (Yksityisviestit aina kopioivat)\",\"set_new_avatar\":\"Aseta uusi profiilikuva\",\"set_new_profile_background\":\"Aseta uusi taustakuva\",\"set_new_profile_banner\":\"Aseta uusi juliste\",\"settings\":\"Asetukset\",\"subject_input_always_show\":\"Näytä aihe-kenttä\",\"subject_line_behavior\":\"Aihe-kentän kopiointi\",\"subject_line_email\":\"Kuten sähköposti: \\\"re: aihe\\\"\",\"subject_line_mastodon\":\"Kopioi sellaisenaan\",\"subject_line_noop\":\"Älä kopioi\",\"stop_gifs\":\"Toista giffit vain kohdistaessa\",\"streaming\":\"Näytä uudet viestit automaattisesti ollessasi ruudun huipulla\",\"text\":\"Teksti\",\"theme\":\"Teema\",\"theme_help\":\"Käytä heksadesimaalivärejä muokataksesi väriteemaasi.\",\"theme_help_v2_1\":\"Voit asettaa tiettyjen osien värin tai läpinäkyvyyden täyttämällä valintalaatikon, käytä \\\"Tyhjennä kaikki\\\"-nappia tyhjentääksesi kaiken.\",\"theme_help_v2_2\":\"Ikonit kenttien alla ovat kontrasti-indikaattoreita, lisätietoa kohdistamalla. Käyttäessä läpinäkyvyyttä ne näyttävät pahimman skenaarion.\",\"tooltipRadius\":\"Ohje- tai huomioviestit\",\"user_settings\":\"Käyttäjän asetukset\",\"values\":{\"false\":\"pois päältä\",\"true\":\"päällä\"}},\"timeline\":{\"collapse\":\"Sulje\",\"conversation\":\"Keskustelu\",\"error_fetching\":\"Virhe ladatessa viestejä\",\"load_older\":\"Lataa vanhempia viestejä\",\"no_retweet_hint\":\"Viesti ei ole julkinen, eikä sitä voi toistaa\",\"repeated\":\"toisti\",\"show_new\":\"Näytä uudet\",\"up_to_date\":\"Ajantasalla\",\"no_more_statuses\":\"Ei enempää viestejä\"},\"status\":{\"reply_to\":\"Vastaus\",\"replies_list\":\"Vastaukset:\"},\"user_card\":{\"approve\":\"Hyväksy\",\"block\":\"Estä\",\"blocked\":\"Estetty!\",\"deny\":\"Älä hyväksy\",\"follow\":\"Seuraa\",\"follow_sent\":\"Pyyntö lähetetty!\",\"follow_progress\":\"Pyydetään...\",\"follow_again\":\"Lähetä pyyntö uudestaan\",\"follow_unfollow\":\"Älä seuraa\",\"followees\":\"Seuraa\",\"followers\":\"Seuraajat\",\"following\":\"Seuraat!\",\"follows_you\":\"Seuraa sinua!\",\"its_you\":\"Sinun tili!\",\"mute\":\"Hiljennä\",\"muted\":\"Hiljennetty\",\"per_day\":\"päivässä\",\"remote_follow\":\"Seuraa muualta\",\"statuses\":\"Viestit\"},\"user_profile\":{\"timeline_title\":\"Käyttäjän aikajana\"},\"who_to_follow\":{\"more\":\"Lisää\",\"who_to_follow\":\"Seurausehdotukset\"},\"tool_tip\":{\"media_upload\":\"Lataa tiedosto\",\"repeat\":\"Toista\",\"reply\":\"Vastaa\",\"favorite\":\"Tykkää\",\"user_settings\":\"Käyttäjäasetukset\"},\"upload\":{\"error\":{\"base\":\"Lataus epäonnistui.\",\"file_too_big\":\"Tiedosto liian suuri [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"Yritä uudestaan myöhemmin\"},\"file_size_units\":{\"B\":\"tavua\",\"KiB\":\"kt\",\"MiB\":\"Mt\",\"GiB\":\"Gt\",\"TiB\":\"Tt\"}}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/fi.json\n// module id = 440\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Chat\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Proxy média\",\"scope_options\":\"Options de visibilité\",\"text_limit\":\"Limite du texte\",\"title\":\"Caractéristiques\",\"who_to_follow\":\"Qui s'abonner\"},\"finder\":{\"error_fetching_user\":\"Erreur lors de la recherche de l'utilisateur\",\"find_user\":\"Chercher un utilisateur\"},\"general\":{\"apply\":\"Appliquer\",\"submit\":\"Envoyer\"},\"login\":{\"login\":\"Connexion\",\"description\":\"Connexion avec OAuth\",\"logout\":\"Déconnexion\",\"password\":\"Mot de passe\",\"placeholder\":\"p.e. lain\",\"register\":\"S'inscrire\",\"username\":\"Identifiant\"},\"nav\":{\"chat\":\"Chat local\",\"friend_requests\":\"Demandes d'ami\",\"dms\":\"Messages adressés\",\"mentions\":\"Notifications\",\"public_tl\":\"Statuts locaux\",\"timeline\":\"Journal\",\"twkn\":\"Le réseau connu\"},\"notifications\":{\"broken_favorite\":\"Chargement d'un message inconnu ...\",\"favorited_you\":\"a aimé votre statut\",\"followed_you\":\"a commencé à vous suivre\",\"load_older\":\"Charger les notifications précédentes\",\"notifications\":\"Notifications\",\"read\":\"Lu !\",\"repeated_you\":\"a partagé votre statut\"},\"post_status\":{\"account_not_locked_warning\":\"Votre compte n'est pas {0}. N'importe qui peut vous suivre pour voir vos billets en Abonné·e·s uniquement.\",\"account_not_locked_warning_link\":\"verrouillé\",\"attachments_sensitive\":\"Marquer le média comme sensible\",\"content_type\":{\"plain_text\":\"Texte brut\"},\"content_warning\":\"Sujet (optionnel)\",\"default\":\"Écrivez ici votre prochain statut.\",\"direct_warning\":\"Ce message sera visible à toutes les personnes mentionnées.\",\"posting\":\"Envoi en cours\",\"scope\":{\"direct\":\"Direct - N'envoyer qu'aux personnes mentionnées\",\"private\":\"Abonné·e·s uniquement - Seul·e·s vos abonné·e·s verront vos billets\",\"public\":\"Publique - Afficher dans les fils publics\",\"unlisted\":\"Non-Listé - Ne pas afficher dans les fils publics\"}},\"registration\":{\"bio\":\"Biographie\",\"email\":\"Adresse email\",\"fullname\":\"Pseudonyme\",\"password_confirm\":\"Confirmation du mot de passe\",\"registration\":\"Inscription\",\"token\":\"Jeton d'invitation\"},\"settings\":{\"attachmentRadius\":\"Pièces jointes\",\"attachments\":\"Pièces jointes\",\"autoload\":\"Charger la suite automatiquement une fois le bas de la page atteint\",\"avatar\":\"Avatar\",\"avatarAltRadius\":\"Avatars (Notifications)\",\"avatarRadius\":\"Avatars\",\"background\":\"Arrière-plan\",\"bio\":\"Biographie\",\"btnRadius\":\"Boutons\",\"cBlue\":\"Bleu (Répondre, suivre)\",\"cGreen\":\"Vert (Partager)\",\"cOrange\":\"Orange (Aimer)\",\"cRed\":\"Rouge (Annuler)\",\"change_password\":\"Changez votre mot de passe\",\"change_password_error\":\"Il y a eu un problème pour changer votre mot de passe.\",\"changed_password\":\"Mot de passe modifié avec succès !\",\"collapse_subject\":\"Réduire les messages avec des sujets\",\"confirm_new_password\":\"Confirmation du nouveau mot de passe\",\"current_avatar\":\"Avatar actuel\",\"current_password\":\"Mot de passe actuel\",\"current_profile_banner\":\"Bannière de profil actuelle\",\"data_import_export_tab\":\"Import / Export des Données\",\"default_vis\":\"Portée de visibilité par défaut\",\"delete_account\":\"Supprimer le compte\",\"delete_account_description\":\"Supprimer définitivement votre compte et tous vos statuts.\",\"delete_account_error\":\"Il y a eu un problème lors de la tentative de suppression de votre compte. Si le problème persiste, contactez l'administrateur de cette instance.\",\"delete_account_instructions\":\"Indiquez votre mot de passe ci-dessous pour confirmer la suppression de votre compte.\",\"export_theme\":\"Enregistrer le thème\",\"filtering\":\"Filtre\",\"filtering_explanation\":\"Tous les statuts contenant ces mots seront masqués. Un mot par ligne\",\"follow_export\":\"Exporter les abonnements\",\"follow_export_button\":\"Exporter les abonnements en csv\",\"follow_export_processing\":\"Exportation en cours…\",\"follow_import\":\"Importer des abonnements\",\"follow_import_error\":\"Erreur lors de l'importation des abonnements\",\"follows_imported\":\"Abonnements importés ! Le traitement peut prendre un moment.\",\"foreground\":\"Premier plan\",\"general\":\"Général\",\"hide_attachments_in_convo\":\"Masquer les pièces jointes dans les conversations\",\"hide_attachments_in_tl\":\"Masquer les pièces jointes dans le journal\",\"hide_post_stats\":\"Masquer les statistiques de publication (le nombre de favoris)\",\"hide_user_stats\":\"Masquer les statistiques de profil (le nombre d'amis)\",\"import_followers_from_a_csv_file\":\"Importer des abonnements depuis un fichier csv\",\"import_theme\":\"Charger le thème\",\"inputRadius\":\"Champs de texte\",\"instance_default\":\"(default: {value})\",\"instance_default_simple\":\"(default)\",\"interfaceLanguage\":\"Langue de l'interface\",\"invalid_theme_imported\":\"Le fichier sélectionné n'est pas un thème Pleroma pris en charge. Aucun changement n'a été apporté à votre thème.\",\"limited_availability\":\"Non disponible dans votre navigateur\",\"links\":\"Liens\",\"lock_account_description\":\"Limitez votre compte aux abonnés acceptés uniquement\",\"loop_video\":\"Vidéos en boucle\",\"loop_video_silent_only\":\"Boucle uniquement les vidéos sans le son (les «gifs» de Mastodon)\",\"name\":\"Nom\",\"name_bio\":\"Nom & Bio\",\"new_password\":\"Nouveau mot de passe\",\"no_rich_text_description\":\"Ne formatez pas le texte\",\"notification_visibility\":\"Types de notifications à afficher\",\"notification_visibility_follows\":\"Abonnements\",\"notification_visibility_likes\":\"J’aime\",\"notification_visibility_mentions\":\"Mentionnés\",\"notification_visibility_repeats\":\"Partages\",\"nsfw_clickthrough\":\"Masquer les images marquées comme contenu adulte ou sensible\",\"oauth_tokens\":\"Jetons OAuth\",\"token\":\"Jeton\",\"refresh_token\":\"Refresh Token\",\"valid_until\":\"Valable jusque\",\"revoke_token\":\"Révoquer\",\"panelRadius\":\"Fenêtres\",\"pause_on_unfocused\":\"Suspendre le streaming lorsque l'onglet n'est pas centré\",\"presets\":\"Thèmes prédéfinis\",\"profile_background\":\"Image de fond\",\"profile_banner\":\"Bannière de profil\",\"profile_tab\":\"Profil\",\"radii_help\":\"Vous pouvez ici choisir le niveau d'arrondi des angles de l'interface (en pixels)\",\"replies_in_timeline\":\"Réponses au journal\",\"reply_link_preview\":\"Afficher un aperçu lors du survol de liens vers une réponse\",\"reply_visibility_all\":\"Montrer toutes les réponses\",\"reply_visibility_following\":\"Afficher uniquement les réponses adressées à moi ou aux utilisateurs que je suis\",\"reply_visibility_self\":\"Afficher uniquement les réponses adressées à moi\",\"saving_err\":\"Erreur lors de l'enregistrement des paramètres\",\"saving_ok\":\"Paramètres enregistrés\",\"security_tab\":\"Sécurité\",\"set_new_avatar\":\"Changer d'avatar\",\"set_new_profile_background\":\"Changer d'image de fond\",\"set_new_profile_banner\":\"Changer de bannière\",\"settings\":\"Paramètres\",\"stop_gifs\":\"N'animer les GIFS que lors du survol du curseur de la souris\",\"streaming\":\"Charger automatiquement les nouveaux statuts lorsque vous êtes au haut de la page\",\"text\":\"Texte\",\"theme\":\"Thème\",\"theme_help\":\"Spécifiez des codes couleur hexadécimaux (#rrvvbb) pour personnaliser les couleurs du thème.\",\"tooltipRadius\":\"Info-bulles/alertes\",\"user_settings\":\"Paramètres utilisateur\",\"values\":{\"false\":\"non\",\"true\":\"oui\"}},\"timeline\":{\"collapse\":\"Fermer\",\"conversation\":\"Conversation\",\"error_fetching\":\"Erreur en cherchant les mises à jour\",\"load_older\":\"Afficher plus\",\"no_retweet_hint\":\"Le message est marqué en abonnés-seulement ou direct et ne peut pas être répété\",\"repeated\":\"a partagé\",\"show_new\":\"Afficher plus\",\"up_to_date\":\"À jour\"},\"user_card\":{\"approve\":\"Accepter\",\"block\":\"Bloquer\",\"blocked\":\"Bloqué !\",\"deny\":\"Rejeter\",\"follow\":\"Suivre\",\"followees\":\"Suivis\",\"followers\":\"Vous suivent\",\"following\":\"Suivi !\",\"follows_you\":\"Vous suit !\",\"mute\":\"Masquer\",\"muted\":\"Masqué\",\"per_day\":\"par jour\",\"remote_follow\":\"Suivre d'une autre instance\",\"statuses\":\"Statuts\"},\"user_profile\":{\"timeline_title\":\"Journal de l'utilisateur\"},\"who_to_follow\":{\"more\":\"Plus\",\"who_to_follow\":\"Qui s'abonner\"}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/fr.json\n// module id = 441\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Comhrá\"},\"features_panel\":{\"chat\":\"Comhrá\",\"gopher\":\"Gófar\",\"media_proxy\":\"Seachfhreastalaí meáin\",\"scope_options\":\"Rogha scóip\",\"text_limit\":\"Teorainn Téacs\",\"title\":\"Gnéithe\",\"who_to_follow\":\"Daoine le leanúint\"},\"finder\":{\"error_fetching_user\":\"Earráid a aimsiú d'úsáideoir\",\"find_user\":\"Aimsigh úsáideoir\"},\"general\":{\"apply\":\"Feidhmigh\",\"submit\":\"Deimhnigh\"},\"login\":{\"login\":\"Logáil isteach\",\"logout\":\"Logáil amach\",\"password\":\"Pasfhocal\",\"placeholder\":\"m.sh. Daire\",\"register\":\"Clárú\",\"username\":\"Ainm Úsáideora\"},\"nav\":{\"chat\":\"Comhrá Áitiúil\",\"friend_requests\":\"Iarratas ar Cairdeas\",\"mentions\":\"Tagairt\",\"public_tl\":\"Amlíne Poiblí\",\"timeline\":\"Amlíne\",\"twkn\":\"An Líonra Iomlán\"},\"notifications\":{\"broken_favorite\":\"Post anaithnid. Cuardach dó...\",\"favorited_you\":\"toghadh le do phost\",\"followed_you\":\"lean tú\",\"load_older\":\"Luchtaigh fógraí aosta\",\"notifications\":\"Fógraí\",\"read\":\"Léigh!\",\"repeated_you\":\"athphostáil tú\"},\"post_status\":{\"account_not_locked_warning\":\"Níl do chuntas {0}. Is féidir le duine ar bith a leanúint leat chun do phoist leantacha amháin a fheiceáil.\",\"account_not_locked_warning_link\":\"faoi glas\",\"attachments_sensitive\":\"Marcáil ceangaltán mar íogair\",\"content_type\":{\"plain_text\":\"Gnáth-théacs\"},\"content_warning\":\"Teideal (roghnach)\",\"default\":\"Lá iontach anseo i nGaillimh\",\"direct_warning\":\"Ní bheidh an post seo le feiceáil ach amháin do na húsáideoirí atá luaite.\",\"posting\":\"Post nua\",\"scope\":{\"direct\":\"Díreach - Post chuig úsáideoirí luaite amháin\",\"private\":\"Leanúna amháin - Post chuig lucht leanúna amháin\",\"public\":\"Poiblí - Post chuig amlínte poiblí\",\"unlisted\":\"Neamhliostaithe - Ná cuir post chuig amlínte poiblí\"}},\"registration\":{\"bio\":\"Scéal saoil\",\"email\":\"Ríomhphost\",\"fullname\":\"Ainm taispeána'\",\"password_confirm\":\"Deimhnigh do pasfhocal\",\"registration\":\"Clárú\",\"token\":\"Cód cuireadh\"},\"settings\":{\"attachmentRadius\":\"Ceangaltáin\",\"attachments\":\"Ceangaltáin\",\"autoload\":\"Cumasaigh luchtú uathoibríoch nuair a scrollaítear go bun\",\"avatar\":\"Phictúir phrófíle\",\"avatarAltRadius\":\"Phictúirí phrófíle (Fograí)\",\"avatarRadius\":\"Phictúirí phrófíle\",\"background\":\"Cúlra\",\"bio\":\"Scéal saoil\",\"btnRadius\":\"Cnaipí\",\"cBlue\":\"Gorm (Freagra, lean)\",\"cGreen\":\"Glas (Athphóstail)\",\"cOrange\":\"Oráiste (Cosúil)\",\"cRed\":\"Dearg (Cealaigh)\",\"change_password\":\"Athraigh do pasfhocal\",\"change_password_error\":\"Bhí fadhb ann ag athrú do pasfhocail\",\"changed_password\":\"Athraigh an pasfhocal go rathúil!\",\"collapse_subject\":\"Poist a chosc le teidil\",\"confirm_new_password\":\"Deimhnigh do pasfhocal nua\",\"current_avatar\":\"Phictúir phrófíle\",\"current_password\":\"Pasfhocal reatha\",\"current_profile_banner\":\"Phictúir ceanntáisc\",\"data_import_export_tab\":\"Iompórtáil / Easpórtáil Sonraí\",\"default_vis\":\"Scóip infheicthe réamhshocraithe\",\"delete_account\":\"Scrios cuntas\",\"delete_account_description\":\"Do chuntas agus do chuid teachtaireachtaí go léir a scriosadh go buan.\",\"delete_account_error\":\"Bhí fadhb ann a scriosadh do chuntas. Má leanann sé seo, téigh i dteagmháil le do riarthóir.\",\"delete_account_instructions\":\"Scríobh do phasfhocal san ionchur thíos chun deimhniú a scriosadh.\",\"export_theme\":\"Sábháil Téama\",\"filtering\":\"Scagadh\",\"filtering_explanation\":\"Beidh gach post ina bhfuil na focail seo i bhfolach, ceann in aghaidh an líne\",\"follow_export\":\"Easpórtáil do leanann\",\"follow_export_button\":\"Easpórtáil do leanann chuig comhad csv\",\"follow_export_processing\":\"Próiseáil. Iarrtar ort go luath an comhad a íoslódáil.\",\"follow_import\":\"Iompórtáil do leanann\",\"follow_import_error\":\"Earráid agus do leanann a iompórtáil\",\"follows_imported\":\"Do leanann iompórtáil! Tógfaidh an próiseas iad le tamall.\",\"foreground\":\"Tulra\",\"general\":\"Ginearálta\",\"hide_attachments_in_convo\":\"Folaigh ceangaltáin i comhráite\",\"hide_attachments_in_tl\":\"Folaigh ceangaltáin sa amlíne\",\"hide_post_stats\":\"Folaigh staitisticí na bpost (m.sh. líon na n-athrá)\",\"hide_user_stats\":\"Folaigh na staitisticí úsáideora (m.sh. líon na leantóiri)\",\"import_followers_from_a_csv_file\":\"Iompórtáil leanann ó chomhad csv\",\"import_theme\":\"Luchtaigh Téama\",\"inputRadius\":\"Limistéar iontrála\",\"instance_default\":\"(Réamhshocrú: {value})\",\"interfaceLanguage\":\"Teanga comhéadain\",\"invalid_theme_imported\":\"Ní téama bailí é an comhad dícheangailte. Níor rinneadh aon athruithe.\",\"limited_availability\":\"Níl sé ar fáil i do bhrabhsálaí\",\"links\":\"Naisc\",\"lock_account_description\":\"Srian a chur ar do chuntas le lucht leanúna ceadaithe amháin\",\"loop_video\":\"Lúb físeáin\",\"loop_video_silent_only\":\"Lúb físeáin amháin gan fuaim (i.e. Mastodon's \\\"gifs\\\")\",\"name\":\"Ainm\",\"name_bio\":\"Ainm ⁊ Scéal\",\"new_password\":\"Pasfhocal nua'\",\"notification_visibility\":\"Cineálacha fógraí a thaispeáint\",\"notification_visibility_follows\":\"Leana\",\"notification_visibility_likes\":\"Thaithin\",\"notification_visibility_mentions\":\"Tagairt\",\"notification_visibility_repeats\":\"Atphostáil\",\"no_rich_text_description\":\"Bain formáidiú téacs saibhir ó gach post\",\"nsfw_clickthrough\":\"Cumasaigh an ceangaltán NSFW cliceáil ar an gcnaipe\",\"oauth_tokens\":\"Tocanna OAuth\",\"token\":\"Token\",\"refresh_token\":\"Athnuachan Comórtas\",\"valid_until\":\"Bailí Go dtí\",\"revoke_token\":\"Athghairm\",\"panelRadius\":\"Painéil\",\"pause_on_unfocused\":\"Sruthú ar sos nuair a bhíonn an fócas caillte\",\"presets\":\"Réamhshocruithe\",\"profile_background\":\"Cúlra Próifíl\",\"profile_banner\":\"Phictúir Ceanntáisc\",\"profile_tab\":\"Próifíl\",\"radii_help\":\"Cruinniú imeall comhéadan a chumrú (i bpicteilíní)\",\"replies_in_timeline\":\"Freagraí sa amlíne\",\"reply_link_preview\":\"Cumasaigh réamhamharc nasc freagartha ar chlár na luiche\",\"reply_visibility_all\":\"Taispeáin gach freagra\",\"reply_visibility_following\":\"Taispeáin freagraí amháin atá dírithe ar mise nó ar úsáideoirí atá mé ag leanúint\",\"reply_visibility_self\":\"Taispeáin freagraí amháin atá dírithe ar mise\",\"saving_err\":\"Earráid socruithe a shábháil\",\"saving_ok\":\"Socruithe sábháilte\",\"security_tab\":\"Slándáil\",\"set_new_avatar\":\"Athraigh do phictúir phrófíle\",\"set_new_profile_background\":\"Athraigh do cúlra próifíl\",\"set_new_profile_banner\":\"Athraigh do phictúir ceanntáisc\",\"settings\":\"Socruithe\",\"stop_gifs\":\"Seinn GIFs ar an scáileán\",\"streaming\":\"Cumasaigh post nua a shruthú uathoibríoch nuair a scrollaítear go barr an leathanaigh\",\"text\":\"Téacs\",\"theme\":\"Téama\",\"theme_help\":\"Úsáid cód daith hex (#rrggbb) chun do schéim a saincheapadh\",\"tooltipRadius\":\"Bileoga eolais\",\"user_settings\":\"Socruithe úsáideora\",\"values\":{\"false\":\"níl\",\"true\":\"tá\"}},\"timeline\":{\"collapse\":\"Folaigh\",\"conversation\":\"Cómhra\",\"error_fetching\":\"Earráid a thabhairt cothrom le dáta\",\"load_older\":\"Luchtaigh níos mó\",\"no_retweet_hint\":\"Tá an post seo marcáilte mar lucht leanúna amháin nó díreach agus ní féidir é a athphostáil\",\"repeated\":\"athphostáil\",\"show_new\":\"Taispeáin nua\",\"up_to_date\":\"Nuashonraithe\"},\"user_card\":{\"approve\":\"Údaraigh\",\"block\":\"Cosc\",\"blocked\":\"Cuireadh coisc!\",\"deny\":\"Diúltaigh\",\"follow\":\"Lean\",\"followees\":\"Leantóirí\",\"followers\":\"Á Leanúint\",\"following\":\"Á Leanúint\",\"follows_you\":\"Leanann tú\",\"mute\":\"Cuir i mód ciúin\",\"muted\":\"Mód ciúin\",\"per_day\":\"laethúil\",\"remote_follow\":\"Leaníunt iargúlta\",\"statuses\":\"Poist\"},\"user_profile\":{\"timeline_title\":\"Amlíne úsáideora\"},\"who_to_follow\":{\"more\":\"Feach uile\",\"who_to_follow\":\"Daoine le leanúint\"}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/ga.json\n// module id = 442\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"צ'אט\"},\"features_panel\":{\"chat\":\"צ'אט\",\"gopher\":\"גופר\",\"media_proxy\":\"מדיה פרוקסי\",\"scope_options\":\"אפשרויות טווח\",\"text_limit\":\"מגבלת טקסט\",\"title\":\"מאפיינים\",\"who_to_follow\":\"אחרי מי לעקוב\"},\"finder\":{\"error_fetching_user\":\"שגיאה במציאת משתמש\",\"find_user\":\"מציאת משתמש\"},\"general\":{\"apply\":\"החל\",\"submit\":\"שלח\"},\"login\":{\"login\":\"התחבר\",\"logout\":\"התנתק\",\"password\":\"סיסמה\",\"placeholder\":\"למשל lain\",\"register\":\"הירשם\",\"username\":\"שם המשתמש\"},\"nav\":{\"chat\":\"צ'אט מקומי\",\"friend_requests\":\"בקשות עקיבה\",\"mentions\":\"אזכורים\",\"public_tl\":\"ציר הזמן הציבורי\",\"timeline\":\"ציר הזמן\",\"twkn\":\"כל הרשת הידועה\"},\"notifications\":{\"broken_favorite\":\"סטאטוס לא ידוע, מחפש...\",\"favorited_you\":\"אהב את הסטטוס שלך\",\"followed_you\":\"עקב אחריך!\",\"load_older\":\"טען התראות ישנות\",\"notifications\":\"התראות\",\"read\":\"קרא!\",\"repeated_you\":\"חזר על הסטטוס שלך\"},\"post_status\":{\"account_not_locked_warning\":\"המשתמש שלך אינו {0}. כל אחד יכול לעקוב אחריך ולראות את ההודעות לעוקבים-בלבד שלך.\",\"account_not_locked_warning_link\":\"נעול\",\"attachments_sensitive\":\"סמן מסמכים מצורפים כלא בטוחים לצפייה\",\"content_type\":{\"plain_text\":\"טקסט פשוט\"},\"content_warning\":\"נושא (נתון לבחירה)\",\"default\":\"הרגע נחת ב-ל.א.\",\"direct_warning\":\"הודעה זו תהיה זמינה רק לאנשים המוזכרים.\",\"posting\":\"מפרסם\",\"scope\":{\"direct\":\"ישיר - שלח לאנשים המוזכרים בלבד\",\"private\":\"עוקבים-בלבד - שלח לעוקבים בלבד\",\"public\":\"ציבורי - שלח לציר הזמן הציבורי\",\"unlisted\":\"מחוץ לרשימה - אל תשלח לציר הזמן הציבורי\"}},\"registration\":{\"bio\":\"אודות\",\"email\":\"אימייל\",\"fullname\":\"שם תצוגה\",\"password_confirm\":\"אישור סיסמה\",\"registration\":\"הרשמה\",\"token\":\"טוקן הזמנה\"},\"settings\":{\"attachmentRadius\":\"צירופים\",\"attachments\":\"צירופים\",\"autoload\":\"החל טעינה אוטומטית בגלילה לתחתית הדף\",\"avatar\":\"תמונת פרופיל\",\"avatarAltRadius\":\"תמונות פרופיל (התראות)\",\"avatarRadius\":\"תמונות פרופיל\",\"background\":\"רקע\",\"bio\":\"אודות\",\"btnRadius\":\"כפתורים\",\"cBlue\":\"כחול (תגובה, עקיבה)\",\"cGreen\":\"ירוק (חזרה)\",\"cOrange\":\"כתום (לייק)\",\"cRed\":\"אדום (ביטול)\",\"change_password\":\"שנה סיסמה\",\"change_password_error\":\"הייתה בעיה בשינוי סיסמתך.\",\"changed_password\":\"סיסמה שונתה בהצלחה!\",\"collapse_subject\":\"מזער הודעות עם נושאים\",\"confirm_new_password\":\"אשר סיסמה\",\"current_avatar\":\"תמונת הפרופיל הנוכחית שלך\",\"current_password\":\"סיסמה נוכחית\",\"current_profile_banner\":\"כרזת הפרופיל הנוכחית שלך\",\"data_import_export_tab\":\"ייבוא או ייצוא מידע\",\"default_vis\":\"ברירת מחדל לטווח הנראות\",\"delete_account\":\"מחק משתמש\",\"delete_account_description\":\"מחק לצמיתות את המשתמש שלך ואת כל הודעותיך.\",\"delete_account_error\":\"הייתה בעיה במחיקת המשתמש. אם זה ממשיך, אנא עדכן את מנהל השרת שלך.\",\"delete_account_instructions\":\"הכנס את סיסמתך בקלט למטה על מנת לאשר מחיקת משתמש.\",\"export_theme\":\"שמור ערכים\",\"filtering\":\"סינון\",\"filtering_explanation\":\"כל הסטטוסים הכוללים את המילים הללו יושתקו, אחד לשורה\",\"follow_export\":\"יצוא עקיבות\",\"follow_export_button\":\"ייצא את הנעקבים שלך לקובץ csv\",\"follow_export_processing\":\"טוען. בקרוב תתבקש להוריד את הקובץ את הקובץ שלך\",\"follow_import\":\"יבוא עקיבות\",\"follow_import_error\":\"שגיאה בייבוא נעקבים.\",\"follows_imported\":\"נעקבים יובאו! ייקח זמן מה לעבד אותם.\",\"foreground\":\"חזית\",\"hide_attachments_in_convo\":\"החבא צירופים בשיחות\",\"hide_attachments_in_tl\":\"החבא צירופים בציר הזמן\",\"import_followers_from_a_csv_file\":\"ייבא את הנעקבים שלך מקובץ csv\",\"import_theme\":\"טען ערכים\",\"inputRadius\":\"שדות קלט\",\"interfaceLanguage\":\"שפת הממשק\",\"invalid_theme_imported\":\"הקובץ הנבחר אינו תמה הנתמכת ע\\\"י פלרומה. שום שינויים לא נעשו לתמה שלך.\",\"limited_availability\":\"לא זמין בדפדפן שלך\",\"links\":\"לינקים\",\"lock_account_description\":\"הגבל את המשתמש לעוקבים מאושרים בלבד\",\"loop_video\":\"נגן סרטונים ללא הפסקה\",\"loop_video_silent_only\":\"נגן רק סרטונים חסרי קול ללא הפסקה\",\"name\":\"שם\",\"name_bio\":\"שם ואודות\",\"new_password\":\"סיסמה חדשה\",\"notification_visibility\":\"סוג ההתראות שתרצו לראות\",\"notification_visibility_follows\":\"עקיבות\",\"notification_visibility_likes\":\"לייקים\",\"notification_visibility_mentions\":\"אזכורים\",\"notification_visibility_repeats\":\"חזרות\",\"nsfw_clickthrough\":\"החל החבאת צירופים לא בטוחים לצפיה בעת עבודה בעזרת לחיצת עכבר\",\"oauth_tokens\":\"אסימוני OAuth\",\"token\":\"אסימון\",\"refresh_token\":\"רענון האסימון\",\"valid_until\":\"בתוקף עד\",\"revoke_token\":\"בטל\",\"panelRadius\":\"פאנלים\",\"pause_on_unfocused\":\"השהה זרימת הודעות כשהחלון לא בפוקוס\",\"presets\":\"ערכים קבועים מראש\",\"profile_background\":\"רקע הפרופיל\",\"profile_banner\":\"כרזת הפרופיל\",\"profile_tab\":\"פרופיל\",\"radii_help\":\"קבע מראש עיגול פינות לממשק (בפיקסלים)\",\"replies_in_timeline\":\"תגובות בציר הזמן\",\"reply_link_preview\":\"החל תצוגה מקדימה של לינק-תגובה בעת ריחוף עם העכבר\",\"reply_visibility_all\":\"הראה את כל התגובות\",\"reply_visibility_following\":\"הראה תגובות שמופנות אליי או לעקובים שלי בלבד\",\"reply_visibility_self\":\"הראה תגובות שמופנות אליי בלבד\",\"security_tab\":\"ביטחון\",\"set_new_avatar\":\"קבע תמונת פרופיל חדשה\",\"set_new_profile_background\":\"קבע רקע פרופיל חדש\",\"set_new_profile_banner\":\"קבע כרזת פרופיל חדשה\",\"settings\":\"הגדרות\",\"stop_gifs\":\"נגן-בעת-ריחוף GIFs\",\"streaming\":\"החל זרימת הודעות אוטומטית בעת גלילה למעלה הדף\",\"text\":\"טקסט\",\"theme\":\"תמה\",\"theme_help\":\"השתמש בקודי צבע הקס (#אדום-אדום-ירוק-ירוק-כחול-כחול) על מנת להתאים אישית את תמת הצבע שלך.\",\"tooltipRadius\":\"טולטיפ \\\\ התראות\",\"user_settings\":\"הגדרות משתמש\"},\"timeline\":{\"collapse\":\"מוטט\",\"conversation\":\"שיחה\",\"error_fetching\":\"שגיאה בהבאת הודעות\",\"load_older\":\"טען סטטוסים חדשים\",\"no_retweet_hint\":\"ההודעה מסומנת כ\\\"לעוקבים-בלבד\\\" ולא ניתן לחזור עליה\",\"repeated\":\"חזר\",\"show_new\":\"הראה חדש\",\"up_to_date\":\"עדכני\"},\"user_card\":{\"approve\":\"אשר\",\"block\":\"חסימה\",\"blocked\":\"חסום!\",\"deny\":\"דחה\",\"follow\":\"עקוב\",\"followees\":\"נעקבים\",\"followers\":\"עוקבים\",\"following\":\"עוקב!\",\"follows_you\":\"עוקב אחריך!\",\"mute\":\"השתק\",\"muted\":\"מושתק\",\"per_day\":\"ליום\",\"remote_follow\":\"עקיבה מרחוק\",\"statuses\":\"סטטוסים\"},\"user_profile\":{\"timeline_title\":\"ציר זמן המשתמש\"},\"who_to_follow\":{\"more\":\"עוד\",\"who_to_follow\":\"אחרי מי לעקוב\"}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/he.json\n// module id = 443\n// module chunks = 2","module.exports = {\"finder\":{\"error_fetching_user\":\"Hiba felhasználó beszerzésével\",\"find_user\":\"Felhasználó keresése\"},\"general\":{\"submit\":\"Elküld\"},\"login\":{\"login\":\"Bejelentkezés\",\"logout\":\"Kijelentkezés\",\"password\":\"Jelszó\",\"placeholder\":\"e.g. lain\",\"register\":\"Feliratkozás\",\"username\":\"Felhasználó név\"},\"nav\":{\"mentions\":\"Említéseim\",\"public_tl\":\"Publikus Idővonal\",\"timeline\":\"Idővonal\",\"twkn\":\"Az Egész Ismert Hálózat\"},\"notifications\":{\"followed_you\":\"követ téged\",\"notifications\":\"Értesítések\",\"read\":\"Olvasva!\"},\"post_status\":{\"default\":\"Most érkeztem L.A.-be\",\"posting\":\"Küldés folyamatban\"},\"registration\":{\"bio\":\"Bio\",\"email\":\"Email\",\"fullname\":\"Teljes név\",\"password_confirm\":\"Jelszó megerősítése\",\"registration\":\"Feliratkozás\"},\"settings\":{\"attachments\":\"Csatolmányok\",\"autoload\":\"Autoatikus betöltés engedélyezése lap aljára görgetéskor\",\"avatar\":\"Avatár\",\"bio\":\"Bio\",\"current_avatar\":\"Jelenlegi avatár\",\"current_profile_banner\":\"Jelenlegi profil banner\",\"filtering\":\"Szűrés\",\"filtering_explanation\":\"Minden tartalom mely ezen szavakat tartalmazza némítva lesz, soronként egy\",\"hide_attachments_in_convo\":\"Csatolmányok elrejtése a társalgásokban\",\"hide_attachments_in_tl\":\"Csatolmányok elrejtése az idővonalon\",\"name\":\"Név\",\"name_bio\":\"Név és Bio\",\"nsfw_clickthrough\":\"NSFW átkattintási tartalom elrejtésének engedélyezése\",\"profile_background\":\"Profil háttérkép\",\"profile_banner\":\"Profil Banner\",\"reply_link_preview\":\"Válasz-link előzetes mutatása egér rátételkor\",\"set_new_avatar\":\"Új avatár\",\"set_new_profile_background\":\"Új profil háttér beállítása\",\"set_new_profile_banner\":\"Új profil banner\",\"settings\":\"Beállítások\",\"theme\":\"Téma\",\"user_settings\":\"Felhasználói beállítások\"},\"timeline\":{\"conversation\":\"Társalgás\",\"error_fetching\":\"Hiba a frissítések beszerzésénél\",\"load_older\":\"Régebbi állapotok betöltése\",\"show_new\":\"Újak mutatása\",\"up_to_date\":\"Naprakész\"},\"user_card\":{\"block\":\"Letilt\",\"blocked\":\"Letiltva!\",\"follow\":\"Követ\",\"followees\":\"Követettek\",\"followers\":\"Követők\",\"following\":\"Követve!\",\"follows_you\":\"Követ téged!\",\"mute\":\"Némít\",\"muted\":\"Némított\",\"per_day\":\"naponta\",\"statuses\":\"Állapotok\"}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/hu.json\n// module id = 444\n// module chunks = 2","module.exports = {\"general\":{\"submit\":\"Invia\",\"apply\":\"Applica\"},\"nav\":{\"mentions\":\"Menzioni\",\"public_tl\":\"Sequenza temporale pubblica\",\"timeline\":\"Sequenza temporale\",\"twkn\":\"L'intera rete conosciuta\",\"chat\":\"Chat Locale\",\"friend_requests\":\"Richieste di Seguirti\"},\"notifications\":{\"followed_you\":\"ti segue\",\"notifications\":\"Notifiche\",\"read\":\"Leggi!\",\"broken_favorite\":\"Stato sconosciuto, lo sto cercando...\",\"favorited_you\":\"ha messo mi piace al tuo stato\",\"load_older\":\"Carica notifiche più vecchie\",\"repeated_you\":\"ha condiviso il tuo stato\"},\"settings\":{\"attachments\":\"Allegati\",\"autoload\":\"Abilita caricamento automatico quando si raggiunge fondo pagina\",\"avatar\":\"Avatar\",\"bio\":\"Introduzione\",\"current_avatar\":\"Il tuo avatar attuale\",\"current_profile_banner\":\"Il tuo banner attuale\",\"filtering\":\"Filtri\",\"filtering_explanation\":\"Tutti i post contenenti queste parole saranno silenziati, uno per linea\",\"hide_attachments_in_convo\":\"Nascondi gli allegati presenti nelle conversazioni\",\"hide_attachments_in_tl\":\"Nascondi gli allegati presenti nella sequenza temporale\",\"name\":\"Nome\",\"name_bio\":\"Nome & Introduzione\",\"nsfw_clickthrough\":\"Abilita il click per visualizzare gli allegati segnati come NSFW\",\"profile_background\":\"Sfondo della tua pagina\",\"profile_banner\":\"Banner del tuo profilo\",\"reply_link_preview\":\"Abilita il link per la risposta al passaggio del mouse\",\"set_new_avatar\":\"Scegli un nuovo avatar\",\"set_new_profile_background\":\"Scegli un nuovo sfondo per la tua pagina\",\"set_new_profile_banner\":\"Scegli un nuovo banner per il tuo profilo\",\"settings\":\"Impostazioni\",\"theme\":\"Tema\",\"user_settings\":\"Impostazioni Utente\",\"attachmentRadius\":\"Allegati\",\"avatarAltRadius\":\"Avatar (Notifiche)\",\"avatarRadius\":\"Avatar\",\"background\":\"Sfondo\",\"btnRadius\":\"Pulsanti\",\"cBlue\":\"Blu (Rispondere, seguire)\",\"cGreen\":\"Verde (Condividi)\",\"cOrange\":\"Arancio (Mi piace)\",\"cRed\":\"Rosso (Annulla)\",\"change_password\":\"Cambia Password\",\"change_password_error\":\"C'è stato un problema durante il cambiamento della password.\",\"changed_password\":\"Password cambiata correttamente!\",\"collapse_subject\":\"Riduci post che hanno un oggetto\",\"confirm_new_password\":\"Conferma la nuova password\",\"current_password\":\"Password attuale\",\"data_import_export_tab\":\"Importa / Esporta Dati\",\"default_vis\":\"Visibilità predefinita dei post\",\"delete_account\":\"Elimina Account\",\"delete_account_description\":\"Elimina definitivamente il tuo account e tutti i tuoi messaggi.\",\"delete_account_error\":\"C'è stato un problema durante l'eliminazione del tuo account. Se il problema persiste contatta l'amministratore della tua istanza.\",\"delete_account_instructions\":\"Digita la tua password nel campo sottostante per confermare l'eliminazione dell'account.\",\"export_theme\":\"Salva settaggi\",\"follow_export\":\"Esporta la lista di chi segui\",\"follow_export_button\":\"Esporta la lista di chi segui in un file csv\",\"follow_export_processing\":\"Sto elaborando, presto ti sarà chiesto di scaricare il tuo file\",\"follow_import\":\"Importa la lista di chi segui\",\"follow_import_error\":\"Errore nell'importazione della lista di chi segui\",\"follows_imported\":\"Importazione riuscita! L'elaborazione richiederà un po' di tempo.\",\"foreground\":\"In primo piano\",\"general\":\"Generale\",\"hide_post_stats\":\"Nascondi statistiche dei post (es. il numero di mi piace)\",\"hide_user_stats\":\"Nascondi statistiche dell'utente (es. il numero di chi ti segue)\",\"import_followers_from_a_csv_file\":\"Importa una lista di chi segui da un file csv\",\"import_theme\":\"Carica settaggi\",\"inputRadius\":\"Campi di testo\",\"instance_default\":\"(predefinito: {value})\",\"interfaceLanguage\":\"Linguaggio dell'interfaccia\",\"invalid_theme_imported\":\"Il file selezionato non è un file di tema per Pleroma supportato. Il tuo tema non è stato modificato.\",\"limited_availability\":\"Non disponibile nel tuo browser\",\"links\":\"Collegamenti\",\"lock_account_description\":\"Limita il tuo account solo per contatti approvati\",\"loop_video\":\"Riproduci video in ciclo continuo\",\"loop_video_silent_only\":\"Riproduci solo video senza audio in ciclo continuo (es. le gif di Mastodon)\",\"new_password\":\"Nuova password\",\"notification_visibility\":\"Tipi di notifiche da mostrare\",\"notification_visibility_follows\":\"Nuove persone ti seguono\",\"notification_visibility_likes\":\"Mi piace\",\"notification_visibility_mentions\":\"Menzioni\",\"notification_visibility_repeats\":\"Condivisioni\",\"no_rich_text_description\":\"Togli la formattazione del testo da tutti i post\",\"oauth_tokens\":\"Token OAuth\",\"token\":\"Token\",\"refresh_token\":\"Aggiorna token\",\"valid_until\":\"Valido fino a\",\"revoke_token\":\"Revocare\",\"panelRadius\":\"Pannelli\",\"pause_on_unfocused\":\"Metti in pausa l'aggiornamento continuo quando la scheda non è in primo piano\",\"presets\":\"Valori predefiniti\",\"profile_tab\":\"Profilo\",\"radii_help\":\"Imposta l'arrotondamento dei bordi (in pixel)\",\"replies_in_timeline\":\"Risposte nella sequenza temporale\",\"reply_visibility_all\":\"Mostra tutte le risposte\",\"reply_visibility_following\":\"Mostra solo le risposte dirette a me o agli utenti che seguo\",\"reply_visibility_self\":\"Mostra solo risposte dirette a me\",\"saving_err\":\"Errore nel salvataggio delle impostazioni\",\"saving_ok\":\"Impostazioni salvate\",\"security_tab\":\"Sicurezza\",\"stop_gifs\":\"Riproduci GIF al passaggio del cursore del mouse\",\"streaming\":\"Abilita aggiornamento automatico dei nuovi post quando si è in alto alla pagina\",\"text\":\"Testo\",\"theme_help\":\"Usa codici colore esadecimali (#rrggbb) per personalizzare il tuo schema di colori.\",\"tooltipRadius\":\"Descrizioni/avvisi\",\"values\":{\"false\":\"no\",\"true\":\"si\"}},\"timeline\":{\"error_fetching\":\"Errore nel prelievo aggiornamenti\",\"load_older\":\"Carica messaggi più vecchi\",\"show_new\":\"Mostra nuovi\",\"up_to_date\":\"Aggiornato\",\"collapse\":\"Riduci\",\"conversation\":\"Conversazione\",\"no_retweet_hint\":\"La visibilità del post è impostata solo per chi ti segue o messaggio diretto e non può essere condiviso\",\"repeated\":\"condiviso\"},\"user_card\":{\"follow\":\"Segui\",\"followees\":\"Chi stai seguendo\",\"followers\":\"Chi ti segue\",\"following\":\"Lo stai seguendo!\",\"follows_you\":\"Ti segue!\",\"mute\":\"Silenzia\",\"muted\":\"Silenziato\",\"per_day\":\"al giorno\",\"statuses\":\"Messaggi\",\"approve\":\"Approva\",\"block\":\"Blocca\",\"blocked\":\"Bloccato!\",\"deny\":\"Nega\",\"remote_follow\":\"Segui da remoto\"},\"chat\":{\"title\":\"Chat\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Media proxy\",\"scope_options\":\"Opzioni di visibilità\",\"text_limit\":\"Lunghezza limite\",\"title\":\"Caratteristiche\",\"who_to_follow\":\"Chi seguire\"},\"finder\":{\"error_fetching_user\":\"Errore nel recupero dell'utente\",\"find_user\":\"Trova utente\"},\"login\":{\"login\":\"Accedi\",\"logout\":\"Disconnettiti\",\"password\":\"Password\",\"placeholder\":\"es. lain\",\"register\":\"Registrati\",\"username\":\"Nome utente\"},\"post_status\":{\"account_not_locked_warning\":\"Il tuo account non è {0}. Chiunque può seguirti e vedere i tuoi post riservati a chi ti segue.\",\"account_not_locked_warning_link\":\"bloccato\",\"attachments_sensitive\":\"Segna allegati come sensibili\",\"content_type\":{\"plain_text\":\"Testo normale\"},\"content_warning\":\"Oggetto (facoltativo)\",\"default\":\"Appena atterrato in L.A.\",\"direct_warning\":\"Questo post sarà visibile solo dagli utenti menzionati.\",\"posting\":\"Pubblica\",\"scope\":{\"direct\":\"Diretto - Pubblicato solo per gli utenti menzionati\",\"private\":\"Solo per chi ti segue - Visibile solo da chi ti segue\",\"public\":\"Pubblico - Visibile sulla sequenza temporale pubblica\",\"unlisted\":\"Non elencato - Non visibile sulla sequenza temporale pubblica\"}},\"registration\":{\"bio\":\"Introduzione\",\"email\":\"Email\",\"fullname\":\"Nome visualizzato\",\"password_confirm\":\"Conferma password\",\"registration\":\"Registrazione\",\"token\":\"Codice d'invito\"},\"user_profile\":{\"timeline_title\":\"Sequenza Temporale dell'Utente\"},\"who_to_follow\":{\"more\":\"Più\",\"who_to_follow\":\"Chi seguire\"}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/it.json\n// module id = 445\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"チャット\"},\"features_panel\":{\"chat\":\"チャット\",\"gopher\":\"Gopher\",\"media_proxy\":\"メディアプロクシ\",\"scope_options\":\"こうかいはんいせんたく\",\"text_limit\":\"もじのかず\",\"title\":\"ゆうこうなきのう\",\"who_to_follow\":\"おすすめユーザー\"},\"finder\":{\"error_fetching_user\":\"ユーザーけんさくがエラーになりました。\",\"find_user\":\"ユーザーをさがす\"},\"general\":{\"apply\":\"てきよう\",\"submit\":\"そうしん\",\"more\":\"つづき\",\"generic_error\":\"エラーになりました\"},\"login\":{\"login\":\"ログイン\",\"description\":\"OAuthでログイン\",\"logout\":\"ログアウト\",\"password\":\"パスワード\",\"placeholder\":\"れい: lain\",\"register\":\"はじめる\",\"username\":\"ユーザーめい\",\"hint\":\"はなしあいにくわわるには、ログインしてください\"},\"nav\":{\"about\":\"これはなに?\",\"back\":\"もどる\",\"chat\":\"ローカルチャット\",\"friend_requests\":\"フォローリクエスト\",\"mentions\":\"メンション\",\"dms\":\"ダイレクトメッセージ\",\"public_tl\":\"パブリックタイムライン\",\"timeline\":\"タイムライン\",\"twkn\":\"つながっているすべてのネットワーク\",\"user_search\":\"ユーザーをさがす\",\"who_to_follow\":\"おすすめユーザー\",\"preferences\":\"せってい\"},\"notifications\":{\"broken_favorite\":\"ステータスがみつかりません。さがしています...\",\"favorited_you\":\"あなたのステータスがおきにいりされました\",\"followed_you\":\"フォローされました\",\"load_older\":\"ふるいつうちをみる\",\"notifications\":\"つうち\",\"read\":\"よんだ!\",\"repeated_you\":\"あなたのステータスがリピートされました\",\"no_more_notifications\":\"つうちはありません\"},\"post_status\":{\"new_status\":\"とうこうする\",\"account_not_locked_warning\":\"あなたのアカウントは {0} ではありません。あなたをフォローすれば、だれでも、フォロワーげんていのステータスをよむことができます。\",\"account_not_locked_warning_link\":\"ロックされたアカウント\",\"attachments_sensitive\":\"ファイルをNSFWにする\",\"content_type\":{\"plain_text\":\"プレーンテキスト\"},\"content_warning\":\"せつめい (かかなくてもよい)\",\"default\":\"はねだくうこうに、つきました。\",\"direct_warning\":\"このステータスは、メンションされたユーザーだけが、よむことができます。\",\"posting\":\"とうこう\",\"scope\":{\"direct\":\"ダイレクト: メンションされたユーザーのみにとどきます。\",\"private\":\"フォロワーげんてい: フォロワーのみにとどきます。\",\"public\":\"パブリック: パブリックタイムラインにとどきます。\",\"unlisted\":\"アンリステッド: パブリックタイムラインにとどきません。\"}},\"registration\":{\"bio\":\"プロフィール\",\"email\":\"Eメール\",\"fullname\":\"スクリーンネーム\",\"password_confirm\":\"パスワードのかくにん\",\"registration\":\"はじめる\",\"token\":\"しょうたいトークン\",\"captcha\":\"CAPTCHA\",\"new_captcha\":\"もじがよめないときは、がぞうをクリックすると、あたらしいがぞうになります\",\"validations\":{\"username_required\":\"なにかかいてください\",\"fullname_required\":\"なにかかいてください\",\"email_required\":\"なにかかいてください\",\"password_required\":\"なにかかいてください\",\"password_confirmation_required\":\"なにかかいてください\",\"password_confirmation_match\":\"パスワードがちがいます\"}},\"settings\":{\"attachmentRadius\":\"ファイル\",\"attachments\":\"ファイル\",\"autoload\":\"したにスクロールしたとき、じどうてきによみこむ。\",\"avatar\":\"アバター\",\"avatarAltRadius\":\"つうちのアバター\",\"avatarRadius\":\"アバター\",\"background\":\"バックグラウンド\",\"bio\":\"プロフィール\",\"btnRadius\":\"ボタン\",\"cBlue\":\"リプライとフォロー\",\"cGreen\":\"リピート\",\"cOrange\":\"おきにいり\",\"cRed\":\"キャンセル\",\"change_password\":\"パスワードをかえる\",\"change_password_error\":\"パスワードをかえることが、できなかったかもしれません。\",\"changed_password\":\"パスワードが、かわりました!\",\"collapse_subject\":\"せつめいのあるとうこうをたたむ\",\"composing\":\"とうこう\",\"confirm_new_password\":\"あたらしいパスワードのかくにん\",\"current_avatar\":\"いまのアバター\",\"current_password\":\"いまのパスワード\",\"current_profile_banner\":\"いまのプロフィールバナー\",\"data_import_export_tab\":\"インポートとエクスポート\",\"default_vis\":\"デフォルトのこうかいはんい\",\"delete_account\":\"アカウントをけす\",\"delete_account_description\":\"あなたのアカウントとメッセージが、きえます。\",\"delete_account_error\":\"アカウントをけすことが、できなかったかもしれません。インスタンスのかんりしゃに、れんらくしてください。\",\"delete_account_instructions\":\"ほんとうにアカウントをけしてもいいなら、パスワードをかいてください。\",\"avatar_size_instruction\":\"アバターのおおきさは、150×150ピクセルか、それよりもおおきくするといいです。\",\"export_theme\":\"セーブ\",\"filtering\":\"フィルタリング\",\"filtering_explanation\":\"これらのことばをふくむすべてのものがミュートされます。1ぎょうに1つのことばをかいてください。\",\"follow_export\":\"フォローのエクスポート\",\"follow_export_button\":\"エクスポート\",\"follow_export_processing\":\"おまちください。まもなくファイルをダウンロードできます。\",\"follow_import\":\"フォローインポート\",\"follow_import_error\":\"フォローのインポートがエラーになりました。\",\"follows_imported\":\"フォローがインポートされました! すこしじかんがかかるかもしれません。\",\"foreground\":\"フォアグラウンド\",\"general\":\"ぜんぱん\",\"hide_attachments_in_convo\":\"スレッドのファイルをかくす\",\"hide_attachments_in_tl\":\"タイムラインのファイルをかくす\",\"hide_isp\":\"インスタンススペシフィックパネルをかくす\",\"preload_images\":\"がぞうをさきよみする\",\"use_one_click_nsfw\":\"NSFWなファイルを1クリックでひらく\",\"hide_post_stats\":\"とうこうのとうけいをかくす (れい: おきにいりのかず)\",\"hide_user_stats\":\"ユーザーのとうけいをかくす (れい: フォロワーのかず)\",\"hide_filtered_statuses\":\"フィルターされたとうこうをかくす\",\"import_followers_from_a_csv_file\":\"CSVファイルからフォローをインポートする\",\"import_theme\":\"ロード\",\"inputRadius\":\"インプットフィールド\",\"checkboxRadius\":\"チェックボックス\",\"instance_default\":\"(デフォルト: {value})\",\"instance_default_simple\":\"(デフォルト)\",\"interface\":\"インターフェース\",\"interfaceLanguage\":\"インターフェースのことば\",\"invalid_theme_imported\":\"このファイルはPleromaのテーマではありません。テーマはへんこうされませんでした。\",\"limited_availability\":\"あなたのブラウザではできません\",\"links\":\"リンク\",\"lock_account_description\":\"あなたがみとめたひとだけ、あなたのアカウントをフォローできる\",\"loop_video\":\"ビデオをくりかえす\",\"loop_video_silent_only\":\"おとのないビデオだけくりかえす\",\"play_videos_in_modal\":\"ビデオをメディアビューアーでみる\",\"use_contain_fit\":\"がぞうのサムネイルを、きりぬかない\",\"name\":\"なまえ\",\"name_bio\":\"なまえとプロフィール\",\"new_password\":\"あたらしいパスワード\",\"notification_visibility\":\"ひょうじするつうち\",\"notification_visibility_follows\":\"フォロー\",\"notification_visibility_likes\":\"おきにいり\",\"notification_visibility_mentions\":\"メンション\",\"notification_visibility_repeats\":\"リピート\",\"no_rich_text_description\":\"リッチテキストをつかわない\",\"hide_follows_description\":\"フォローしているひとをみせない\",\"hide_followers_description\":\"フォロワーをみせない\",\"show_admin_badge\":\"アドミンのしるしをみる\",\"show_moderator_badge\":\"モデレーターのしるしをみる\",\"nsfw_clickthrough\":\"NSFWなファイルをかくす\",\"oauth_tokens\":\"OAuthトークン\",\"token\":\"トークン\",\"refresh_token\":\"トークンを更新\",\"valid_until\":\"まで有効\",\"revoke_token\":\"取り消す\",\"panelRadius\":\"パネル\",\"pause_on_unfocused\":\"タブにフォーカスがないときストリーミングをとめる\",\"presets\":\"プリセット\",\"profile_background\":\"プロフィールのバックグラウンド\",\"profile_banner\":\"プロフィールバナー\",\"profile_tab\":\"プロフィール\",\"radii_help\":\"インターフェースのまるさをせっていする。\",\"replies_in_timeline\":\"タイムラインのリプライ\",\"reply_link_preview\":\"カーソルをかさねたとき、リプライのプレビューをみる\",\"reply_visibility_all\":\"すべてのリプライをみる\",\"reply_visibility_following\":\"わたしにあてられたリプライと、フォローしているひとからのリプライをみる\",\"reply_visibility_self\":\"わたしにあてられたリプライをみる\",\"saving_err\":\"せっていをセーブできませんでした\",\"saving_ok\":\"せっていをセーブしました\",\"security_tab\":\"セキュリティ\",\"scope_copy\":\"リプライするとき、こうかいはんいをコピーする (DMのこうかいはんいは、つねにコピーされます)\",\"set_new_avatar\":\"あたらしいアバターをせっていする\",\"set_new_profile_background\":\"あたらしいプロフィールのバックグラウンドをせっていする\",\"set_new_profile_banner\":\"あたらしいプロフィールバナーを設定する\",\"settings\":\"せってい\",\"subject_input_always_show\":\"サブジェクトフィールドをいつでもひょうじする\",\"subject_line_behavior\":\"リプライするときサブジェクトをコピーする\",\"subject_line_email\":\"メールふう: \\\"re: サブジェクト\\\"\",\"subject_line_mastodon\":\"マストドンふう: そのままコピー\",\"subject_line_noop\":\"コピーしない\",\"post_status_content_type\":\"とうこうのコンテントタイプ\",\"status_content_type_plain\":\"プレーンテキスト\",\"stop_gifs\":\"カーソルをかさねたとき、GIFをうごかす\",\"streaming\":\"うえまでスクロールしたとき、じどうてきにストリーミングする\",\"text\":\"もじ\",\"theme\":\"テーマ\",\"theme_help\":\"カラーテーマをカスタマイズできます\",\"theme_help_v2_1\":\"チェックボックスをONにすると、コンポーネントごとに、いろと、とうめいどを、オーバーライドできます。「すべてクリア」ボタンをおすと、すべてのオーバーライドを、やめます。\",\"theme_help_v2_2\":\"バックグラウンドとテキストのコントラストをあらわすアイコンがあります。マウスをホバーすると、くわしいせつめいがでます。とうめいないろをつかっているときは、もっともわるいばあいのコントラストがしめされます。\",\"tooltipRadius\":\"ツールチップとアラート\",\"user_settings\":\"ユーザーせってい\",\"values\":{\"false\":\"いいえ\",\"true\":\"はい\"},\"notifications\":\"つうち\",\"enable_web_push_notifications\":\"ウェブプッシュつうちをゆるす\",\"style\":{\"switcher\":{\"keep_color\":\"いろをのこす\",\"keep_shadows\":\"かげをのこす\",\"keep_opacity\":\"とうめいどをのこす\",\"keep_roundness\":\"まるさをのこす\",\"keep_fonts\":\"フォントをのこす\",\"save_load_hint\":\"「のこす」オプションをONにすると、テーマをえらんだときとロードしたとき、いまのせっていをのこします。また、テーマをエクスポートするとき、これらのオプションをストアします。すべてのチェックボックスをOFFにすると、テーマをエクスポートしたとき、すべてのせっていをセーブします。\",\"reset\":\"リセット\",\"clear_all\":\"すべてクリア\",\"clear_opacity\":\"とうめいどをクリア\"},\"common\":{\"color\":\"いろ\",\"opacity\":\"とうめいど\",\"contrast\":{\"hint\":\"コントラストは {ratio} です。{level}。({context})\",\"level\":{\"aa\":\"AAレベルガイドライン (ミニマル) をみたします\",\"aaa\":\"AAAレベルガイドライン (レコメンデッド) をみたします。\",\"bad\":\"ガイドラインをみたしません。\"},\"context\":{\"18pt\":\"おおきい (18ポイントいじょう) テキスト\",\"text\":\"テキスト\"}}},\"common_colors\":{\"_tab_label\":\"きょうつう\",\"main\":\"きょうつうのいろ\",\"foreground_hint\":\"「くわしく」タブで、もっとこまかくせっていできます\",\"rgbo\":\"アイコンとアクセントとバッジ\"},\"advanced_colors\":{\"_tab_label\":\"くわしく\",\"alert\":\"アラートのバックグラウンド\",\"alert_error\":\"エラー\",\"badge\":\"バッジのバックグラウンド\",\"badge_notification\":\"つうち\",\"panel_header\":\"パネルヘッダー\",\"top_bar\":\"トップバー\",\"borders\":\"さかいめ\",\"buttons\":\"ボタン\",\"inputs\":\"インプットフィールド\",\"faint_text\":\"うすいテキスト\"},\"radii\":{\"_tab_label\":\"まるさ\"},\"shadows\":{\"_tab_label\":\"ひかりとかげ\",\"component\":\"コンポーネント\",\"override\":\"オーバーライド\",\"shadow_id\":\"かげ #{value}\",\"blur\":\"ぼかし\",\"spread\":\"ひろがり\",\"inset\":\"うちがわ\",\"hint\":\"かげのせっていでは、いろのあたいとして --variable をつかうことができます。これはCSS3へんすうです。ただし、とうめいどのせっていは、きかなくなります。\",\"filter_hint\":{\"always_drop_shadow\":\"ブラウザーがサポートしていれば、つねに {0} がつかわれます。\",\"drop_shadow_syntax\":\"{0} は、{1} パラメーターと {2} キーワードをサポートしていません。\",\"avatar_inset\":\"うちがわのかげと、そとがわのかげを、いっしょにつかうと、とうめいなアバターが、へんなみためになります。\",\"spread_zero\":\"ひろがりが 0 よりもおおきなかげは、0 とおなじです。\",\"inset_classic\":\"うちがわのかげは {0} をつかいます。\"},\"components\":{\"panel\":\"パネル\",\"panelHeader\":\"パネルヘッダー\",\"topBar\":\"トップバー\",\"avatar\":\"ユーザーアバター (プロフィール)\",\"avatarStatus\":\"ユーザーアバター (とうこう)\",\"popup\":\"ポップアップとツールチップ\",\"button\":\"ボタン\",\"buttonHover\":\"ボタン (ホバー)\",\"buttonPressed\":\"ボタン (おされているとき)\",\"buttonPressedHover\":\"ボタン (ホバー、かつ、おされているとき)\",\"input\":\"インプットフィールド\"}},\"fonts\":{\"_tab_label\":\"フォント\",\"help\":\"「カスタム」をえらんだときは、システムにあるフォントのなまえを、ただしくにゅうりょくしてください。\",\"components\":{\"interface\":\"インターフェース\",\"input\":\"インプットフィールド\",\"post\":\"とうこう\",\"postCode\":\"モノスペース (とうこうがリッチテキストであるとき)\"},\"family\":\"フォントめい\",\"size\":\"おおきさ (px)\",\"weight\":\"ふとさ\",\"custom\":\"カスタム\"},\"preview\":{\"header\":\"プレビュー\",\"content\":\"ほんぶん\",\"error\":\"エラーのれい\",\"button\":\"ボタン\",\"text\":\"これは{0}と{1}のれいです。\",\"mono\":\"monospace\",\"input\":\"はねだくうこうに、つきました。\",\"faint_link\":\"とてもたすけになるマニュアル\",\"fine_print\":\"わたしたちの{0}を、よまないでください!\",\"header_faint\":\"エラーではありません\",\"checkbox\":\"りようきやくを、よみました\",\"link\":\"ハイパーリンク\"}}},\"timeline\":{\"collapse\":\"たたむ\",\"conversation\":\"スレッド\",\"error_fetching\":\"よみこみがエラーになりました\",\"load_older\":\"ふるいステータス\",\"no_retweet_hint\":\"とうこうを「フォロワーのみ」または「ダイレクト」にすると、リピートできなくなります\",\"repeated\":\"リピート\",\"show_new\":\"よみこみ\",\"up_to_date\":\"さいしん\",\"no_more_statuses\":\"これでおわりです\"},\"user_card\":{\"approve\":\"うけいれ\",\"block\":\"ブロック\",\"blocked\":\"ブロックしています!\",\"deny\":\"おことわり\",\"favorites\":\"おきにいり\",\"follow\":\"フォロー\",\"follow_sent\":\"リクエストを、おくりました!\",\"follow_progress\":\"リクエストしています…\",\"follow_again\":\"ふたたびリクエストをおくりますか?\",\"follow_unfollow\":\"フォローをやめる\",\"followees\":\"フォロー\",\"followers\":\"フォロワー\",\"following\":\"フォローしています!\",\"follows_you\":\"フォローされました!\",\"its_you\":\"これはあなたです!\",\"media\":\"メディア\",\"mute\":\"ミュート\",\"muted\":\"ミュートしています!\",\"per_day\":\"/日\",\"remote_follow\":\"リモートフォロー\",\"statuses\":\"ステータス\"},\"user_profile\":{\"timeline_title\":\"ユーザータイムライン\"},\"who_to_follow\":{\"more\":\"くわしく\",\"who_to_follow\":\"おすすめユーザー\"},\"tool_tip\":{\"media_upload\":\"メディアをアップロード\",\"repeat\":\"リピート\",\"reply\":\"リプライ\",\"favorite\":\"おきにいり\",\"user_settings\":\"ユーザーせってい\"},\"upload\":{\"error\":{\"base\":\"アップロードにしっぱいしました。\",\"file_too_big\":\"ファイルがおおきすぎます [{filesize} {filesizeunit} / {allowedsize} {allowedsizeunit}]\",\"default\":\"しばらくしてから、ためしてください\"},\"file_size_units\":{\"B\":\"B\",\"KiB\":\"KiB\",\"MiB\":\"MiB\",\"GiB\":\"GiB\",\"TiB\":\"TiB\"}}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/ja.json\n// module id = 446\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"챗\"},\"features_panel\":{\"chat\":\"챗\",\"gopher\":\"고퍼\",\"media_proxy\":\"미디어 프록시\",\"scope_options\":\"범위 옵션\",\"text_limit\":\"텍스트 제한\",\"title\":\"기능\",\"who_to_follow\":\"팔로우 추천\"},\"finder\":{\"error_fetching_user\":\"사용자 정보 불러오기 실패\",\"find_user\":\"사용자 찾기\"},\"general\":{\"apply\":\"적용\",\"submit\":\"보내기\"},\"login\":{\"login\":\"로그인\",\"description\":\"OAuth로 로그인\",\"logout\":\"로그아웃\",\"password\":\"암호\",\"placeholder\":\"예시: lain\",\"register\":\"가입\",\"username\":\"사용자 이름\"},\"nav\":{\"about\":\"About\",\"back\":\"뒤로\",\"chat\":\"로컬 챗\",\"friend_requests\":\"팔로우 요청\",\"mentions\":\"멘션\",\"dms\":\"다이렉트 메시지\",\"public_tl\":\"공개 타임라인\",\"timeline\":\"타임라인\",\"twkn\":\"모든 알려진 네트워크\",\"user_search\":\"사용자 검색\",\"preferences\":\"환경설정\"},\"notifications\":{\"broken_favorite\":\"알 수 없는 게시물입니다, 검색 합니다...\",\"favorited_you\":\"당신의 게시물을 즐겨찾기\",\"followed_you\":\"당신을 팔로우\",\"load_older\":\"오래 된 알림 불러오기\",\"notifications\":\"알림\",\"read\":\"읽음!\",\"repeated_you\":\"당신의 게시물을 리핏\"},\"post_status\":{\"new_status\":\"새 게시물 게시\",\"account_not_locked_warning\":\"당신의 계정은 {0} 상태가 아닙니다. 누구나 당신을 팔로우 하고 팔로워 전용 게시물을 볼 수 있습니다.\",\"account_not_locked_warning_link\":\"잠김\",\"attachments_sensitive\":\"첨부물을 민감함으로 설정\",\"content_type\":{\"plain_text\":\"평문\"},\"content_warning\":\"주제 (필수 아님)\",\"default\":\"LA에 도착!\",\"direct_warning\":\"이 게시물을 멘션 된 사용자들에게만 보여집니다\",\"posting\":\"게시\",\"scope\":{\"direct\":\"다이렉트 - 멘션 된 사용자들에게만\",\"private\":\"팔로워 전용 - 팔로워들에게만\",\"public\":\"공개 - 공개 타임라인으로\",\"unlisted\":\"비공개 - 공개 타임라인에 게시 안 함\"}},\"registration\":{\"bio\":\"소개\",\"email\":\"이메일\",\"fullname\":\"표시 되는 이름\",\"password_confirm\":\"암호 확인\",\"registration\":\"가입하기\",\"token\":\"초대 토큰\",\"captcha\":\"캡차\",\"new_captcha\":\"이미지를 클릭해서 새로운 캡차\",\"validations\":{\"username_required\":\"공백으로 둘 수 없습니다\",\"fullname_required\":\"공백으로 둘 수 없습니다\",\"email_required\":\"공백으로 둘 수 없습니다\",\"password_required\":\"공백으로 둘 수 없습니다\",\"password_confirmation_required\":\"공백으로 둘 수 없습니다\",\"password_confirmation_match\":\"패스워드와 일치해야 합니다\"}},\"settings\":{\"attachmentRadius\":\"첨부물\",\"attachments\":\"첨부물\",\"autoload\":\"최하단에 도착하면 자동으로 로드 활성화\",\"avatar\":\"아바타\",\"avatarAltRadius\":\"아바타 (알림)\",\"avatarRadius\":\"아바타\",\"background\":\"배경\",\"bio\":\"소개\",\"btnRadius\":\"버튼\",\"cBlue\":\"파랑 (답글, 팔로우)\",\"cGreen\":\"초록 (리트윗)\",\"cOrange\":\"주황 (즐겨찾기)\",\"cRed\":\"빨강 (취소)\",\"change_password\":\"암호 바꾸기\",\"change_password_error\":\"암호를 바꾸는 데 몇 가지 문제가 있습니다.\",\"changed_password\":\"암호를 바꾸었습니다!\",\"collapse_subject\":\"주제를 가진 게시물 접기\",\"composing\":\"작성\",\"confirm_new_password\":\"새 패스워드 확인\",\"current_avatar\":\"현재 아바타\",\"current_password\":\"현재 패스워드\",\"current_profile_banner\":\"현재 프로필 배너\",\"data_import_export_tab\":\"데이터 불러오기 / 내보내기\",\"default_vis\":\"기본 공개 범위\",\"delete_account\":\"계정 삭제\",\"delete_account_description\":\"계정과 메시지를 영구히 삭제.\",\"delete_account_error\":\"계정을 삭제하는데 문제가 있습니다. 계속 발생한다면 인스턴스 관리자에게 문의하세요.\",\"delete_account_instructions\":\"계정 삭제를 확인하기 위해 아래에 패스워드 입력.\",\"export_theme\":\"프리셋 저장\",\"filtering\":\"필터링\",\"filtering_explanation\":\"아래의 단어를 가진 게시물들은 뮤트 됩니다, 한 줄에 하나씩 적으세요\",\"follow_export\":\"팔로우 내보내기\",\"follow_export_button\":\"팔로우 목록을 csv로 내보내기\",\"follow_export_processing\":\"진행 중입니다, 곧 다운로드 가능해 질 것입니다\",\"follow_import\":\"팔로우 불러오기\",\"follow_import_error\":\"팔로우 불러오기 실패\",\"follows_imported\":\"팔로우 목록을 불러왔습니다! 처리에는 시간이 걸립니다.\",\"foreground\":\"전경\",\"general\":\"일반\",\"hide_attachments_in_convo\":\"대화의 첨부물 숨기기\",\"hide_attachments_in_tl\":\"타임라인의 첨부물 숨기기\",\"hide_isp\":\"인스턴스 전용 패널 숨기기\",\"preload_images\":\"이미지 미리 불러오기\",\"hide_post_stats\":\"게시물 통계 숨기기 (즐겨찾기 수 등)\",\"hide_user_stats\":\"사용자 통계 숨기기 (팔로워 수 등)\",\"import_followers_from_a_csv_file\":\"csv 파일에서 팔로우 목록 불러오기\",\"import_theme\":\"프리셋 불러오기\",\"inputRadius\":\"입력 칸\",\"checkboxRadius\":\"체크박스\",\"instance_default\":\"(기본: {value})\",\"instance_default_simple\":\"(기본)\",\"interface\":\"인터페이스\",\"interfaceLanguage\":\"인터페이스 언어\",\"invalid_theme_imported\":\"선택한 파일은 지원하는 플레로마 테마가 아닙니다. 아무런 변경도 일어나지 않았습니다.\",\"limited_availability\":\"이 브라우저에서 사용 불가\",\"links\":\"링크\",\"lock_account_description\":\"계정을 승인 된 팔로워들로 제한\",\"loop_video\":\"비디오 반복재생\",\"loop_video_silent_only\":\"소리가 없는 비디오만 반복 재생 (마스토돈의 \\\"gifs\\\" 같은 것들)\",\"name\":\"이름\",\"name_bio\":\"이름 & 소개\",\"new_password\":\"새 암호\",\"notification_visibility\":\"보여 줄 알림 종류\",\"notification_visibility_follows\":\"팔로우\",\"notification_visibility_likes\":\"좋아함\",\"notification_visibility_mentions\":\"멘션\",\"notification_visibility_repeats\":\"반복\",\"no_rich_text_description\":\"모든 게시물의 서식을 지우기\",\"hide_follows_description\":\"내가 팔로우하는 사람을 표시하지 않음\",\"hide_followers_description\":\"나를 따르는 사람을 보여주지 마라.\",\"nsfw_clickthrough\":\"NSFW 이미지 \\\"클릭해서 보이기\\\"를 활성화\",\"oauth_tokens\":\"OAuth 토큰\",\"token\":\"토큰\",\"refresh_token\":\"토큰 새로 고침\",\"valid_until\":\"까지 유효하다\",\"revoke_token\":\"취소\",\"panelRadius\":\"패널\",\"pause_on_unfocused\":\"탭이 활성 상태가 아닐 때 스트리밍 멈추기\",\"presets\":\"프리셋\",\"profile_background\":\"프로필 배경\",\"profile_banner\":\"프로필 배너\",\"profile_tab\":\"프로필\",\"radii_help\":\"인터페이스 모서리 둥글기 (픽셀 단위)\",\"replies_in_timeline\":\"답글을 타임라인에\",\"reply_link_preview\":\"마우스를 올려서 답글 링크 미리보기 활성화\",\"reply_visibility_all\":\"모든 답글 보기\",\"reply_visibility_following\":\"나에게 직접 오는 답글이나 내가 팔로우 중인 사람에게서 오는 답글만 표시\",\"reply_visibility_self\":\"나에게 직접 전송 된 답글만 보이기\",\"saving_err\":\"설정 저장 실패\",\"saving_ok\":\"설정 저장 됨\",\"security_tab\":\"보안\",\"scope_copy\":\"답글을 달 때 공개 범위 따라가리 (다이렉트 메시지는 언제나 따라감)\",\"set_new_avatar\":\"새 아바타 설정\",\"set_new_profile_background\":\"새 프로필 배경 설정\",\"set_new_profile_banner\":\"새 프로필 배너 설정\",\"settings\":\"설정\",\"subject_input_always_show\":\"항상 주제 칸 보이기\",\"subject_line_behavior\":\"답글을 달 때 주제 복사하기\",\"subject_line_email\":\"이메일처럼: \\\"re: 주제\\\"\",\"subject_line_mastodon\":\"마스토돈처럼: 그대로 복사\",\"subject_line_noop\":\"복사 안 함\",\"stop_gifs\":\"GIF파일에 마우스를 올려서 재생\",\"streaming\":\"최상단에 도달하면 자동으로 새 게시물 스트리밍\",\"text\":\"텍스트\",\"theme\":\"테마\",\"theme_help\":\"16진수 색상코드(#rrggbb)를 사용해 색상 테마를 커스터마이즈.\",\"theme_help_v2_1\":\"체크박스를 통해 몇몇 컴포넌트의 색상과 불투명도를 조절 가능, \\\"모두 지우기\\\" 버튼으로 덮어 씌운 것을 모두 취소.\",\"theme_help_v2_2\":\"몇몇 입력칸 밑의 아이콘은 전경/배경 대비 관련 표시등입니다, 마우스를 올려 자세한 정보를 볼 수 있습니다. 투명도 대비 표시등이 가장 최악의 경우를 나타낸다는 것을 유의하세요.\",\"tooltipRadius\":\"툴팁/경고\",\"user_settings\":\"사용자 설정\",\"values\":{\"false\":\"아니오\",\"true\":\"네\"},\"notifications\":\"알림\",\"enable_web_push_notifications\":\"웹 푸시 알림 활성화\",\"style\":{\"switcher\":{\"keep_color\":\"색상 유지\",\"keep_shadows\":\"그림자 유지\",\"keep_opacity\":\"불투명도 유지\",\"keep_roundness\":\"둥글기 유지\",\"keep_fonts\":\"글자체 유지\",\"save_load_hint\":\"\\\"유지\\\" 옵션들은 다른 테마를 고르거나 불러 올 때 현재 설정 된 옵션들을 건드리지 않게 합니다, 테마를 내보내기 할 때도 이 옵션에 따라 저장합니다. 아무 것도 체크 되지 않았다면 모든 설정을 내보냅니다.\",\"reset\":\"초기화\",\"clear_all\":\"모두 지우기\",\"clear_opacity\":\"불투명도 지우기\"},\"common\":{\"color\":\"색상\",\"opacity\":\"불투명도\",\"contrast\":{\"hint\":\"대비율이 {ratio}입니다, 이것은 {context} {level}\",\"level\":{\"aa\":\"AA등급 가이드라인에 부합합니다 (최소한도)\",\"aaa\":\"AAA등급 가이드라인에 부합합니다 (권장)\",\"bad\":\"아무런 가이드라인 등급에도 미치지 못합니다\"},\"context\":{\"18pt\":\"큰 (18pt 이상) 텍스트에 대해\",\"text\":\"텍스트에 대해\"}}},\"common_colors\":{\"_tab_label\":\"일반\",\"main\":\"일반 색상\",\"foreground_hint\":\"\\\"고급\\\" 탭에서 더 자세한 설정이 가능합니다\",\"rgbo\":\"아이콘, 강조, 배지\"},\"advanced_colors\":{\"_tab_label\":\"고급\",\"alert\":\"주의 배경\",\"alert_error\":\"에러\",\"badge\":\"배지 배경\",\"badge_notification\":\"알림\",\"panel_header\":\"패널 헤더\",\"top_bar\":\"상단 바\",\"borders\":\"테두리\",\"buttons\":\"버튼\",\"inputs\":\"입력칸\",\"faint_text\":\"흐려진 텍스트\"},\"radii\":{\"_tab_label\":\"둥글기\"},\"shadows\":{\"_tab_label\":\"그림자와 빛\",\"component\":\"컴포넌트\",\"override\":\"덮어쓰기\",\"shadow_id\":\"그림자 #{value}\",\"blur\":\"흐리기\",\"spread\":\"퍼지기\",\"inset\":\"안쪽으로\",\"hint\":\"그림자에는 CSS3 변수를 --variable을 통해 색상 값으로 사용할 수 있습니다. 불투명도에는 적용 되지 않습니다.\",\"filter_hint\":{\"always_drop_shadow\":\"경고, 이 그림자는 브라우저가 지원하는 경우 항상 {0}을 사용합니다.\",\"drop_shadow_syntax\":\"{0}는 {1} 파라미터와 {2} 키워드를 지원하지 않습니다.\",\"avatar_inset\":\"안쪽과 안쪽이 아닌 그림자를 모두 설정하는 경우 투명 아바타에서 예상치 못 한 결과가 나올 수 있다는 것에 주의해 주세요.\",\"spread_zero\":\"퍼지기가 0보다 큰 그림자는 0으로 설정한 것과 동일하게 보여집니다\",\"inset_classic\":\"안쪽 그림자는 {0}를 사용합니다\"},\"components\":{\"panel\":\"패널\",\"panelHeader\":\"패널 헤더\",\"topBar\":\"상단 바\",\"avatar\":\"사용자 아바타 (프로필 뷰에서)\",\"avatarStatus\":\"사용자 아바타 (게시물에서)\",\"popup\":\"팝업과 툴팁\",\"button\":\"버튼\",\"buttonHover\":\"버튼 (마우스 올렸을 때)\",\"buttonPressed\":\"버튼 (눌렸을 때)\",\"buttonPressedHover\":\"Button (마우스 올림 + 눌림)\",\"input\":\"입력칸\"}},\"fonts\":{\"_tab_label\":\"글자체\",\"help\":\"인터페이스의 요소에 사용 될 글자체를 고르세요. \\\"커스텀\\\"은 시스템에 있는 폰트 이름을 정확히 입력해야 합니다.\",\"components\":{\"interface\":\"인터페이스\",\"input\":\"입력칸\",\"post\":\"게시물 텍스트\",\"postCode\":\"게시물의 고정폭 텍스트 (서식 있는 텍스트)\"},\"family\":\"글자체 이름\",\"size\":\"크기 (px 단위)\",\"weight\":\"굵기\",\"custom\":\"커스텀\"},\"preview\":{\"header\":\"미리보기\",\"content\":\"내용\",\"error\":\"에러 예시\",\"button\":\"버튼\",\"text\":\"더 많은 {0} 그리고 {1}\",\"mono\":\"내용\",\"input\":\"LA에 막 도착!\",\"faint_link\":\"도움 되는 설명서\",\"fine_print\":\"우리의 {0} 를 읽고 도움 되지 않는 것들을 배우자!\",\"header_faint\":\"이건 괜찮아\",\"checkbox\":\"나는 약관을 대충 훑어보았습니다\",\"link\":\"작고 귀여운 링크\"}}},\"timeline\":{\"collapse\":\"접기\",\"conversation\":\"대화\",\"error_fetching\":\"업데이트 불러오기 실패\",\"load_older\":\"더 오래 된 게시물 불러오기\",\"no_retweet_hint\":\"팔로워 전용, 다이렉트 메시지는 반복할 수 없습니다\",\"repeated\":\"반복 됨\",\"show_new\":\"새로운 것 보기\",\"up_to_date\":\"최신 상태\"},\"user_card\":{\"approve\":\"승인\",\"block\":\"차단\",\"blocked\":\"차단 됨!\",\"deny\":\"거부\",\"follow\":\"팔로우\",\"follow_sent\":\"요청 보내짐!\",\"follow_progress\":\"요청 중…\",\"follow_again\":\"요청을 다시 보낼까요?\",\"follow_unfollow\":\"팔로우 중지\",\"followees\":\"팔로우 중\",\"followers\":\"팔로워\",\"following\":\"팔로우 중!\",\"follows_you\":\"당신을 팔로우 합니다!\",\"its_you\":\"당신입니다!\",\"mute\":\"침묵\",\"muted\":\"침묵 됨\",\"per_day\":\" / 하루\",\"remote_follow\":\"원격 팔로우\",\"statuses\":\"게시물\"},\"user_profile\":{\"timeline_title\":\"사용자 타임라인\"},\"who_to_follow\":{\"more\":\"더 보기\",\"who_to_follow\":\"팔로우 추천\"},\"tool_tip\":{\"media_upload\":\"미디어 업로드\",\"repeat\":\"반복\",\"reply\":\"답글\",\"favorite\":\"즐겨찾기\",\"user_settings\":\"사용자 설정\"},\"upload\":{\"error\":{\"base\":\"업로드 실패.\",\"file_too_big\":\"파일이 너무 커요 [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"잠시 후에 다시 시도해 보세요\"},\"file_size_units\":{\"B\":\"바이트\",\"KiB\":\"키비바이트\",\"MiB\":\"메비바이트\",\"GiB\":\"기비바이트\",\"TiB\":\"테비바이트\"}}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/ko.json\n// module id = 447\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Nettprat\"},\"features_panel\":{\"chat\":\"Nettprat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Media proxy\",\"scope_options\":\"Velg mottakere\",\"text_limit\":\"Tekst-grense\",\"title\":\"Egenskaper\",\"who_to_follow\":\"Hvem å følge\"},\"finder\":{\"error_fetching_user\":\"Feil ved henting av bruker\",\"find_user\":\"Finn bruker\"},\"general\":{\"apply\":\"Bruk\",\"submit\":\"Send\"},\"login\":{\"login\":\"Logg inn\",\"logout\":\"Logg ut\",\"password\":\"Passord\",\"placeholder\":\"f. eks lain\",\"register\":\"Registrer\",\"username\":\"Brukernavn\"},\"nav\":{\"chat\":\"Lokal nettprat\",\"friend_requests\":\"Følgeforespørsler\",\"mentions\":\"Nevnt\",\"public_tl\":\"Offentlig Tidslinje\",\"timeline\":\"Tidslinje\",\"twkn\":\"Det hele kjente nettverket\"},\"notifications\":{\"broken_favorite\":\"Ukjent status, leter etter den...\",\"favorited_you\":\"likte din status\",\"followed_you\":\"fulgte deg\",\"load_older\":\"Last eldre varsler\",\"notifications\":\"Varslinger\",\"read\":\"Les!\",\"repeated_you\":\"Gjentok din status\"},\"post_status\":{\"account_not_locked_warning\":\"Kontoen din er ikke {0}. Hvem som helst kan følge deg for å se dine statuser til følgere\",\"account_not_locked_warning_link\":\"låst\",\"attachments_sensitive\":\"Merk vedlegg som sensitive\",\"content_type\":{\"plain_text\":\"Klar tekst\"},\"content_warning\":\"Tema (valgfritt)\",\"default\":\"Landet akkurat i L.A.\",\"direct_warning\":\"Denne statusen vil kun bli sett av nevnte brukere\",\"posting\":\"Publiserer\",\"scope\":{\"direct\":\"Direkte, publiser bare til nevnte brukere\",\"private\":\"Bare følgere, publiser bare til brukere som følger deg\",\"public\":\"Offentlig, publiser til offentlige tidslinjer\",\"unlisted\":\"Uoppført, ikke publiser til offentlige tidslinjer\"}},\"registration\":{\"bio\":\"Biografi\",\"email\":\"Epost-adresse\",\"fullname\":\"Visningsnavn\",\"password_confirm\":\"Bekreft passord\",\"registration\":\"Registrering\",\"token\":\"Invitasjons-bevis\"},\"settings\":{\"attachmentRadius\":\"Vedlegg\",\"attachments\":\"Vedlegg\",\"autoload\":\"Automatisk lasting når du blar ned til bunnen\",\"avatar\":\"Profilbilde\",\"avatarAltRadius\":\"Profilbilde (Varslinger)\",\"avatarRadius\":\"Profilbilde\",\"background\":\"Bakgrunn\",\"bio\":\"Biografi\",\"btnRadius\":\"Knapper\",\"cBlue\":\"Blå (Svar, følg)\",\"cGreen\":\"Grønn (Gjenta)\",\"cOrange\":\"Oransje (Lik)\",\"cRed\":\"Rød (Avbryt)\",\"change_password\":\"Endre passord\",\"change_password_error\":\"Feil ved endring av passord\",\"changed_password\":\"Passord endret\",\"collapse_subject\":\"Sammenfold statuser med tema\",\"confirm_new_password\":\"Bekreft nytt passord\",\"current_avatar\":\"Ditt nåværende profilbilde\",\"current_password\":\"Nåværende passord\",\"current_profile_banner\":\"Din nåværende profil-banner\",\"data_import_export_tab\":\"Data import / eksport\",\"default_vis\":\"Standard visnings-omfang\",\"delete_account\":\"Slett konto\",\"delete_account_description\":\"Slett din konto og alle dine statuser\",\"delete_account_error\":\"Det oppsto et problem ved sletting av kontoen din, hvis dette problemet forblir kontakt din administrator\",\"delete_account_instructions\":\"Skriv inn ditt passord i feltet nedenfor for å bekrefte sletting av konto\",\"export_theme\":\"Lagre tema\",\"filtering\":\"Filtrering\",\"filtering_explanation\":\"Alle statuser som inneholder disse ordene vil bli dempet, en kombinasjon av tegn per linje\",\"follow_export\":\"Eksporter følginger\",\"follow_export_button\":\"Eksporter følgingene dine til en .csv fil\",\"follow_export_processing\":\"Jobber, du vil snart bli spurt om å laste ned filen din.\",\"follow_import\":\"Importer følginger\",\"follow_import_error\":\"Feil ved importering av følginger.\",\"follows_imported\":\"Følginger importert! Behandling vil ta litt tid.\",\"foreground\":\"Forgrunn\",\"general\":\"Generell\",\"hide_attachments_in_convo\":\"Gjem vedlegg i samtaler\",\"hide_attachments_in_tl\":\"Gjem vedlegg på tidslinje\",\"import_followers_from_a_csv_file\":\"Importer følginger fra en csv fil\",\"import_theme\":\"Last tema\",\"inputRadius\":\"Input felt\",\"instance_default\":\"(standard: {value})\",\"interfaceLanguage\":\"Grensesnitt-språk\",\"invalid_theme_imported\":\"Den valgte filen er ikke ett støttet Pleroma-tema, ingen endringer til ditt tema ble gjort\",\"limited_availability\":\"Ikke tilgjengelig i din nettleser\",\"links\":\"Linker\",\"lock_account_description\":\"Begrens din konto til bare godkjente følgere\",\"loop_video\":\"Gjenta videoer\",\"loop_video_silent_only\":\"Gjenta bare videoer uten lyd, (for eksempel Mastodon sine \\\"gifs\\\")\",\"name\":\"Navn\",\"name_bio\":\"Navn & Biografi\",\"new_password\":\"Nytt passord\",\"notification_visibility\":\"Typer varsler som skal vises\",\"notification_visibility_follows\":\"Følginger\",\"notification_visibility_likes\":\"Likes\",\"notification_visibility_mentions\":\"Nevnt\",\"notification_visibility_repeats\":\"Gjentakelser\",\"no_rich_text_description\":\"Fjern all formatering fra statuser\",\"nsfw_clickthrough\":\"Krev trykk for å vise statuser som kan være upassende\",\"oauth_tokens\":\"OAuth Tokens\",\"token\":\"Pollett\",\"refresh_token\":\"Refresh Token\",\"valid_until\":\"Gyldig til\",\"revoke_token\":\"Tilbakekall\",\"panelRadius\":\"Panel\",\"pause_on_unfocused\":\"Stopp henting av poster når vinduet ikke er i fokus\",\"presets\":\"Forhåndsdefinerte tema\",\"profile_background\":\"Profil-bakgrunn\",\"profile_banner\":\"Profil-banner\",\"profile_tab\":\"Profil\",\"radii_help\":\"Bestem hvor runde hjørnene i brukergrensesnittet skal være (i piksler)\",\"replies_in_timeline\":\"Svar på tidslinje\",\"reply_link_preview\":\"Vis en forhåndsvisning når du holder musen over svar til en status\",\"reply_visibility_all\":\"Vis alle svar\",\"reply_visibility_following\":\"Vis bare svar som er til meg eller folk jeg følger\",\"reply_visibility_self\":\"Vis bare svar som er til meg\",\"saving_err\":\"Feil ved lagring av innstillinger\",\"saving_ok\":\"Innstillinger lagret\",\"security_tab\":\"Sikkerhet\",\"set_new_avatar\":\"Rediger profilbilde\",\"set_new_profile_background\":\"Rediger profil-bakgrunn\",\"set_new_profile_banner\":\"Sett ny profil-banner\",\"settings\":\"Innstillinger\",\"stop_gifs\":\"Spill av GIFs når du holder over dem\",\"streaming\":\"Automatisk strømming av nye statuser når du har bladd til toppen\",\"text\":\"Tekst\",\"theme\":\"Tema\",\"theme_help\":\"Bruk heksadesimale fargekoder (#rrggbb) til å endre farge-temaet ditt.\",\"tooltipRadius\":\"Verktøytips/advarsler\",\"user_settings\":\"Brukerinstillinger\",\"values\":{\"false\":\"nei\",\"true\":\"ja\"}},\"timeline\":{\"collapse\":\"Sammenfold\",\"conversation\":\"Samtale\",\"error_fetching\":\"Feil ved henting av oppdateringer\",\"load_older\":\"Last eldre statuser\",\"no_retweet_hint\":\"Status er markert som bare til følgere eller direkte og kan ikke gjentas\",\"repeated\":\"gjentok\",\"show_new\":\"Vis nye\",\"up_to_date\":\"Oppdatert\"},\"user_card\":{\"approve\":\"Godkjenn\",\"block\":\"Blokker\",\"blocked\":\"Blokkert!\",\"deny\":\"Avslå\",\"follow\":\"Følg\",\"followees\":\"Følger\",\"followers\":\"Følgere\",\"following\":\"Følger!\",\"follows_you\":\"Følger deg!\",\"mute\":\"Demp\",\"muted\":\"Dempet\",\"per_day\":\"per dag\",\"remote_follow\":\"Følg eksternt\",\"statuses\":\"Statuser\"},\"user_profile\":{\"timeline_title\":\"Bruker-tidslinje\"},\"who_to_follow\":{\"more\":\"Mer\",\"who_to_follow\":\"Hvem å følge\"}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/nb.json\n// module id = 448\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Chat\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Media proxy\",\"scope_options\":\"Zichtbaarheidsopties\",\"text_limit\":\"Tekst limiet\",\"title\":\"Features\",\"who_to_follow\":\"Wie te volgen\"},\"finder\":{\"error_fetching_user\":\"Fout tijdens ophalen gebruiker\",\"find_user\":\"Gebruiker zoeken\"},\"general\":{\"apply\":\"toepassen\",\"submit\":\"Verzend\"},\"login\":{\"login\":\"Log in\",\"description\":\"Log in met OAuth\",\"logout\":\"Log uit\",\"password\":\"Wachtwoord\",\"placeholder\":\"bv. lain\",\"register\":\"Registreer\",\"username\":\"Gebruikersnaam\"},\"nav\":{\"about\":\"Over\",\"back\":\"Terug\",\"chat\":\"Locale Chat\",\"friend_requests\":\"Volgverzoek\",\"mentions\":\"Vermeldingen\",\"dms\":\"Directe Berichten\",\"public_tl\":\"Publieke Tijdlijn\",\"timeline\":\"Tijdlijn\",\"twkn\":\"Het Geheel Gekende Netwerk\",\"user_search\":\"Zoek Gebruiker\",\"who_to_follow\":\"Wie te volgen\",\"preferences\":\"Voorkeuren\"},\"notifications\":{\"broken_favorite\":\"Onbekende status, aan het zoeken...\",\"favorited_you\":\"vond je status leuk\",\"followed_you\":\"volgt jou\",\"load_older\":\"Laad oudere meldingen\",\"notifications\":\"Meldingen\",\"read\":\"Gelezen!\",\"repeated_you\":\"Herhaalde je status\"},\"post_status\":{\"new_status\":\"Post nieuwe status\",\"account_not_locked_warning\":\"Je account is niet {0}. Iedereen die je volgt kan enkel-volgers posts lezen.\",\"account_not_locked_warning_link\":\"gesloten\",\"attachments_sensitive\":\"Markeer bijlage als gevoelig\",\"content_type\":{\"plain_text\":\"Gewone tekst\"},\"content_warning\":\"Onderwerp (optioneel)\",\"default\":\"Tijd voor een pauze!\",\"direct_warning\":\"Deze post zal enkel zichtbaar zijn voor de personen die genoemd zijn.\",\"posting\":\"Plaatsen\",\"scope\":{\"direct\":\"Direct - Post enkel naar genoemde gebruikers\",\"private\":\"Enkel volgers - Post enkel naar volgers\",\"public\":\"Publiek - Post op publieke tijdlijnen\",\"unlisted\":\"Unlisted - Toon niet op publieke tijdlijnen\"}},\"registration\":{\"bio\":\"Bio\",\"email\":\"Email\",\"fullname\":\"Weergave naam\",\"password_confirm\":\"Wachtwoord bevestiging\",\"registration\":\"Registratie\",\"token\":\"Uitnodigingstoken\",\"captcha\":\"CAPTCHA\",\"new_captcha\":\"Klik op de afbeelding voor een nieuwe captcha\",\"validations\":{\"username_required\":\"moet ingevuld zijn\",\"fullname_required\":\"moet ingevuld zijn\",\"email_required\":\"moet ingevuld zijn\",\"password_required\":\"moet ingevuld zijn\",\"password_confirmation_required\":\"moet ingevuld zijn\",\"password_confirmation_match\":\"komt niet overeen met het wachtwoord\"}},\"settings\":{\"attachmentRadius\":\"Bijlages\",\"attachments\":\"Bijlages\",\"autoload\":\"Automatisch laden wanneer tot de bodem gescrold inschakelen\",\"avatar\":\"Avatar\",\"avatarAltRadius\":\"Avatars (Meldingen)\",\"avatarRadius\":\"Avatars\",\"background\":\"Achtergrond\",\"bio\":\"Bio\",\"btnRadius\":\"Knoppen\",\"cBlue\":\"Blauw (Antwoord, volgen)\",\"cGreen\":\"Groen (Herhaal)\",\"cOrange\":\"Oranje (Vind ik leuk)\",\"cRed\":\"Rood (Annuleer)\",\"change_password\":\"Verander Wachtwoord\",\"change_password_error\":\"Er was een probleem bij het aanpassen van je wachtwoord.\",\"changed_password\":\"Wachtwoord succesvol aangepast!\",\"collapse_subject\":\"Klap posts met onderwerp in\",\"composing\":\"Samenstellen\",\"confirm_new_password\":\"Bevestig nieuw wachtwoord\",\"current_avatar\":\"Je huidige avatar\",\"current_password\":\"Huidig wachtwoord\",\"current_profile_banner\":\"Je huidige profiel banner\",\"data_import_export_tab\":\"Data Import / Export\",\"default_vis\":\"Standaard zichtbaarheidsscope\",\"delete_account\":\"Verwijder Account\",\"delete_account_description\":\"Verwijder je account en berichten permanent.\",\"delete_account_error\":\"Er was een probleem bij het verwijderen van je account. Indien dit probleem blijft, gelieve de administratie van deze instantie te verwittigen.\",\"delete_account_instructions\":\"Typ je wachtwoord in de input hieronder om het verwijderen van je account te bevestigen.\",\"export_theme\":\"Sla preset op\",\"filtering\":\"Filtering\",\"filtering_explanation\":\"Alle statussen die deze woorden bevatten worden genegeerd, één filter per lijn.\",\"follow_export\":\"Volgers export\",\"follow_export_button\":\"Exporteer je volgers naar een csv file\",\"follow_export_processing\":\"Aan het verwerken, binnen enkele ogenblikken wordt je gevraagd je bestand te downloaden\",\"follow_import\":\"Volgers import\",\"follow_import_error\":\"Fout bij importeren volgers\",\"follows_imported\":\"Volgers geïmporteerd! Het kan even duren om ze allemaal te verwerken.\",\"foreground\":\"Voorgrond\",\"general\":\"Algemeen\",\"hide_attachments_in_convo\":\"Verberg bijlages in conversaties\",\"hide_attachments_in_tl\":\"Verberg bijlages in de tijdlijn\",\"hide_isp\":\"Verberg instantie-specifiek paneel\",\"preload_images\":\"Afbeeldingen voorladen\",\"hide_post_stats\":\"Verberg post statistieken (bv. het aantal vind-ik-leuks)\",\"hide_user_stats\":\"Verberg post statistieken (bv. het aantal volgers)\",\"import_followers_from_a_csv_file\":\"Importeer volgers uit een csv file\",\"import_theme\":\"Laad preset\",\"inputRadius\":\"Invoer velden\",\"checkboxRadius\":\"Checkboxen\",\"instance_default\":\"(standaard: {value})\",\"instance_default_simple\":\"(standaard)\",\"interface\":\"Interface\",\"interfaceLanguage\":\"Interface taal\",\"invalid_theme_imported\":\"Het geselecteerde thema is geen door Pleroma ondersteund thema. Er zijn geen aanpassingen gedaan.\",\"limited_availability\":\"Onbeschikbaar in je browser\",\"links\":\"Links\",\"lock_account_description\":\"Laat volgers enkel toe na expliciete toestemming\",\"loop_video\":\"Speel videos af in een lus\",\"loop_video_silent_only\":\"Speel enkel videos zonder geluid af in een lus (bv. Mastodon's \\\"gifs\\\")\",\"name\":\"Naam\",\"name_bio\":\"Naam & Bio\",\"new_password\":\"Nieuw wachtwoord\",\"notification_visibility\":\"Type meldingen die getoond worden\",\"notification_visibility_follows\":\"Volgers\",\"notification_visibility_likes\":\"Vind-ik-leuks\",\"notification_visibility_mentions\":\"Vermeldingen\",\"notification_visibility_repeats\":\"Herhalingen\",\"no_rich_text_description\":\"Strip rich text formattering van alle posts\",\"hide_network_description\":\"Toon niet wie mij volgt en wie ik volg.\",\"nsfw_clickthrough\":\"Schakel doorklikbaar verbergen van NSFW bijlages in\",\"oauth_tokens\":\"OAuth-tokens\",\"token\":\"Token\",\"refresh_token\":\"Token vernieuwen\",\"valid_until\":\"Geldig tot\",\"revoke_token\":\"Intrekken\",\"panelRadius\":\"Panelen\",\"pause_on_unfocused\":\"Pauzeer streamen wanneer de tab niet gefocused is\",\"presets\":\"Presets\",\"profile_background\":\"Profiel Achtergrond\",\"profile_banner\":\"Profiel Banner\",\"profile_tab\":\"Profiel\",\"radii_help\":\"Stel afronding van hoeken in de interface in (in pixels)\",\"replies_in_timeline\":\"Antwoorden in tijdlijn\",\"reply_link_preview\":\"Schakel antwoordlink preview in bij over zweven met muisaanwijzer\",\"reply_visibility_all\":\"Toon alle antwoorden\",\"reply_visibility_following\":\"Toon enkel antwoorden naar mij of andere gebruikers gericht\",\"reply_visibility_self\":\"Toon enkel antwoorden naar mij gericht\",\"saving_err\":\"Fout tijdens opslaan van instellingen\",\"saving_ok\":\"Instellingen opgeslagen\",\"security_tab\":\"Veiligheid\",\"scope_copy\":\"Neem scope over bij antwoorden (Directe Berichten blijven altijd Direct)\",\"set_new_avatar\":\"Zet nieuwe avatar\",\"set_new_profile_background\":\"Zet nieuwe profiel achtergrond\",\"set_new_profile_banner\":\"Zet nieuwe profiel banner\",\"settings\":\"Instellingen\",\"subject_input_always_show\":\"Maak onderwerpveld altijd zichtbaar\",\"subject_line_behavior\":\"Kopieer onderwerp bij antwoorden\",\"subject_line_email\":\"Zoals email: \\\"re: onderwerp\\\"\",\"subject_line_mastodon\":\"Zoals Mastodon: kopieer zoals het is\",\"subject_line_noop\":\"Kopieer niet\",\"stop_gifs\":\"Speel GIFs af bij zweven\",\"streaming\":\"Schakel automatisch streamen van posts in wanneer tot boven gescrold.\",\"text\":\"Tekst\",\"theme\":\"Thema\",\"theme_help\":\"Gebruik hex color codes (#rrggbb) om je kleurschema te wijzigen.\",\"theme_help_v2_1\":\"Je kan ook de kleur en transparantie van bepaalde componenten overschrijven door de checkbox aan te vinken, gebruik de \\\"Wis alles\\\" knop om alle overschrijvingen te annuleren.\",\"theme_help_v2_2\":\"Iconen onder sommige items zijn achtergrond/tekst contrast indicators, zweef er over voor gedetailleerde info. Hou er rekening mee dat bij doorzichtigheid de ergst mogelijke situatie wordt weer gegeven.\",\"tooltipRadius\":\"Gereedschapstips/alarmen\",\"user_settings\":\"Gebruikers Instellingen\",\"values\":{\"false\":\"nee\",\"true\":\"ja\"},\"notifications\":\"Meldingen\",\"enable_web_push_notifications\":\"Schakel web push meldingen in\",\"style\":{\"switcher\":{\"keep_color\":\"Behoud kleuren\",\"keep_shadows\":\"Behoud schaduwen\",\"keep_opacity\":\"Behoud transparantie\",\"keep_roundness\":\"Behoud afrondingen\",\"keep_fonts\":\"Behoud lettertypes\",\"save_load_hint\":\"\\\"Behoud\\\" opties behouden de momenteel ingestelde opties bij het selecteren of laden van thema's, maar slaan ook de genoemde opties op bij het exporteren van een thema. Wanneer alle selectievakjes zijn uitgeschakeld, zal het exporteren van thema's alles opslaan.\",\"reset\":\"Reset\",\"clear_all\":\"Wis alles\",\"clear_opacity\":\"Wis transparantie\"},\"common\":{\"color\":\"Kleur\",\"opacity\":\"Transparantie\",\"contrast\":{\"hint\":\"Contrast ratio is {ratio}, {level} {context}\",\"level\":{\"aa\":\"voldoet aan de richtlijn van niveau AA (minimum)\",\"aaa\":\"voldoet aan de richtlijn van niveau AAA (aangeraden)\",\"bad\":\"voldoet aan geen enkele toegankelijkheidsrichtlijn\"},\"context\":{\"18pt\":\"voor grote (18pt+) tekst\",\"text\":\"voor tekst\"}}},\"common_colors\":{\"_tab_label\":\"Gemeenschappelijk\",\"main\":\"Gemeenschappelijke kleuren\",\"foreground_hint\":\"Zie \\\"Geavanceerd\\\" tab voor meer gedetailleerde controle\",\"rgbo\":\"Iconen, accenten, badges\"},\"advanced_colors\":{\"_tab_label\":\"Geavanceerd\",\"alert\":\"Alarm achtergrond\",\"alert_error\":\"Fout\",\"badge\":\"Badge achtergrond\",\"badge_notification\":\"Meldingen\",\"panel_header\":\"Paneel hoofding\",\"top_bar\":\"Top bar\",\"borders\":\"Randen\",\"buttons\":\"Knoppen\",\"inputs\":\"Invoervelden\",\"faint_text\":\"Vervaagde tekst\"},\"radii\":{\"_tab_label\":\"Rondheid\"},\"shadows\":{\"_tab_label\":\"Schaduw en belichting\",\"component\":\"Component\",\"override\":\"Overschrijven\",\"shadow_id\":\"Schaduw #{value}\",\"blur\":\"Vervagen\",\"spread\":\"Spreid\",\"inset\":\"Inzet\",\"hint\":\"Voor schaduw kan je ook --variable gebruiken als een kleur waarde om CSS3 variabelen te gebruiken. Houd er rekening mee dat het instellen van opaciteit in dit geval niet werkt.\",\"filter_hint\":{\"always_drop_shadow\":\"Waarschuwing, deze schaduw gebruikt altijd {0} als de browser dit ondersteund.\",\"drop_shadow_syntax\":\"{0} ondersteund niet de {1} parameter en {2} sleutelwoord.\",\"avatar_inset\":\"Houd er rekening mee dat het combineren van zowel inzet and niet-inzet schaduwen op transparante avatars onverwachte resultaten kan opleveren.\",\"spread_zero\":\"Schaduw met spreiding > 0 worden weergegeven alsof ze op nul staan\",\"inset_classic\":\"Inzet schaduw zal {0} gebruiken\"},\"components\":{\"panel\":\"Paneel\",\"panelHeader\":\"Paneel hoofding\",\"topBar\":\"Top bar\",\"avatar\":\"Gebruiker avatar (in profiel weergave)\",\"avatarStatus\":\"Gebruiker avatar (in post weergave)\",\"popup\":\"Popups en gereedschapstips\",\"button\":\"Knop\",\"buttonHover\":\"Knop (zweven)\",\"buttonPressed\":\"Knop (ingedrukt)\",\"buttonPressedHover\":\"Knop (ingedrukt+zweven)\",\"input\":\"Invoerveld\"}},\"fonts\":{\"_tab_label\":\"Lettertypes\",\"help\":\"Selecteer het lettertype om te gebruiken voor elementen van de UI.Voor \\\"aangepast\\\" moet je de exacte naam van het lettertype invoeren zoals die in het systeem wordt weergegeven.\",\"components\":{\"interface\":\"Interface\",\"input\":\"Invoervelden\",\"post\":\"Post tekst\",\"postCode\":\"Monospaced tekst in een post (rich text)\"},\"family\":\"Naam lettertype\",\"size\":\"Grootte (in px)\",\"weight\":\"Gewicht (vetheid)\",\"custom\":\"Aangepast\"},\"preview\":{\"header\":\"Voorvertoning\",\"content\":\"Inhoud\",\"error\":\"Voorbeeld fout\",\"button\":\"Knop\",\"text\":\"Nog een boel andere {0} en {1}\",\"mono\":\"inhoud\",\"input\":\"Tijd voor een pauze!\",\"faint_link\":\"handige gebruikershandleiding\",\"fine_print\":\"Lees onze {0} om niets nuttig te leren!\",\"header_faint\":\"Alles komt goed\",\"checkbox\":\"Ik heb de gebruikersvoorwaarden eens van ver bekeken\",\"link\":\"een link\"}}},\"timeline\":{\"collapse\":\"Inklappen\",\"conversation\":\"Conversatie\",\"error_fetching\":\"Fout bij ophalen van updates\",\"load_older\":\"Laad oudere Statussen\",\"no_retweet_hint\":\"Post is gemarkeerd als enkel volgers of direct en kan niet worden herhaald\",\"repeated\":\"herhaalde\",\"show_new\":\"Toon nieuwe\",\"up_to_date\":\"Up-to-date\"},\"user_card\":{\"approve\":\"Goedkeuren\",\"block\":\"Blokkeren\",\"blocked\":\"Geblokkeerd!\",\"deny\":\"Ontzeggen\",\"favorites\":\"Vind-ik-leuks\",\"follow\":\"Volgen\",\"follow_sent\":\"Aanvraag verzonden!\",\"follow_progress\":\"Aanvragen…\",\"follow_again\":\"Aanvraag opnieuw zenden?\",\"follow_unfollow\":\"Stop volgen\",\"followees\":\"Aan het volgen\",\"followers\":\"Volgers\",\"following\":\"Aan het volgen!\",\"follows_you\":\"Volgt jou!\",\"its_you\":\"'t is jij!\",\"mute\":\"Dempen\",\"muted\":\"Gedempt\",\"per_day\":\"per dag\",\"remote_follow\":\"Volg vanop afstand\",\"statuses\":\"Statussen\"},\"user_profile\":{\"timeline_title\":\"Gebruikers Tijdlijn\"},\"who_to_follow\":{\"more\":\"Meer\",\"who_to_follow\":\"Wie te volgen\"},\"tool_tip\":{\"media_upload\":\"Upload Media\",\"repeat\":\"Herhaal\",\"reply\":\"Antwoord\",\"favorite\":\"Vind-ik-leuk\",\"user_settings\":\"Gebruikers Instellingen\"},\"upload\":{\"error\":{\"base\":\"Upload gefaald.\",\"file_too_big\":\"Bestand is te groot [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"Probeer later opnieuw\"},\"file_size_units\":{\"B\":\"B\",\"KiB\":\"KiB\",\"MiB\":\"MiB\",\"GiB\":\"GiB\",\"TiB\":\"TiB\"}}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/nl.json\n// module id = 449\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Messatjariá\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Servidor mandatari mèdia\",\"scope_options\":\"Nivèls de confidencialitat\",\"text_limit\":\"Limita de tèxte\",\"title\":\"Foncionalitats\",\"who_to_follow\":\"Qual seguir\"},\"finder\":{\"error_fetching_user\":\"Error pendent la cèrca d’un utilizaire\",\"find_user\":\"Cercar un utilizaire\"},\"general\":{\"apply\":\"Aplicar\",\"submit\":\"Mandar\",\"more\":\"Mai\",\"generic_error\":\"Una error s’es producha\",\"optional\":\"opcional\"},\"image_cropper\":{\"crop_picture\":\"Talhar l’imatge\",\"save\":\"Salvar\",\"cancel\":\"Anullar\"},\"login\":{\"login\":\"Connexion\",\"description\":\"Connexion via OAuth\",\"logout\":\"Desconnexion\",\"password\":\"Senhal\",\"placeholder\":\"e.g. lain\",\"register\":\"Se marcar\",\"username\":\"Nom d’utilizaire\",\"hint\":\"Connectatz-vos per participar a la discutida\"},\"media_modal\":{\"previous\":\"Precedent\",\"next\":\"Seguent\"},\"nav\":{\"about\":\"A prepaus\",\"back\":\"Tornar\",\"chat\":\"Chat local\",\"friend_requests\":\"Demandas de seguiment\",\"mentions\":\"Notificacions\",\"dms\":\"Messatges privats\",\"public_tl\":\"Estatuts locals\",\"timeline\":\"Flux d’actualitat\",\"twkn\":\"Lo malhum conegut\",\"user_search\":\"Cèrca d’utilizaires\",\"who_to_follow\":\"Qual seguir\",\"preferences\":\"Preferéncias\"},\"notifications\":{\"broken_favorite\":\"Estatut desconegut, sèm a lo cercar...\",\"favorited_you\":\"a aimat vòstre estatut\",\"followed_you\":\"vos a seguit\",\"load_older\":\"Cargar las notificaciones mai ancianas\",\"notifications\":\"Notficacions\",\"read\":\"Legit !\",\"repeated_you\":\"a repetit vòstre estatut\",\"no_more_notifications\":\"Pas mai de notificacions\"},\"post_status\":{\"new_status\":\"Publicar d’estatuts novèls\",\"account_not_locked_warning\":\"Vòstre compte es pas {0}. Qual que siá pòt vos seguir per veire vòstras publicacions destinadas pas qu'a vòstres seguidors.\",\"account_not_locked_warning_link\":\"clavat\",\"attachments_sensitive\":\"Marcar las pèças juntas coma sensiblas\",\"content_type\":{\"plain_text\":\"Tèxte brut\"},\"content_warning\":\"Avís de contengut (opcional)\",\"default\":\"Escrivètz aquí vòstre estatut.\",\"direct_warning\":\"Aquesta publicacion serà pas que visibla pels utilizaires mencionats.\",\"posting\":\"Mandadís\",\"scope\":{\"direct\":\"Dirècte - Publicar pels utilizaires mencionats solament\",\"private\":\"Seguidors solament - Publicar pels sols seguidors\",\"public\":\"Public - Publicar pel flux d’actualitat public\",\"unlisted\":\"Pas listat - Publicar pas pel flux public\"}},\"registration\":{\"bio\":\"Biografia\",\"email\":\"Adreça de corrièl\",\"fullname\":\"Nom complèt\",\"password_confirm\":\"Confirmar lo senhal\",\"registration\":\"Inscripcion\",\"token\":\"Geton de convidat\",\"captcha\":\"CAPTCHA\",\"new_captcha\":\"Clicatz l’imatge per obténer una nòva captcha\",\"username_placeholder\":\"e.g. lain\",\"fullname_placeholder\":\"e.g. Lain Iwakura\",\"bio_placeholder\":\"e.g.\\nHi, Soi lo Lain\\nSoi afocada d’animes e vivi al Japan. Benlèu que me coneissètz de the Wired.\",\"validations\":{\"username_required\":\"pòt pas èsser void\",\"fullname_required\":\"pòt pas èsser void\",\"email_required\":\"pòt pas èsser void\",\"password_required\":\"pòt pas èsser void\",\"password_confirmation_required\":\"pòt pas èsser void\",\"password_confirmation_match\":\"deu èsser lo meteis senhal\"}},\"settings\":{\"app_name\":\"Nom de l’aplicacion\",\"attachmentRadius\":\"Pèças juntas\",\"attachments\":\"Pèças juntas\",\"autoload\":\"Activar lo cargament automatic un còp arribat al cap de la pagina\",\"avatar\":\"Avatar\",\"avatarAltRadius\":\"Avatars (Notificacions)\",\"avatarRadius\":\"Avatars\",\"background\":\"Rèire plan\",\"bio\":\"Biografia\",\"blocks_tab\":\"Blocatges\",\"btnRadius\":\"Botons\",\"cBlue\":\"Blau (Respondre, seguir)\",\"cGreen\":\"Verd (Repartajar)\",\"cOrange\":\"Irange (Aimar)\",\"cRed\":\"Roge (Anullar)\",\"change_password\":\"Cambiar lo senhal\",\"change_password_error\":\"Una error s’es producha en cambiant lo senhal.\",\"changed_password\":\"Senhal corrèctament cambiat !\",\"collapse_subject\":\"Replegar las publicacions amb de subjèctes\",\"composing\":\"Escritura\",\"confirm_new_password\":\"Confirmatz lo nòu senhal\",\"current_avatar\":\"Vòstre avatar actual\",\"current_password\":\"Senhal actual\",\"current_profile_banner\":\"Bandièra actuala del perfil\",\"data_import_export_tab\":\"Importar / Exportar las donadas\",\"default_vis\":\"Nivèl de visibilitat per defaut\",\"delete_account\":\"Suprimir lo compte\",\"delete_account_description\":\"Suprimir vòstre compte e los messatges per sempre.\",\"delete_account_error\":\"Una error s’es producha en suprimir lo compte. S’aquò ten d’arribar mercés de contactar vòstre administrador d’instància.\",\"delete_account_instructions\":\"Picatz vòstre senhal dins lo camp tèxte çai-jos per confirmar la supression del compte.\",\"avatar_size_instruction\":\"La talha minimum recomandada pels imatges d’avatar es 150x150 pixèls.\",\"export_theme\":\"Enregistrar la preconfiguracion\",\"filtering\":\"Filtratge\",\"filtering_explanation\":\"Totes los estatuts amb aqueles mots seràn en silenci, un mot per linha\",\"follow_export\":\"Exportar los abonaments\",\"follow_export_button\":\"Exportar vòstres abonaments dins un fichièr csv\",\"follow_export_processing\":\"Tractament, vos demandarem lèu de telecargar lo fichièr\",\"follow_import\":\"Importar los abonaments\",\"follow_import_error\":\"Error en important los seguidors\",\"follows_imported\":\"Seguidors importats. Lo tractament pòt trigar una estona.\",\"foreground\":\"Endavant\",\"general\":\"General\",\"hide_attachments_in_convo\":\"Rescondre las pèças juntas dins las conversacions\",\"hide_attachments_in_tl\":\"Rescondre las pèças juntas\",\"max_thumbnails\":\"Nombre maximum de vinhetas per publicacion\",\"hide_isp\":\"Amagar lo panèl especial instància\",\"preload_images\":\"Precargar los imatges\",\"use_one_click_nsfw\":\"Dobrir las pèças juntas NSFW amb un clic\",\"hide_post_stats\":\"Amagar los estatistics de publicacion (ex. lo ombre de favorits)\",\"hide_user_stats\":\"Amagar las estatisticas de l’utilizaire (ex. lo nombre de seguidors)\",\"hide_filtered_statuses\":\"Amagar los estatuts filtrats\",\"import_followers_from_a_csv_file\":\"Importar los seguidors d’un fichièr csv\",\"import_theme\":\"Cargar un tèma\",\"inputRadius\":\"Camps tèxte\",\"checkboxRadius\":\"Casas de marcar\",\"instance_default\":\"(defaut : {value})\",\"instance_default_simple\":\"(defaut)\",\"interface\":\"Interfàcia\",\"interfaceLanguage\":\"Lenga de l’interfàcia\",\"invalid_theme_imported\":\"Lo fichièr seleccionat es pas un tèma Pleroma valid. Cap de cambiament es estat fach a vòstre tèma.\",\"limited_availability\":\"Pas disponible per vòstre navigador\",\"links\":\"Ligams\",\"lock_account_description\":\"Limitar vòstre compte als seguidors acceptats solament\",\"loop_video\":\"Bocla vidèo\",\"loop_video_silent_only\":\"Legir en bocla solament las vidèos sens son (coma los « Gifs » de Mastodon)\",\"mutes_tab\":\"Agamats\",\"play_videos_in_modal\":\"Legir las vidèoas dirèctament dins la visualizaira mèdia\",\"use_contain_fit\":\"Talhar pas las pèças juntas per las vinhetas\",\"name\":\"Nom\",\"name_bio\":\"Nom & Bio\",\"new_password\":\"Nòu senhal\",\"notification_visibility_follows\":\"Abonaments\",\"notification_visibility_likes\":\"Aimar\",\"notification_visibility_mentions\":\"Mencions\",\"notification_visibility_repeats\":\"Repeticions\",\"notification_visibility\":\"Tipes de notificacion de mostrar\",\"no_rich_text_description\":\"Netejar lo format tèxte de totas las publicacions\",\"no_blocks\":\"Cap de blocatge\",\"no_mutes\":\"Cap d’amagat\",\"hide_follows_description\":\"Mostrar pas qual seguissi\",\"hide_followers_description\":\"Mostrar pas qual me seguisson\",\"show_admin_badge\":\"Mostrar lo badge Admin badge al perfil meu\",\"show_moderator_badge\":\"Mostrar lo badge Moderator al perfil meu\",\"nsfw_clickthrough\":\"Activar lo clic per mostrar los imatges marcats coma pels adults o sensibles\",\"oauth_tokens\":\"Listats OAuth\",\"token\":\"Geton\",\"refresh_token\":\"Actualizar lo geton\",\"valid_until\":\"Valid fins a\",\"revoke_token\":\"Revocar\",\"panelRadius\":\"Panèls\",\"pause_on_unfocused\":\"Pausar la difusion quand l’onglet es pas seleccionat\",\"presets\":\"Pre-enregistrats\",\"profile_background\":\"Imatge de fons\",\"profile_banner\":\"Bandièra del perfil\",\"profile_tab\":\"Perfil\",\"radii_help\":\"Configurar los caires arredondits de l’interfàcia (en pixèls)\",\"replies_in_timeline\":\"Responsas del flux\",\"reply_link_preview\":\"Activar l’apercebut en passar la mirga\",\"reply_visibility_all\":\"Mostrar totas las responsas\",\"reply_visibility_following\":\"Mostrar pas que las responsas que me son destinada a ieu o un utilizaire que seguissi\",\"reply_visibility_self\":\"Mostrar pas que las responsas que me son destinadas\",\"saving_err\":\"Error en enregistrant los paramètres\",\"saving_ok\":\"Paramètres enregistrats\",\"scope_copy\":\"Copiar lo nivèl de confidencialitat per las responsas (Totjorn aissí pels Messatges Dirèctes)\",\"security_tab\":\"Seguretat\",\"set_new_avatar\":\"Definir un nòu avatar\",\"set_new_profile_background\":\"Definir un nòu fons de perfil\",\"set_new_profile_banner\":\"Definir una nòva bandièra de perfil\",\"settings\":\"Paramètres\",\"subject_input_always_show\":\"Totjorn mostrar lo camp de subjècte\",\"subject_line_behavior\":\"Copiar lo subjècte per las responsas\",\"subject_line_email\":\"Coma los corrièls : \\\"re: subjècte\\\"\",\"subject_line_mastodon\":\"Coma mastodon : copiar tal coma es\",\"subject_line_noop\":\"Copiar pas\",\"post_status_content_type\":\"Publicar lo tipe de contengut dels estatuts\",\"status_content_type_plain\":\"Tèxte brut\",\"stop_gifs\":\"Lançar los GIFs al subrevòl\",\"streaming\":\"Activar lo cargament automatic dels novèls estatus en anar amont\",\"text\":\"Tèxt\",\"theme\":\"Tèma\",\"theme_help_v2_1\":\"You can also override certain component's colors and opacity by toggling the checkbox, use \\\"Clear all\\\" button to clear all overrides.\",\"theme_help_v2_2\":\"Icons underneath some entries are background/text contrast indicators, hover over for detailed info. Please keep in mind that when using transparency contrast indicators show the worst possible case.\",\"theme_help\":\"Emplegatz los còdis de color hex (#rrggbb) per personalizar vòstre tèma de color.\",\"tooltipRadius\":\"Astúcias/alèrtas\",\"upload_a_photo\":\"Enviar una fotografia\",\"user_settings\":\"Paramètres utilizaire\",\"values\":{\"false\":\"non\",\"true\":\"òc\"}},\"timeline\":{\"collapse\":\"Tampar\",\"conversation\":\"Conversacion\",\"error_fetching\":\"Error en cercant de mesas a jorn\",\"load_older\":\"Ne veire mai\",\"repeated\":\"repetit\",\"show_new\":\"Ne veire mai\",\"up_to_date\":\"A jorn\",\"no_retweet_hint\":\"La publicacion marcada coma pels seguidors solament o dirècte pòt pas èsser repetida\"},\"status\":{\"reply_to\":\"Respondre à\",\"replies_list\":\"Responsas :\"},\"user_card\":{\"approve\":\"Validar\",\"block\":\"Blocar\",\"blocked\":\"Blocat !\",\"deny\":\"Refusar\",\"favorites\":\"Favorits\",\"follow\":\"Seguir\",\"follow_sent\":\"Demanda enviada !\",\"follow_progress\":\"Demanda…\",\"follow_again\":\"Tornar enviar la demanda ?\",\"follow_unfollow\":\"Quitar de seguir\",\"followees\":\"Abonaments\",\"followers\":\"Seguidors\",\"following\":\"Seguit !\",\"follows_you\":\"Vos sèc !\",\"its_you\":\"Sètz vos !\",\"media\":\"Mèdia\",\"mute\":\"Amagar\",\"muted\":\"Amagat\",\"per_day\":\"per jorn\",\"remote_follow\":\"Seguir a distància\",\"statuses\":\"Estatuts\",\"unblock\":\"Desblocar\",\"unblock_progress\":\"Desblocatge...\",\"block_progress\":\"Blocatge...\",\"unmute\":\"Tornar mostrar\",\"unmute_progress\":\"Afichatge...\",\"mute_progress\":\"A amagar...\"},\"user_profile\":{\"timeline_title\":\"Flux utilizaire\",\"profile_does_not_exist\":\"Aqueste perfil existís pas.\",\"profile_loading_error\":\"Una error s’es producha en cargant aqueste perfil.\"},\"who_to_follow\":{\"more\":\"Mai\",\"who_to_follow\":\"Qual seguir\"},\"tool_tip\":{\"media_upload\":\"Enviar un mèdia\",\"repeat\":\"Repetir\",\"reply\":\"Respondre\",\"favorite\":\"aimar\",\"user_settings\":\"Paramètres utilizaire\"},\"upload\":{\"error\":{\"base\":\"Mandadís fracassat.\",\"file_too_big\":\"Fichièr tròp grand [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"Tornatz ensajar mai tard\"},\"file_size_units\":{\"B\":\"o\",\"KiB\":\"Kio\",\"MiB\":\"Mio\",\"GiB\":\"Gio\",\"TiB\":\"Tio\"}}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/oc.json\n// module id = 450\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Czat\"},\"finder\":{\"error_fetching_user\":\"Błąd przy pobieraniu profilu\",\"find_user\":\"Znajdź użytkownika\"},\"general\":{\"apply\":\"Zastosuj\",\"submit\":\"Wyślij\"},\"login\":{\"login\":\"Zaloguj\",\"logout\":\"Wyloguj\",\"password\":\"Hasło\",\"placeholder\":\"n.p. lain\",\"register\":\"Zarejestruj\",\"username\":\"Użytkownik\"},\"nav\":{\"chat\":\"Lokalny czat\",\"mentions\":\"Wzmianki\",\"public_tl\":\"Publiczna oś czasu\",\"timeline\":\"Oś czasu\",\"twkn\":\"Cała znana sieć\"},\"notifications\":{\"favorited_you\":\"dodał twój status do ulubionych\",\"followed_you\":\"obserwuje cię\",\"notifications\":\"Powiadomienia\",\"read\":\"Przeczytane!\",\"repeated_you\":\"powtórzył twój status\"},\"post_status\":{\"default\":\"Właśnie wróciłem z kościoła\",\"posting\":\"Wysyłanie\"},\"registration\":{\"bio\":\"Bio\",\"email\":\"Email\",\"fullname\":\"Wyświetlana nazwa profilu\",\"password_confirm\":\"Potwierdzenie hasła\",\"registration\":\"Rejestracja\"},\"settings\":{\"attachmentRadius\":\"Załączniki\",\"attachments\":\"Załączniki\",\"autoload\":\"Włącz automatyczne ładowanie po przewinięciu do końca strony\",\"avatar\":\"Awatar\",\"avatarAltRadius\":\"Awatary (powiadomienia)\",\"avatarRadius\":\"Awatary\",\"background\":\"Tło\",\"bio\":\"Bio\",\"btnRadius\":\"Przyciski\",\"cBlue\":\"Niebieski (odpowiedz, obserwuj)\",\"cGreen\":\"Zielony (powtórzenia)\",\"cOrange\":\"Pomarańczowy (ulubione)\",\"cRed\":\"Czerwony (anuluj)\",\"change_password\":\"Zmień hasło\",\"change_password_error\":\"Podczas zmiany hasła wystąpił problem.\",\"changed_password\":\"Hasło zmienione poprawnie!\",\"confirm_new_password\":\"Potwierdź nowe hasło\",\"current_avatar\":\"Twój obecny awatar\",\"current_password\":\"Obecne hasło\",\"current_profile_banner\":\"Twój obecny banner profilu\",\"delete_account\":\"Usuń konto\",\"delete_account_description\":\"Trwale usuń konto i wszystkie posty.\",\"delete_account_error\":\"Wystąpił problem z usuwaniem twojego konta. Jeżeli problem powtarza się, poinformuj administratora swojej instancji.\",\"delete_account_instructions\":\"Wprowadź swoje hasło w poniższe pole aby potwierdzić usunięcie konta.\",\"filtering\":\"Filtrowanie\",\"filtering_explanation\":\"Wszystkie statusy zawierające te słowa będą wyciszone. Jedno słowo na linijkę.\",\"follow_export\":\"Eksport obserwowanych\",\"follow_export_button\":\"Eksportuj swoją listę obserwowanych do pliku CSV\",\"follow_export_processing\":\"Przetwarzanie, wkrótce twój plik zacznie się ściągać.\",\"follow_import\":\"Import obserwowanych\",\"follow_import_error\":\"Błąd przy importowaniu obserwowanych\",\"follows_imported\":\"Obserwowani zaimportowani! Przetwarzanie może trochę potrwać.\",\"foreground\":\"Pierwszy plan\",\"hide_attachments_in_convo\":\"Ukryj załączniki w rozmowach\",\"hide_attachments_in_tl\":\"Ukryj załączniki w osi czasu\",\"import_followers_from_a_csv_file\":\"Importuj obserwowanych z pliku CSV\",\"inputRadius\":\"Pola tekstowe\",\"links\":\"Łącza\",\"name\":\"Imię\",\"name_bio\":\"Imię i bio\",\"new_password\":\"Nowe hasło\",\"nsfw_clickthrough\":\"Włącz domyślne ukrywanie załączników o treści nieprzyzwoitej (NSFW)\",\"oauth_tokens\":\"Tokeny OAuth\",\"token\":\"Token\",\"refresh_token\":\"Odśwież token\",\"valid_until\":\"Ważne do\",\"revoke_token\":\"Odwołać\",\"panelRadius\":\"Panele\",\"presets\":\"Gotowe motywy\",\"profile_background\":\"Tło profilu\",\"profile_banner\":\"Banner profilu\",\"radii_help\":\"Ustaw zaokrąglenie krawędzi interfejsu (w pikselach)\",\"reply_link_preview\":\"Włącz dymek z podglądem postu po najechaniu na znak odpowiedzi\",\"set_new_avatar\":\"Ustaw nowy awatar\",\"set_new_profile_background\":\"Ustaw nowe tło profilu\",\"set_new_profile_banner\":\"Ustaw nowy banner profilu\",\"settings\":\"Ustawienia\",\"stop_gifs\":\"Odtwarzaj GIFy po najechaniu kursorem\",\"streaming\":\"Włącz automatycznie strumieniowanie nowych postów gdy na początku strony\",\"text\":\"Tekst\",\"theme\":\"Motyw\",\"theme_help\":\"Użyj kolorów w notacji szesnastkowej (#rrggbb), by stworzyć swój motyw.\",\"tooltipRadius\":\"Etykiety/alerty\",\"user_settings\":\"Ustawienia użytkownika\"},\"timeline\":{\"collapse\":\"Zwiń\",\"conversation\":\"Rozmowa\",\"error_fetching\":\"Błąd pobierania\",\"load_older\":\"Załaduj starsze statusy\",\"repeated\":\"powtórzono\",\"show_new\":\"Pokaż nowe\",\"up_to_date\":\"Na bieżąco\"},\"user_card\":{\"block\":\"Zablokuj\",\"blocked\":\"Zablokowany!\",\"follow\":\"Obserwuj\",\"followees\":\"Obserwowani\",\"followers\":\"Obserwujący\",\"following\":\"Obserwowany!\",\"follows_you\":\"Obserwuje cię!\",\"mute\":\"Wycisz\",\"muted\":\"Wyciszony\",\"per_day\":\"dziennie\",\"remote_follow\":\"Zdalna obserwacja\",\"statuses\":\"Statusy\"},\"user_profile\":{\"timeline_title\":\"Oś czasu użytkownika\"}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/pl.json\n// module id = 451\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Chat\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Proxy de mídia\",\"scope_options\":\"Opções de privacidade\",\"text_limit\":\"Limite de caracteres\",\"title\":\"Funções\",\"who_to_follow\":\"Quem seguir\"},\"finder\":{\"error_fetching_user\":\"Erro ao procurar usuário\",\"find_user\":\"Buscar usuário\"},\"general\":{\"apply\":\"Aplicar\",\"submit\":\"Enviar\",\"more\":\"Mais\",\"generic_error\":\"Houve um erro\",\"optional\":\"opcional\"},\"image_cropper\":{\"crop_picture\":\"Cortar imagem\",\"save\":\"Salvar\",\"cancel\":\"Cancelar\"},\"login\":{\"login\":\"Entrar\",\"description\":\"Entrar com OAuth\",\"logout\":\"Sair\",\"password\":\"Senha\",\"placeholder\":\"p.e. lain\",\"register\":\"Registrar\",\"username\":\"Usuário\",\"hint\":\"Entre para participar da discussão\"},\"media_modal\":{\"previous\":\"Anterior\",\"next\":\"Próximo\"},\"nav\":{\"about\":\"Sobre\",\"back\":\"Voltar\",\"chat\":\"Chat local\",\"friend_requests\":\"Solicitações de seguidores\",\"mentions\":\"Menções\",\"dms\":\"Mensagens diretas\",\"public_tl\":\"Linha do tempo pública\",\"timeline\":\"Linha do tempo\",\"twkn\":\"Toda a rede conhecida\",\"user_search\":\"Busca de usuário\",\"who_to_follow\":\"Quem seguir\",\"preferences\":\"Preferências\"},\"notifications\":{\"broken_favorite\":\"Status desconhecido, buscando...\",\"favorited_you\":\"favoritou sua postagem\",\"followed_you\":\"seguiu você\",\"load_older\":\"Carregar notificações antigas\",\"notifications\":\"Notificações\",\"read\":\"Lido!\",\"repeated_you\":\"repetiu sua postagem\",\"no_more_notifications\":\"Mais nenhuma notificação\"},\"post_status\":{\"new_status\":\"Postar novo status\",\"account_not_locked_warning\":\"Sua conta não está {0}. Qualquer pessoa pode te seguir para ver seus posts restritos.\",\"account_not_locked_warning_link\":\"fechada\",\"attachments_sensitive\":\"Marcar anexos como sensíveis\",\"content_type\":{\"plain_text\":\"Texto puro\"},\"content_warning\":\"Assunto (opcional)\",\"default\":\"Acabei de chegar no Rio!\",\"direct_warning\":\"Este post será visível apenas para os usuários mencionados.\",\"posting\":\"Publicando\",\"scope\":{\"direct\":\"Direto - Enviar somente aos usuários mencionados\",\"private\":\"Apenas para seguidores - Enviar apenas para seguidores\",\"public\":\"Público - Enviar a linhas do tempo públicas\",\"unlisted\":\"Não listado - Não enviar a linhas do tempo públicas\"}},\"registration\":{\"bio\":\"Biografia\",\"email\":\"Correio eletrônico\",\"fullname\":\"Nome para exibição\",\"password_confirm\":\"Confirmação de senha\",\"registration\":\"Registro\",\"token\":\"Código do convite\",\"captcha\":\"CAPTCHA\",\"new_captcha\":\"Clique na imagem para carregar um novo captcha\",\"username_placeholder\":\"p. ex. lain\",\"fullname_placeholder\":\"p. ex. Lain Iwakura\",\"bio_placeholder\":\"e.g.\\nOi, sou Lain\\nSou uma garota que vive no subúrbio do Japão. Você deve me conhecer da Rede.\",\"validations\":{\"username_required\":\"não pode ser deixado em branco\",\"fullname_required\":\"não pode ser deixado em branco\",\"email_required\":\"não pode ser deixado em branco\",\"password_required\":\"não pode ser deixado em branco\",\"password_confirmation_required\":\"não pode ser deixado em branco\",\"password_confirmation_match\":\"deve ser idêntica à senha\"}},\"settings\":{\"app_name\":\"Nome do aplicativo\",\"attachmentRadius\":\"Anexos\",\"attachments\":\"Anexos\",\"autoload\":\"Habilitar carregamento automático quando a rolagem chegar ao fim.\",\"avatar\":\"Avatar\",\"avatarAltRadius\":\"Avatares (Notificações)\",\"avatarRadius\":\"Avatares\",\"background\":\"Pano de Fundo\",\"bio\":\"Biografia\",\"blocks_tab\":\"Blocos\",\"btnRadius\":\"Botões\",\"cBlue\":\"Azul (Responder, seguir)\",\"cGreen\":\"Verde (Repetir)\",\"cOrange\":\"Laranja (Favoritar)\",\"cRed\":\"Vermelho (Cancelar)\",\"change_password\":\"Mudar senha\",\"change_password_error\":\"Houve um erro ao modificar sua senha.\",\"changed_password\":\"Senha modificada com sucesso!\",\"collapse_subject\":\"Esconder posts com assunto\",\"composing\":\"Escrevendo\",\"confirm_new_password\":\"Confirmar nova senha\",\"current_avatar\":\"Seu avatar atual\",\"current_password\":\"Sua senha atual\",\"current_profile_banner\":\"Sua capa de perfil atual\",\"data_import_export_tab\":\"Importação/exportação de dados\",\"default_vis\":\"Opção de privacidade padrão\",\"delete_account\":\"Deletar conta\",\"delete_account_description\":\"Deletar sua conta e mensagens permanentemente.\",\"delete_account_error\":\"Houve um problema ao deletar sua conta. Se ele persistir, por favor entre em contato com o/a administrador/a da instância.\",\"delete_account_instructions\":\"Digite sua senha no campo abaixo para confirmar a exclusão da conta.\",\"avatar_size_instruction\":\"O tamanho mínimo recomendado para imagens de avatar é 150x150 pixels.\",\"export_theme\":\"Salvar predefinições\",\"filtering\":\"Filtragem\",\"filtering_explanation\":\"Todas as postagens contendo estas palavras serão silenciadas, uma por linha.\",\"follow_export\":\"Exportar quem você segue\",\"follow_export_button\":\"Exportar quem você segue para um arquivo CSV\",\"follow_export_processing\":\"Processando. Em breve você receberá a solicitação de download do arquivo\",\"follow_import\":\"Importar quem você segue\",\"follow_import_error\":\"Erro ao importar seguidores\",\"follows_imported\":\"Seguidores importados! O processamento pode demorar um pouco.\",\"foreground\":\"Primeiro Plano\",\"general\":\"Geral\",\"hide_attachments_in_convo\":\"Ocultar anexos em conversas\",\"hide_attachments_in_tl\":\"Ocultar anexos na linha do tempo.\",\"max_thumbnails\":\"Número máximo de miniaturas por post\",\"hide_isp\":\"Esconder painel específico da instância\",\"preload_images\":\"Pré-carregar imagens\",\"use_one_click_nsfw\":\"Abrir anexos sensíveis com um clique\",\"hide_post_stats\":\"Esconder estatísticas de posts (p. ex. número de favoritos)\",\"hide_user_stats\":\"Esconder estatísticas do usuário (p. ex. número de seguidores)\",\"hide_filtered_statuses\":\"Esconder posts filtrados\",\"import_followers_from_a_csv_file\":\"Importe seguidores a partir de um arquivo CSV\",\"import_theme\":\"Carregar pré-definição\",\"inputRadius\":\"Campos de entrada\",\"checkboxRadius\":\"Checkboxes\",\"instance_default\":\"(padrão: {value})\",\"instance_default_simple\":\"(padrão)\",\"interface\":\"Interface\",\"interfaceLanguage\":\"Idioma da interface\",\"invalid_theme_imported\":\"O arquivo selecionado não é um tema compatível com o Pleroma. Nenhuma mudança no tema foi feita.\",\"limited_availability\":\"Indisponível para seu navegador\",\"links\":\"Links\",\"lock_account_description\":\"Restringir sua conta a seguidores aprovados\",\"loop_video\":\"Repetir vídeos\",\"loop_video_silent_only\":\"Repetir apenas vídeos sem som (como os \\\"gifs\\\" do Mastodon)\",\"mutes_tab\":\"Silenciados\",\"play_videos_in_modal\":\"Tocar vídeos diretamente no visualizador de mídia\",\"use_contain_fit\":\"Não cortar o anexo na miniatura\",\"name\":\"Nome\",\"name_bio\":\"Nome & Biografia\",\"new_password\":\"Nova senha\",\"notification_visibility\":\"Tipos de notificação para mostrar\",\"notification_visibility_follows\":\"Seguidos\",\"notification_visibility_likes\":\"Favoritos\",\"notification_visibility_mentions\":\"Menções\",\"notification_visibility_repeats\":\"Repetições\",\"no_rich_text_description\":\"Remover formatação de todos os posts\",\"no_blocks\":\"Sem bloqueios\",\"no_mutes\":\"Sem silenciados\",\"hide_follows_description\":\"Não mostrar quem estou seguindo\",\"hide_followers_description\":\"Não mostrar quem me segue\",\"show_admin_badge\":\"Mostrar distintivo de Administrador em meu perfil\",\"show_moderator_badge\":\"Mostrar título de Moderador em meu perfil\",\"nsfw_clickthrough\":\"Habilitar clique para ocultar anexos sensíveis\",\"oauth_tokens\":\"Token OAuth\",\"token\":\"Token\",\"refresh_token\":\"Atualizar Token\",\"valid_until\":\"Válido até\",\"revoke_token\":\"Revogar\",\"panelRadius\":\"Paineis\",\"pause_on_unfocused\":\"Parar transmissão quando a aba não estiver em primeiro plano\",\"presets\":\"Predefinições\",\"profile_background\":\"Pano de fundo de perfil\",\"profile_banner\":\"Capa de perfil\",\"profile_tab\":\"Perfil\",\"radii_help\":\"Arredondar arestas da interface (em píxeis)\",\"replies_in_timeline\":\"Respostas na linha do tempo\",\"reply_link_preview\":\"Habilitar a pré-visualização de link de respostas ao passar o mouse.\",\"reply_visibility_all\":\"Mostrar todas as respostas\",\"reply_visibility_following\":\"Só mostrar respostas direcionadas a mim ou a usuários que sigo\",\"reply_visibility_self\":\"Só mostrar respostas direcionadas a mim\",\"saving_err\":\"Erro ao salvar configurações\",\"saving_ok\":\"Configurações salvas\",\"security_tab\":\"Segurança\",\"scope_copy\":\"Copiar opções de privacidade ao responder (Mensagens diretas sempre copiam)\",\"set_new_avatar\":\"Alterar avatar\",\"set_new_profile_background\":\"Alterar o plano de fundo de perfil\",\"set_new_profile_banner\":\"Alterar capa de perfil\",\"settings\":\"Configurações\",\"subject_input_always_show\":\"Sempre mostrar campo de assunto\",\"subject_line_behavior\":\"Copiar assunto ao responder\",\"subject_line_email\":\"Como em email: \\\"re: assunto\\\"\",\"subject_line_mastodon\":\"Como o Mastodon: copiar como está\",\"subject_line_noop\":\"Não copiar\",\"post_status_content_type\":\"Postar tipo de conteúdo do status\",\"status_content_type_plain\":\"Texto puro\",\"stop_gifs\":\"Reproduzir GIFs ao passar o cursor em cima\",\"streaming\":\"Habilitar o fluxo automático de postagens quando ao topo da página\",\"text\":\"Texto\",\"theme\":\"Tema\",\"theme_help\":\"Use cores em código hexadecimal (#rrggbb) para personalizar seu esquema de cores.\",\"theme_help_v2_1\":\"Você também pode sobrescrever as cores e opacidade de alguns componentes ao modificar o checkbox, use \\\"Limpar todos\\\" para limpar todas as modificações.\",\"theme_help_v2_2\":\"Alguns ícones sob registros são indicadores de fundo/contraste de textos, passe por cima para informações detalhadas. Tenha ciência de que os indicadores de contraste não funcionam muito bem com transparência.\",\"tooltipRadius\":\"Dicas/alertas\",\"upload_a_photo\":\"Enviar uma foto\",\"user_settings\":\"Configurações de Usuário\",\"values\":{\"false\":\"não\",\"true\":\"sim\"},\"notifications\":\"Notifications\",\"enable_web_push_notifications\":\"Habilitar notificações web push\",\"style\":{\"switcher\":{\"keep_color\":\"Manter cores\",\"keep_shadows\":\"Manter sombras\",\"keep_opacity\":\"Manter opacidade\",\"keep_roundness\":\"Manter arredondado\",\"keep_fonts\":\"Manter fontes\",\"save_load_hint\":\"Manter as opções preserva as opções atuais ao selecionar ou carregar temas; também salva as opções ao exportar um tempo. Quanto todos os campos estiverem desmarcados, tudo será salvo ao exportar o tema.\",\"reset\":\"Voltar ao padrão\",\"clear_all\":\"Limpar tudo\",\"clear_opacity\":\"Limpar opacidade\"},\"common\":{\"color\":\"Cor\",\"opacity\":\"Opacidade\",\"contrast\":{\"hint\":\"A taxa de contraste é {ratio}, {level} {context}\",\"level\":{\"aa\":\"padrão Nível AA (mínimo)\",\"aaa\":\"padrão Nível AAA (recomendado)\",\"bad\":\"nenhum padrão de acessibilidade\"},\"context\":{\"18pt\":\"para textos longos (18pt+)\",\"text\":\"para texto\"}}},\"common_colors\":{\"_tab_label\":\"Comum\",\"main\":\"Cores Comuns\",\"foreground_hint\":\"Configurações mais detalhadas na aba\\\"Avançado\\\"\",\"rgbo\":\"Ícones, acentuação, distintivos\"},\"advanced_colors\":{\"_tab_label\":\"Avançado\",\"alert\":\"Fundo de alerta\",\"alert_error\":\"Erro\",\"badge\":\"Fundo do distintivo\",\"badge_notification\":\"Notificação\",\"panel_header\":\"Topo do painel\",\"top_bar\":\"Barra do topo\",\"borders\":\"Bordas\",\"buttons\":\"Botões\",\"inputs\":\"Caixas de entrada\",\"faint_text\":\"Texto esmaecido\"},\"radii\":{\"_tab_label\":\"Arredondado\"},\"shadows\":{\"_tab_label\":\"Luz e sombra\",\"component\":\"Componente\",\"override\":\"Sobrescrever\",\"shadow_id\":\"Sombra #{value}\",\"blur\":\"Borrado\",\"spread\":\"Difusão\",\"inset\":\"Inserção\",\"hint\":\"Para as sombras você também pode usar --variável como valor de cor para utilizar variáveis do CSS3. Tenha em mente que configurar a opacidade não será possível neste caso.\",\"filter_hint\":{\"always_drop_shadow\":\"Atenção, esta sombra sempre utiliza {0} quando compatível com o navegador.\",\"drop_shadow_syntax\":\"{0} não é compatível com o parâmetro {1} e a palavra-chave {2}.\",\"avatar_inset\":\"Tenha em mente que combinar as sombras de inserção e a não-inserção em avatares pode causar resultados inesperados em avatares transparentes.\",\"spread_zero\":\"Sombras com uma difusão > 0 aparecerão como se fossem definidas como 0.\",\"inset_classic\":\"Sombras de inserção utilizarão {0}\"},\"components\":{\"panel\":\"Painel\",\"panelHeader\":\"Topo do painel\",\"topBar\":\"Barra do topo\",\"avatar\":\"Avatar do usuário (na visualização do perfil)\",\"avatarStatus\":\"Avatar do usuário (na exibição de posts)\",\"popup\":\"Dicas e notificações\",\"button\":\"Botão\",\"buttonHover\":\"Botão (em cima)\",\"buttonPressed\":\"Botão (pressionado)\",\"buttonPressedHover\":\"Botão (pressionado+em cima)\",\"input\":\"Campo de entrada\"}},\"fonts\":{\"_tab_label\":\"Fontes\",\"help\":\"Selecionar fonte dos elementos da interface. Para fonte \\\"personalizada\\\" você deve entrar exatamente o nome da fonte no sistema.\",\"components\":{\"interface\":\"Interface\",\"input\":\"Campo de entrada\",\"post\":\"Postar texto\",\"postCode\":\"Texto monoespaçado em post (formatação rica)\"},\"family\":\"Nome da fonte\",\"size\":\"Tamanho (em px)\",\"weight\":\"Peso\",\"custom\":\"Personalizada\"},\"preview\":{\"header\":\"Pré-visualizar\",\"content\":\"Conteúdo\",\"error\":\"Erro de exemplo\",\"button\":\"Botão\",\"text\":\"Vários {0} e {1}\",\"mono\":\"conteúdo\",\"input\":\"Acabei de chegar no Rio!\",\"faint_link\":\"manual útil\",\"fine_print\":\"Leia nosso {0} para não aprender nada!\",\"header_faint\":\"Está ok!\",\"checkbox\":\"Li os termos e condições\",\"link\":\"um belo link\"}}},\"timeline\":{\"collapse\":\"Esconder\",\"conversation\":\"Conversa\",\"error_fetching\":\"Erro ao buscar atualizações\",\"load_older\":\"Carregar postagens antigas\",\"no_retweet_hint\":\"Posts apenas para seguidores ou diretos não podem ser repetidos\",\"repeated\":\"Repetido\",\"show_new\":\"Mostrar novas\",\"up_to_date\":\"Atualizado\",\"no_more_statuses\":\"Sem mais posts\",\"no_statuses\":\"Sem posts\"},\"status\":{\"reply_to\":\"Responder a\",\"replies_list\":\"Respostas:\"},\"user_card\":{\"approve\":\"Aprovar\",\"block\":\"Bloquear\",\"blocked\":\"Bloqueado!\",\"deny\":\"Negar\",\"favorites\":\"Favoritos\",\"follow\":\"Seguir\",\"follow_sent\":\"Pedido enviado!\",\"follow_progress\":\"Enviando…\",\"follow_again\":\"Enviar solicitação novamente?\",\"follow_unfollow\":\"Deixar de seguir\",\"followees\":\"Seguindo\",\"followers\":\"Seguidores\",\"following\":\"Seguindo!\",\"follows_you\":\"Segue você!\",\"its_you\":\"É você!\",\"media\":\"Mídia\",\"mute\":\"Silenciar\",\"muted\":\"Silenciado\",\"per_day\":\"por dia\",\"remote_follow\":\"Seguidor Remoto\",\"statuses\":\"Postagens\",\"unblock\":\"Desbloquear\",\"unblock_progress\":\"Desbloqueando...\",\"block_progress\":\"Bloqueando...\",\"unmute\":\"Retirar silêncio\",\"unmute_progress\":\"Retirando silêncio...\",\"mute_progress\":\"Silenciando...\"},\"user_profile\":{\"timeline_title\":\"Linha do tempo do usuário\",\"profile_does_not_exist\":\"Desculpe, este perfil não existe.\",\"profile_loading_error\":\"Desculpe, houve um erro ao carregar este perfil.\"},\"who_to_follow\":{\"more\":\"Mais\",\"who_to_follow\":\"Quem seguir\"},\"tool_tip\":{\"media_upload\":\"Envio de mídia\",\"repeat\":\"Repetir\",\"reply\":\"Responder\",\"favorite\":\"Favoritar\",\"user_settings\":\"Configurações do usuário\"},\"upload\":{\"error\":{\"base\":\"Falha no envio.\",\"file_too_big\":\"Arquivo grande demais [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"Tente novamente mais tarde\"},\"file_size_units\":{\"B\":\"B\",\"KiB\":\"KiB\",\"MiB\":\"MiB\",\"GiB\":\"GiB\",\"TiB\":\"TiB\"}}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/pt.json\n// module id = 452\n// module chunks = 2","module.exports = {\"finder\":{\"error_fetching_user\":\"Eroare la preluarea utilizatorului\",\"find_user\":\"Găsește utilizator\"},\"general\":{\"submit\":\"trimite\"},\"login\":{\"login\":\"Loghează\",\"logout\":\"Deloghează\",\"password\":\"Parolă\",\"placeholder\":\"d.e. lain\",\"register\":\"Înregistrare\",\"username\":\"Nume utilizator\"},\"nav\":{\"mentions\":\"Menționări\",\"public_tl\":\"Cronologie Publică\",\"timeline\":\"Cronologie\",\"twkn\":\"Toată Reșeaua Cunoscută\"},\"notifications\":{\"followed_you\":\"te-a urmărit\",\"notifications\":\"Notificări\",\"read\":\"Citit!\"},\"post_status\":{\"default\":\"Nu de mult am aterizat în L.A.\",\"posting\":\"Postează\"},\"registration\":{\"bio\":\"Bio\",\"email\":\"Email\",\"fullname\":\"Numele întreg\",\"password_confirm\":\"Cofirmă parola\",\"registration\":\"Îregistrare\"},\"settings\":{\"attachments\":\"Atașamente\",\"autoload\":\"Permite încărcarea automată când scrolat la capăt\",\"avatar\":\"Avatar\",\"bio\":\"Bio\",\"current_avatar\":\"Avatarul curent\",\"current_profile_banner\":\"Bannerul curent al profilului\",\"filtering\":\"Filtru\",\"filtering_explanation\":\"Toate stările care conțin aceste cuvinte vor fi puse pe mut, una pe linie\",\"hide_attachments_in_convo\":\"Ascunde atașamentele în conversații\",\"hide_attachments_in_tl\":\"Ascunde atașamentele în cronologie\",\"name\":\"Nume\",\"name_bio\":\"Nume și Bio\",\"nsfw_clickthrough\":\"Permite ascunderea al atașamentelor NSFW\",\"profile_background\":\"Fundalul de profil\",\"profile_banner\":\"Banner de profil\",\"reply_link_preview\":\"Permite previzualizarea linkului de răspuns la planarea de mouse\",\"set_new_avatar\":\"Setează avatar nou\",\"set_new_profile_background\":\"Setează fundal nou\",\"set_new_profile_banner\":\"Setează banner nou la profil\",\"settings\":\"Setări\",\"theme\":\"Temă\",\"user_settings\":\"Setările utilizatorului\"},\"timeline\":{\"conversation\":\"Conversație\",\"error_fetching\":\"Erare la preluarea actualizărilor\",\"load_older\":\"Încarcă stări mai vechi\",\"show_new\":\"Arată cele noi\",\"up_to_date\":\"La zi\"},\"user_card\":{\"block\":\"Blochează\",\"blocked\":\"Blocat!\",\"follow\":\"Urmărește\",\"followees\":\"Urmărește\",\"followers\":\"Următori\",\"following\":\"Urmărit!\",\"follows_you\":\"Te urmărește!\",\"mute\":\"Pune pe mut\",\"muted\":\"Pus pe mut\",\"per_day\":\"pe zi\",\"statuses\":\"Stări\"}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/ro.json\n// module id = 453\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Чат\"},\"finder\":{\"error_fetching_user\":\"Пользователь не найден\",\"find_user\":\"Найти пользователя\"},\"general\":{\"apply\":\"Применить\",\"submit\":\"Отправить\"},\"login\":{\"login\":\"Войти\",\"logout\":\"Выйти\",\"password\":\"Пароль\",\"placeholder\":\"e.c. lain\",\"register\":\"Зарегистрироваться\",\"username\":\"Имя пользователя\"},\"nav\":{\"back\":\"Назад\",\"chat\":\"Локальный чат\",\"mentions\":\"Упоминания\",\"public_tl\":\"Публичная лента\",\"timeline\":\"Лента\",\"twkn\":\"Федеративная лента\"},\"notifications\":{\"broken_favorite\":\"Неизвестный статус, ищем...\",\"favorited_you\":\"нравится ваш статус\",\"followed_you\":\"начал(а) читать вас\",\"load_older\":\"Загрузить старые уведомления\",\"notifications\":\"Уведомления\",\"read\":\"Прочесть\",\"repeated_you\":\"повторил(а) ваш статус\"},\"post_status\":{\"account_not_locked_warning\":\"Ваш аккаунт не {0}. Кто угодно может зафоловить вас чтобы прочитать посты только для подписчиков\",\"account_not_locked_warning_link\":\"залочен\",\"attachments_sensitive\":\"Вложения содержат чувствительный контент\",\"content_warning\":\"Тема (не обязательно)\",\"default\":\"Что нового?\",\"direct_warning\":\"Этот пост будет видет только упомянутым пользователям\",\"posting\":\"Отправляется\",\"scope\":{\"direct\":\"Личное - этот пост видят только те кто в нём упомянут\",\"private\":\"Для подписчиков - этот пост видят только подписчики\",\"public\":\"Публичный - этот пост виден всем\",\"unlisted\":\"Непубличный - этот пост не виден на публичных лентах\"}},\"registration\":{\"bio\":\"Описание\",\"email\":\"Email\",\"fullname\":\"Отображаемое имя\",\"password_confirm\":\"Подтверждение пароля\",\"registration\":\"Регистрация\",\"token\":\"Код приглашения\",\"validations\":{\"username_required\":\"не должно быть пустым\",\"fullname_required\":\"не должно быть пустым\",\"email_required\":\"не должен быть пустым\",\"password_required\":\"не должен быть пустым\",\"password_confirmation_required\":\"не должно быть пустым\",\"password_confirmation_match\":\"должно совпадать с паролем\"}},\"settings\":{\"attachmentRadius\":\"Прикреплённые файлы\",\"attachments\":\"Вложения\",\"autoload\":\"Включить автоматическую загрузку при прокрутке вниз\",\"avatar\":\"Аватар\",\"avatarAltRadius\":\"Аватары в уведомлениях\",\"avatarRadius\":\"Аватары\",\"background\":\"Фон\",\"bio\":\"Описание\",\"btnRadius\":\"Кнопки\",\"cBlue\":\"Ответить, читать\",\"cGreen\":\"Повторить\",\"cOrange\":\"Нравится\",\"cRed\":\"Отменить\",\"change_password\":\"Сменить пароль\",\"change_password_error\":\"Произошла ошибка при попытке изменить пароль.\",\"changed_password\":\"Пароль изменён успешно.\",\"collapse_subject\":\"Сворачивать посты с темой\",\"confirm_new_password\":\"Подтверждение нового пароля\",\"current_avatar\":\"Текущий аватар\",\"current_password\":\"Текущий пароль\",\"current_profile_banner\":\"Текущий баннер профиля\",\"data_import_export_tab\":\"Импорт / Экспорт данных\",\"delete_account\":\"Удалить аккаунт\",\"delete_account_description\":\"Удалить ваш аккаунт и все ваши сообщения.\",\"delete_account_error\":\"Возникла ошибка в процессе удаления вашего аккаунта. Если это повторяется, свяжитесь с администратором вашего сервера.\",\"delete_account_instructions\":\"Введите ваш пароль в поле ниже для подтверждения удаления.\",\"export_theme\":\"Сохранить Тему\",\"filtering\":\"Фильтрация\",\"filtering_explanation\":\"Все статусы, содержащие данные слова, будут игнорироваться, по одному в строке\",\"follow_export\":\"Экспортировать читаемых\",\"follow_export_button\":\"Экспортировать читаемых в файл .csv\",\"follow_export_processing\":\"Ведётся обработка, скоро вам будет предложено загрузить файл\",\"follow_import\":\"Импортировать читаемых\",\"follow_import_error\":\"Ошибка при импортировании читаемых.\",\"follows_imported\":\"Список читаемых импортирован. Обработка займёт некоторое время..\",\"foreground\":\"Передний план\",\"general\":\"Общие\",\"hide_attachments_in_convo\":\"Прятать вложения в разговорах\",\"hide_attachments_in_tl\":\"Прятать вложения в ленте\",\"hide_isp\":\"Скрыть серверную панель\",\"import_followers_from_a_csv_file\":\"Импортировать читаемых из файла .csv\",\"import_theme\":\"Загрузить Тему\",\"inputRadius\":\"Поля ввода\",\"checkboxRadius\":\"Чекбоксы\",\"interface\":\"Интерфейс\",\"interfaceLanguage\":\"Язык интерфейса\",\"limited_availability\":\"Не доступно в вашем браузере\",\"links\":\"Ссылки\",\"lock_account_description\":\"Аккаунт доступен только подтверждённым подписчикам\",\"loop_video\":\"Зациливать видео\",\"loop_video_silent_only\":\"Зацикливать только беззвучные видео (т.е. \\\"гифки\\\" с Mastodon)\",\"name\":\"Имя\",\"name_bio\":\"Имя и описание\",\"new_password\":\"Новый пароль\",\"notification_visibility\":\"Показывать уведомления\",\"notification_visibility_follows\":\"Подписки\",\"notification_visibility_likes\":\"Лайки\",\"notification_visibility_mentions\":\"Упоминания\",\"notification_visibility_repeats\":\"Повторы\",\"no_rich_text_description\":\"Убрать форматирование из всех постов\",\"hide_follows_description\":\"Не показывать кого я читаю\",\"hide_followers_description\":\"Не показывать кто читает меня\",\"show_admin_badge\":\"Показывать значок администратора в моем профиле\",\"show_moderator_badge\":\"Показывать значок модератора в моем профиле\",\"nsfw_clickthrough\":\"Включить скрытие NSFW вложений\",\"oauth_tokens\":\"OAuth токены\",\"token\":\"Токен\",\"refresh_token\":\"Рефреш токен\",\"valid_until\":\"Годен до\",\"revoke_token\":\"Удалить\",\"panelRadius\":\"Панели\",\"pause_on_unfocused\":\"Приостановить загрузку когда вкладка не в фокусе\",\"presets\":\"Пресеты\",\"profile_background\":\"Фон профиля\",\"profile_banner\":\"Баннер профиля\",\"profile_tab\":\"Профиль\",\"radii_help\":\"Скругление углов элементов интерфейса (в пикселях)\",\"replies_in_timeline\":\"Ответы в ленте\",\"reply_link_preview\":\"Включить предварительный просмотр ответа при наведении мыши\",\"reply_visibility_all\":\"Показывать все ответы\",\"reply_visibility_following\":\"Показывать только ответы мне и тех на кого я подписан\",\"reply_visibility_self\":\"Показывать только ответы мне\",\"security_tab\":\"Безопасность\",\"set_new_avatar\":\"Загрузить новый аватар\",\"set_new_profile_background\":\"Загрузить новый фон профиля\",\"set_new_profile_banner\":\"Загрузить новый баннер профиля\",\"settings\":\"Настройки\",\"subject_input_always_show\":\"Всегда показывать поле ввода темы\",\"stop_gifs\":\"Проигрывать GIF анимации только при наведении\",\"streaming\":\"Включить автоматическую загрузку новых сообщений при прокрутке вверх\",\"text\":\"Текст\",\"theme\":\"Тема\",\"theme_help\":\"Используйте шестнадцатеричные коды цветов (#rrggbb) для настройки темы.\",\"theme_help_v2_1\":\"Вы так же можете перепоределить цвета определенных компонентов нажав соотв. галочку. Используйте кнопку \\\"Очистить всё\\\" чтобы снять все переопределения\",\"theme_help_v2_2\":\"Под некоторыми полями ввода это идикаторы контрастности, наведите на них мышью чтобы узнать больше. Приспользовании прозрачности контраст расчитывается для наихудшего варианта.\",\"tooltipRadius\":\"Всплывающие подсказки/уведомления\",\"user_settings\":\"Настройки пользователя\",\"style\":{\"switcher\":{\"keep_color\":\"Оставить цвета\",\"keep_shadows\":\"Оставить тени\",\"keep_opacity\":\"Оставить прозрачность\",\"keep_roundness\":\"Оставить скругление\",\"keep_fonts\":\"Оставить шрифты\",\"save_load_hint\":\"Опции \\\"оставить...\\\" позволяют сохранить текущие настройки при выборе другой темы или импорта её из файла. Так же они влияют на то какие компоненты будут сохранены при экспорте темы. Когда все галочки сняты все компоненты будут экспортированы.\",\"reset\":\"Сбросить\",\"clear_all\":\"Очистить всё\",\"clear_opacity\":\"Очистить прозрачность\"},\"common\":{\"color\":\"Цвет\",\"opacity\":\"Прозрачность\",\"contrast\":{\"hint\":\"Уровень контраста: {ratio}, что {level} {context}\",\"level\":{\"aa\":\"соответствует гайдлайну Level AA (минимальный)\",\"aaa\":\"соответствует гайдлайну Level AAA (рекомендуемый)\",\"bad\":\"не соответствует каким либо гайдлайнам\"},\"context\":{\"18pt\":\"для крупного (18pt+) текста\",\"text\":\"для текста\"}}},\"common_colors\":{\"_tab_label\":\"Общие\",\"main\":\"Общие цвета\",\"foreground_hint\":\"См. вкладку \\\"Дополнительно\\\" для более детального контроля\",\"rgbo\":\"Иконки, акценты, ярылки\"},\"advanced_colors\":{\"_tab_label\":\"Дополнительно\",\"alert\":\"Фон уведомлений\",\"alert_error\":\"Ошибки\",\"badge\":\"Фон значков\",\"badge_notification\":\"Уведомления\",\"panel_header\":\"Заголовок панели\",\"top_bar\":\"Верняя полоска\",\"borders\":\"Границы\",\"buttons\":\"Кнопки\",\"inputs\":\"Поля ввода\",\"faint_text\":\"Маловажный текст\"},\"radii\":{\"_tab_label\":\"Скругление\"},\"shadows\":{\"_tab_label\":\"Светотень\",\"component\":\"Компонент\",\"override\":\"Переопределить\",\"shadow_id\":\"Тень №{value}\",\"blur\":\"Размытие\",\"spread\":\"Разброс\",\"inset\":\"Внутренняя\",\"hint\":\"Для теней вы так же можете использовать --variable в качестве цвета чтобы использовать CSS3-переменные. В таком случае прозрачность работать не будет.\",\"filter_hint\":{\"always_drop_shadow\":\"Внимание, эта тень всегда использует {0} когда браузер поддерживает это\",\"drop_shadow_syntax\":\"{0} не поддерживает параметр {1} и ключевое слово {2}\",\"avatar_inset\":\"Одновременное использование внутренних и внешних теней на (прозрачных) аватарках может дать не те результаты что вы ожидаете\",\"spread_zero\":\"Тени с разбросом > 0 будут выглядеть как если бы разброс установлен в 0\",\"inset_classic\":\"Внутренние тени будут использовать {0}\"},\"components\":{\"panel\":\"Панель\",\"panelHeader\":\"Заголовок панели\",\"topBar\":\"Верхняя полоска\",\"avatar\":\"Аватарка (профиль)\",\"avatarStatus\":\"Аватарка (в ленте)\",\"popup\":\"Всплывающие подсказки\",\"button\":\"Кнопки\",\"buttonHover\":\"Кнопки (наведен курсор)\",\"buttonPressed\":\"Кнопки (нажата)\",\"buttonPressedHover\":\"Кнопки (нажата+наведен курсор)\",\"input\":\"Поля ввода\"}},\"fonts\":{\"_tab_label\":\"Шрифты\",\"help\":\"Выберите тип шрифта для использования в интерфейсе. При выборе варианта \\\"другой\\\" надо ввести название шрифта в точности как он называется в системе.\",\"components\":{\"interface\":\"Интерфейс\",\"input\":\"Поля ввода\",\"post\":\"Текст постов\",\"postCode\":\"Моноширинный текст в посте (форматирование)\"},\"family\":\"Шрифт\",\"size\":\"Размер (в пикселях)\",\"weight\":\"Ширина\",\"custom\":\"Другой\"},\"preview\":{\"header\":\"Пример\",\"content\":\"Контент\",\"error\":\"Ошибка стоп 000\",\"button\":\"Кнопка\",\"text\":\"Еще немного {0} и масенькая {1}\",\"mono\":\"контента\",\"input\":\"Что нового?\",\"faint_link\":\"Его придется убрать\",\"fine_print\":\"Если проблемы остались — ваш гуртовщик мыши плохо стоит. {0}.\",\"header_faint\":\"Все идет по плану\",\"checkbox\":\"Я подтверждаю что не было ни единого разрыва\",\"link\":\"ссылка\"}}},\"timeline\":{\"collapse\":\"Свернуть\",\"conversation\":\"Разговор\",\"error_fetching\":\"Ошибка при обновлении\",\"load_older\":\"Загрузить старые статусы\",\"no_retweet_hint\":\"Пост помечен как \\\"только для подписчиков\\\" или \\\"личное\\\" и поэтому не может быть повторён\",\"repeated\":\"повторил(а)\",\"show_new\":\"Показать новые\",\"up_to_date\":\"Обновлено\"},\"user_card\":{\"block\":\"Заблокировать\",\"blocked\":\"Заблокирован\",\"favorites\":\"Понравившиеся\",\"follow\":\"Читать\",\"follow_sent\":\"Запрос отправлен!\",\"follow_progress\":\"Запрашиваем…\",\"follow_again\":\"Запросить еще заново?\",\"follow_unfollow\":\"Перестать читать\",\"followees\":\"Читаемые\",\"followers\":\"Читатели\",\"following\":\"Читаю\",\"follows_you\":\"Читает вас\",\"mute\":\"Игнорировать\",\"muted\":\"Игнорирую\",\"per_day\":\"в день\",\"remote_follow\":\"Читать удалённо\",\"statuses\":\"Статусы\"},\"user_profile\":{\"timeline_title\":\"Лента пользователя\"}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/ru.json\n// module id = 454\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"聊天\"},\"features_panel\":{\"chat\":\"聊天\",\"gopher\":\"Gopher\",\"media_proxy\":\"媒体代理\",\"scope_options\":\"可见范围设置\",\"text_limit\":\"文本长度限制\",\"title\":\"功能\",\"who_to_follow\":\"推荐关注\"},\"finder\":{\"error_fetching_user\":\"获取用户时发生错误\",\"find_user\":\"寻找用户\"},\"general\":{\"apply\":\"应用\",\"submit\":\"提交\"},\"login\":{\"login\":\"登录\",\"logout\":\"登出\",\"password\":\"密码\",\"placeholder\":\"例如:lain\",\"register\":\"注册\",\"username\":\"用户名\"},\"nav\":{\"chat\":\"本地聊天\",\"friend_requests\":\"关注请求\",\"mentions\":\"提及\",\"public_tl\":\"公共时间线\",\"timeline\":\"时间线\",\"twkn\":\"所有已知网络\"},\"notifications\":{\"broken_favorite\":\"未知的状态,正在搜索中...\",\"favorited_you\":\"收藏了你的状态\",\"followed_you\":\"关注了你\",\"load_older\":\"加载更早的通知\",\"notifications\":\"通知\",\"read\":\"阅读!\",\"repeated_you\":\"转发了你的状态\"},\"post_status\":{\"account_not_locked_warning\":\"你的帐号没有 {0}。任何人都可以关注你并浏览你的上锁内容。\",\"account_not_locked_warning_link\":\"上锁\",\"attachments_sensitive\":\"标记附件为敏感内容\",\"content_type\":{\"plain_text\":\"纯文本\"},\"content_warning\":\"主题(可选)\",\"default\":\"刚刚抵达上海\",\"direct_warning\":\"本条内容只有被提及的用户能够看到。\",\"posting\":\"发送\",\"scope\":{\"direct\":\"私信 - 只发送给被提及的用户\",\"private\":\"仅关注者 - 只有关注了你的人能看到\",\"public\":\"公共 - 发送到公共时间轴\",\"unlisted\":\"不公开 - 所有人可见,但不会发送到公共时间轴\"}},\"registration\":{\"bio\":\"简介\",\"email\":\"电子邮箱\",\"fullname\":\"全名\",\"password_confirm\":\"确认密码\",\"registration\":\"注册\",\"token\":\"邀请码\"},\"settings\":{\"attachmentRadius\":\"附件\",\"attachments\":\"附件\",\"autoload\":\"启用滚动到底部时的自动加载\",\"avatar\":\"头像\",\"avatarAltRadius\":\"头像(通知)\",\"avatarRadius\":\"头像\",\"background\":\"背景\",\"bio\":\"简介\",\"btnRadius\":\"按钮\",\"cBlue\":\"蓝色(回复,关注)\",\"cGreen\":\"绿色(转发)\",\"cOrange\":\"橙色(收藏)\",\"cRed\":\"红色(取消)\",\"change_password\":\"修改密码\",\"change_password_error\":\"修改密码的时候出了点问题。\",\"changed_password\":\"成功修改了密码!\",\"collapse_subject\":\"折叠带主题的内容\",\"confirm_new_password\":\"确认新密码\",\"current_avatar\":\"当前头像\",\"current_password\":\"当前密码\",\"current_profile_banner\":\"您当前的横幅图片\",\"data_import_export_tab\":\"数据导入/导出\",\"default_vis\":\"默认可见范围\",\"delete_account\":\"删除账户\",\"delete_account_description\":\"永久删除你的帐号和所有消息。\",\"delete_account_error\":\"删除账户时发生错误,如果一直删除不了,请联系实例管理员。\",\"delete_account_instructions\":\"在下面输入你的密码来确认删除账户\",\"export_theme\":\"导出预置主题\",\"filtering\":\"过滤器\",\"filtering_explanation\":\"所有包含以下词汇的内容都会被隐藏,一行一个\",\"follow_export\":\"导出关注\",\"follow_export_button\":\"将关注导出成 csv 文件\",\"follow_export_processing\":\"正在处理,过一会儿就可以下载你的文件了\",\"follow_import\":\"导入关注\",\"follow_import_error\":\"导入关注时错误\",\"follows_imported\":\"关注已导入!尚需要一些时间来处理。\",\"foreground\":\"前景\",\"general\":\"通用\",\"hide_attachments_in_convo\":\"在对话中隐藏附件\",\"hide_attachments_in_tl\":\"在时间线上隐藏附件\",\"hide_post_stats\":\"隐藏推文相关的统计数据(例如:收藏的次数)\",\"hide_user_stats\":\"隐藏用户的统计数据(例如:关注者的数量)\",\"import_followers_from_a_csv_file\":\"从 csv 文件中导入关注\",\"import_theme\":\"导入预置主题\",\"inputRadius\":\"输入框\",\"instance_default\":\"(默认:{value})\",\"interfaceLanguage\":\"界面语言\",\"invalid_theme_imported\":\"您所选择的主题文件不被 Pleroma 支持,因此主题未被修改。\",\"limited_availability\":\"在您的浏览器中无法使用\",\"links\":\"链接\",\"lock_account_description\":\"你需要手动审核关注请求\",\"loop_video\":\"循环视频\",\"loop_video_silent_only\":\"只循环没有声音的视频(例如:Mastodon 里的“GIF”)\",\"name\":\"名字\",\"name_bio\":\"名字及简介\",\"new_password\":\"新密码\",\"notification_visibility\":\"要显示的通知类型\",\"notification_visibility_follows\":\"关注\",\"notification_visibility_likes\":\"点赞\",\"notification_visibility_mentions\":\"提及\",\"notification_visibility_repeats\":\"转发\",\"no_rich_text_description\":\"不显示富文本格式\",\"nsfw_clickthrough\":\"将不和谐附件隐藏,点击才能打开\",\"oauth_tokens\":\"OAuth令牌\",\"token\":\"代币\",\"refresh_token\":\"刷新令牌\",\"valid_until\":\"有效期至\",\"revoke_token\":\"撤消\",\"panelRadius\":\"面板\",\"pause_on_unfocused\":\"在离开页面时暂停时间线推送\",\"presets\":\"预置\",\"profile_background\":\"个人资料背景图\",\"profile_banner\":\"横幅图片\",\"profile_tab\":\"个人资料\",\"radii_help\":\"设置界面边缘的圆角 (单位:像素)\",\"replies_in_timeline\":\"时间线中的回复\",\"reply_link_preview\":\"启用鼠标悬停时预览回复链接\",\"reply_visibility_all\":\"显示所有回复\",\"reply_visibility_following\":\"只显示发送给我的回复/发送给我关注的用户的回复\",\"reply_visibility_self\":\"只显示发送给我的回复\",\"saving_err\":\"保存设置时发生错误\",\"saving_ok\":\"设置已保存\",\"security_tab\":\"安全\",\"set_new_avatar\":\"设置新头像\",\"set_new_profile_background\":\"设置新的个人资料背景\",\"set_new_profile_banner\":\"设置新的横幅图片\",\"settings\":\"设置\",\"stop_gifs\":\"鼠标悬停时播放GIF\",\"streaming\":\"开启滚动到顶部时的自动推送\",\"text\":\"文本\",\"theme\":\"主题\",\"theme_help\":\"使用十六进制代码(#rrggbb)来设置主题颜色。\",\"tooltipRadius\":\"提醒\",\"user_settings\":\"用户设置\",\"values\":{\"false\":\"否\",\"true\":\"是\"}},\"timeline\":{\"collapse\":\"折叠\",\"conversation\":\"对话\",\"error_fetching\":\"获取更新时发生错误\",\"load_older\":\"加载更早的状态\",\"no_retweet_hint\":\"这条内容仅关注者可见,或者是私信,因此不能转发。\",\"repeated\":\"已转发\",\"show_new\":\"显示新内容\",\"up_to_date\":\"已是最新\"},\"user_card\":{\"approve\":\"允许\",\"block\":\"屏蔽\",\"blocked\":\"已屏蔽!\",\"deny\":\"拒绝\",\"follow\":\"关注\",\"followees\":\"正在关注\",\"followers\":\"关注者\",\"following\":\"正在关注!\",\"follows_you\":\"关注了你!\",\"mute\":\"隐藏\",\"muted\":\"已隐藏\",\"per_day\":\"每天\",\"remote_follow\":\"跨站关注\",\"statuses\":\"状态\"},\"user_profile\":{\"timeline_title\":\"用户时间线\"},\"who_to_follow\":{\"more\":\"更多\",\"who_to_follow\":\"推荐关注\"}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/zh.json\n// module id = 455\n// module chunks = 2","module.exports = [\"teď\",[\"%s s\",\"%s s\"],[\"%s min\",\"%s min\"],[\"%s h\",\"%s h\"],[\"%s d\",\"%s d\"],[\"%s týd\",\"%s týd\"],[\"%s měs\",\"%s měs\"],[\"%s r\",\"%s l\"]]\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./static/timeago-cs.json\n// module id = 456\n// module chunks = 2","module.exports = [\"now\",[\"%ss\",\"%ss\"],[\"%smin\",\"%smin\"],[\"%sh\",\"%sh\"],[\"%sd\",\"%sd\"],[\"%sw\",\"%sw\"],[\"%smo\",\"%smo\"],[\"%sy\",\"%sy\"]]\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./static/timeago-en.json\n// module id = 457\n// module chunks = 2","module.exports = [\"たった今\",\"%s 秒前\",\"%s 分前\",\"%s 時間前\",\"%s 日前\",\"%s 週間前\",\"%s ヶ月前\",\"%s 年前\"]\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./static/timeago-ja.json\n// module id = 458\n// module chunks = 2","module.exports = __webpack_public_path__ + \"static/img/nsfw.74818f9.png\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/assets/nsfw.png\n// module id = 627\n// module chunks = 2","\n/* styles */\nrequire(\"!!../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-e918ada2\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!./App.scss\")\n\nvar Component = require(\"!../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./App.js\"),\n /* template */\n require(\"!!../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-e918ada2\\\"}!../node_modules/vue-loader/lib/selector?type=template&index=0!./App.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/App.vue\n// module id = 631\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-a9b2b458\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./about.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./about.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-a9b2b458\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./about.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/about/about.vue\n// module id = 632\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-0cfc2f90\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./block_card.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./block_card.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-0cfc2f90\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./block_card.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/block_card/block_card.vue\n// module id = 633\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-1a970f38\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./contrast_ratio.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!../../../node_modules/vue-loader/lib/selector?type=script&index=0!./contrast_ratio.vue\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-1a970f38\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./contrast_ratio.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/contrast_ratio/contrast_ratio.vue\n// module id = 634\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./conversation-page.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-1771daec\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./conversation-page.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/conversation-page/conversation-page.vue\n// module id = 635\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-0b8ce2f4\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./delete_button.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./delete_button.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-0b8ce2f4\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./delete_button.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/delete_button/delete_button.vue\n// module id = 636\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./dm_timeline.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-d8bc97b0\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./dm_timeline.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/dm_timeline/dm_timeline.vue\n// module id = 637\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-45eb80cc\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./export_import.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!../../../node_modules/vue-loader/lib/selector?type=script&index=0!./export_import.vue\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-45eb80cc\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./export_import.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/export_import/export_import.vue\n// module id = 638\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-08c6b5b8\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./favorite_button.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./favorite_button.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-08c6b5b8\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./favorite_button.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/favorite_button/favorite_button.vue\n// module id = 639\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-45e71c56\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./follow_request_card.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./follow_request_card.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-45e71c56\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./follow_request_card.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/follow_request_card/follow_request_card.vue\n// module id = 640\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./follow_requests.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-56ec10de\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./follow_requests.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/follow_requests/follow_requests.vue\n// module id = 641\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-2979f658\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./font_control.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./font_control.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-2979f658\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./font_control.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/font_control/font_control.vue\n// module id = 642\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./friends_timeline.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-87ffcfd0\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./friends_timeline.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/friends_timeline/friends_timeline.vue\n// module id = 643\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-34b44944\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./gallery.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./gallery.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-34b44944\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./gallery.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/gallery/gallery.vue\n// module id = 644\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-0803a50c\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./image_cropper.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./image_cropper.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-0803a50c\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./image_cropper.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/image_cropper/image_cropper.vue\n// module id = 645\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!../../../node_modules/vue-loader/lib/selector?type=script&index=0!./interface_language_switcher.vue\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-119964fe\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./interface_language_switcher.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/interface_language_switcher/interface_language_switcher.vue\n// module id = 646\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-4cb37358\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./link-preview.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./link-preview.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-4cb37358\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./link-preview.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/link-preview/link-preview.vue\n// module id = 647\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-1351175e\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./media_modal.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./media_modal.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-1351175e\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./media_modal.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/media_modal/media_modal.vue\n// module id = 648\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-32209eb8\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./media_upload.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./media_upload.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-32209eb8\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./media_upload.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/media_upload/media_upload.vue\n// module id = 649\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./mentions.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-2de5c050\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./mentions.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/mentions/mentions.vue\n// module id = 650\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./mute_card.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-fd544d34\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./mute_card.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/mute_card/mute_card.vue\n// module id = 651\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-23ab246c\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./nav_panel.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./nav_panel.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-23ab246c\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./nav_panel.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/nav_panel/nav_panel.vue\n// module id = 652\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./notification.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-46ab3318\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./notification.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/notification/notification.vue\n// module id = 653\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./oauth_callback.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-3b485558\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./oauth_callback.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/oauth_callback/oauth_callback.vue\n// module id = 654\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./public_and_external_timeline.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-b0da3ad0\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./public_and_external_timeline.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/public_and_external_timeline/public_and_external_timeline.vue\n// module id = 655\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./public_timeline.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-84f9a930\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./public_timeline.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/public_timeline/public_timeline.vue\n// module id = 656\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!../../../node_modules/vue-loader/lib/selector?type=script&index=0!./range_input.vue\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-b947c06c\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./range_input.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/range_input/range_input.vue\n// module id = 657\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-23a871d8\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./registration.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./registration.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-23a871d8\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./registration.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/registration/registration.vue\n// module id = 658\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-28288ed0\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./retweet_button.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./retweet_button.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-28288ed0\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./retweet_button.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/retweet_button/retweet_button.vue\n// module id = 659\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-5719c518\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./settings.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./settings.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-5719c518\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./settings.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/settings/settings.vue\n// module id = 660\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-75a4cd90\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./shadow_control.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./shadow_control.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-75a4cd90\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./shadow_control.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/shadow_control/shadow_control.vue\n// module id = 661\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-b0cc0b28\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./side_drawer.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./side_drawer.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-b0cc0b28\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./side_drawer.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/side_drawer/side_drawer.vue\n// module id = 662\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-073787b8\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./status_or_conversation.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./status_or_conversation.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-073787b8\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./status_or_conversation.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/status_or_conversation/status_or_conversation.vue\n// module id = 663\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n null,\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-2da7d1a2\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./preview.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/style_switcher/preview.vue\n// module id = 664\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./tag_timeline.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-59e5a210\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./tag_timeline.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/tag_timeline/tag_timeline.vue\n// module id = 665\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-37956e90\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./terms_of_service_panel.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./terms_of_service_panel.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-37956e90\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./terms_of_service_panel.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/terms_of_service_panel/terms_of_service_panel.vue\n// module id = 666\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-7ca85c6e\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./user_finder.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./user_finder.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-7ca85c6e\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./user_finder.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/user_finder/user_finder.vue\n// module id = 667\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-26005b58\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./user_profile.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./user_profile.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-26005b58\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./user_profile.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/user_profile/user_profile.vue\n// module id = 668\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-c7873b1c\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./user_search.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./user_search.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-c7873b1c\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./user_search.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/user_search/user_search.vue\n// module id = 669\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-06130768\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./user_settings.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./user_settings.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-06130768\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./user_settings.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/user_settings/user_settings.vue\n// module id = 670\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-6a618ce2\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./who_to_follow.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./who_to_follow.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-6a618ce2\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./who_to_follow.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/who_to_follow/who_to_follow.vue\n// module id = 671\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-bf9ee3a8\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./who_to_follow_panel.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./who_to_follow_panel.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-bf9ee3a8\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./who_to_follow_panel.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/who_to_follow_panel/who_to_follow_panel.vue\n// module id = 672\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"login panel panel-default\"\n }, [_c('div', {\n staticClass: \"panel-heading\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('login.login')) + \"\\n \")]), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-body\"\n }, [(_vm.loginMethod == 'password') ? _c('form', {\n staticClass: \"login-form\",\n on: {\n \"submit\": function($event) {\n $event.preventDefault();\n _vm.submit(_vm.user)\n }\n }\n }, [_c('div', {\n staticClass: \"form-group\"\n }, [_c('label', {\n attrs: {\n \"for\": \"username\"\n }\n }, [_vm._v(_vm._s(_vm.$t('login.username')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.user.username),\n expression: \"user.username\"\n }],\n staticClass: \"form-control\",\n attrs: {\n \"disabled\": _vm.loggingIn,\n \"id\": \"username\",\n \"placeholder\": _vm.$t('login.placeholder')\n },\n domProps: {\n \"value\": (_vm.user.username)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.user, \"username\", $event.target.value)\n }\n }\n })]), _vm._v(\" \"), _c('div', {\n staticClass: \"form-group\"\n }, [_c('label', {\n attrs: {\n \"for\": \"password\"\n }\n }, [_vm._v(_vm._s(_vm.$t('login.password')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.user.password),\n expression: \"user.password\"\n }],\n staticClass: \"form-control\",\n attrs: {\n \"disabled\": _vm.loggingIn,\n \"id\": \"password\",\n \"type\": \"password\"\n },\n domProps: {\n \"value\": (_vm.user.password)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.user, \"password\", $event.target.value)\n }\n }\n })]), _vm._v(\" \"), _c('div', {\n staticClass: \"form-group\"\n }, [_c('div', {\n staticClass: \"login-bottom\"\n }, [_c('div', [(_vm.registrationOpen) ? _c('router-link', {\n staticClass: \"register\",\n attrs: {\n \"to\": {\n name: 'registration'\n }\n }\n }, [_vm._v(_vm._s(_vm.$t('login.register')))]) : _vm._e()], 1), _vm._v(\" \"), _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": _vm.loggingIn,\n \"type\": \"submit\"\n }\n }, [_vm._v(_vm._s(_vm.$t('login.login')))])])])]) : _vm._e(), _vm._v(\" \"), (_vm.loginMethod == 'token') ? _c('form', {\n staticClass: \"login-form\",\n on: {\n \"submit\": function($event) {\n $event.preventDefault();\n return _vm.oAuthLogin($event)\n }\n }\n }, [_c('div', {\n staticClass: \"form-group\"\n }, [_c('p', [_vm._v(_vm._s(_vm.$t('login.description')))])]), _vm._v(\" \"), _c('div', {\n staticClass: \"form-group\"\n }, [_c('div', {\n staticClass: \"login-bottom\"\n }, [_c('div', [(_vm.registrationOpen) ? _c('router-link', {\n staticClass: \"register\",\n attrs: {\n \"to\": {\n name: 'registration'\n }\n }\n }, [_vm._v(_vm._s(_vm.$t('login.register')))]) : _vm._e()], 1), _vm._v(\" \"), _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": _vm.loggingIn,\n \"type\": \"submit\"\n }\n }, [_vm._v(_vm._s(_vm.$t('login.login')))])])])]) : _vm._e(), _vm._v(\" \"), (_vm.authError) ? _c('div', {\n staticClass: \"form-group\"\n }, [_c('div', {\n staticClass: \"alert error\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.authError) + \"\\n \"), _c('i', {\n staticClass: \"button-icon icon-cancel\",\n on: {\n \"click\": _vm.clearError\n }\n })])]) : _vm._e()])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-017c4138\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/login_form/login_form.vue\n// module id = 673\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"color-control style-control\",\n class: {\n disabled: !_vm.present || _vm.disabled\n }\n }, [_c('label', {\n staticClass: \"label\",\n attrs: {\n \"for\": _vm.name\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.label) + \"\\n \")]), _vm._v(\" \"), (typeof _vm.fallback !== 'undefined') ? _c('input', {\n staticClass: \"opt exlcude-disabled\",\n attrs: {\n \"id\": _vm.name + '-o',\n \"type\": \"checkbox\"\n },\n domProps: {\n \"checked\": _vm.present\n },\n on: {\n \"input\": function($event) {\n _vm.$emit('input', typeof _vm.value === 'undefined' ? _vm.fallback : undefined)\n }\n }\n }) : _vm._e(), _vm._v(\" \"), (typeof _vm.fallback !== 'undefined') ? _c('label', {\n staticClass: \"opt-l\",\n attrs: {\n \"for\": _vm.name + '-o'\n }\n }) : _vm._e(), _vm._v(\" \"), _c('input', {\n staticClass: \"color-input\",\n attrs: {\n \"id\": _vm.name,\n \"type\": \"color\",\n \"disabled\": !_vm.present || _vm.disabled\n },\n domProps: {\n \"value\": _vm.value || _vm.fallback\n },\n on: {\n \"input\": function($event) {\n _vm.$emit('input', $event.target.value)\n }\n }\n }), _vm._v(\" \"), _c('input', {\n staticClass: \"text-input\",\n attrs: {\n \"id\": _vm.name + '-t',\n \"type\": \"text\",\n \"disabled\": !_vm.present || _vm.disabled\n },\n domProps: {\n \"value\": _vm.value || _vm.fallback\n },\n on: {\n \"input\": function($event) {\n _vm.$emit('input', $event.target.value)\n }\n }\n })])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-04195416\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/color_input/color_input.vue\n// module id = 674\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"settings panel panel-default\"\n }, [_c('div', {\n staticClass: \"panel-heading\"\n }, [_c('div', {\n staticClass: \"title\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.user_settings')) + \"\\n \")]), _vm._v(\" \"), _c('transition', {\n attrs: {\n \"name\": \"fade\"\n }\n }, [(_vm.currentSaveStateNotice) ? [(_vm.currentSaveStateNotice.error) ? _c('div', {\n staticClass: \"alert error\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.saving_err')) + \"\\n \")]) : _vm._e(), _vm._v(\" \"), (!_vm.currentSaveStateNotice.error) ? _c('div', {\n staticClass: \"alert transparent\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.saving_ok')) + \"\\n \")]) : _vm._e()] : _vm._e()], 2)], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-body profile-edit\"\n }, [_c('tab-switcher', [_c('div', {\n attrs: {\n \"label\": _vm.$t('settings.profile_tab')\n }\n }, [_c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.name_bio')))]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.name')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.newName),\n expression: \"newName\"\n }],\n staticClass: \"name-changer\",\n attrs: {\n \"id\": \"username\"\n },\n domProps: {\n \"value\": (_vm.newName)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.newName = $event.target.value\n }\n }\n }), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.bio')))]), _vm._v(\" \"), _c('textarea', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.newBio),\n expression: \"newBio\"\n }],\n staticClass: \"bio\",\n domProps: {\n \"value\": (_vm.newBio)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.newBio = $event.target.value\n }\n }\n }), _vm._v(\" \"), _c('p', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.newLocked),\n expression: \"newLocked\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"account-locked\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.newLocked) ? _vm._i(_vm.newLocked, null) > -1 : (_vm.newLocked)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.newLocked,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.newLocked = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.newLocked = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.newLocked = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"account-locked\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.lock_account_description')))])]), _vm._v(\" \"), (_vm.scopeOptionsEnabled) ? _c('div', [_c('label', {\n attrs: {\n \"for\": \"default-vis\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.default_vis')))]), _vm._v(\" \"), _c('div', {\n staticClass: \"visibility-tray\",\n attrs: {\n \"id\": \"default-vis\"\n }\n }, [_c('i', {\n staticClass: \"icon-mail-alt\",\n class: _vm.vis.direct,\n attrs: {\n \"title\": _vm.$t('post_status.scope.direct')\n },\n on: {\n \"click\": function($event) {\n _vm.changeVis('direct')\n }\n }\n }), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-lock\",\n class: _vm.vis.private,\n attrs: {\n \"title\": _vm.$t('post_status.scope.private')\n },\n on: {\n \"click\": function($event) {\n _vm.changeVis('private')\n }\n }\n }), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-lock-open-alt\",\n class: _vm.vis.unlisted,\n attrs: {\n \"title\": _vm.$t('post_status.scope.unlisted')\n },\n on: {\n \"click\": function($event) {\n _vm.changeVis('unlisted')\n }\n }\n }), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-globe\",\n class: _vm.vis.public,\n attrs: {\n \"title\": _vm.$t('post_status.scope.public')\n },\n on: {\n \"click\": function($event) {\n _vm.changeVis('public')\n }\n }\n })])]) : _vm._e(), _vm._v(\" \"), _c('p', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.newNoRichText),\n expression: \"newNoRichText\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"account-no-rich-text\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.newNoRichText) ? _vm._i(_vm.newNoRichText, null) > -1 : (_vm.newNoRichText)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.newNoRichText,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.newNoRichText = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.newNoRichText = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.newNoRichText = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"account-no-rich-text\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.no_rich_text_description')))])]), _vm._v(\" \"), _c('p', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.hideFollows),\n expression: \"hideFollows\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"account-hide-follows\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.hideFollows) ? _vm._i(_vm.hideFollows, null) > -1 : (_vm.hideFollows)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.hideFollows,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.hideFollows = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.hideFollows = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.hideFollows = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"account-hide-follows\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.hide_follows_description')))])]), _vm._v(\" \"), _c('p', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.hideFollowers),\n expression: \"hideFollowers\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"account-hide-followers\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.hideFollowers) ? _vm._i(_vm.hideFollowers, null) > -1 : (_vm.hideFollowers)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.hideFollowers,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.hideFollowers = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.hideFollowers = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.hideFollowers = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"account-hide-followers\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.hide_followers_description')))])]), _vm._v(\" \"), _c('p', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.showRole),\n expression: \"showRole\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"account-show-role\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.showRole) ? _vm._i(_vm.showRole, null) > -1 : (_vm.showRole)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.showRole,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.showRole = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.showRole = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.showRole = $$c\n }\n }\n }\n }), _vm._v(\" \"), (_vm.role === 'admin') ? _c('label', {\n attrs: {\n \"for\": \"account-show-role\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.show_admin_badge')))]) : _vm._e(), _vm._v(\" \"), (_vm.role === 'moderator') ? _c('label', {\n attrs: {\n \"for\": \"account-show-role\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.show_moderator_badge')))]) : _vm._e()]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": _vm.newName && _vm.newName.length === 0\n },\n on: {\n \"click\": _vm.updateProfile\n }\n }, [_vm._v(_vm._s(_vm.$t('general.submit')))])]), _vm._v(\" \"), _c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.avatar')))]), _vm._v(\" \"), _c('p', {\n staticClass: \"visibility-notice\"\n }, [_vm._v(_vm._s(_vm.$t('settings.avatar_size_instruction')))]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.current_avatar')))]), _vm._v(\" \"), _c('img', {\n staticClass: \"current-avatar\",\n attrs: {\n \"src\": _vm.user.profile_image_url_original\n }\n }), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.set_new_avatar')))]), _vm._v(\" \"), _c('button', {\n directives: [{\n name: \"show\",\n rawName: \"v-show\",\n value: (_vm.pickAvatarBtnVisible),\n expression: \"pickAvatarBtnVisible\"\n }],\n staticClass: \"btn\",\n attrs: {\n \"type\": \"button\",\n \"id\": \"pick-avatar\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.upload_a_photo')))]), _vm._v(\" \"), _c('image-cropper', {\n attrs: {\n \"trigger\": \"#pick-avatar\",\n \"submitHandler\": _vm.submitAvatar\n },\n on: {\n \"open\": function($event) {\n _vm.pickAvatarBtnVisible = false\n },\n \"close\": function($event) {\n _vm.pickAvatarBtnVisible = true\n }\n }\n })], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.profile_banner')))]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.current_profile_banner')))]), _vm._v(\" \"), _c('img', {\n staticClass: \"banner\",\n attrs: {\n \"src\": _vm.user.cover_photo\n }\n }), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.set_new_profile_banner')))]), _vm._v(\" \"), (_vm.bannerPreview) ? _c('img', {\n staticClass: \"banner\",\n attrs: {\n \"src\": _vm.bannerPreview\n }\n }) : _vm._e(), _vm._v(\" \"), _c('div', [_c('input', {\n attrs: {\n \"type\": \"file\"\n },\n on: {\n \"change\": function($event) {\n _vm.uploadFile('banner', $event)\n }\n }\n })]), _vm._v(\" \"), (_vm.bannerUploading) ? _c('i', {\n staticClass: \" icon-spin4 animate-spin uploading\"\n }) : (_vm.bannerPreview) ? _c('button', {\n staticClass: \"btn btn-default\",\n on: {\n \"click\": _vm.submitBanner\n }\n }, [_vm._v(_vm._s(_vm.$t('general.submit')))]) : _vm._e(), _vm._v(\" \"), (_vm.bannerUploadError) ? _c('div', {\n staticClass: \"alert error\"\n }, [_vm._v(\"\\n Error: \" + _vm._s(_vm.bannerUploadError) + \"\\n \"), _c('i', {\n staticClass: \"button-icon icon-cancel\",\n on: {\n \"click\": function($event) {\n _vm.clearUploadError('banner')\n }\n }\n })]) : _vm._e()]), _vm._v(\" \"), _c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.profile_background')))]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.set_new_profile_background')))]), _vm._v(\" \"), (_vm.backgroundPreview) ? _c('img', {\n staticClass: \"bg\",\n attrs: {\n \"src\": _vm.backgroundPreview\n }\n }) : _vm._e(), _vm._v(\" \"), _c('div', [_c('input', {\n attrs: {\n \"type\": \"file\"\n },\n on: {\n \"change\": function($event) {\n _vm.uploadFile('background', $event)\n }\n }\n })]), _vm._v(\" \"), (_vm.backgroundUploading) ? _c('i', {\n staticClass: \" icon-spin4 animate-spin uploading\"\n }) : (_vm.backgroundPreview) ? _c('button', {\n staticClass: \"btn btn-default\",\n on: {\n \"click\": _vm.submitBg\n }\n }, [_vm._v(_vm._s(_vm.$t('general.submit')))]) : _vm._e(), _vm._v(\" \"), (_vm.backgroundUploadError) ? _c('div', {\n staticClass: \"alert error\"\n }, [_vm._v(\"\\n Error: \" + _vm._s(_vm.backgroundUploadError) + \"\\n \"), _c('i', {\n staticClass: \"button-icon icon-cancel\",\n on: {\n \"click\": function($event) {\n _vm.clearUploadError('background')\n }\n }\n })]) : _vm._e()])]), _vm._v(\" \"), _c('div', {\n attrs: {\n \"label\": _vm.$t('settings.security_tab')\n }\n }, [_c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.change_password')))]), _vm._v(\" \"), _c('div', [_c('p', [_vm._v(_vm._s(_vm.$t('settings.current_password')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.changePasswordInputs[0]),\n expression: \"changePasswordInputs[0]\"\n }],\n attrs: {\n \"type\": \"password\"\n },\n domProps: {\n \"value\": (_vm.changePasswordInputs[0])\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.changePasswordInputs, 0, $event.target.value)\n }\n }\n })]), _vm._v(\" \"), _c('div', [_c('p', [_vm._v(_vm._s(_vm.$t('settings.new_password')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.changePasswordInputs[1]),\n expression: \"changePasswordInputs[1]\"\n }],\n attrs: {\n \"type\": \"password\"\n },\n domProps: {\n \"value\": (_vm.changePasswordInputs[1])\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.changePasswordInputs, 1, $event.target.value)\n }\n }\n })]), _vm._v(\" \"), _c('div', [_c('p', [_vm._v(_vm._s(_vm.$t('settings.confirm_new_password')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.changePasswordInputs[2]),\n expression: \"changePasswordInputs[2]\"\n }],\n attrs: {\n \"type\": \"password\"\n },\n domProps: {\n \"value\": (_vm.changePasswordInputs[2])\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.changePasswordInputs, 2, $event.target.value)\n }\n }\n })]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn btn-default\",\n on: {\n \"click\": _vm.changePassword\n }\n }, [_vm._v(_vm._s(_vm.$t('general.submit')))]), _vm._v(\" \"), (_vm.changedPassword) ? _c('p', [_vm._v(_vm._s(_vm.$t('settings.changed_password')))]) : (_vm.changePasswordError !== false) ? _c('p', [_vm._v(_vm._s(_vm.$t('settings.change_password_error')))]) : _vm._e(), _vm._v(\" \"), (_vm.changePasswordError) ? _c('p', [_vm._v(_vm._s(_vm.changePasswordError))]) : _vm._e()]), _vm._v(\" \"), _c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.oauth_tokens')))]), _vm._v(\" \"), _c('table', {\n staticClass: \"oauth-tokens\"\n }, [_c('thead', [_c('tr', [_c('th', [_vm._v(_vm._s(_vm.$t('settings.app_name')))]), _vm._v(\" \"), _c('th', [_vm._v(_vm._s(_vm.$t('settings.valid_until')))]), _vm._v(\" \"), _c('th')])]), _vm._v(\" \"), _c('tbody', _vm._l((_vm.oauthTokens), function(oauthToken) {\n return _c('tr', {\n key: oauthToken.id\n }, [_c('td', [_vm._v(_vm._s(oauthToken.appName))]), _vm._v(\" \"), _c('td', [_vm._v(_vm._s(oauthToken.validUntil))]), _vm._v(\" \"), _c('td', {\n staticClass: \"actions\"\n }, [_c('button', {\n staticClass: \"btn btn-default\",\n on: {\n \"click\": function($event) {\n _vm.revokeToken(oauthToken.id)\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.revoke_token')) + \"\\n \")])])])\n }), 0)])]), _vm._v(\" \"), _c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.delete_account')))]), _vm._v(\" \"), (!_vm.deletingAccount) ? _c('p', [_vm._v(_vm._s(_vm.$t('settings.delete_account_description')))]) : _vm._e(), _vm._v(\" \"), (_vm.deletingAccount) ? _c('div', [_c('p', [_vm._v(_vm._s(_vm.$t('settings.delete_account_instructions')))]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('login.password')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.deleteAccountConfirmPasswordInput),\n expression: \"deleteAccountConfirmPasswordInput\"\n }],\n attrs: {\n \"type\": \"password\"\n },\n domProps: {\n \"value\": (_vm.deleteAccountConfirmPasswordInput)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.deleteAccountConfirmPasswordInput = $event.target.value\n }\n }\n }), _vm._v(\" \"), _c('button', {\n staticClass: \"btn btn-default\",\n on: {\n \"click\": _vm.deleteAccount\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.delete_account')))])]) : _vm._e(), _vm._v(\" \"), (_vm.deleteAccountError !== false) ? _c('p', [_vm._v(_vm._s(_vm.$t('settings.delete_account_error')))]) : _vm._e(), _vm._v(\" \"), (_vm.deleteAccountError) ? _c('p', [_vm._v(_vm._s(_vm.deleteAccountError))]) : _vm._e(), _vm._v(\" \"), (!_vm.deletingAccount) ? _c('button', {\n staticClass: \"btn btn-default\",\n on: {\n \"click\": _vm.confirmDelete\n }\n }, [_vm._v(_vm._s(_vm.$t('general.submit')))]) : _vm._e()])]), _vm._v(\" \"), (_vm.pleromaBackend) ? _c('div', {\n attrs: {\n \"label\": _vm.$t('settings.data_import_export_tab')\n }\n }, [_c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.follow_import')))]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.import_followers_from_a_csv_file')))]), _vm._v(\" \"), _c('form', [_c('input', {\n ref: \"followlist\",\n attrs: {\n \"type\": \"file\"\n },\n on: {\n \"change\": _vm.followListChange\n }\n })]), _vm._v(\" \"), (_vm.followListUploading) ? _c('i', {\n staticClass: \" icon-spin4 animate-spin uploading\"\n }) : _c('button', {\n staticClass: \"btn btn-default\",\n on: {\n \"click\": _vm.importFollows\n }\n }, [_vm._v(_vm._s(_vm.$t('general.submit')))]), _vm._v(\" \"), (_vm.followsImported) ? _c('div', [_c('i', {\n staticClass: \"icon-cross\",\n on: {\n \"click\": _vm.dismissImported\n }\n }), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.follows_imported')))])]) : (_vm.followImportError) ? _c('div', [_c('i', {\n staticClass: \"icon-cross\",\n on: {\n \"click\": _vm.dismissImported\n }\n }), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.follow_import_error')))])]) : _vm._e()]), _vm._v(\" \"), (_vm.enableFollowsExport) ? _c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.follow_export')))]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn btn-default\",\n on: {\n \"click\": _vm.exportFollows\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.follow_export_button')))])]) : _c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.follow_export_processing')))])])]) : _vm._e(), _vm._v(\" \"), _c('div', {\n attrs: {\n \"label\": _vm.$t('settings.blocks_tab')\n }\n }, [_c('block-list', {\n attrs: {\n \"refresh\": true\n }\n }, [_c('template', {\n slot: \"empty\"\n }, [_vm._v(_vm._s(_vm.$t('settings.no_blocks')))])], 2)], 1)])], 1)])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-06130768\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/user_settings/user_settings.vue\n// module id = 675\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"still-image\",\n class: {\n animated: _vm.animated\n }\n }, [(_vm.animated) ? _c('canvas', {\n ref: \"canvas\"\n }) : _vm._e(), _vm._v(\" \"), _c('img', {\n ref: \"src\",\n attrs: {\n \"src\": _vm.src,\n \"referrerpolicy\": _vm.referrerpolicy\n },\n on: {\n \"load\": _vm.onLoad,\n \"error\": _vm.onError\n }\n })])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-06a2da26\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/still-image/still-image.vue\n// module id = 676\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', [(_vm.expanded) ? _c('conversation', {\n attrs: {\n \"collapsable\": true,\n \"statusoid\": _vm.statusoid\n },\n on: {\n \"toggleExpanded\": _vm.toggleExpanded\n }\n }) : _vm._e(), _vm._v(\" \"), (!_vm.expanded) ? _c('status', {\n attrs: {\n \"expandable\": true,\n \"inConversation\": false,\n \"focused\": false,\n \"statusoid\": _vm.statusoid\n },\n on: {\n \"toggleExpanded\": _vm.toggleExpanded\n }\n }) : _vm._e()], 1)\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-073787b8\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/status_or_conversation/status_or_conversation.vue\n// module id = 677\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"image-cropper\"\n }, [(_vm.dataUrl) ? _c('div', [_c('div', {\n staticClass: \"image-cropper-image-container\"\n }, [_c('img', {\n ref: \"img\",\n attrs: {\n \"src\": _vm.dataUrl,\n \"alt\": \"\"\n },\n on: {\n \"load\": function($event) {\n $event.stopPropagation();\n return _vm.createCropper($event)\n }\n }\n })]), _vm._v(\" \"), _c('div', {\n staticClass: \"image-cropper-buttons-wrapper\"\n }, [_c('button', {\n staticClass: \"btn\",\n attrs: {\n \"type\": \"button\",\n \"disabled\": _vm.submitting\n },\n domProps: {\n \"textContent\": _vm._s(_vm.saveText)\n },\n on: {\n \"click\": _vm.submit\n }\n }), _vm._v(\" \"), _c('button', {\n staticClass: \"btn\",\n attrs: {\n \"type\": \"button\",\n \"disabled\": _vm.submitting\n },\n domProps: {\n \"textContent\": _vm._s(_vm.cancelText)\n },\n on: {\n \"click\": _vm.destroy\n }\n }), _vm._v(\" \"), (_vm.submitting) ? _c('i', {\n staticClass: \"icon-spin4 animate-spin\"\n }) : _vm._e()]), _vm._v(\" \"), (_vm.submitError) ? _c('div', {\n staticClass: \"alert error\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.submitErrorMsg) + \"\\n \"), _c('i', {\n staticClass: \"button-icon icon-cancel\",\n on: {\n \"click\": _vm.clearError\n }\n })]) : _vm._e()]) : _vm._e(), _vm._v(\" \"), _c('input', {\n ref: \"input\",\n staticClass: \"image-cropper-img-input\",\n attrs: {\n \"type\": \"file\",\n \"accept\": _vm.mimes\n }\n })])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-0803a50c\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/image_cropper/image_cropper.vue\n// module id = 678\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return (_vm.loggedIn) ? _c('div', [_c('i', {\n staticClass: \"button-icon favorite-button fav-active\",\n class: _vm.classes,\n attrs: {\n \"title\": _vm.$t('tool_tip.favorite')\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n _vm.favorite()\n }\n }\n }), _vm._v(\" \"), (!_vm.hidePostStatsLocal && _vm.status.fave_num > 0) ? _c('span', [_vm._v(_vm._s(_vm.status.fave_num))]) : _vm._e()]) : _c('div', [_c('i', {\n staticClass: \"button-icon favorite-button\",\n class: _vm.classes,\n attrs: {\n \"title\": _vm.$t('tool_tip.favorite')\n }\n }), _vm._v(\" \"), (!_vm.hidePostStatsLocal && _vm.status.fave_num > 0) ? _c('span', [_vm._v(_vm._s(_vm.status.fave_num))]) : _vm._e()])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-08c6b5b8\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/favorite_button/favorite_button.vue\n// module id = 679\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return (_vm.canDelete) ? _c('div', [_c('a', {\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n _vm.deleteStatus()\n }\n }\n }, [_c('i', {\n staticClass: \"button-icon icon-cancel delete-status\"\n })])]) : _vm._e()\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-0b8ce2f4\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/delete_button/delete_button.vue\n// module id = 680\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('basic-user-card', {\n attrs: {\n \"user\": _vm.user\n }\n }, [_c('div', {\n staticClass: \"block-card-content-container\"\n }, [(_vm.blocked) ? _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": _vm.progress\n },\n on: {\n \"click\": _vm.unblockUser\n }\n }, [(_vm.progress) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.unblock_progress')) + \"\\n \")] : [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.unblock')) + \"\\n \")]], 2) : _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": _vm.progress\n },\n on: {\n \"click\": _vm.blockUser\n }\n }, [(_vm.progress) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.block_progress')) + \"\\n \")] : [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.block')) + \"\\n \")]], 2)])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-0cfc2f90\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/block_card/block_card.vue\n// module id = 681\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', [_c('label', {\n attrs: {\n \"for\": \"interface-language-switcher\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.interfaceLanguage')) + \"\\n \")]), _vm._v(\" \"), _c('label', {\n staticClass: \"select\",\n attrs: {\n \"for\": \"interface-language-switcher\"\n }\n }, [_c('select', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.language),\n expression: \"language\"\n }],\n attrs: {\n \"id\": \"interface-language-switcher\"\n },\n on: {\n \"change\": function($event) {\n var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n return o.selected\n }).map(function(o) {\n var val = \"_value\" in o ? o._value : o.value;\n return val\n });\n _vm.language = $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n }\n }\n }, _vm._l((_vm.languageCodes), function(langCode, i) {\n return _c('option', {\n domProps: {\n \"value\": langCode\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.languageNames[i]) + \"\\n \")])\n }), 0), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-down-open\"\n })])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-119964fe\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/interface_language_switcher/interface_language_switcher.vue\n// module id = 682\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return (_vm.showing) ? _c('div', {\n staticClass: \"modal-view\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.hide($event)\n }\n }\n }, [(_vm.type === 'image') ? _c('img', {\n staticClass: \"modal-image\",\n attrs: {\n \"src\": _vm.currentMedia.url\n }\n }) : _vm._e(), _vm._v(\" \"), (_vm.type === 'video') ? _c('VideoAttachment', {\n staticClass: \"modal-image\",\n attrs: {\n \"attachment\": _vm.currentMedia,\n \"controls\": true\n },\n nativeOn: {\n \"click\": function($event) {\n $event.stopPropagation();\n }\n }\n }) : _vm._e(), _vm._v(\" \"), (_vm.canNavigate) ? _c('button', {\n staticClass: \"modal-view-button-arrow modal-view-button-arrow--prev\",\n attrs: {\n \"title\": _vm.$t('media_modal.previous')\n },\n on: {\n \"click\": function($event) {\n $event.stopPropagation();\n $event.preventDefault();\n return _vm.goPrev($event)\n }\n }\n }, [_c('i', {\n staticClass: \"icon-left-open arrow-icon\"\n })]) : _vm._e(), _vm._v(\" \"), (_vm.canNavigate) ? _c('button', {\n staticClass: \"modal-view-button-arrow modal-view-button-arrow--next\",\n attrs: {\n \"title\": _vm.$t('media_modal.next')\n },\n on: {\n \"click\": function($event) {\n $event.stopPropagation();\n $event.preventDefault();\n return _vm.goNext($event)\n }\n }\n }, [_c('i', {\n staticClass: \"icon-right-open arrow-icon\"\n })]) : _vm._e()], 1) : _vm._e()\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-1351175e\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/media_modal/media_modal.vue\n// module id = 683\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('conversation', {\n attrs: {\n \"collapsable\": false,\n \"statusoid\": _vm.statusoid\n }\n })\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-1771daec\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/conversation-page/conversation-page.vue\n// module id = 684\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"post-status-form\"\n }, [_c('form', {\n on: {\n \"submit\": function($event) {\n $event.preventDefault();\n _vm.postStatus(_vm.newStatus)\n }\n }\n }, [_c('div', {\n staticClass: \"form-group\"\n }, [(!this.$store.state.users.currentUser.locked && this.newStatus.visibility == 'private') ? _c('i18n', {\n staticClass: \"visibility-notice\",\n attrs: {\n \"path\": \"post_status.account_not_locked_warning\",\n \"tag\": \"p\"\n }\n }, [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'user-settings'\n }\n }\n }, [_vm._v(_vm._s(_vm.$t('post_status.account_not_locked_warning_link')))])], 1) : _vm._e(), _vm._v(\" \"), (this.newStatus.visibility == 'direct') ? _c('p', {\n staticClass: \"visibility-notice\"\n }, [_vm._v(_vm._s(_vm.$t('post_status.direct_warning')))]) : _vm._e(), _vm._v(\" \"), (_vm.newStatus.spoilerText || _vm.alwaysShowSubject) ? _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.newStatus.spoilerText),\n expression: \"newStatus.spoilerText\"\n }],\n staticClass: \"form-cw\",\n attrs: {\n \"type\": \"text\",\n \"placeholder\": _vm.$t('post_status.content_warning')\n },\n domProps: {\n \"value\": (_vm.newStatus.spoilerText)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.newStatus, \"spoilerText\", $event.target.value)\n }\n }\n }) : _vm._e(), _vm._v(\" \"), _c('textarea', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.newStatus.status),\n expression: \"newStatus.status\"\n }],\n ref: \"textarea\",\n staticClass: \"form-control\",\n attrs: {\n \"placeholder\": _vm.$t('post_status.default'),\n \"rows\": \"1\",\n \"disabled\": _vm.posting\n },\n domProps: {\n \"value\": (_vm.newStatus.status)\n },\n on: {\n \"click\": _vm.setCaret,\n \"keyup\": [_vm.setCaret, function($event) {\n if (!('button' in $event) && _vm._k($event.keyCode, \"enter\", 13, $event.key, \"Enter\")) { return null; }\n if (!$event.ctrlKey) { return null; }\n _vm.postStatus(_vm.newStatus)\n }],\n \"keydown\": [function($event) {\n if (!('button' in $event) && _vm._k($event.keyCode, \"down\", 40, $event.key, [\"Down\", \"ArrowDown\"])) { return null; }\n return _vm.cycleForward($event)\n }, function($event) {\n if (!('button' in $event) && _vm._k($event.keyCode, \"up\", 38, $event.key, [\"Up\", \"ArrowUp\"])) { return null; }\n return _vm.cycleBackward($event)\n }, function($event) {\n if (!('button' in $event) && _vm._k($event.keyCode, \"tab\", 9, $event.key, \"Tab\")) { return null; }\n if (!$event.shiftKey) { return null; }\n return _vm.cycleBackward($event)\n }, function($event) {\n if (!('button' in $event) && _vm._k($event.keyCode, \"tab\", 9, $event.key, \"Tab\")) { return null; }\n return _vm.cycleForward($event)\n }, function($event) {\n if (!('button' in $event) && _vm._k($event.keyCode, \"enter\", 13, $event.key, \"Enter\")) { return null; }\n return _vm.replaceCandidate($event)\n }, function($event) {\n if (!('button' in $event) && _vm._k($event.keyCode, \"enter\", 13, $event.key, \"Enter\")) { return null; }\n if (!$event.metaKey) { return null; }\n _vm.postStatus(_vm.newStatus)\n }],\n \"drop\": _vm.fileDrop,\n \"dragover\": function($event) {\n $event.preventDefault();\n return _vm.fileDrag($event)\n },\n \"input\": [function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.newStatus, \"status\", $event.target.value)\n }, _vm.resize],\n \"paste\": _vm.paste\n }\n }), _vm._v(\" \"), _c('div', {\n staticClass: \"visibility-tray\"\n }, [(_vm.formattingOptionsEnabled) ? _c('span', {\n staticClass: \"text-format\"\n }, [_c('label', {\n staticClass: \"select\",\n attrs: {\n \"for\": \"post-content-type\"\n }\n }, [_c('select', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.newStatus.contentType),\n expression: \"newStatus.contentType\"\n }],\n staticClass: \"form-control\",\n attrs: {\n \"id\": \"post-content-type\"\n },\n on: {\n \"change\": function($event) {\n var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n return o.selected\n }).map(function(o) {\n var val = \"_value\" in o ? o._value : o.value;\n return val\n });\n _vm.$set(_vm.newStatus, \"contentType\", $event.target.multiple ? $$selectedVal : $$selectedVal[0])\n }\n }\n }, [_c('option', {\n attrs: {\n \"value\": \"text/plain\"\n }\n }, [_vm._v(_vm._s(_vm.$t('post_status.content_type.plain_text')))]), _vm._v(\" \"), _c('option', {\n attrs: {\n \"value\": \"text/html\"\n }\n }, [_vm._v(\"HTML\")]), _vm._v(\" \"), _c('option', {\n attrs: {\n \"value\": \"text/markdown\"\n }\n }, [_vm._v(\"Markdown\")])]), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-down-open\"\n })])]) : _vm._e(), _vm._v(\" \"), (_vm.scopeOptionsEnabled) ? _c('div', [_c('i', {\n staticClass: \"icon-mail-alt\",\n class: _vm.vis.direct,\n attrs: {\n \"title\": _vm.$t('post_status.scope.direct')\n },\n on: {\n \"click\": function($event) {\n _vm.changeVis('direct')\n }\n }\n }), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-lock\",\n class: _vm.vis.private,\n attrs: {\n \"title\": _vm.$t('post_status.scope.private')\n },\n on: {\n \"click\": function($event) {\n _vm.changeVis('private')\n }\n }\n }), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-lock-open-alt\",\n class: _vm.vis.unlisted,\n attrs: {\n \"title\": _vm.$t('post_status.scope.unlisted')\n },\n on: {\n \"click\": function($event) {\n _vm.changeVis('unlisted')\n }\n }\n }), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-globe\",\n class: _vm.vis.public,\n attrs: {\n \"title\": _vm.$t('post_status.scope.public')\n },\n on: {\n \"click\": function($event) {\n _vm.changeVis('public')\n }\n }\n })]) : _vm._e()])], 1), _vm._v(\" \"), (_vm.candidates) ? _c('div', {\n staticStyle: {\n \"position\": \"relative\"\n }\n }, [_c('div', {\n staticClass: \"autocomplete-panel\"\n }, _vm._l((_vm.candidates), function(candidate) {\n return _c('div', {\n on: {\n \"click\": function($event) {\n _vm.replace(candidate.utf || (candidate.screen_name + ' '))\n }\n }\n }, [_c('div', {\n staticClass: \"autocomplete\",\n class: {\n highlighted: candidate.highlighted\n }\n }, [(candidate.img) ? _c('span', [_c('img', {\n attrs: {\n \"src\": candidate.img\n }\n })]) : _c('span', [_vm._v(_vm._s(candidate.utf))]), _vm._v(\" \"), _c('span', [_vm._v(_vm._s(candidate.screen_name)), _c('small', [_vm._v(_vm._s(candidate.name))])])])])\n }), 0)]) : _vm._e(), _vm._v(\" \"), _c('div', {\n staticClass: \"form-bottom\"\n }, [_c('media-upload', {\n ref: \"mediaUpload\",\n attrs: {\n \"drop-files\": _vm.dropFiles\n },\n on: {\n \"uploading\": _vm.disableSubmit,\n \"uploaded\": _vm.addMediaFile,\n \"upload-failed\": _vm.uploadFailed\n }\n }), _vm._v(\" \"), (_vm.isOverLengthLimit) ? _c('p', {\n staticClass: \"error\"\n }, [_vm._v(_vm._s(_vm.charactersLeft))]) : (_vm.hasStatusLengthLimit) ? _c('p', {\n staticClass: \"faint\"\n }, [_vm._v(_vm._s(_vm.charactersLeft))]) : _vm._e(), _vm._v(\" \"), (_vm.posting) ? _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": \"\"\n }\n }, [_vm._v(_vm._s(_vm.$t('post_status.posting')))]) : (_vm.isOverLengthLimit) ? _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": \"\"\n }\n }, [_vm._v(_vm._s(_vm.$t('general.submit')))]) : _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": _vm.submitDisabled,\n \"type\": \"submit\"\n }\n }, [_vm._v(_vm._s(_vm.$t('general.submit')))])], 1), _vm._v(\" \"), (_vm.error) ? _c('div', {\n staticClass: \"alert error\"\n }, [_vm._v(\"\\n Error: \" + _vm._s(_vm.error) + \"\\n \"), _c('i', {\n staticClass: \"button-icon icon-cancel\",\n on: {\n \"click\": _vm.clearError\n }\n })]) : _vm._e(), _vm._v(\" \"), _c('div', {\n staticClass: \"attachments\"\n }, _vm._l((_vm.newStatus.files), function(file) {\n return _c('div', {\n staticClass: \"media-upload-wrapper\"\n }, [_c('i', {\n staticClass: \"fa button-icon icon-cancel\",\n on: {\n \"click\": function($event) {\n _vm.removeMediaFile(file)\n }\n }\n }), _vm._v(\" \"), _c('div', {\n staticClass: \"media-upload-container attachment\"\n }, [(_vm.type(file) === 'image') ? _c('img', {\n staticClass: \"thumbnail media-upload\",\n attrs: {\n \"src\": file.image\n }\n }) : _vm._e(), _vm._v(\" \"), (_vm.type(file) === 'video') ? _c('video', {\n attrs: {\n \"src\": file.image,\n \"controls\": \"\"\n }\n }) : _vm._e(), _vm._v(\" \"), (_vm.type(file) === 'audio') ? _c('audio', {\n attrs: {\n \"src\": file.image,\n \"controls\": \"\"\n }\n }) : _vm._e(), _vm._v(\" \"), (_vm.type(file) === 'unknown') ? _c('a', {\n attrs: {\n \"href\": file.image\n }\n }, [_vm._v(_vm._s(file.url))]) : _vm._e()])])\n }), 0), _vm._v(\" \"), (_vm.newStatus.files.length > 0) ? _c('div', {\n staticClass: \"upload_settings\"\n }, [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.newStatus.nsfw),\n expression: \"newStatus.nsfw\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"filesSensitive\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.newStatus.nsfw) ? _vm._i(_vm.newStatus.nsfw, null) > -1 : (_vm.newStatus.nsfw)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.newStatus.nsfw,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.$set(_vm.newStatus, \"nsfw\", $$a.concat([$$v])))\n } else {\n $$i > -1 && (_vm.$set(_vm.newStatus, \"nsfw\", $$a.slice(0, $$i).concat($$a.slice($$i + 1))))\n }\n } else {\n _vm.$set(_vm.newStatus, \"nsfw\", $$c)\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"filesSensitive\"\n }\n }, [_vm._v(_vm._s(_vm.$t('post_status.attachments_sensitive')))])]) : _vm._e()])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-17731af8\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/post_status_form/post_status_form.vue\n// module id = 685\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return (_vm.contrast) ? _c('span', {\n staticClass: \"contrast-ratio\"\n }, [_c('span', {\n staticClass: \"rating\",\n attrs: {\n \"title\": _vm.hint\n }\n }, [(_vm.contrast.aaa) ? _c('span', [_c('i', {\n staticClass: \"icon-thumbs-up-alt\"\n })]) : _vm._e(), _vm._v(\" \"), (!_vm.contrast.aaa && _vm.contrast.aa) ? _c('span', [_c('i', {\n staticClass: \"icon-adjust\"\n })]) : _vm._e(), _vm._v(\" \"), (!_vm.contrast.aaa && !_vm.contrast.aa) ? _c('span', [_c('i', {\n staticClass: \"icon-attention\"\n })]) : _vm._e()]), _vm._v(\" \"), (_vm.contrast && _vm.large) ? _c('span', {\n staticClass: \"rating\",\n attrs: {\n \"title\": _vm.hint_18pt\n }\n }, [(_vm.contrast.laaa) ? _c('span', [_c('i', {\n staticClass: \"icon-thumbs-up-alt\"\n })]) : _vm._e(), _vm._v(\" \"), (!_vm.contrast.laaa && _vm.contrast.laa) ? _c('span', [_c('i', {\n staticClass: \"icon-adjust\"\n })]) : _vm._e(), _vm._v(\" \"), (!_vm.contrast.laaa && !_vm.contrast.laa) ? _c('span', [_c('i', {\n staticClass: \"icon-attention\"\n })]) : _vm._e()]) : _vm._e()]) : _vm._e()\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-1a970f38\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/contrast_ratio/contrast_ratio.vue\n// module id = 686\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"settings panel panel-default\"\n }, [_c('div', {\n staticClass: \"panel-heading\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('registration.registration')) + \"\\n \")]), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-body\"\n }, [_c('form', {\n staticClass: \"registration-form\",\n on: {\n \"submit\": function($event) {\n $event.preventDefault();\n _vm.submit(_vm.user)\n }\n }\n }, [_c('div', {\n staticClass: \"container\"\n }, [_c('div', {\n staticClass: \"text-fields\"\n }, [_c('div', {\n staticClass: \"form-group\",\n class: {\n 'form-group--error': _vm.$v.user.username.$error\n }\n }, [_c('label', {\n staticClass: \"form--label\",\n attrs: {\n \"for\": \"sign-up-username\"\n }\n }, [_vm._v(_vm._s(_vm.$t('login.username')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model.trim\",\n value: (_vm.$v.user.username.$model),\n expression: \"$v.user.username.$model\",\n modifiers: {\n \"trim\": true\n }\n }],\n staticClass: \"form-control\",\n attrs: {\n \"disabled\": _vm.isPending,\n \"id\": \"sign-up-username\",\n \"placeholder\": _vm.$t('registration.username_placeholder')\n },\n domProps: {\n \"value\": (_vm.$v.user.username.$model)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.$v.user.username, \"$model\", $event.target.value.trim())\n },\n \"blur\": function($event) {\n _vm.$forceUpdate()\n }\n }\n })]), _vm._v(\" \"), (_vm.$v.user.username.$dirty) ? _c('div', {\n staticClass: \"form-error\"\n }, [_c('ul', [(!_vm.$v.user.username.required) ? _c('li', [_c('span', [_vm._v(_vm._s(_vm.$t('registration.validations.username_required')))])]) : _vm._e()])]) : _vm._e(), _vm._v(\" \"), _c('div', {\n staticClass: \"form-group\",\n class: {\n 'form-group--error': _vm.$v.user.fullname.$error\n }\n }, [_c('label', {\n staticClass: \"form--label\",\n attrs: {\n \"for\": \"sign-up-fullname\"\n }\n }, [_vm._v(_vm._s(_vm.$t('registration.fullname')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model.trim\",\n value: (_vm.$v.user.fullname.$model),\n expression: \"$v.user.fullname.$model\",\n modifiers: {\n \"trim\": true\n }\n }],\n staticClass: \"form-control\",\n attrs: {\n \"disabled\": _vm.isPending,\n \"id\": \"sign-up-fullname\",\n \"placeholder\": _vm.$t('registration.fullname_placeholder')\n },\n domProps: {\n \"value\": (_vm.$v.user.fullname.$model)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.$v.user.fullname, \"$model\", $event.target.value.trim())\n },\n \"blur\": function($event) {\n _vm.$forceUpdate()\n }\n }\n })]), _vm._v(\" \"), (_vm.$v.user.fullname.$dirty) ? _c('div', {\n staticClass: \"form-error\"\n }, [_c('ul', [(!_vm.$v.user.fullname.required) ? _c('li', [_c('span', [_vm._v(_vm._s(_vm.$t('registration.validations.fullname_required')))])]) : _vm._e()])]) : _vm._e(), _vm._v(\" \"), _c('div', {\n staticClass: \"form-group\",\n class: {\n 'form-group--error': _vm.$v.user.email.$error\n }\n }, [_c('label', {\n staticClass: \"form--label\",\n attrs: {\n \"for\": \"email\"\n }\n }, [_vm._v(_vm._s(_vm.$t('registration.email')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.$v.user.email.$model),\n expression: \"$v.user.email.$model\"\n }],\n staticClass: \"form-control\",\n attrs: {\n \"disabled\": _vm.isPending,\n \"id\": \"email\",\n \"type\": \"email\"\n },\n domProps: {\n \"value\": (_vm.$v.user.email.$model)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.$v.user.email, \"$model\", $event.target.value)\n }\n }\n })]), _vm._v(\" \"), (_vm.$v.user.email.$dirty) ? _c('div', {\n staticClass: \"form-error\"\n }, [_c('ul', [(!_vm.$v.user.email.required) ? _c('li', [_c('span', [_vm._v(_vm._s(_vm.$t('registration.validations.email_required')))])]) : _vm._e()])]) : _vm._e(), _vm._v(\" \"), _c('div', {\n staticClass: \"form-group\"\n }, [_c('label', {\n staticClass: \"form--label\",\n attrs: {\n \"for\": \"bio\"\n }\n }, [_vm._v(_vm._s(_vm.$t('registration.bio')) + \" (\" + _vm._s(_vm.$t('general.optional')) + \")\")]), _vm._v(\" \"), _c('textarea', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.user.bio),\n expression: \"user.bio\"\n }],\n staticClass: \"form-control\",\n attrs: {\n \"disabled\": _vm.isPending,\n \"id\": \"bio\",\n \"placeholder\": _vm.$t('registration.bio_placeholder')\n },\n domProps: {\n \"value\": (_vm.user.bio)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.user, \"bio\", $event.target.value)\n }\n }\n })]), _vm._v(\" \"), _c('div', {\n staticClass: \"form-group\",\n class: {\n 'form-group--error': _vm.$v.user.password.$error\n }\n }, [_c('label', {\n staticClass: \"form--label\",\n attrs: {\n \"for\": \"sign-up-password\"\n }\n }, [_vm._v(_vm._s(_vm.$t('login.password')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.user.password),\n expression: \"user.password\"\n }],\n staticClass: \"form-control\",\n attrs: {\n \"disabled\": _vm.isPending,\n \"id\": \"sign-up-password\",\n \"type\": \"password\"\n },\n domProps: {\n \"value\": (_vm.user.password)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.user, \"password\", $event.target.value)\n }\n }\n })]), _vm._v(\" \"), (_vm.$v.user.password.$dirty) ? _c('div', {\n staticClass: \"form-error\"\n }, [_c('ul', [(!_vm.$v.user.password.required) ? _c('li', [_c('span', [_vm._v(_vm._s(_vm.$t('registration.validations.password_required')))])]) : _vm._e()])]) : _vm._e(), _vm._v(\" \"), _c('div', {\n staticClass: \"form-group\",\n class: {\n 'form-group--error': _vm.$v.user.confirm.$error\n }\n }, [_c('label', {\n staticClass: \"form--label\",\n attrs: {\n \"for\": \"sign-up-password-confirmation\"\n }\n }, [_vm._v(_vm._s(_vm.$t('registration.password_confirm')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.user.confirm),\n expression: \"user.confirm\"\n }],\n staticClass: \"form-control\",\n attrs: {\n \"disabled\": _vm.isPending,\n \"id\": \"sign-up-password-confirmation\",\n \"type\": \"password\"\n },\n domProps: {\n \"value\": (_vm.user.confirm)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.user, \"confirm\", $event.target.value)\n }\n }\n })]), _vm._v(\" \"), (_vm.$v.user.confirm.$dirty) ? _c('div', {\n staticClass: \"form-error\"\n }, [_c('ul', [(!_vm.$v.user.confirm.required) ? _c('li', [_c('span', [_vm._v(_vm._s(_vm.$t('registration.validations.password_confirmation_required')))])]) : _vm._e(), _vm._v(\" \"), (!_vm.$v.user.confirm.sameAsPassword) ? _c('li', [_c('span', [_vm._v(_vm._s(_vm.$t('registration.validations.password_confirmation_match')))])]) : _vm._e()])]) : _vm._e(), _vm._v(\" \"), (_vm.captcha.type != 'none') ? _c('div', {\n staticClass: \"form-group\",\n attrs: {\n \"id\": \"captcha-group\"\n }\n }, [_c('label', {\n staticClass: \"form--label\",\n attrs: {\n \"for\": \"captcha-label\"\n }\n }, [_vm._v(_vm._s(_vm.$t('captcha')))]), _vm._v(\" \"), (_vm.captcha.type == 'kocaptcha') ? [_c('img', {\n attrs: {\n \"src\": _vm.captcha.url\n },\n on: {\n \"click\": _vm.setCaptcha\n }\n }), _vm._v(\" \"), _c('sub', [_vm._v(_vm._s(_vm.$t('registration.new_captcha')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.captcha.solution),\n expression: \"captcha.solution\"\n }],\n staticClass: \"form-control\",\n attrs: {\n \"disabled\": _vm.isPending,\n \"id\": \"captcha-answer\",\n \"type\": \"text\",\n \"autocomplete\": \"off\"\n },\n domProps: {\n \"value\": (_vm.captcha.solution)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.captcha, \"solution\", $event.target.value)\n }\n }\n })] : _vm._e()], 2) : _vm._e(), _vm._v(\" \"), (_vm.token) ? _c('div', {\n staticClass: \"form-group\"\n }, [_c('label', {\n attrs: {\n \"for\": \"token\"\n }\n }, [_vm._v(_vm._s(_vm.$t('registration.token')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.token),\n expression: \"token\"\n }],\n staticClass: \"form-control\",\n attrs: {\n \"disabled\": \"true\",\n \"id\": \"token\",\n \"type\": \"text\"\n },\n domProps: {\n \"value\": (_vm.token)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.token = $event.target.value\n }\n }\n })]) : _vm._e(), _vm._v(\" \"), _c('div', {\n staticClass: \"form-group\"\n }, [_c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": _vm.isPending,\n \"type\": \"submit\"\n }\n }, [_vm._v(_vm._s(_vm.$t('general.submit')))])])]), _vm._v(\" \"), _c('div', {\n staticClass: \"terms-of-service\",\n domProps: {\n \"innerHTML\": _vm._s(_vm.termsOfService)\n }\n })]), _vm._v(\" \"), (_vm.serverValidationErrors.length) ? _c('div', {\n staticClass: \"form-group\"\n }, [_c('div', {\n staticClass: \"alert error\"\n }, _vm._l((_vm.serverValidationErrors), function(error) {\n return _c('span', [_vm._v(_vm._s(error))])\n }), 0)]) : _vm._e()])])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-23a871d8\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/registration/registration.vue\n// module id = 687\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"nav-panel\"\n }, [_c('div', {\n staticClass: \"panel panel-default\"\n }, [_c('ul', [(_vm.currentUser) ? _c('li', [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'friends'\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.timeline\")) + \"\\n \")])], 1) : _vm._e(), _vm._v(\" \"), (_vm.currentUser) ? _c('li', [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'mentions',\n params: {\n username: _vm.currentUser.screen_name\n }\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.mentions\")) + \"\\n \")])], 1) : _vm._e(), _vm._v(\" \"), (_vm.currentUser) ? _c('li', [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'dms',\n params: {\n username: _vm.currentUser.screen_name\n }\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.dms\")) + \"\\n \")])], 1) : _vm._e(), _vm._v(\" \"), (_vm.currentUser && _vm.currentUser.locked) ? _c('li', [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'friend-requests'\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.friend_requests\")) + \"\\n \"), (_vm.followRequestCount > 0) ? _c('span', {\n staticClass: \"badge follow-request-count\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.followRequestCount) + \"\\n \")]) : _vm._e()])], 1) : _vm._e(), _vm._v(\" \"), _c('li', [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'public-timeline'\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.public_tl\")) + \"\\n \")])], 1), _vm._v(\" \"), _c('li', [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'public-external-timeline'\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.twkn\")) + \"\\n \")])], 1)])])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-23ab246c\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/nav_panel/nav_panel.vue\n// module id = 688\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', [(_vm.user.id) ? _c('div', {\n staticClass: \"user-profile panel panel-default\"\n }, [_c('user-card-content', {\n attrs: {\n \"user\": _vm.user,\n \"switcher\": true,\n \"selected\": _vm.timeline.viewing\n }\n }), _vm._v(\" \"), _c('tab-switcher', {\n ref: \"tabSwitcher\",\n attrs: {\n \"renderOnlyFocused\": true\n }\n }, [_c('Timeline', {\n attrs: {\n \"label\": _vm.$t('user_card.statuses'),\n \"disabled\": !_vm.user.statuses_count,\n \"count\": _vm.user.statuses_count,\n \"embedded\": true,\n \"title\": _vm.$t('user_profile.timeline_title'),\n \"timeline\": _vm.timeline,\n \"timeline-name\": 'user',\n \"user-id\": _vm.fetchBy\n }\n }), _vm._v(\" \"), (_vm.followsTabVisible) ? _c('div', {\n attrs: {\n \"label\": _vm.$t('user_card.followees'),\n \"disabled\": !_vm.user.friends_count\n }\n }, [_c('FriendList', {\n attrs: {\n \"userId\": _vm.userId\n }\n })], 1) : _vm._e(), _vm._v(\" \"), (_vm.followersTabVisible) ? _c('div', {\n attrs: {\n \"label\": _vm.$t('user_card.followers'),\n \"disabled\": !_vm.user.followers_count\n }\n }, [_c('FollowerList', {\n attrs: {\n \"userId\": _vm.userId,\n \"entryProps\": {\n noFollowsYou: _vm.isUs\n }\n }\n })], 1) : _vm._e(), _vm._v(\" \"), _c('Timeline', {\n attrs: {\n \"label\": _vm.$t('user_card.media'),\n \"disabled\": !_vm.media.visibleStatuses.length,\n \"embedded\": true,\n \"title\": _vm.$t('user_card.media'),\n \"timeline-name\": \"media\",\n \"timeline\": _vm.media,\n \"user-id\": _vm.fetchBy\n }\n }), _vm._v(\" \"), (_vm.isUs) ? _c('Timeline', {\n attrs: {\n \"label\": _vm.$t('user_card.favorites'),\n \"disabled\": !_vm.favorites.visibleStatuses.length,\n \"embedded\": true,\n \"title\": _vm.$t('user_card.favorites'),\n \"timeline-name\": \"favorites\",\n \"timeline\": _vm.favorites\n }\n }) : _vm._e()], 1)], 1) : _c('div', {\n staticClass: \"panel user-profile-placeholder\"\n }, [_c('div', {\n staticClass: \"panel-heading\"\n }, [_c('div', {\n staticClass: \"title\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.profile_tab')) + \"\\n \")])]), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-body\"\n }, [(_vm.error) ? _c('span', [_vm._v(_vm._s(_vm.error))]) : _c('i', {\n staticClass: \"icon-spin3 animate-spin\"\n })])])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-26005b58\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/user_profile/user_profile.vue\n// module id = 689\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return (_vm.loggedIn) ? _c('div', [(_vm.visibility !== 'private' && _vm.visibility !== 'direct') ? [_c('i', {\n staticClass: \"button-icon retweet-button icon-retweet rt-active\",\n class: _vm.classes,\n attrs: {\n \"title\": _vm.$t('tool_tip.repeat')\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n _vm.retweet()\n }\n }\n }), _vm._v(\" \"), (!_vm.hidePostStatsLocal && _vm.status.repeat_num > 0) ? _c('span', [_vm._v(_vm._s(_vm.status.repeat_num))]) : _vm._e()] : [_c('i', {\n staticClass: \"button-icon icon-lock\",\n class: _vm.classes,\n attrs: {\n \"title\": _vm.$t('timeline.no_retweet_hint')\n }\n })]], 2) : (!_vm.loggedIn) ? _c('div', [_c('i', {\n staticClass: \"button-icon icon-retweet\",\n class: _vm.classes,\n attrs: {\n \"title\": _vm.$t('tool_tip.repeat')\n }\n }), _vm._v(\" \"), (!_vm.hidePostStatsLocal && _vm.status.repeat_num > 0) ? _c('span', [_vm._v(_vm._s(_vm.status.repeat_num))]) : _vm._e()]) : _vm._e()\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-28288ed0\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/retweet_button/retweet_button.vue\n// module id = 690\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"font-control style-control\",\n class: {\n custom: _vm.isCustom\n }\n }, [_c('label', {\n staticClass: \"label\",\n attrs: {\n \"for\": _vm.preset === 'custom' ? _vm.name : _vm.name + '-font-switcher'\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.label) + \"\\n \")]), _vm._v(\" \"), (typeof _vm.fallback !== 'undefined') ? _c('input', {\n staticClass: \"opt exlcude-disabled\",\n attrs: {\n \"type\": \"checkbox\",\n \"id\": _vm.name + '-o'\n },\n domProps: {\n \"checked\": _vm.present\n },\n on: {\n \"input\": function($event) {\n _vm.$emit('input', typeof _vm.value === 'undefined' ? _vm.fallback : undefined)\n }\n }\n }) : _vm._e(), _vm._v(\" \"), (typeof _vm.fallback !== 'undefined') ? _c('label', {\n staticClass: \"opt-l\",\n attrs: {\n \"for\": _vm.name + '-o'\n }\n }) : _vm._e(), _vm._v(\" \"), _c('label', {\n staticClass: \"select\",\n attrs: {\n \"for\": _vm.name + '-font-switcher',\n \"disabled\": !_vm.present\n }\n }, [_c('select', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.preset),\n expression: \"preset\"\n }],\n staticClass: \"font-switcher\",\n attrs: {\n \"disabled\": !_vm.present,\n \"id\": _vm.name + '-font-switcher'\n },\n on: {\n \"change\": function($event) {\n var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n return o.selected\n }).map(function(o) {\n var val = \"_value\" in o ? o._value : o.value;\n return val\n });\n _vm.preset = $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n }\n }\n }, _vm._l((_vm.availableOptions), function(option) {\n return _c('option', {\n domProps: {\n \"value\": option\n }\n }, [_vm._v(\"\\n \" + _vm._s(option === 'custom' ? _vm.$t('settings.style.fonts.custom') : option) + \"\\n \")])\n }), 0), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-down-open\"\n })]), _vm._v(\" \"), (_vm.isCustom) ? _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.family),\n expression: \"family\"\n }],\n staticClass: \"custom-font\",\n attrs: {\n \"type\": \"text\",\n \"id\": _vm.name\n },\n domProps: {\n \"value\": (_vm.family)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.family = $event.target.value\n }\n }\n }) : _vm._e()])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-2979f658\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/font_control/font_control.vue\n// module id = 691\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"panel dummy\"\n }, [_c('div', {\n staticClass: \"panel-heading\"\n }, [_c('div', {\n staticClass: \"title\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.header')) + \"\\n \"), _c('span', {\n staticClass: \"badge badge-notification\"\n }, [_vm._v(\"\\n 99\\n \")])]), _vm._v(\" \"), _c('span', {\n staticClass: \"faint\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.header_faint')) + \"\\n \")]), _vm._v(\" \"), _c('span', {\n staticClass: \"alert error\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.error')) + \"\\n \")]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.button')) + \"\\n \")])]), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-body theme-preview-content\"\n }, [_c('div', {\n staticClass: \"post\"\n }, [_c('div', {\n staticClass: \"avatar\"\n }, [_vm._v(\"\\n ( ͡° ͜ʖ ͡°)\\n \")]), _vm._v(\" \"), _c('div', {\n staticClass: \"content\"\n }, [_c('h4', [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.content')) + \"\\n \")]), _vm._v(\" \"), _c('i18n', {\n attrs: {\n \"path\": \"settings.style.preview.text\"\n }\n }, [_c('code', {\n staticStyle: {\n \"font-family\": \"var(--postCodeFont)\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.mono')) + \"\\n \")]), _vm._v(\" \"), _c('a', {\n staticStyle: {\n \"color\": \"var(--link)\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.link')) + \"\\n \")])]), _vm._v(\" \"), _vm._m(0)], 1)]), _vm._v(\" \"), _c('div', {\n staticClass: \"after-post\"\n }, [_c('div', {\n staticClass: \"avatar-alt\"\n }, [_vm._v(\"\\n :^)\\n \")]), _vm._v(\" \"), _c('div', {\n staticClass: \"content\"\n }, [_c('i18n', {\n staticClass: \"faint\",\n attrs: {\n \"path\": \"settings.style.preview.fine_print\",\n \"tag\": \"span\"\n }\n }, [_c('a', {\n staticStyle: {\n \"color\": \"var(--faintLink)\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.faint_link')) + \"\\n \")])])], 1)]), _vm._v(\" \"), _c('div', {\n staticClass: \"separator\"\n }), _vm._v(\" \"), _c('span', {\n staticClass: \"alert error\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.error')) + \"\\n \")]), _vm._v(\" \"), _c('input', {\n attrs: {\n \"type\": \"text\"\n },\n domProps: {\n \"value\": _vm.$t('settings.style.preview.input')\n }\n }), _vm._v(\" \"), _c('div', {\n staticClass: \"actions\"\n }, [_c('span', {\n staticClass: \"checkbox\"\n }, [_c('input', {\n attrs: {\n \"checked\": \"very yes\",\n \"type\": \"checkbox\",\n \"id\": \"preview_checkbox\"\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"preview_checkbox\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.preview.checkbox')))])]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.button')) + \"\\n \")])])])])\n},staticRenderFns: [function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"icons\"\n }, [_c('i', {\n staticClass: \"button-icon icon-reply\",\n staticStyle: {\n \"color\": \"var(--cBlue)\"\n }\n }), _vm._v(\" \"), _c('i', {\n staticClass: \"button-icon icon-retweet\",\n staticStyle: {\n \"color\": \"var(--cGreen)\"\n }\n }), _vm._v(\" \"), _c('i', {\n staticClass: \"button-icon icon-star\",\n staticStyle: {\n \"color\": \"var(--cOrange)\"\n }\n }), _vm._v(\" \"), _c('i', {\n staticClass: \"button-icon icon-cancel\",\n staticStyle: {\n \"color\": \"var(--cRed)\"\n }\n })])\n}]}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-2da7d1a2\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/style_switcher/preview.vue\n// module id = 692\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('Timeline', {\n attrs: {\n \"title\": _vm.$t('nav.mentions'),\n \"timeline\": _vm.timeline,\n \"timeline-name\": 'mentions'\n }\n })\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-2de5c050\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/mentions/mentions.vue\n// module id = 693\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"media-upload\",\n on: {\n \"drop\": [function($event) {\n $event.preventDefault();\n }, _vm.fileDrop],\n \"dragover\": function($event) {\n $event.preventDefault();\n return _vm.fileDrag($event)\n }\n }\n }, [_c('label', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"title\": _vm.$t('tool_tip.media_upload')\n }\n }, [(_vm.uploading) ? _c('i', {\n staticClass: \"icon-spin4 animate-spin\"\n }) : _vm._e(), _vm._v(\" \"), (!_vm.uploading) ? _c('i', {\n staticClass: \"icon-upload\"\n }) : _vm._e(), _vm._v(\" \"), (_vm.uploadReady) ? _c('input', {\n staticStyle: {\n \"position\": \"fixed\",\n \"top\": \"-100em\"\n },\n attrs: {\n \"type\": \"file\",\n \"multiple\": \"true\"\n },\n on: {\n \"change\": _vm.change\n }\n }) : _vm._e()])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-32209eb8\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/media_upload/media_upload.vue\n// module id = 694\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n ref: \"galleryContainer\",\n staticStyle: {\n \"width\": \"100%\"\n }\n }, _vm._l((_vm.rows), function(row) {\n return _c('div', {\n staticClass: \"gallery-row\",\n class: {\n 'contain-fit': _vm.useContainFit, 'cover-fit': !_vm.useContainFit\n },\n style: (_vm.rowHeight(row.length))\n }, _vm._l((row), function(attachment) {\n return _c('attachment', {\n key: attachment.id,\n attrs: {\n \"setMedia\": _vm.setMedia,\n \"nsfw\": _vm.nsfw,\n \"attachment\": attachment,\n \"allowPlay\": false\n }\n })\n }), 1)\n }), 0)\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-34b44944\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/gallery/gallery.vue\n// module id = 695\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', [_c('div', {\n staticClass: \"panel panel-default\"\n }, [_c('div', {\n staticClass: \"panel-body\"\n }, [_c('div', {\n staticClass: \"tos-content\",\n domProps: {\n \"innerHTML\": _vm._s(_vm.content)\n }\n })])])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-37956e90\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/terms_of_service_panel/terms_of_service_panel.vue\n// module id = 696\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('h1', [_vm._v(\"...\")])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-3b485558\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/oauth_callback/oauth_callback.vue\n// module id = 697\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"features-panel\"\n }, [_c('div', {\n staticClass: \"panel panel-default base01-background\"\n }, [_c('div', {\n staticClass: \"panel-heading timeline-heading base02-background base04\"\n }, [_c('div', {\n staticClass: \"title\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('features_panel.title')) + \"\\n \")])]), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-body features-panel\"\n }, [_c('ul', [(_vm.chat) ? _c('li', [_vm._v(_vm._s(_vm.$t('features_panel.chat')))]) : _vm._e(), _vm._v(\" \"), (_vm.gopher) ? _c('li', [_vm._v(_vm._s(_vm.$t('features_panel.gopher')))]) : _vm._e(), _vm._v(\" \"), (_vm.whoToFollow) ? _c('li', [_vm._v(_vm._s(_vm.$t('features_panel.who_to_follow')))]) : _vm._e(), _vm._v(\" \"), (_vm.mediaProxy) ? _c('li', [_vm._v(_vm._s(_vm.$t('features_panel.media_proxy')))]) : _vm._e(), _vm._v(\" \"), (_vm.scopeOptions) ? _c('li', [_vm._v(_vm._s(_vm.$t('features_panel.scope_options')))]) : _vm._e(), _vm._v(\" \"), _c('li', [_vm._v(_vm._s(_vm.$t('features_panel.text_limit')) + \" = \" + _vm._s(_vm.textlimit))])])])])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-40f388b8\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/features_panel/features_panel.vue\n// module id = 698\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('basic-user-card', {\n attrs: {\n \"user\": _vm.user\n }\n }, [_c('div', {\n staticClass: \"follow-request-card-content-container\"\n }, [_c('button', {\n staticClass: \"btn btn-default\",\n on: {\n \"click\": _vm.approveUser\n }\n }, [_vm._v(_vm._s(_vm.$t('user_card.approve')))]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn btn-default\",\n on: {\n \"click\": _vm.denyUser\n }\n }, [_vm._v(_vm._s(_vm.$t('user_card.deny')))])])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-45e71c56\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/follow_request_card/follow_request_card.vue\n// module id = 699\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"import-export-container\"\n }, [_vm._t(\"before\"), _vm._v(\" \"), _c('button', {\n staticClass: \"btn\",\n on: {\n \"click\": _vm.exportData\n }\n }, [_vm._v(_vm._s(_vm.exportLabel))]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn\",\n on: {\n \"click\": _vm.importData\n }\n }, [_vm._v(_vm._s(_vm.importLabel))]), _vm._v(\" \"), _vm._t(\"afterButtons\"), _vm._v(\" \"), (_vm.importFailed) ? _c('p', {\n staticClass: \"alert error\"\n }, [_vm._v(_vm._s(_vm.importFailedText))]) : _vm._e(), _vm._v(\" \"), _vm._t(\"afterError\")], 2)\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-45eb80cc\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/export_import/export_import.vue\n// module id = 700\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return (_vm.notification.type === 'mention') ? _c('status', {\n attrs: {\n \"compact\": true,\n \"statusoid\": _vm.notification.status\n }\n }) : _c('div', {\n staticClass: \"non-mention\",\n class: [_vm.userClass, {\n highlighted: _vm.userStyle\n }],\n style: ([_vm.userStyle])\n }, [_c('a', {\n staticClass: \"avatar-container\",\n attrs: {\n \"href\": _vm.notification.action.user.statusnet_profile_url\n },\n on: {\n \"!click\": function($event) {\n $event.stopPropagation();\n $event.preventDefault();\n return _vm.toggleUserExpanded($event)\n }\n }\n }, [_c('UserAvatar', {\n attrs: {\n \"compact\": true,\n \"betterShadow\": _vm.betterShadow,\n \"src\": _vm.notification.action.user.profile_image_url_original\n }\n })], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"notification-right\"\n }, [(_vm.userExpanded) ? _c('div', {\n staticClass: \"usercard notification-usercard\"\n }, [_c('user-card-content', {\n attrs: {\n \"user\": _vm.notification.action.user,\n \"switcher\": false\n }\n })], 1) : _vm._e(), _vm._v(\" \"), _c('span', {\n staticClass: \"notification-details\"\n }, [_c('div', {\n staticClass: \"name-and-action\"\n }, [(!!_vm.notification.action.user.name_html) ? _c('span', {\n staticClass: \"username\",\n attrs: {\n \"title\": '@' + _vm.notification.action.user.screen_name\n },\n domProps: {\n \"innerHTML\": _vm._s(_vm.notification.action.user.name_html)\n }\n }) : _c('span', {\n staticClass: \"username\",\n attrs: {\n \"title\": '@' + _vm.notification.action.user.screen_name\n }\n }, [_vm._v(_vm._s(_vm.notification.action.user.name))]), _vm._v(\" \"), (_vm.notification.type === 'like') ? _c('span', [_c('i', {\n staticClass: \"fa icon-star lit\"\n }), _vm._v(\" \"), _c('small', [_vm._v(_vm._s(_vm.$t('notifications.favorited_you')))])]) : _vm._e(), _vm._v(\" \"), (_vm.notification.type === 'repeat') ? _c('span', [_c('i', {\n staticClass: \"fa icon-retweet lit\",\n attrs: {\n \"title\": _vm.$t('tool_tip.repeat')\n }\n }), _vm._v(\" \"), _c('small', [_vm._v(_vm._s(_vm.$t('notifications.repeated_you')))])]) : _vm._e(), _vm._v(\" \"), (_vm.notification.type === 'follow') ? _c('span', [_c('i', {\n staticClass: \"fa icon-user-plus lit\"\n }), _vm._v(\" \"), _c('small', [_vm._v(_vm._s(_vm.$t('notifications.followed_you')))])]) : _vm._e()]), _vm._v(\" \"), _c('div', {\n staticClass: \"timeago\"\n }, [(_vm.notification.status) ? _c('router-link', {\n staticClass: \"faint-link\",\n attrs: {\n \"to\": {\n name: 'conversation',\n params: {\n id: _vm.notification.status.id\n }\n }\n }\n }, [_c('timeago', {\n attrs: {\n \"since\": _vm.notification.action.created_at,\n \"auto-update\": 240\n }\n })], 1) : _vm._e()], 1)]), _vm._v(\" \"), (_vm.notification.type === 'follow') ? _c('div', {\n staticClass: \"follow-text\"\n }, [_c('router-link', {\n attrs: {\n \"to\": _vm.userProfileLink(_vm.notification.action.user)\n }\n }, [_vm._v(\"\\n @\" + _vm._s(_vm.notification.action.user.screen_name) + \"\\n \")])], 1) : [_c('status', {\n staticClass: \"faint\",\n attrs: {\n \"compact\": true,\n \"statusoid\": _vm.notification.status,\n \"noHeading\": true\n }\n })]], 2)])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-46ab3318\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/notification/notification.vue\n// module id = 701\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('StillImage', {\n staticClass: \"avatar\",\n class: {\n 'avatar-compact': _vm.compact, 'better-shadow': _vm.betterShadow\n },\n attrs: {\n \"src\": _vm.imgSrc,\n \"imageLoadError\": _vm.imageLoadError\n }\n })\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-48225754\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/user_avatar/user_avatar.vue\n// module id = 702\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', [_c('a', {\n staticClass: \"link-preview-card\",\n attrs: {\n \"href\": _vm.card.url,\n \"target\": \"_blank\",\n \"rel\": \"noopener\"\n }\n }, [(_vm.useImage) ? _c('div', {\n staticClass: \"card-image\",\n class: {\n 'small-image': _vm.size === 'small'\n }\n }, [_c('img', {\n attrs: {\n \"src\": _vm.card.image\n }\n })]) : _vm._e(), _vm._v(\" \"), _c('div', {\n staticClass: \"card-content\"\n }, [_c('span', {\n staticClass: \"card-host faint\"\n }, [_vm._v(_vm._s(_vm.card.provider_name))]), _vm._v(\" \"), _c('h4', {\n staticClass: \"card-title\"\n }, [_vm._v(_vm._s(_vm.card.title))]), _vm._v(\" \"), (_vm.useDescription) ? _c('p', {\n staticClass: \"card-description\"\n }, [_vm._v(_vm._s(_vm.card.description))]) : _vm._e()])])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-4cb37358\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/link-preview/link-preview.vue\n// module id = 703\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"notifications\"\n }, [_c('div', {\n staticClass: \"panel panel-default\"\n }, [_c('div', {\n staticClass: \"panel-heading\"\n }, [_c('div', {\n staticClass: \"title\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('notifications.notifications')) + \"\\n \"), (_vm.unseenCount) ? _c('span', {\n staticClass: \"badge badge-notification unseen-count\"\n }, [_vm._v(_vm._s(_vm.unseenCount))]) : _vm._e()]), _vm._v(\" \"), (_vm.error) ? _c('div', {\n staticClass: \"loadmore-error alert error\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('timeline.error_fetching')) + \"\\n \")]) : _vm._e(), _vm._v(\" \"), (_vm.unseenCount) ? _c('button', {\n staticClass: \"read-button\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.markAsSeen($event)\n }\n }\n }, [_vm._v(_vm._s(_vm.$t('notifications.read')))]) : _vm._e()]), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-body\"\n }, _vm._l((_vm.visibleNotifications), function(notification) {\n return _c('div', {\n key: notification.action.id,\n staticClass: \"notification\",\n class: {\n \"unseen\": !notification.seen\n }\n }, [_c('div', {\n staticClass: \"notification-overlay\"\n }), _vm._v(\" \"), _c('notification', {\n attrs: {\n \"notification\": notification\n }\n })], 1)\n }), 0), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-footer\"\n }, [(_vm.bottomedOut) ? _c('div', {\n staticClass: \"new-status-notification text-center panel-footer faint\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('notifications.no_more_notifications')) + \"\\n \")]) : (!_vm.loading) ? _c('a', {\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n _vm.fetchOlderNotifications()\n }\n }\n }, [_c('div', {\n staticClass: \"new-status-notification text-center panel-footer\"\n }, [_vm._v(_vm._s(_vm.$t('notifications.load_older')))])]) : _c('div', {\n staticClass: \"new-status-notification text-center panel-footer\"\n }, [_c('i', {\n staticClass: \"icon-spin3 animate-spin\"\n })])])])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-4ffc824a\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/notifications/notifications.vue\n// module id = 704\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"settings panel panel-default\"\n }, [_c('div', {\n staticClass: \"panel-heading\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('nav.friend_requests')) + \"\\n \")]), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-body\"\n }, _vm._l((_vm.requests), function(request) {\n return _c('FollowRequestCard', {\n key: request.id,\n attrs: {\n \"user\": request\n }\n })\n }), 1)])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-56ec10de\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/follow_requests/follow_requests.vue\n// module id = 705\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"timeline panel panel-default\"\n }, [_c('div', {\n staticClass: \"panel-heading conversation-heading\"\n }, [_c('span', {\n staticClass: \"title\"\n }, [_vm._v(\" \" + _vm._s(_vm.$t('timeline.conversation')) + \" \")]), _vm._v(\" \"), (_vm.collapsable) ? _c('span', [_c('a', {\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n _vm.$emit('toggleExpanded')\n }\n }\n }, [_vm._v(_vm._s(_vm.$t('timeline.collapse')))])]) : _vm._e()]), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-body\"\n }, [_c('div', {\n staticClass: \"timeline\"\n }, _vm._l((_vm.conversation), function(status) {\n return _c('status', {\n key: status.id,\n staticClass: \"status-fadein\",\n attrs: {\n \"inlineExpanded\": _vm.collapsable,\n \"statusoid\": status,\n \"expandable\": false,\n \"focused\": _vm.focused(status.id),\n \"inConversation\": true,\n \"highlight\": _vm.highlight,\n \"replies\": _vm.getReplies(status.id)\n },\n on: {\n \"goto\": _vm.setHighlight\n }\n })\n }), 1)])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-57136bd0\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/conversation/conversation.vue\n// module id = 706\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"settings panel panel-default\"\n }, [_c('div', {\n staticClass: \"panel-heading\"\n }, [_c('div', {\n staticClass: \"title\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.settings')) + \"\\n \")]), _vm._v(\" \"), _c('transition', {\n attrs: {\n \"name\": \"fade\"\n }\n }, [(_vm.currentSaveStateNotice) ? [(_vm.currentSaveStateNotice.error) ? _c('div', {\n staticClass: \"alert error\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.saving_err')) + \"\\n \")]) : _vm._e(), _vm._v(\" \"), (!_vm.currentSaveStateNotice.error) ? _c('div', {\n staticClass: \"alert transparent\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.saving_ok')) + \"\\n \")]) : _vm._e()] : _vm._e()], 2)], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-body\"\n }, [_c('keep-alive', [_c('tab-switcher', [_c('div', {\n attrs: {\n \"label\": _vm.$t('settings.general')\n }\n }, [_c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.interface')))]), _vm._v(\" \"), _c('ul', {\n staticClass: \"setting-list\"\n }, [_c('li', [_c('interface-language-switcher')], 1), _vm._v(\" \"), (_vm.instanceSpecificPanelPresent) ? _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.hideISPLocal),\n expression: \"hideISPLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"hideISP\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.hideISPLocal) ? _vm._i(_vm.hideISPLocal, null) > -1 : (_vm.hideISPLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.hideISPLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.hideISPLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.hideISPLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.hideISPLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"hideISP\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.hide_isp')))])]) : _vm._e()])]), _vm._v(\" \"), _c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('nav.timeline')))]), _vm._v(\" \"), _c('ul', {\n staticClass: \"setting-list\"\n }, [_c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.collapseMessageWithSubjectLocal),\n expression: \"collapseMessageWithSubjectLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"collapseMessageWithSubject\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.collapseMessageWithSubjectLocal) ? _vm._i(_vm.collapseMessageWithSubjectLocal, null) > -1 : (_vm.collapseMessageWithSubjectLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.collapseMessageWithSubjectLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.collapseMessageWithSubjectLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.collapseMessageWithSubjectLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.collapseMessageWithSubjectLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"collapseMessageWithSubject\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.collapse_subject')) + \" \" + _vm._s(_vm.$t('settings.instance_default', {\n value: _vm.collapseMessageWithSubjectDefault\n })) + \"\\n \")])]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.streamingLocal),\n expression: \"streamingLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"streaming\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.streamingLocal) ? _vm._i(_vm.streamingLocal, null) > -1 : (_vm.streamingLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.streamingLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.streamingLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.streamingLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.streamingLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"streaming\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.streaming')))]), _vm._v(\" \"), _c('ul', {\n staticClass: \"setting-list suboptions\",\n class: [{\n disabled: !_vm.streamingLocal\n }]\n }, [_c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.pauseOnUnfocusedLocal),\n expression: \"pauseOnUnfocusedLocal\"\n }],\n attrs: {\n \"disabled\": !_vm.streamingLocal,\n \"type\": \"checkbox\",\n \"id\": \"pauseOnUnfocused\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.pauseOnUnfocusedLocal) ? _vm._i(_vm.pauseOnUnfocusedLocal, null) > -1 : (_vm.pauseOnUnfocusedLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.pauseOnUnfocusedLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.pauseOnUnfocusedLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.pauseOnUnfocusedLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.pauseOnUnfocusedLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"pauseOnUnfocused\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.pause_on_unfocused')))])])])]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.autoLoadLocal),\n expression: \"autoLoadLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"autoload\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.autoLoadLocal) ? _vm._i(_vm.autoLoadLocal, null) > -1 : (_vm.autoLoadLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.autoLoadLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.autoLoadLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.autoLoadLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.autoLoadLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"autoload\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.autoload')))])]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.hoverPreviewLocal),\n expression: \"hoverPreviewLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"hoverPreview\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.hoverPreviewLocal) ? _vm._i(_vm.hoverPreviewLocal, null) > -1 : (_vm.hoverPreviewLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.hoverPreviewLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.hoverPreviewLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.hoverPreviewLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.hoverPreviewLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"hoverPreview\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.reply_link_preview')))])])])]), _vm._v(\" \"), _c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.composing')))]), _vm._v(\" \"), _c('ul', {\n staticClass: \"setting-list\"\n }, [_c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.scopeCopyLocal),\n expression: \"scopeCopyLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"scopeCopy\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.scopeCopyLocal) ? _vm._i(_vm.scopeCopyLocal, null) > -1 : (_vm.scopeCopyLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.scopeCopyLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.scopeCopyLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.scopeCopyLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.scopeCopyLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"scopeCopy\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.scope_copy')) + \" \" + _vm._s(_vm.$t('settings.instance_default', {\n value: _vm.scopeCopyDefault\n })) + \"\\n \")])]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.alwaysShowSubjectInputLocal),\n expression: \"alwaysShowSubjectInputLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"subjectHide\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.alwaysShowSubjectInputLocal) ? _vm._i(_vm.alwaysShowSubjectInputLocal, null) > -1 : (_vm.alwaysShowSubjectInputLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.alwaysShowSubjectInputLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.alwaysShowSubjectInputLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.alwaysShowSubjectInputLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.alwaysShowSubjectInputLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"subjectHide\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.subject_input_always_show')) + \" \" + _vm._s(_vm.$t('settings.instance_default', {\n value: _vm.alwaysShowSubjectInputDefault\n })) + \"\\n \")])]), _vm._v(\" \"), _c('li', [_c('div', [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.subject_line_behavior')) + \"\\n \"), _c('label', {\n staticClass: \"select\",\n attrs: {\n \"for\": \"subjectLineBehavior\"\n }\n }, [_c('select', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.subjectLineBehaviorLocal),\n expression: \"subjectLineBehaviorLocal\"\n }],\n attrs: {\n \"id\": \"subjectLineBehavior\"\n },\n on: {\n \"change\": function($event) {\n var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n return o.selected\n }).map(function(o) {\n var val = \"_value\" in o ? o._value : o.value;\n return val\n });\n _vm.subjectLineBehaviorLocal = $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n }\n }\n }, [_c('option', {\n attrs: {\n \"value\": \"email\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.subject_line_email')) + \"\\n \" + _vm._s(_vm.subjectLineBehaviorDefault == 'email' ? _vm.$t('settings.instance_default_simple') : '') + \"\\n \")]), _vm._v(\" \"), _c('option', {\n attrs: {\n \"value\": \"masto\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.subject_line_mastodon')) + \"\\n \" + _vm._s(_vm.subjectLineBehaviorDefault == 'mastodon' ? _vm.$t('settings.instance_default_simple') : '') + \"\\n \")]), _vm._v(\" \"), _c('option', {\n attrs: {\n \"value\": \"noop\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.subject_line_noop')) + \"\\n \" + _vm._s(_vm.subjectLineBehaviorDefault == 'noop' ? _vm.$t('settings.instance_default_simple') : '') + \"\\n \")])]), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-down-open\"\n })])])]), _vm._v(\" \"), _c('li', [_c('div', [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.post_status_content_type')) + \"\\n \"), _c('label', {\n staticClass: \"select\",\n attrs: {\n \"for\": \"postContentType\"\n }\n }, [_c('select', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.postContentTypeLocal),\n expression: \"postContentTypeLocal\"\n }],\n attrs: {\n \"id\": \"postContentType\"\n },\n on: {\n \"change\": function($event) {\n var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n return o.selected\n }).map(function(o) {\n var val = \"_value\" in o ? o._value : o.value;\n return val\n });\n _vm.postContentTypeLocal = $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n }\n }\n }, [_c('option', {\n attrs: {\n \"value\": \"text/plain\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.status_content_type_plain')) + \"\\n \" + _vm._s(_vm.postContentTypeDefault == 'text/plain' ? _vm.$t('settings.instance_default_simple') : '') + \"\\n \")]), _vm._v(\" \"), _c('option', {\n attrs: {\n \"value\": \"text/html\"\n }\n }, [_vm._v(\"\\n HTML\\n \" + _vm._s(_vm.postContentTypeDefault == 'text/html' ? _vm.$t('settings.instance_default_simple') : '') + \"\\n \")]), _vm._v(\" \"), _c('option', {\n attrs: {\n \"value\": \"text/markdown\"\n }\n }, [_vm._v(\"\\n Markdown\\n \" + _vm._s(_vm.postContentTypeDefault == 'text/markdown' ? _vm.$t('settings.instance_default_simple') : '') + \"\\n \")])]), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-down-open\"\n })])])])])]), _vm._v(\" \"), _c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.attachments')))]), _vm._v(\" \"), _c('ul', {\n staticClass: \"setting-list\"\n }, [_c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.hideAttachmentsLocal),\n expression: \"hideAttachmentsLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"hideAttachments\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.hideAttachmentsLocal) ? _vm._i(_vm.hideAttachmentsLocal, null) > -1 : (_vm.hideAttachmentsLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.hideAttachmentsLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.hideAttachmentsLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.hideAttachmentsLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.hideAttachmentsLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"hideAttachments\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.hide_attachments_in_tl')))])]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.hideAttachmentsInConvLocal),\n expression: \"hideAttachmentsInConvLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"hideAttachmentsInConv\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.hideAttachmentsInConvLocal) ? _vm._i(_vm.hideAttachmentsInConvLocal, null) > -1 : (_vm.hideAttachmentsInConvLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.hideAttachmentsInConvLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.hideAttachmentsInConvLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.hideAttachmentsInConvLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.hideAttachmentsInConvLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"hideAttachmentsInConv\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.hide_attachments_in_convo')))])]), _vm._v(\" \"), _c('li', [_c('label', {\n attrs: {\n \"for\": \"maxThumbnails\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.max_thumbnails')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model.number\",\n value: (_vm.maxThumbnails),\n expression: \"maxThumbnails\",\n modifiers: {\n \"number\": true\n }\n }],\n staticClass: \"number-input\",\n attrs: {\n \"type\": \"number\",\n \"id\": \"maxThumbnails\",\n \"min\": \"0\",\n \"step\": \"1\"\n },\n domProps: {\n \"value\": (_vm.maxThumbnails)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.maxThumbnails = _vm._n($event.target.value)\n },\n \"blur\": function($event) {\n _vm.$forceUpdate()\n }\n }\n })]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.hideNsfwLocal),\n expression: \"hideNsfwLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"hideNsfw\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.hideNsfwLocal) ? _vm._i(_vm.hideNsfwLocal, null) > -1 : (_vm.hideNsfwLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.hideNsfwLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.hideNsfwLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.hideNsfwLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.hideNsfwLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"hideNsfw\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.nsfw_clickthrough')))])]), _vm._v(\" \"), _c('ul', {\n staticClass: \"setting-list suboptions\"\n }, [_c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.preloadImage),\n expression: \"preloadImage\"\n }],\n attrs: {\n \"disabled\": !_vm.hideNsfwLocal,\n \"type\": \"checkbox\",\n \"id\": \"preloadImage\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.preloadImage) ? _vm._i(_vm.preloadImage, null) > -1 : (_vm.preloadImage)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.preloadImage,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.preloadImage = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.preloadImage = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.preloadImage = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"preloadImage\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.preload_images')))])]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.useOneClickNsfw),\n expression: \"useOneClickNsfw\"\n }],\n attrs: {\n \"disabled\": !_vm.hideNsfwLocal,\n \"type\": \"checkbox\",\n \"id\": \"useOneClickNsfw\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.useOneClickNsfw) ? _vm._i(_vm.useOneClickNsfw, null) > -1 : (_vm.useOneClickNsfw)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.useOneClickNsfw,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.useOneClickNsfw = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.useOneClickNsfw = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.useOneClickNsfw = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"useOneClickNsfw\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.use_one_click_nsfw')))])])]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.stopGifs),\n expression: \"stopGifs\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"stopGifs\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.stopGifs) ? _vm._i(_vm.stopGifs, null) > -1 : (_vm.stopGifs)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.stopGifs,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.stopGifs = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.stopGifs = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.stopGifs = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"stopGifs\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.stop_gifs')))])]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.loopVideoLocal),\n expression: \"loopVideoLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"loopVideo\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.loopVideoLocal) ? _vm._i(_vm.loopVideoLocal, null) > -1 : (_vm.loopVideoLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.loopVideoLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.loopVideoLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.loopVideoLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.loopVideoLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"loopVideo\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.loop_video')))]), _vm._v(\" \"), _c('ul', {\n staticClass: \"setting-list suboptions\",\n class: [{\n disabled: !_vm.streamingLocal\n }]\n }, [_c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.loopVideoSilentOnlyLocal),\n expression: \"loopVideoSilentOnlyLocal\"\n }],\n attrs: {\n \"disabled\": !_vm.loopVideoLocal || !_vm.loopSilentAvailable,\n \"type\": \"checkbox\",\n \"id\": \"loopVideoSilentOnly\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.loopVideoSilentOnlyLocal) ? _vm._i(_vm.loopVideoSilentOnlyLocal, null) > -1 : (_vm.loopVideoSilentOnlyLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.loopVideoSilentOnlyLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.loopVideoSilentOnlyLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.loopVideoSilentOnlyLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.loopVideoSilentOnlyLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"loopVideoSilentOnly\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.loop_video_silent_only')))]), _vm._v(\" \"), (!_vm.loopSilentAvailable) ? _c('div', {\n staticClass: \"unavailable\"\n }, [_c('i', {\n staticClass: \"icon-globe\"\n }), _vm._v(\"! \" + _vm._s(_vm.$t('settings.limited_availability')) + \"\\n \")]) : _vm._e()])])]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.playVideosInModal),\n expression: \"playVideosInModal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"playVideosInModal\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.playVideosInModal) ? _vm._i(_vm.playVideosInModal, null) > -1 : (_vm.playVideosInModal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.playVideosInModal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.playVideosInModal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.playVideosInModal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.playVideosInModal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"playVideosInModal\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.play_videos_in_modal')))])]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.useContainFit),\n expression: \"useContainFit\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"useContainFit\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.useContainFit) ? _vm._i(_vm.useContainFit, null) > -1 : (_vm.useContainFit)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.useContainFit,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.useContainFit = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.useContainFit = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.useContainFit = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"useContainFit\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.use_contain_fit')))])])])]), _vm._v(\" \"), _c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.notifications')))]), _vm._v(\" \"), _c('ul', {\n staticClass: \"setting-list\"\n }, [_c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.webPushNotificationsLocal),\n expression: \"webPushNotificationsLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"webPushNotifications\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.webPushNotificationsLocal) ? _vm._i(_vm.webPushNotificationsLocal, null) > -1 : (_vm.webPushNotificationsLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.webPushNotificationsLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.webPushNotificationsLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.webPushNotificationsLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.webPushNotificationsLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"webPushNotifications\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.enable_web_push_notifications')) + \"\\n \")])])])])]), _vm._v(\" \"), _c('div', {\n attrs: {\n \"label\": _vm.$t('settings.theme')\n }\n }, [_c('div', {\n staticClass: \"setting-item\"\n }, [_c('style-switcher')], 1)]), _vm._v(\" \"), _c('div', {\n attrs: {\n \"label\": _vm.$t('settings.filtering')\n }\n }, [_c('div', {\n staticClass: \"setting-item\"\n }, [_c('div', {\n staticClass: \"select-multiple\"\n }, [_c('span', {\n staticClass: \"label\"\n }, [_vm._v(_vm._s(_vm.$t('settings.notification_visibility')))]), _vm._v(\" \"), _c('ul', {\n staticClass: \"option-list\"\n }, [_c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.notificationVisibilityLocal.likes),\n expression: \"notificationVisibilityLocal.likes\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"notification-visibility-likes\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.notificationVisibilityLocal.likes) ? _vm._i(_vm.notificationVisibilityLocal.likes, null) > -1 : (_vm.notificationVisibilityLocal.likes)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.notificationVisibilityLocal.likes,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.$set(_vm.notificationVisibilityLocal, \"likes\", $$a.concat([$$v])))\n } else {\n $$i > -1 && (_vm.$set(_vm.notificationVisibilityLocal, \"likes\", $$a.slice(0, $$i).concat($$a.slice($$i + 1))))\n }\n } else {\n _vm.$set(_vm.notificationVisibilityLocal, \"likes\", $$c)\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"notification-visibility-likes\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.notification_visibility_likes')) + \"\\n \")])]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.notificationVisibilityLocal.repeats),\n expression: \"notificationVisibilityLocal.repeats\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"notification-visibility-repeats\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.notificationVisibilityLocal.repeats) ? _vm._i(_vm.notificationVisibilityLocal.repeats, null) > -1 : (_vm.notificationVisibilityLocal.repeats)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.notificationVisibilityLocal.repeats,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.$set(_vm.notificationVisibilityLocal, \"repeats\", $$a.concat([$$v])))\n } else {\n $$i > -1 && (_vm.$set(_vm.notificationVisibilityLocal, \"repeats\", $$a.slice(0, $$i).concat($$a.slice($$i + 1))))\n }\n } else {\n _vm.$set(_vm.notificationVisibilityLocal, \"repeats\", $$c)\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"notification-visibility-repeats\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.notification_visibility_repeats')) + \"\\n \")])]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.notificationVisibilityLocal.follows),\n expression: \"notificationVisibilityLocal.follows\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"notification-visibility-follows\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.notificationVisibilityLocal.follows) ? _vm._i(_vm.notificationVisibilityLocal.follows, null) > -1 : (_vm.notificationVisibilityLocal.follows)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.notificationVisibilityLocal.follows,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.$set(_vm.notificationVisibilityLocal, \"follows\", $$a.concat([$$v])))\n } else {\n $$i > -1 && (_vm.$set(_vm.notificationVisibilityLocal, \"follows\", $$a.slice(0, $$i).concat($$a.slice($$i + 1))))\n }\n } else {\n _vm.$set(_vm.notificationVisibilityLocal, \"follows\", $$c)\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"notification-visibility-follows\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.notification_visibility_follows')) + \"\\n \")])]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.notificationVisibilityLocal.mentions),\n expression: \"notificationVisibilityLocal.mentions\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"notification-visibility-mentions\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.notificationVisibilityLocal.mentions) ? _vm._i(_vm.notificationVisibilityLocal.mentions, null) > -1 : (_vm.notificationVisibilityLocal.mentions)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.notificationVisibilityLocal.mentions,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.$set(_vm.notificationVisibilityLocal, \"mentions\", $$a.concat([$$v])))\n } else {\n $$i > -1 && (_vm.$set(_vm.notificationVisibilityLocal, \"mentions\", $$a.slice(0, $$i).concat($$a.slice($$i + 1))))\n }\n } else {\n _vm.$set(_vm.notificationVisibilityLocal, \"mentions\", $$c)\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"notification-visibility-mentions\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.notification_visibility_mentions')) + \"\\n \")])])])]), _vm._v(\" \"), _c('div', [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.replies_in_timeline')) + \"\\n \"), _c('label', {\n staticClass: \"select\",\n attrs: {\n \"for\": \"replyVisibility\"\n }\n }, [_c('select', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.replyVisibilityLocal),\n expression: \"replyVisibilityLocal\"\n }],\n attrs: {\n \"id\": \"replyVisibility\"\n },\n on: {\n \"change\": function($event) {\n var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n return o.selected\n }).map(function(o) {\n var val = \"_value\" in o ? o._value : o.value;\n return val\n });\n _vm.replyVisibilityLocal = $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n }\n }\n }, [_c('option', {\n attrs: {\n \"value\": \"all\",\n \"selected\": \"\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.reply_visibility_all')))]), _vm._v(\" \"), _c('option', {\n attrs: {\n \"value\": \"following\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.reply_visibility_following')))]), _vm._v(\" \"), _c('option', {\n attrs: {\n \"value\": \"self\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.reply_visibility_self')))])]), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-down-open\"\n })])]), _vm._v(\" \"), _c('div', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.hidePostStatsLocal),\n expression: \"hidePostStatsLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"hidePostStats\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.hidePostStatsLocal) ? _vm._i(_vm.hidePostStatsLocal, null) > -1 : (_vm.hidePostStatsLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.hidePostStatsLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.hidePostStatsLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.hidePostStatsLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.hidePostStatsLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"hidePostStats\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.hide_post_stats')) + \" \" + _vm._s(_vm.$t('settings.instance_default', {\n value: _vm.hidePostStatsDefault\n })) + \"\\n \")])]), _vm._v(\" \"), _c('div', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.hideUserStatsLocal),\n expression: \"hideUserStatsLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"hideUserStats\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.hideUserStatsLocal) ? _vm._i(_vm.hideUserStatsLocal, null) > -1 : (_vm.hideUserStatsLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.hideUserStatsLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.hideUserStatsLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.hideUserStatsLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.hideUserStatsLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"hideUserStats\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.hide_user_stats')) + \" \" + _vm._s(_vm.$t('settings.instance_default', {\n value: _vm.hideUserStatsDefault\n })) + \"\\n \")])])]), _vm._v(\" \"), _c('div', {\n staticClass: \"setting-item\"\n }, [_c('div', [_c('p', [_vm._v(_vm._s(_vm.$t('settings.filtering_explanation')))]), _vm._v(\" \"), _c('textarea', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.muteWordsString),\n expression: \"muteWordsString\"\n }],\n attrs: {\n \"id\": \"muteWords\"\n },\n domProps: {\n \"value\": (_vm.muteWordsString)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.muteWordsString = $event.target.value\n }\n }\n })]), _vm._v(\" \"), _c('div', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.hideFilteredStatusesLocal),\n expression: \"hideFilteredStatusesLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"hideFilteredStatuses\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.hideFilteredStatusesLocal) ? _vm._i(_vm.hideFilteredStatusesLocal, null) > -1 : (_vm.hideFilteredStatusesLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.hideFilteredStatusesLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.hideFilteredStatusesLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.hideFilteredStatusesLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.hideFilteredStatusesLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"hideFilteredStatuses\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.hide_filtered_statuses')) + \" \" + _vm._s(_vm.$t('settings.instance_default', {\n value: _vm.hideFilteredStatusesDefault\n })) + \"\\n \")])])])])])], 1)], 1)])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-5719c518\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/settings/settings.vue\n// module id = 707\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('video', {\n staticClass: \"video\",\n attrs: {\n \"src\": _vm.attachment.url,\n \"loop\": _vm.loopVideo,\n \"controls\": _vm.controls,\n \"playsinline\": \"\"\n },\n on: {\n \"loadeddata\": _vm.onVideoDataLoad\n }\n })\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-582fc798\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/video_attachment/video_attachment.vue\n// module id = 708\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('Timeline', {\n attrs: {\n \"title\": _vm.tag,\n \"timeline\": _vm.timeline,\n \"timeline-name\": 'tag',\n \"tag\": _vm.tag\n }\n })\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-59e5a210\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/tag_timeline/tag_timeline.vue\n// module id = 709\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return (!this.collapsed || !this.floating) ? _c('div', {\n staticClass: \"chat-panel\"\n }, [_c('div', {\n staticClass: \"panel panel-default\"\n }, [_c('div', {\n staticClass: \"panel-heading timeline-heading\",\n class: {\n 'chat-heading': _vm.floating\n },\n on: {\n \"click\": function($event) {\n $event.stopPropagation();\n $event.preventDefault();\n return _vm.togglePanel($event)\n }\n }\n }, [_c('div', {\n staticClass: \"title\"\n }, [_c('span', [_vm._v(_vm._s(_vm.$t('chat.title')))]), _vm._v(\" \"), (_vm.floating) ? _c('i', {\n staticClass: \"icon-cancel\"\n }) : _vm._e()])]), _vm._v(\" \"), _c('div', {\n directives: [{\n name: \"chat-scroll\",\n rawName: \"v-chat-scroll\"\n }],\n staticClass: \"chat-window\"\n }, _vm._l((_vm.messages), function(message) {\n return _c('div', {\n key: message.id,\n staticClass: \"chat-message\"\n }, [_c('span', {\n staticClass: \"chat-avatar\"\n }, [_c('img', {\n attrs: {\n \"src\": message.author.avatar\n }\n })]), _vm._v(\" \"), _c('div', {\n staticClass: \"chat-content\"\n }, [_c('router-link', {\n staticClass: \"chat-name\",\n attrs: {\n \"to\": _vm.userProfileLink(message.author)\n }\n }, [_vm._v(\"\\n \" + _vm._s(message.author.username) + \"\\n \")]), _vm._v(\" \"), _c('br'), _vm._v(\" \"), _c('span', {\n staticClass: \"chat-text\"\n }, [_vm._v(\"\\n \" + _vm._s(message.text) + \"\\n \")])], 1)])\n }), 0), _vm._v(\" \"), _c('div', {\n staticClass: \"chat-input\"\n }, [_c('textarea', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.currentMessage),\n expression: \"currentMessage\"\n }],\n staticClass: \"chat-input-textarea\",\n attrs: {\n \"rows\": \"1\"\n },\n domProps: {\n \"value\": (_vm.currentMessage)\n },\n on: {\n \"keyup\": function($event) {\n if (!('button' in $event) && _vm._k($event.keyCode, \"enter\", 13, $event.key, \"Enter\")) { return null; }\n _vm.submit(_vm.currentMessage)\n },\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.currentMessage = $event.target.value\n }\n }\n })])])]) : _c('div', {\n staticClass: \"chat-panel\"\n }, [_c('div', {\n staticClass: \"panel panel-default\"\n }, [_c('div', {\n staticClass: \"panel-heading stub timeline-heading chat-heading\",\n on: {\n \"click\": function($event) {\n $event.stopPropagation();\n $event.preventDefault();\n return _vm.togglePanel($event)\n }\n }\n }, [_c('div', {\n staticClass: \"title\"\n }, [_c('i', {\n staticClass: \"icon-comment-empty\"\n }), _vm._v(\"\\n \" + _vm._s(_vm.$t('chat.title')) + \"\\n \")])])])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-5b021158\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/chat_panel/chat_panel.vue\n// module id = 710\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('basic-user-card', {\n attrs: {\n \"user\": _vm.user\n }\n }, [_c('div', {\n staticClass: \"follow-card-content-container\"\n }, [(!_vm.noFollowsYou && _vm.user.follows_you) ? _c('span', {\n staticClass: \"faint\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.isMe ? _vm.$t('user_card.its_you') : _vm.$t('user_card.follows_you')) + \"\\n \")]) : _vm._e(), _vm._v(\" \"), (_vm.showFollow) ? _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": _vm.inProgress,\n \"title\": _vm.requestSent ? _vm.$t('user_card.follow_again') : ''\n },\n on: {\n \"click\": _vm.followUser\n }\n }, [(_vm.inProgress) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follow_progress')) + \"\\n \")] : (_vm.requestSent) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follow_sent')) + \"\\n \")] : [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follow')) + \"\\n \")]], 2) : _vm._e(), _vm._v(\" \"), (_vm.following) ? _c('button', {\n staticClass: \"btn btn-default pressed\",\n attrs: {\n \"disabled\": _vm.inProgress\n },\n on: {\n \"click\": _vm.unfollowUser\n }\n }, [(_vm.inProgress) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follow_progress')) + \"\\n \")] : [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follow_unfollow')) + \"\\n \")]], 2) : _vm._e()])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-609a91f6\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/follow_card/follow_card.vue\n// module id = 711\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"panel panel-default\"\n }, [_c('div', {\n staticClass: \"panel-heading\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('who_to_follow.who_to_follow')) + \"\\n \")]), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-body\"\n }, _vm._l((_vm.users), function(user) {\n return _c('FollowCard', {\n key: user.id,\n attrs: {\n \"user\": user\n }\n })\n }), 1)])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-6a618ce2\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/who_to_follow/who_to_follow.vue\n// module id = 712\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return (_vm.usePlaceHolder) ? _c('div', {\n on: {\n \"click\": _vm.openModal\n }\n }, [(_vm.type !== 'html') ? _c('a', {\n staticClass: \"placeholder\",\n attrs: {\n \"target\": \"_blank\",\n \"href\": _vm.attachment.url\n }\n }, [_vm._v(\"\\n [\" + _vm._s(_vm.nsfw ? \"NSFW/\" : \"\") + _vm._s(_vm.type.toUpperCase()) + \"]\\n \")]) : _vm._e()]) : _c('div', {\n directives: [{\n name: \"show\",\n rawName: \"v-show\",\n value: (!_vm.isEmpty),\n expression: \"!isEmpty\"\n }],\n staticClass: \"attachment\",\n class: ( _obj = {\n loading: _vm.loading,\n 'fullwidth': _vm.fullwidth,\n 'nsfw-placeholder': _vm.hidden\n }, _obj[_vm.type] = true, _obj )\n }, [(_vm.hidden) ? _c('a', {\n staticClass: \"image-attachment\",\n attrs: {\n \"href\": _vm.attachment.url\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.toggleHidden($event)\n }\n }\n }, [_c('img', {\n key: _vm.nsfwImage,\n staticClass: \"nsfw\",\n class: {\n 'small': _vm.isSmall\n },\n attrs: {\n \"src\": _vm.nsfwImage\n }\n }), _vm._v(\" \"), (_vm.type === 'video') ? _c('i', {\n staticClass: \"play-icon icon-play-circled\"\n }) : _vm._e()]) : _vm._e(), _vm._v(\" \"), (_vm.nsfw && _vm.hideNsfwLocal && !_vm.hidden) ? _c('div', {\n staticClass: \"hider\"\n }, [_c('a', {\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.toggleHidden($event)\n }\n }\n }, [_vm._v(\"Hide\")])]) : _vm._e(), _vm._v(\" \"), (_vm.type === 'image' && (!_vm.hidden || _vm.preloadImage)) ? _c('a', {\n staticClass: \"image-attachment\",\n class: {\n 'hidden': _vm.hidden && _vm.preloadImage\n },\n attrs: {\n \"href\": _vm.attachment.url,\n \"target\": \"_blank\",\n \"title\": _vm.attachment.description\n },\n on: {\n \"click\": _vm.openModal\n }\n }, [_c('StillImage', {\n attrs: {\n \"referrerpolicy\": _vm.referrerpolicy,\n \"mimetype\": _vm.attachment.mimetype,\n \"src\": _vm.attachment.large_thumb_url || _vm.attachment.url\n }\n })], 1) : _vm._e(), _vm._v(\" \"), (_vm.type === 'video' && !_vm.hidden) ? _c('a', {\n staticClass: \"video-container\",\n class: {\n 'small': _vm.isSmall\n },\n attrs: {\n \"href\": _vm.allowPlay ? undefined : _vm.attachment.url\n },\n on: {\n \"click\": _vm.openModal\n }\n }, [_c('VideoAttachment', {\n staticClass: \"video\",\n attrs: {\n \"attachment\": _vm.attachment,\n \"controls\": _vm.allowPlay\n }\n }), _vm._v(\" \"), (!_vm.allowPlay) ? _c('i', {\n staticClass: \"play-icon icon-play-circled\"\n }) : _vm._e()], 1) : _vm._e(), _vm._v(\" \"), (_vm.type === 'audio') ? _c('audio', {\n attrs: {\n \"src\": _vm.attachment.url,\n \"controls\": \"\"\n }\n }) : _vm._e(), _vm._v(\" \"), (_vm.type === 'html' && _vm.attachment.oembed) ? _c('div', {\n staticClass: \"oembed\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.linkClicked($event)\n }\n }\n }, [(_vm.attachment.thumb_url) ? _c('div', {\n staticClass: \"image\"\n }, [_c('img', {\n attrs: {\n \"src\": _vm.attachment.thumb_url\n }\n })]) : _vm._e(), _vm._v(\" \"), _c('div', {\n staticClass: \"text\"\n }, [_c('h1', [_c('a', {\n attrs: {\n \"href\": _vm.attachment.url\n }\n }, [_vm._v(_vm._s(_vm.attachment.oembed.title))])]), _vm._v(\" \"), _c('div', {\n domProps: {\n \"innerHTML\": _vm._s(_vm.attachment.oembed.oembedHTML)\n }\n })])]) : _vm._e()])\n var _obj;\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-6c119998\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/attachment/attachment.vue\n// module id = 713\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"shadow-control\",\n class: {\n disabled: !_vm.present\n }\n }, [_c('div', {\n staticClass: \"shadow-preview-container\"\n }, [_c('div', {\n staticClass: \"y-shift-control\",\n attrs: {\n \"disabled\": !_vm.present\n }\n }, [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.selected.y),\n expression: \"selected.y\"\n }],\n staticClass: \"input-number\",\n attrs: {\n \"disabled\": !_vm.present,\n \"type\": \"number\"\n },\n domProps: {\n \"value\": (_vm.selected.y)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.selected, \"y\", $event.target.value)\n }\n }\n }), _vm._v(\" \"), _c('div', {\n staticClass: \"wrap\"\n }, [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.selected.y),\n expression: \"selected.y\"\n }],\n staticClass: \"input-range\",\n attrs: {\n \"disabled\": !_vm.present,\n \"type\": \"range\",\n \"max\": \"20\",\n \"min\": \"-20\"\n },\n domProps: {\n \"value\": (_vm.selected.y)\n },\n on: {\n \"__r\": function($event) {\n _vm.$set(_vm.selected, \"y\", $event.target.value)\n }\n }\n })])]), _vm._v(\" \"), _c('div', {\n staticClass: \"preview-window\"\n }, [_c('div', {\n staticClass: \"preview-block\",\n style: (_vm.style)\n })]), _vm._v(\" \"), _c('div', {\n staticClass: \"x-shift-control\",\n attrs: {\n \"disabled\": !_vm.present\n }\n }, [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.selected.x),\n expression: \"selected.x\"\n }],\n staticClass: \"input-number\",\n attrs: {\n \"disabled\": !_vm.present,\n \"type\": \"number\"\n },\n domProps: {\n \"value\": (_vm.selected.x)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.selected, \"x\", $event.target.value)\n }\n }\n }), _vm._v(\" \"), _c('div', {\n staticClass: \"wrap\"\n }, [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.selected.x),\n expression: \"selected.x\"\n }],\n staticClass: \"input-range\",\n attrs: {\n \"disabled\": !_vm.present,\n \"type\": \"range\",\n \"max\": \"20\",\n \"min\": \"-20\"\n },\n domProps: {\n \"value\": (_vm.selected.x)\n },\n on: {\n \"__r\": function($event) {\n _vm.$set(_vm.selected, \"x\", $event.target.value)\n }\n }\n })])])]), _vm._v(\" \"), _c('div', {\n staticClass: \"shadow-tweak\"\n }, [_c('div', {\n staticClass: \"id-control style-control\",\n attrs: {\n \"disabled\": _vm.usingFallback\n }\n }, [_c('label', {\n staticClass: \"select\",\n attrs: {\n \"for\": \"shadow-switcher\",\n \"disabled\": !_vm.ready || _vm.usingFallback\n }\n }, [_c('select', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.selectedId),\n expression: \"selectedId\"\n }],\n staticClass: \"shadow-switcher\",\n attrs: {\n \"disabled\": !_vm.ready || _vm.usingFallback,\n \"id\": \"shadow-switcher\"\n },\n on: {\n \"change\": function($event) {\n var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n return o.selected\n }).map(function(o) {\n var val = \"_value\" in o ? o._value : o.value;\n return val\n });\n _vm.selectedId = $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n }\n }\n }, _vm._l((_vm.cValue), function(shadow, index) {\n return _c('option', {\n domProps: {\n \"value\": index\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.shadows.shadow_id', {\n value: index\n })) + \"\\n \")])\n }), 0), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-down-open\"\n })]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": !_vm.ready || !_vm.present\n },\n on: {\n \"click\": _vm.del\n }\n }, [_c('i', {\n staticClass: \"icon-cancel\"\n })]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": !_vm.moveUpValid\n },\n on: {\n \"click\": _vm.moveUp\n }\n }, [_c('i', {\n staticClass: \"icon-up-open\"\n })]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": !_vm.moveDnValid\n },\n on: {\n \"click\": _vm.moveDn\n }\n }, [_c('i', {\n staticClass: \"icon-down-open\"\n })]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": _vm.usingFallback\n },\n on: {\n \"click\": _vm.add\n }\n }, [_c('i', {\n staticClass: \"icon-plus\"\n })])]), _vm._v(\" \"), _c('div', {\n staticClass: \"inset-control style-control\",\n attrs: {\n \"disabled\": !_vm.present\n }\n }, [_c('label', {\n staticClass: \"label\",\n attrs: {\n \"for\": \"inset\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.shadows.inset')) + \"\\n \")]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.selected.inset),\n expression: \"selected.inset\"\n }],\n staticClass: \"input-inset\",\n attrs: {\n \"disabled\": !_vm.present,\n \"name\": \"inset\",\n \"id\": \"inset\",\n \"type\": \"checkbox\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.selected.inset) ? _vm._i(_vm.selected.inset, null) > -1 : (_vm.selected.inset)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.selected.inset,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.$set(_vm.selected, \"inset\", $$a.concat([$$v])))\n } else {\n $$i > -1 && (_vm.$set(_vm.selected, \"inset\", $$a.slice(0, $$i).concat($$a.slice($$i + 1))))\n }\n } else {\n _vm.$set(_vm.selected, \"inset\", $$c)\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n staticClass: \"checkbox-label\",\n attrs: {\n \"for\": \"inset\"\n }\n })]), _vm._v(\" \"), _c('div', {\n staticClass: \"blur-control style-control\",\n attrs: {\n \"disabled\": !_vm.present\n }\n }, [_c('label', {\n staticClass: \"label\",\n attrs: {\n \"for\": \"spread\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.shadows.blur')) + \"\\n \")]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.selected.blur),\n expression: \"selected.blur\"\n }],\n staticClass: \"input-range\",\n attrs: {\n \"disabled\": !_vm.present,\n \"name\": \"blur\",\n \"id\": \"blur\",\n \"type\": \"range\",\n \"max\": \"20\",\n \"min\": \"0\"\n },\n domProps: {\n \"value\": (_vm.selected.blur)\n },\n on: {\n \"__r\": function($event) {\n _vm.$set(_vm.selected, \"blur\", $event.target.value)\n }\n }\n }), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.selected.blur),\n expression: \"selected.blur\"\n }],\n staticClass: \"input-number\",\n attrs: {\n \"disabled\": !_vm.present,\n \"type\": \"number\",\n \"min\": \"0\"\n },\n domProps: {\n \"value\": (_vm.selected.blur)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.selected, \"blur\", $event.target.value)\n }\n }\n })]), _vm._v(\" \"), _c('div', {\n staticClass: \"spread-control style-control\",\n attrs: {\n \"disabled\": !_vm.present\n }\n }, [_c('label', {\n staticClass: \"label\",\n attrs: {\n \"for\": \"spread\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.shadows.spread')) + \"\\n \")]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.selected.spread),\n expression: \"selected.spread\"\n }],\n staticClass: \"input-range\",\n attrs: {\n \"disabled\": !_vm.present,\n \"name\": \"spread\",\n \"id\": \"spread\",\n \"type\": \"range\",\n \"max\": \"20\",\n \"min\": \"-20\"\n },\n domProps: {\n \"value\": (_vm.selected.spread)\n },\n on: {\n \"__r\": function($event) {\n _vm.$set(_vm.selected, \"spread\", $event.target.value)\n }\n }\n }), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.selected.spread),\n expression: \"selected.spread\"\n }],\n staticClass: \"input-number\",\n attrs: {\n \"disabled\": !_vm.present,\n \"type\": \"number\"\n },\n domProps: {\n \"value\": (_vm.selected.spread)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.selected, \"spread\", $event.target.value)\n }\n }\n })]), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"disabled\": !_vm.present,\n \"label\": _vm.$t('settings.style.common.color'),\n \"name\": \"shadow\"\n },\n model: {\n value: (_vm.selected.color),\n callback: function($$v) {\n _vm.$set(_vm.selected, \"color\", $$v)\n },\n expression: \"selected.color\"\n }\n }), _vm._v(\" \"), _c('OpacityInput', {\n attrs: {\n \"disabled\": !_vm.present\n },\n model: {\n value: (_vm.selected.alpha),\n callback: function($$v) {\n _vm.$set(_vm.selected, \"alpha\", $$v)\n },\n expression: \"selected.alpha\"\n }\n }), _vm._v(\" \"), _c('p', [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.shadows.hint')) + \"\\n \")])], 1)])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-75a4cd90\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/shadow_control/shadow_control.vue\n// module id = 714\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return (_vm.show) ? _c('div', {\n staticClass: \"instance-specific-panel\"\n }, [_c('div', {\n staticClass: \"panel panel-default\"\n }, [_c('div', {\n staticClass: \"panel-body\"\n }, [_c('div', {\n domProps: {\n \"innerHTML\": _vm._s(_vm.instanceSpecificPanelContent)\n }\n })])])]) : _vm._e()\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-77c211fc\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/instance_specific_panel/instance_specific_panel.vue\n// module id = 715\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"user-card\"\n }, [_c('router-link', {\n attrs: {\n \"to\": _vm.userProfileLink(_vm.user)\n }\n }, [_c('UserAvatar', {\n staticClass: \"avatar\",\n attrs: {\n \"src\": _vm.user.profile_image_url\n },\n nativeOn: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.toggleUserExpanded($event)\n }\n }\n })], 1), _vm._v(\" \"), (_vm.userExpanded) ? _c('div', {\n staticClass: \"user-card-expanded-content\"\n }, [_c('user-card-content', {\n attrs: {\n \"user\": _vm.user,\n \"switcher\": false\n }\n })], 1) : _c('div', {\n staticClass: \"user-card-collapsed-content\"\n }, [_c('div', {\n staticClass: \"user-card-user-name\",\n attrs: {\n \"title\": _vm.user.name\n }\n }, [(_vm.user.name_html) ? _c('span', {\n domProps: {\n \"innerHTML\": _vm._s(_vm.user.name_html)\n }\n }) : _c('span', [_vm._v(_vm._s(_vm.user.name))])]), _vm._v(\" \"), _c('div', [_c('router-link', {\n staticClass: \"user-card-screen-name\",\n attrs: {\n \"to\": _vm.userProfileLink(_vm.user)\n }\n }, [_vm._v(\"\\n @\" + _vm._s(_vm.user.screen_name) + \"\\n \")])], 1), _vm._v(\" \"), _vm._t(\"default\")], 2)], 1)\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-7b67c5c0\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/basic_user_card/basic_user_card.vue\n// module id = 716\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', [_c('div', {\n staticClass: \"user-finder-container\"\n }, [(_vm.loading) ? _c('i', {\n staticClass: \"icon-spin4 user-finder-icon animate-spin-slow\"\n }) : _vm._e(), _vm._v(\" \"), (_vm.hidden) ? _c('a', {\n attrs: {\n \"href\": \"#\",\n \"title\": _vm.$t('finder.find_user')\n }\n }, [_c('i', {\n staticClass: \"icon-user-plus user-finder-icon\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n $event.stopPropagation();\n return _vm.toggleHidden($event)\n }\n }\n })]) : [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.username),\n expression: \"username\"\n }],\n ref: \"userSearchInput\",\n staticClass: \"user-finder-input\",\n attrs: {\n \"placeholder\": _vm.$t('finder.find_user'),\n \"id\": \"user-finder-input\",\n \"type\": \"text\"\n },\n domProps: {\n \"value\": (_vm.username)\n },\n on: {\n \"keyup\": function($event) {\n if (!('button' in $event) && _vm._k($event.keyCode, \"enter\", 13, $event.key, \"Enter\")) { return null; }\n _vm.findUser(_vm.username)\n },\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.username = $event.target.value\n }\n }\n }), _vm._v(\" \"), _c('button', {\n staticClass: \"btn search-button\",\n on: {\n \"click\": function($event) {\n _vm.findUser(_vm.username)\n }\n }\n }, [_c('i', {\n staticClass: \"icon-search\"\n })]), _vm._v(\" \"), _c('i', {\n staticClass: \"button-icon icon-cancel user-finder-icon\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n $event.stopPropagation();\n return _vm.toggleHidden($event)\n }\n }\n })]], 2)])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-7ca85c6e\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/user_finder/user_finder.vue\n// module id = 717\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('Timeline', {\n attrs: {\n \"title\": _vm.$t('nav.public_tl'),\n \"timeline\": _vm.timeline,\n \"timeline-name\": 'public'\n }\n })\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-84f9a930\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/public_timeline/public_timeline.vue\n// module id = 718\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('Timeline', {\n attrs: {\n \"title\": _vm.$t('nav.timeline'),\n \"timeline\": _vm.timeline,\n \"timeline-name\": 'friends'\n }\n })\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-87ffcfd0\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/friends_timeline/friends_timeline.vue\n// module id = 719\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n class: _vm.classes.root\n }, [_c('div', {\n class: _vm.classes.header\n }, [_c('div', {\n staticClass: \"title\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.title) + \"\\n \")]), _vm._v(\" \"), (_vm.timelineError) ? _c('div', {\n staticClass: \"loadmore-error alert error\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('timeline.error_fetching')) + \"\\n \")]) : _vm._e(), _vm._v(\" \"), (_vm.timeline.newStatusCount > 0 && !_vm.timelineError) ? _c('button', {\n staticClass: \"loadmore-button\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.showNewStatuses($event)\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('timeline.show_new')) + _vm._s(_vm.newStatusCountStr) + \"\\n \")]) : _vm._e(), _vm._v(\" \"), (!_vm.timeline.newStatusCount > 0 && !_vm.timelineError) ? _c('div', {\n staticClass: \"loadmore-text faint\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('timeline.up_to_date')) + \"\\n \")]) : _vm._e()]), _vm._v(\" \"), _c('div', {\n class: _vm.classes.body\n }, [_c('div', {\n staticClass: \"timeline\"\n }, _vm._l((_vm.timeline.visibleStatuses), function(status) {\n return _c('status-or-conversation', {\n key: status.id,\n staticClass: \"status-fadein\",\n attrs: {\n \"statusoid\": status\n }\n })\n }), 1)]), _vm._v(\" \"), _c('div', {\n class: _vm.classes.footer\n }, [(_vm.count === 0) ? _c('div', {\n staticClass: \"new-status-notification text-center panel-footer faint\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('timeline.no_statuses')) + \"\\n \")]) : (_vm.bottomedOut) ? _c('div', {\n staticClass: \"new-status-notification text-center panel-footer faint\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('timeline.no_more_statuses')) + \"\\n \")]) : (!_vm.timeline.loading) ? _c('a', {\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n _vm.fetchOlderStatuses()\n }\n }\n }, [_c('div', {\n staticClass: \"new-status-notification text-center panel-footer\"\n }, [_vm._v(_vm._s(_vm.$t('timeline.load_older')))])]) : _c('div', {\n staticClass: \"new-status-notification text-center panel-footer\"\n }, [_c('i', {\n staticClass: \"icon-spin3 animate-spin\"\n })])])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-8acdb250\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/timeline/timeline.vue\n// module id = 720\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"profile-panel-background\",\n style: (_vm.headingStyle),\n attrs: {\n \"id\": \"heading\"\n }\n }, [_c('div', {\n staticClass: \"panel-heading text-center\"\n }, [_c('div', {\n staticClass: \"user-info\"\n }, [_c('div', {\n staticClass: \"container\"\n }, [_c('router-link', {\n attrs: {\n \"to\": _vm.userProfileLink(_vm.user)\n }\n }, [_c('UserAvatar', {\n attrs: {\n \"betterShadow\": _vm.betterShadow,\n \"src\": _vm.user.profile_image_url_original\n }\n })], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"name-and-screen-name\"\n }, [_c('div', {\n staticClass: \"top-line\"\n }, [(_vm.user.name_html) ? _c('div', {\n staticClass: \"user-name\",\n attrs: {\n \"title\": _vm.user.name\n },\n domProps: {\n \"innerHTML\": _vm._s(_vm.user.name_html)\n }\n }) : _c('div', {\n staticClass: \"user-name\",\n attrs: {\n \"title\": _vm.user.name\n }\n }, [_vm._v(_vm._s(_vm.user.name))]), _vm._v(\" \"), (!_vm.isOtherUser) ? _c('router-link', {\n attrs: {\n \"to\": {\n name: 'user-settings'\n }\n }\n }, [_c('i', {\n staticClass: \"button-icon icon-cog usersettings\",\n attrs: {\n \"title\": _vm.$t('tool_tip.user_settings')\n }\n })]) : _vm._e(), _vm._v(\" \"), (_vm.isOtherUser && !_vm.user.is_local) ? _c('a', {\n attrs: {\n \"href\": _vm.user.statusnet_profile_url,\n \"target\": \"_blank\"\n }\n }, [_c('i', {\n staticClass: \"icon-link-ext usersettings\"\n })]) : _vm._e()], 1), _vm._v(\" \"), _c('router-link', {\n staticClass: \"user-screen-name\",\n attrs: {\n \"to\": _vm.userProfileLink(_vm.user)\n }\n }, [_c('span', {\n staticClass: \"handle\"\n }, [_vm._v(\"@\" + _vm._s(_vm.user.screen_name) + \"\\n \"), (!_vm.hideBio && !!_vm.visibleRole) ? _c('span', {\n staticClass: \"alert staff\"\n }, [_vm._v(_vm._s(_vm.visibleRole))]) : _vm._e()]), (_vm.user.locked) ? _c('span', [_c('i', {\n staticClass: \"icon icon-lock\"\n })]) : _vm._e(), _vm._v(\" \"), (!_vm.hideUserStatsLocal && !_vm.hideBio) ? _c('span', {\n staticClass: \"dailyAvg\"\n }, [_vm._v(_vm._s(_vm.dailyAvg) + \" \" + _vm._s(_vm.$t('user_card.per_day')))]) : _vm._e()])], 1)], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"user-meta\"\n }, [(_vm.user.follows_you && _vm.loggedIn && _vm.isOtherUser) ? _c('div', {\n staticClass: \"following\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follows_you')) + \"\\n \")]) : _vm._e(), _vm._v(\" \"), (_vm.isOtherUser && (_vm.loggedIn || !_vm.switcher)) ? _c('div', {\n staticClass: \"highlighter\"\n }, [(_vm.userHighlightType !== 'disabled') ? _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.userHighlightColor),\n expression: \"userHighlightColor\"\n }],\n staticClass: \"userHighlightText\",\n attrs: {\n \"type\": \"text\",\n \"id\": 'userHighlightColorTx' + _vm.user.id\n },\n domProps: {\n \"value\": (_vm.userHighlightColor)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.userHighlightColor = $event.target.value\n }\n }\n }) : _vm._e(), _vm._v(\" \"), (_vm.userHighlightType !== 'disabled') ? _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.userHighlightColor),\n expression: \"userHighlightColor\"\n }],\n staticClass: \"userHighlightCl\",\n attrs: {\n \"type\": \"color\",\n \"id\": 'userHighlightColor' + _vm.user.id\n },\n domProps: {\n \"value\": (_vm.userHighlightColor)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.userHighlightColor = $event.target.value\n }\n }\n }) : _vm._e(), _vm._v(\" \"), _c('label', {\n staticClass: \"userHighlightSel select\",\n attrs: {\n \"for\": \"style-switcher\"\n }\n }, [_c('select', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.userHighlightType),\n expression: \"userHighlightType\"\n }],\n staticClass: \"userHighlightSel\",\n attrs: {\n \"id\": 'userHighlightSel' + _vm.user.id\n },\n on: {\n \"change\": function($event) {\n var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n return o.selected\n }).map(function(o) {\n var val = \"_value\" in o ? o._value : o.value;\n return val\n });\n _vm.userHighlightType = $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n }\n }\n }, [_c('option', {\n attrs: {\n \"value\": \"disabled\"\n }\n }, [_vm._v(\"No highlight\")]), _vm._v(\" \"), _c('option', {\n attrs: {\n \"value\": \"solid\"\n }\n }, [_vm._v(\"Solid bg\")]), _vm._v(\" \"), _c('option', {\n attrs: {\n \"value\": \"striped\"\n }\n }, [_vm._v(\"Striped bg\")]), _vm._v(\" \"), _c('option', {\n attrs: {\n \"value\": \"side\"\n }\n }, [_vm._v(\"Side stripe\")])]), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-down-open\"\n })])]) : _vm._e()]), _vm._v(\" \"), (_vm.isOtherUser) ? _c('div', {\n staticClass: \"user-interactions\"\n }, [(_vm.loggedIn) ? _c('div', {\n staticClass: \"follow\"\n }, [(_vm.user.following) ? _c('span', [_c('button', {\n staticClass: \"pressed\",\n attrs: {\n \"disabled\": _vm.followRequestInProgress,\n \"title\": _vm.$t('user_card.follow_unfollow')\n },\n on: {\n \"click\": _vm.unfollowUser\n }\n }, [(_vm.followRequestInProgress) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follow_progress')) + \"\\n \")] : [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.following')) + \"\\n \")]], 2)]) : _vm._e(), _vm._v(\" \"), (!_vm.user.following) ? _c('span', [_c('button', {\n attrs: {\n \"disabled\": _vm.followRequestInProgress,\n \"title\": _vm.followRequestSent ? _vm.$t('user_card.follow_again') : ''\n },\n on: {\n \"click\": _vm.followUser\n }\n }, [(_vm.followRequestInProgress) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follow_progress')) + \"\\n \")] : (_vm.followRequestSent) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follow_sent')) + \"\\n \")] : [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follow')) + \"\\n \")]], 2)]) : _vm._e()]) : _vm._e(), _vm._v(\" \"), (_vm.isOtherUser && _vm.loggedIn) ? _c('div', {\n staticClass: \"mute\"\n }, [(_vm.user.muted) ? _c('span', [_c('button', {\n staticClass: \"pressed\",\n on: {\n \"click\": _vm.toggleMute\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.muted')) + \"\\n \")])]) : _vm._e(), _vm._v(\" \"), (!_vm.user.muted) ? _c('span', [_c('button', {\n on: {\n \"click\": _vm.toggleMute\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.mute')) + \"\\n \")])]) : _vm._e()]) : _vm._e(), _vm._v(\" \"), (!_vm.loggedIn && _vm.user.is_local) ? _c('div', {\n staticClass: \"remote-follow\"\n }, [_c('form', {\n attrs: {\n \"method\": \"POST\",\n \"action\": _vm.subscribeUrl\n }\n }, [_c('input', {\n attrs: {\n \"type\": \"hidden\",\n \"name\": \"nickname\"\n },\n domProps: {\n \"value\": _vm.user.screen_name\n }\n }), _vm._v(\" \"), _c('input', {\n attrs: {\n \"type\": \"hidden\",\n \"name\": \"profile\",\n \"value\": \"\"\n }\n }), _vm._v(\" \"), _c('button', {\n staticClass: \"remote-button\",\n attrs: {\n \"click\": \"submit\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.remote_follow')) + \"\\n \")])])]) : _vm._e(), _vm._v(\" \"), (_vm.isOtherUser && _vm.loggedIn) ? _c('div', {\n staticClass: \"block\"\n }, [(_vm.user.statusnet_blocking) ? _c('span', [_c('button', {\n staticClass: \"pressed\",\n on: {\n \"click\": _vm.unblockUser\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.blocked')) + \"\\n \")])]) : _vm._e(), _vm._v(\" \"), (!_vm.user.statusnet_blocking) ? _c('span', [_c('button', {\n on: {\n \"click\": _vm.blockUser\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.block')) + \"\\n \")])]) : _vm._e()]) : _vm._e()]) : _vm._e()])]), _vm._v(\" \"), (!_vm.hideBio) ? _c('div', {\n staticClass: \"panel-body profile-panel-body\"\n }, [(!_vm.hideUserStatsLocal && _vm.switcher) ? _c('div', {\n staticClass: \"user-counts\"\n }, [_c('div', {\n staticClass: \"user-count\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n _vm.setProfileView('statuses')\n }\n }\n }, [_c('h5', [_vm._v(_vm._s(_vm.$t('user_card.statuses')))]), _vm._v(\" \"), _c('span', [_vm._v(_vm._s(_vm.user.statuses_count) + \" \"), _c('br')])]), _vm._v(\" \"), _c('div', {\n staticClass: \"user-count\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n _vm.setProfileView('friends')\n }\n }\n }, [_c('h5', [_vm._v(_vm._s(_vm.$t('user_card.followees')))]), _vm._v(\" \"), _c('span', [_vm._v(_vm._s(_vm.user.friends_count))])]), _vm._v(\" \"), _c('div', {\n staticClass: \"user-count\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n _vm.setProfileView('followers')\n }\n }\n }, [_c('h5', [_vm._v(_vm._s(_vm.$t('user_card.followers')))]), _vm._v(\" \"), _c('span', [_vm._v(_vm._s(_vm.user.followers_count))])])]) : _vm._e(), _vm._v(\" \"), (!_vm.hideBio && _vm.user.description_html) ? _c('p', {\n staticClass: \"profile-bio\",\n domProps: {\n \"innerHTML\": _vm._s(_vm.user.description_html)\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.linkClicked($event)\n }\n }\n }) : (!_vm.hideBio) ? _c('p', {\n staticClass: \"profile-bio\"\n }, [_vm._v(_vm._s(_vm.user.description))]) : _vm._e()]) : _vm._e()])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-a0166014\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/user_card_content/user_card_content.vue\n// module id = 721\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"user-panel\"\n }, [(_vm.user) ? _c('div', {\n staticClass: \"panel panel-default\",\n staticStyle: {\n \"overflow\": \"visible\"\n }\n }, [_c('user-card-content', {\n attrs: {\n \"user\": _vm.user,\n \"switcher\": false,\n \"hideBio\": true\n }\n }), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-footer\"\n }, [(_vm.user) ? _c('post-status-form') : _vm._e()], 1)], 1) : _vm._e(), _vm._v(\" \"), (!_vm.user) ? _c('login-form') : _vm._e()], 1)\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-a72b9910\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/user_panel/user_panel.vue\n// module id = 722\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"sidebar\"\n }, [_c('instance-specific-panel'), _vm._v(\" \"), (_vm.showFeaturesPanel) ? _c('features-panel') : _vm._e(), _vm._v(\" \"), _c('terms-of-service-panel')], 1)\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-a9b2b458\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/about/about.vue\n// module id = 723\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"side-drawer-container\",\n class: {\n 'side-drawer-container-closed': _vm.closed, 'side-drawer-container-open': !_vm.closed\n }\n }, [_c('div', {\n staticClass: \"side-drawer\",\n class: {\n 'side-drawer-closed': _vm.closed\n },\n on: {\n \"touchstart\": _vm.touchStart,\n \"touchmove\": _vm.touchMove\n }\n }, [_c('div', {\n staticClass: \"side-drawer-heading\",\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [(_vm.currentUser) ? _c('user-card-content', {\n attrs: {\n \"user\": _vm.currentUser,\n \"switcher\": false,\n \"hideBio\": true\n }\n }) : _c('div', {\n staticClass: \"side-drawer-logo-wrapper\"\n }, [_c('img', {\n attrs: {\n \"src\": _vm.logo\n }\n }), _vm._v(\" \"), _c('span', [_vm._v(_vm._s(_vm.sitename))])])], 1), _vm._v(\" \"), _c('ul', [(_vm.currentUser) ? _c('li', {\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'new-status',\n params: {\n username: _vm.currentUser.screen_name\n }\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"post_status.new_status\")) + \"\\n \")])], 1) : _c('li', {\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'login'\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"login.login\")) + \"\\n \")])], 1), _vm._v(\" \"), (_vm.currentUser) ? _c('li', {\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'notifications',\n params: {\n username: _vm.currentUser.screen_name\n }\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"notifications.notifications\")) + \" \" + _vm._s(_vm.unseenNotificationsCount > 0 ? (\"(\" + _vm.unseenNotificationsCount + \")\") : '') + \"\\n \")])], 1) : _vm._e(), _vm._v(\" \"), (_vm.currentUser) ? _c('li', {\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'dms',\n params: {\n username: _vm.currentUser.screen_name\n }\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.dms\")) + \"\\n \")])], 1) : _vm._e()]), _vm._v(\" \"), _c('ul', [(_vm.currentUser) ? _c('li', {\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'friends'\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.timeline\")) + \"\\n \")])], 1) : _vm._e(), _vm._v(\" \"), (_vm.currentUser && _vm.currentUser.locked) ? _c('li', {\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [_c('router-link', {\n attrs: {\n \"to\": \"/friend-requests\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.friend_requests\")) + \"\\n \"), (_vm.followRequestCount > 0) ? _c('span', {\n staticClass: \"badge follow-request-count\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.followRequestCount) + \"\\n \")]) : _vm._e()])], 1) : _vm._e(), _vm._v(\" \"), _c('li', {\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [_c('router-link', {\n attrs: {\n \"to\": \"/main/public\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.public_tl\")) + \"\\n \")])], 1), _vm._v(\" \"), _c('li', {\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [_c('router-link', {\n attrs: {\n \"to\": \"/main/all\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.twkn\")) + \"\\n \")])], 1), _vm._v(\" \"), (_vm.currentUser && _vm.chat) ? _c('li', {\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'chat'\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.chat\")) + \"\\n \")])], 1) : _vm._e()]), _vm._v(\" \"), _c('ul', [_c('li', {\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'user-search'\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.user_search\")) + \"\\n \")])], 1), _vm._v(\" \"), (_vm.currentUser && _vm.suggestionsEnabled) ? _c('li', {\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'who-to-follow'\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.who_to_follow\")) + \"\\n \")])], 1) : _vm._e(), _vm._v(\" \"), _c('li', {\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'settings'\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"settings.settings\")) + \"\\n \")])], 1), _vm._v(\" \"), _c('li', {\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'about'\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.about\")) + \"\\n \")])], 1), _vm._v(\" \"), (_vm.currentUser) ? _c('li', {\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [_c('a', {\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": _vm.doLogout\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"login.logout\")) + \"\\n \")])]) : _vm._e()])]), _vm._v(\" \"), _c('div', {\n staticClass: \"side-drawer-click-outside\",\n class: {\n 'side-drawer-click-outside-closed': _vm.closed\n },\n on: {\n \"click\": function($event) {\n $event.stopPropagation();\n $event.preventDefault();\n return _vm.toggleDrawer($event)\n }\n }\n })])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-b0cc0b28\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/side_drawer/side_drawer.vue\n// module id = 724\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('Timeline', {\n attrs: {\n \"title\": _vm.$t('nav.twkn'),\n \"timeline\": _vm.timeline,\n \"timeline-name\": 'publicAndExternal'\n }\n })\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-b0da3ad0\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/public_and_external_timeline/public_and_external_timeline.vue\n// module id = 725\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"range-control style-control\",\n class: {\n disabled: !_vm.present || _vm.disabled\n }\n }, [_c('label', {\n staticClass: \"label\",\n attrs: {\n \"for\": _vm.name\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.label) + \"\\n \")]), _vm._v(\" \"), (typeof _vm.fallback !== 'undefined') ? _c('input', {\n staticClass: \"opt exclude-disabled\",\n attrs: {\n \"id\": _vm.name + '-o',\n \"type\": \"checkbox\"\n },\n domProps: {\n \"checked\": _vm.present\n },\n on: {\n \"input\": function($event) {\n _vm.$emit('input', !_vm.present ? _vm.fallback : undefined)\n }\n }\n }) : _vm._e(), _vm._v(\" \"), (typeof _vm.fallback !== 'undefined') ? _c('label', {\n staticClass: \"opt-l\",\n attrs: {\n \"for\": _vm.name + '-o'\n }\n }) : _vm._e(), _vm._v(\" \"), _c('input', {\n staticClass: \"input-number\",\n attrs: {\n \"id\": _vm.name,\n \"type\": \"range\",\n \"disabled\": !_vm.present || _vm.disabled,\n \"max\": _vm.max || _vm.hardMax || 100,\n \"min\": _vm.min || _vm.hardMin || 0,\n \"step\": _vm.step || 1\n },\n domProps: {\n \"value\": _vm.value || _vm.fallback\n },\n on: {\n \"input\": function($event) {\n _vm.$emit('input', $event.target.value)\n }\n }\n }), _vm._v(\" \"), _c('input', {\n staticClass: \"input-number\",\n attrs: {\n \"id\": _vm.name,\n \"type\": \"number\",\n \"disabled\": !_vm.present || _vm.disabled,\n \"max\": _vm.hardMax,\n \"min\": _vm.hardMin,\n \"step\": _vm.step || 1\n },\n domProps: {\n \"value\": _vm.value || _vm.fallback\n },\n on: {\n \"input\": function($event) {\n _vm.$emit('input', $event.target.value)\n }\n }\n })])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-b947c06c\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/range_input/range_input.vue\n// module id = 726\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"style-switcher\"\n }, [_c('div', {\n staticClass: \"presets-container\"\n }, [_c('div', {\n staticClass: \"save-load\"\n }, [_c('export-import', {\n attrs: {\n \"exportObject\": _vm.exportedTheme,\n \"exportLabel\": _vm.$t(\"settings.export_theme\"),\n \"importLabel\": _vm.$t(\"settings.import_theme\"),\n \"importFailedText\": _vm.$t(\"settings.invalid_theme_imported\"),\n \"onImport\": _vm.onImport,\n \"validator\": _vm.importValidator\n }\n }, [_c('template', {\n slot: \"before\"\n }, [_c('div', {\n staticClass: \"presets\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.presets')) + \"\\n \"), _c('label', {\n staticClass: \"select\",\n attrs: {\n \"for\": \"preset-switcher\"\n }\n }, [_c('select', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.selected),\n expression: \"selected\"\n }],\n staticClass: \"preset-switcher\",\n attrs: {\n \"id\": \"preset-switcher\"\n },\n on: {\n \"change\": function($event) {\n var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n return o.selected\n }).map(function(o) {\n var val = \"_value\" in o ? o._value : o.value;\n return val\n });\n _vm.selected = $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n }\n }\n }, _vm._l((_vm.availableStyles), function(style) {\n return _c('option', {\n style: ({\n backgroundColor: style[1] || style.theme.colors.bg,\n color: style[3] || style.theme.colors.text\n }),\n domProps: {\n \"value\": style\n }\n }, [_vm._v(\"\\n \" + _vm._s(style[0] || style.name) + \"\\n \")])\n }), 0), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-down-open\"\n })])])])], 2)], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"save-load-options\"\n }, [_c('span', {\n staticClass: \"keep-option\"\n }, [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.keepColor),\n expression: \"keepColor\"\n }],\n attrs: {\n \"id\": \"keep-color\",\n \"type\": \"checkbox\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.keepColor) ? _vm._i(_vm.keepColor, null) > -1 : (_vm.keepColor)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.keepColor,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.keepColor = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.keepColor = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.keepColor = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"keep-color\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.keep_color')))])]), _vm._v(\" \"), _c('span', {\n staticClass: \"keep-option\"\n }, [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.keepShadows),\n expression: \"keepShadows\"\n }],\n attrs: {\n \"id\": \"keep-shadows\",\n \"type\": \"checkbox\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.keepShadows) ? _vm._i(_vm.keepShadows, null) > -1 : (_vm.keepShadows)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.keepShadows,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.keepShadows = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.keepShadows = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.keepShadows = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"keep-shadows\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.keep_shadows')))])]), _vm._v(\" \"), _c('span', {\n staticClass: \"keep-option\"\n }, [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.keepOpacity),\n expression: \"keepOpacity\"\n }],\n attrs: {\n \"id\": \"keep-opacity\",\n \"type\": \"checkbox\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.keepOpacity) ? _vm._i(_vm.keepOpacity, null) > -1 : (_vm.keepOpacity)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.keepOpacity,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.keepOpacity = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.keepOpacity = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.keepOpacity = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"keep-opacity\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.keep_opacity')))])]), _vm._v(\" \"), _c('span', {\n staticClass: \"keep-option\"\n }, [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.keepRoundness),\n expression: \"keepRoundness\"\n }],\n attrs: {\n \"id\": \"keep-roundness\",\n \"type\": \"checkbox\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.keepRoundness) ? _vm._i(_vm.keepRoundness, null) > -1 : (_vm.keepRoundness)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.keepRoundness,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.keepRoundness = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.keepRoundness = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.keepRoundness = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"keep-roundness\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.keep_roundness')))])]), _vm._v(\" \"), _c('span', {\n staticClass: \"keep-option\"\n }, [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.keepFonts),\n expression: \"keepFonts\"\n }],\n attrs: {\n \"id\": \"keep-fonts\",\n \"type\": \"checkbox\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.keepFonts) ? _vm._i(_vm.keepFonts, null) > -1 : (_vm.keepFonts)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.keepFonts,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.keepFonts = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.keepFonts = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.keepFonts = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"keep-fonts\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.keep_fonts')))])]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.style.switcher.save_load_hint')))])])]), _vm._v(\" \"), _c('div', {\n staticClass: \"preview-container\"\n }, [_c('preview', {\n style: (_vm.previewRules)\n })], 1), _vm._v(\" \"), _c('keep-alive', [_c('tab-switcher', {\n key: \"style-tweak\"\n }, [_c('div', {\n staticClass: \"color-container\",\n attrs: {\n \"label\": _vm.$t('settings.style.common_colors._tab_label')\n }\n }, [_c('div', {\n staticClass: \"tab-header\"\n }, [_c('p', [_vm._v(_vm._s(_vm.$t('settings.theme_help')))]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn\",\n on: {\n \"click\": _vm.clearOpacity\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.clear_opacity')))]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn\",\n on: {\n \"click\": _vm.clearV1\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.clear_all')))])]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.theme_help_v2_1')))]), _vm._v(\" \"), _c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.common_colors.main')))]), _vm._v(\" \"), _c('div', {\n staticClass: \"color-item\"\n }, [_c('ColorInput', {\n attrs: {\n \"name\": \"bgColor\",\n \"label\": _vm.$t('settings.background')\n },\n model: {\n value: (_vm.bgColorLocal),\n callback: function($$v) {\n _vm.bgColorLocal = $$v\n },\n expression: \"bgColorLocal\"\n }\n }), _vm._v(\" \"), _c('OpacityInput', {\n attrs: {\n \"name\": \"bgOpacity\",\n \"fallback\": _vm.previewTheme.opacity.bg || 1\n },\n model: {\n value: (_vm.bgOpacityLocal),\n callback: function($$v) {\n _vm.bgOpacityLocal = $$v\n },\n expression: \"bgOpacityLocal\"\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"textColor\",\n \"label\": _vm.$t('settings.text')\n },\n model: {\n value: (_vm.textColorLocal),\n callback: function($$v) {\n _vm.textColorLocal = $$v\n },\n expression: \"textColorLocal\"\n }\n }), _vm._v(\" \"), _c('ContrastRatio', {\n attrs: {\n \"contrast\": _vm.previewContrast.bgText\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"linkColor\",\n \"label\": _vm.$t('settings.links')\n },\n model: {\n value: (_vm.linkColorLocal),\n callback: function($$v) {\n _vm.linkColorLocal = $$v\n },\n expression: \"linkColorLocal\"\n }\n }), _vm._v(\" \"), _c('ContrastRatio', {\n attrs: {\n \"contrast\": _vm.previewContrast.bgLink\n }\n })], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"color-item\"\n }, [_c('ColorInput', {\n attrs: {\n \"name\": \"fgColor\",\n \"label\": _vm.$t('settings.foreground')\n },\n model: {\n value: (_vm.fgColorLocal),\n callback: function($$v) {\n _vm.fgColorLocal = $$v\n },\n expression: \"fgColorLocal\"\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"fgTextColor\",\n \"label\": _vm.$t('settings.text'),\n \"fallback\": _vm.previewTheme.colors.fgText\n },\n model: {\n value: (_vm.fgTextColorLocal),\n callback: function($$v) {\n _vm.fgTextColorLocal = $$v\n },\n expression: \"fgTextColorLocal\"\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"fgLinkColor\",\n \"label\": _vm.$t('settings.links'),\n \"fallback\": _vm.previewTheme.colors.fgLink\n },\n model: {\n value: (_vm.fgLinkColorLocal),\n callback: function($$v) {\n _vm.fgLinkColorLocal = $$v\n },\n expression: \"fgLinkColorLocal\"\n }\n }), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.style.common_colors.foreground_hint')))])], 1), _vm._v(\" \"), _c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.common_colors.rgbo')))]), _vm._v(\" \"), _c('div', {\n staticClass: \"color-item\"\n }, [_c('ColorInput', {\n attrs: {\n \"name\": \"cRedColor\",\n \"label\": _vm.$t('settings.cRed')\n },\n model: {\n value: (_vm.cRedColorLocal),\n callback: function($$v) {\n _vm.cRedColorLocal = $$v\n },\n expression: \"cRedColorLocal\"\n }\n }), _vm._v(\" \"), _c('ContrastRatio', {\n attrs: {\n \"contrast\": _vm.previewContrast.bgRed\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"cBlueColor\",\n \"label\": _vm.$t('settings.cBlue')\n },\n model: {\n value: (_vm.cBlueColorLocal),\n callback: function($$v) {\n _vm.cBlueColorLocal = $$v\n },\n expression: \"cBlueColorLocal\"\n }\n }), _vm._v(\" \"), _c('ContrastRatio', {\n attrs: {\n \"contrast\": _vm.previewContrast.bgBlue\n }\n })], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"color-item\"\n }, [_c('ColorInput', {\n attrs: {\n \"name\": \"cGreenColor\",\n \"label\": _vm.$t('settings.cGreen')\n },\n model: {\n value: (_vm.cGreenColorLocal),\n callback: function($$v) {\n _vm.cGreenColorLocal = $$v\n },\n expression: \"cGreenColorLocal\"\n }\n }), _vm._v(\" \"), _c('ContrastRatio', {\n attrs: {\n \"contrast\": _vm.previewContrast.bgGreen\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"cOrangeColor\",\n \"label\": _vm.$t('settings.cOrange')\n },\n model: {\n value: (_vm.cOrangeColorLocal),\n callback: function($$v) {\n _vm.cOrangeColorLocal = $$v\n },\n expression: \"cOrangeColorLocal\"\n }\n }), _vm._v(\" \"), _c('ContrastRatio', {\n attrs: {\n \"contrast\": _vm.previewContrast.bgOrange\n }\n })], 1), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.theme_help_v2_2')))])]), _vm._v(\" \"), _c('div', {\n staticClass: \"color-container\",\n attrs: {\n \"label\": _vm.$t('settings.style.advanced_colors._tab_label')\n }\n }, [_c('div', {\n staticClass: \"tab-header\"\n }, [_c('p', [_vm._v(_vm._s(_vm.$t('settings.theme_help')))]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn\",\n on: {\n \"click\": _vm.clearOpacity\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.clear_opacity')))]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn\",\n on: {\n \"click\": _vm.clearV1\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.clear_all')))])]), _vm._v(\" \"), _c('div', {\n staticClass: \"color-item\"\n }, [_c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.advanced_colors.alert')))]), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"alertError\",\n \"label\": _vm.$t('settings.style.advanced_colors.alert_error'),\n \"fallback\": _vm.previewTheme.colors.alertError\n },\n model: {\n value: (_vm.alertErrorColorLocal),\n callback: function($$v) {\n _vm.alertErrorColorLocal = $$v\n },\n expression: \"alertErrorColorLocal\"\n }\n }), _vm._v(\" \"), _c('ContrastRatio', {\n attrs: {\n \"contrast\": _vm.previewContrast.alertError\n }\n })], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"color-item\"\n }, [_c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.advanced_colors.badge')))]), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"badgeNotification\",\n \"label\": _vm.$t('settings.style.advanced_colors.badge_notification'),\n \"fallback\": _vm.previewTheme.colors.badgeNotification\n },\n model: {\n value: (_vm.badgeNotificationColorLocal),\n callback: function($$v) {\n _vm.badgeNotificationColorLocal = $$v\n },\n expression: \"badgeNotificationColorLocal\"\n }\n })], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"color-item\"\n }, [_c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.advanced_colors.panel_header')))]), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"panelColor\",\n \"fallback\": _vm.fgColorLocal,\n \"label\": _vm.$t('settings.background')\n },\n model: {\n value: (_vm.panelColorLocal),\n callback: function($$v) {\n _vm.panelColorLocal = $$v\n },\n expression: \"panelColorLocal\"\n }\n }), _vm._v(\" \"), _c('OpacityInput', {\n attrs: {\n \"name\": \"panelOpacity\",\n \"fallback\": _vm.previewTheme.opacity.panel || 1\n },\n model: {\n value: (_vm.panelOpacityLocal),\n callback: function($$v) {\n _vm.panelOpacityLocal = $$v\n },\n expression: \"panelOpacityLocal\"\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"panelTextColor\",\n \"fallback\": _vm.previewTheme.colors.panelText,\n \"label\": _vm.$t('settings.text')\n },\n model: {\n value: (_vm.panelTextColorLocal),\n callback: function($$v) {\n _vm.panelTextColorLocal = $$v\n },\n expression: \"panelTextColorLocal\"\n }\n }), _vm._v(\" \"), _c('ContrastRatio', {\n attrs: {\n \"contrast\": _vm.previewContrast.panelText,\n \"large\": \"1\"\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"panelLinkColor\",\n \"fallback\": _vm.previewTheme.colors.panelLink,\n \"label\": _vm.$t('settings.links')\n },\n model: {\n value: (_vm.panelLinkColorLocal),\n callback: function($$v) {\n _vm.panelLinkColorLocal = $$v\n },\n expression: \"panelLinkColorLocal\"\n }\n }), _vm._v(\" \"), _c('ContrastRatio', {\n attrs: {\n \"contrast\": _vm.previewContrast.panelLink,\n \"large\": \"1\"\n }\n })], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"color-item\"\n }, [_c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.advanced_colors.top_bar')))]), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"topBarColor\",\n \"fallback\": _vm.fgColorLocal,\n \"label\": _vm.$t('settings.background')\n },\n model: {\n value: (_vm.topBarColorLocal),\n callback: function($$v) {\n _vm.topBarColorLocal = $$v\n },\n expression: \"topBarColorLocal\"\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"topBarTextColor\",\n \"fallback\": _vm.previewTheme.colors.topBarText,\n \"label\": _vm.$t('settings.text')\n },\n model: {\n value: (_vm.topBarTextColorLocal),\n callback: function($$v) {\n _vm.topBarTextColorLocal = $$v\n },\n expression: \"topBarTextColorLocal\"\n }\n }), _vm._v(\" \"), _c('ContrastRatio', {\n attrs: {\n \"contrast\": _vm.previewContrast.topBarText\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"topBarLinkColor\",\n \"fallback\": _vm.previewTheme.colors.topBarLink,\n \"label\": _vm.$t('settings.links')\n },\n model: {\n value: (_vm.topBarLinkColorLocal),\n callback: function($$v) {\n _vm.topBarLinkColorLocal = $$v\n },\n expression: \"topBarLinkColorLocal\"\n }\n }), _vm._v(\" \"), _c('ContrastRatio', {\n attrs: {\n \"contrast\": _vm.previewContrast.topBarLink\n }\n })], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"color-item\"\n }, [_c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.advanced_colors.inputs')))]), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"inputColor\",\n \"fallback\": _vm.fgColorLocal,\n \"label\": _vm.$t('settings.background')\n },\n model: {\n value: (_vm.inputColorLocal),\n callback: function($$v) {\n _vm.inputColorLocal = $$v\n },\n expression: \"inputColorLocal\"\n }\n }), _vm._v(\" \"), _c('OpacityInput', {\n attrs: {\n \"name\": \"inputOpacity\",\n \"fallback\": _vm.previewTheme.opacity.input || 1\n },\n model: {\n value: (_vm.inputOpacityLocal),\n callback: function($$v) {\n _vm.inputOpacityLocal = $$v\n },\n expression: \"inputOpacityLocal\"\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"inputTextColor\",\n \"fallback\": _vm.previewTheme.colors.inputText,\n \"label\": _vm.$t('settings.text')\n },\n model: {\n value: (_vm.inputTextColorLocal),\n callback: function($$v) {\n _vm.inputTextColorLocal = $$v\n },\n expression: \"inputTextColorLocal\"\n }\n }), _vm._v(\" \"), _c('ContrastRatio', {\n attrs: {\n \"contrast\": _vm.previewContrast.inputText\n }\n })], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"color-item\"\n }, [_c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.advanced_colors.buttons')))]), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"btnColor\",\n \"fallback\": _vm.fgColorLocal,\n \"label\": _vm.$t('settings.background')\n },\n model: {\n value: (_vm.btnColorLocal),\n callback: function($$v) {\n _vm.btnColorLocal = $$v\n },\n expression: \"btnColorLocal\"\n }\n }), _vm._v(\" \"), _c('OpacityInput', {\n attrs: {\n \"name\": \"btnOpacity\",\n \"fallback\": _vm.previewTheme.opacity.btn || 1\n },\n model: {\n value: (_vm.btnOpacityLocal),\n callback: function($$v) {\n _vm.btnOpacityLocal = $$v\n },\n expression: \"btnOpacityLocal\"\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"btnTextColor\",\n \"fallback\": _vm.previewTheme.colors.btnText,\n \"label\": _vm.$t('settings.text')\n },\n model: {\n value: (_vm.btnTextColorLocal),\n callback: function($$v) {\n _vm.btnTextColorLocal = $$v\n },\n expression: \"btnTextColorLocal\"\n }\n }), _vm._v(\" \"), _c('ContrastRatio', {\n attrs: {\n \"contrast\": _vm.previewContrast.btnText\n }\n })], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"color-item\"\n }, [_c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.advanced_colors.borders')))]), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"borderColor\",\n \"fallback\": _vm.previewTheme.colors.border,\n \"label\": _vm.$t('settings.style.common.color')\n },\n model: {\n value: (_vm.borderColorLocal),\n callback: function($$v) {\n _vm.borderColorLocal = $$v\n },\n expression: \"borderColorLocal\"\n }\n }), _vm._v(\" \"), _c('OpacityInput', {\n attrs: {\n \"name\": \"borderOpacity\",\n \"fallback\": _vm.previewTheme.opacity.border || 1\n },\n model: {\n value: (_vm.borderOpacityLocal),\n callback: function($$v) {\n _vm.borderOpacityLocal = $$v\n },\n expression: \"borderOpacityLocal\"\n }\n })], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"color-item\"\n }, [_c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.advanced_colors.faint_text')))]), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"faintColor\",\n \"fallback\": _vm.previewTheme.colors.faint || 1,\n \"label\": _vm.$t('settings.text')\n },\n model: {\n value: (_vm.faintColorLocal),\n callback: function($$v) {\n _vm.faintColorLocal = $$v\n },\n expression: \"faintColorLocal\"\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"faintLinkColor\",\n \"fallback\": _vm.previewTheme.colors.faintLink,\n \"label\": _vm.$t('settings.links')\n },\n model: {\n value: (_vm.faintLinkColorLocal),\n callback: function($$v) {\n _vm.faintLinkColorLocal = $$v\n },\n expression: \"faintLinkColorLocal\"\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"panelFaintColor\",\n \"fallback\": _vm.previewTheme.colors.panelFaint,\n \"label\": _vm.$t('settings.style.advanced_colors.panel_header')\n },\n model: {\n value: (_vm.panelFaintColorLocal),\n callback: function($$v) {\n _vm.panelFaintColorLocal = $$v\n },\n expression: \"panelFaintColorLocal\"\n }\n }), _vm._v(\" \"), _c('OpacityInput', {\n attrs: {\n \"name\": \"faintOpacity\",\n \"fallback\": _vm.previewTheme.opacity.faint || 0.5\n },\n model: {\n value: (_vm.faintOpacityLocal),\n callback: function($$v) {\n _vm.faintOpacityLocal = $$v\n },\n expression: \"faintOpacityLocal\"\n }\n })], 1)]), _vm._v(\" \"), _c('div', {\n staticClass: \"radius-container\",\n attrs: {\n \"label\": _vm.$t('settings.style.radii._tab_label')\n }\n }, [_c('div', {\n staticClass: \"tab-header\"\n }, [_c('p', [_vm._v(_vm._s(_vm.$t('settings.radii_help')))]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn\",\n on: {\n \"click\": _vm.clearRoundness\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.clear_all')))])]), _vm._v(\" \"), _c('RangeInput', {\n attrs: {\n \"name\": \"btnRadius\",\n \"label\": _vm.$t('settings.btnRadius'),\n \"fallback\": _vm.previewTheme.radii.btn,\n \"max\": \"16\",\n \"hardMin\": \"0\"\n },\n model: {\n value: (_vm.btnRadiusLocal),\n callback: function($$v) {\n _vm.btnRadiusLocal = $$v\n },\n expression: \"btnRadiusLocal\"\n }\n }), _vm._v(\" \"), _c('RangeInput', {\n attrs: {\n \"name\": \"inputRadius\",\n \"label\": _vm.$t('settings.inputRadius'),\n \"fallback\": _vm.previewTheme.radii.input,\n \"max\": \"9\",\n \"hardMin\": \"0\"\n },\n model: {\n value: (_vm.inputRadiusLocal),\n callback: function($$v) {\n _vm.inputRadiusLocal = $$v\n },\n expression: \"inputRadiusLocal\"\n }\n }), _vm._v(\" \"), _c('RangeInput', {\n attrs: {\n \"name\": \"checkboxRadius\",\n \"label\": _vm.$t('settings.checkboxRadius'),\n \"fallback\": _vm.previewTheme.radii.checkbox,\n \"max\": \"16\",\n \"hardMin\": \"0\"\n },\n model: {\n value: (_vm.checkboxRadiusLocal),\n callback: function($$v) {\n _vm.checkboxRadiusLocal = $$v\n },\n expression: \"checkboxRadiusLocal\"\n }\n }), _vm._v(\" \"), _c('RangeInput', {\n attrs: {\n \"name\": \"panelRadius\",\n \"label\": _vm.$t('settings.panelRadius'),\n \"fallback\": _vm.previewTheme.radii.panel,\n \"max\": \"50\",\n \"hardMin\": \"0\"\n },\n model: {\n value: (_vm.panelRadiusLocal),\n callback: function($$v) {\n _vm.panelRadiusLocal = $$v\n },\n expression: \"panelRadiusLocal\"\n }\n }), _vm._v(\" \"), _c('RangeInput', {\n attrs: {\n \"name\": \"avatarRadius\",\n \"label\": _vm.$t('settings.avatarRadius'),\n \"fallback\": _vm.previewTheme.radii.avatar,\n \"max\": \"28\",\n \"hardMin\": \"0\"\n },\n model: {\n value: (_vm.avatarRadiusLocal),\n callback: function($$v) {\n _vm.avatarRadiusLocal = $$v\n },\n expression: \"avatarRadiusLocal\"\n }\n }), _vm._v(\" \"), _c('RangeInput', {\n attrs: {\n \"name\": \"avatarAltRadius\",\n \"label\": _vm.$t('settings.avatarAltRadius'),\n \"fallback\": _vm.previewTheme.radii.avatarAlt,\n \"max\": \"28\",\n \"hardMin\": \"0\"\n },\n model: {\n value: (_vm.avatarAltRadiusLocal),\n callback: function($$v) {\n _vm.avatarAltRadiusLocal = $$v\n },\n expression: \"avatarAltRadiusLocal\"\n }\n }), _vm._v(\" \"), _c('RangeInput', {\n attrs: {\n \"name\": \"attachmentRadius\",\n \"label\": _vm.$t('settings.attachmentRadius'),\n \"fallback\": _vm.previewTheme.radii.attachment,\n \"max\": \"50\",\n \"hardMin\": \"0\"\n },\n model: {\n value: (_vm.attachmentRadiusLocal),\n callback: function($$v) {\n _vm.attachmentRadiusLocal = $$v\n },\n expression: \"attachmentRadiusLocal\"\n }\n }), _vm._v(\" \"), _c('RangeInput', {\n attrs: {\n \"name\": \"tooltipRadius\",\n \"label\": _vm.$t('settings.tooltipRadius'),\n \"fallback\": _vm.previewTheme.radii.tooltip,\n \"max\": \"50\",\n \"hardMin\": \"0\"\n },\n model: {\n value: (_vm.tooltipRadiusLocal),\n callback: function($$v) {\n _vm.tooltipRadiusLocal = $$v\n },\n expression: \"tooltipRadiusLocal\"\n }\n })], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"shadow-container\",\n attrs: {\n \"label\": _vm.$t('settings.style.shadows._tab_label')\n }\n }, [_c('div', {\n staticClass: \"tab-header shadow-selector\"\n }, [_c('div', {\n staticClass: \"select-container\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.shadows.component')) + \"\\n \"), _c('label', {\n staticClass: \"select\",\n attrs: {\n \"for\": \"shadow-switcher\"\n }\n }, [_c('select', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.shadowSelected),\n expression: \"shadowSelected\"\n }],\n staticClass: \"shadow-switcher\",\n attrs: {\n \"id\": \"shadow-switcher\"\n },\n on: {\n \"change\": function($event) {\n var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n return o.selected\n }).map(function(o) {\n var val = \"_value\" in o ? o._value : o.value;\n return val\n });\n _vm.shadowSelected = $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n }\n }\n }, _vm._l((_vm.shadowsAvailable), function(shadow) {\n return _c('option', {\n domProps: {\n \"value\": shadow\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.shadows.components.' + shadow)) + \"\\n \")])\n }), 0), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-down-open\"\n })])]), _vm._v(\" \"), _c('div', {\n staticClass: \"override\"\n }, [_c('label', {\n staticClass: \"label\",\n attrs: {\n \"for\": \"override\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.shadows.override')) + \"\\n \")]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.currentShadowOverriden),\n expression: \"currentShadowOverriden\"\n }],\n staticClass: \"input-override\",\n attrs: {\n \"name\": \"override\",\n \"id\": \"override\",\n \"type\": \"checkbox\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.currentShadowOverriden) ? _vm._i(_vm.currentShadowOverriden, null) > -1 : (_vm.currentShadowOverriden)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.currentShadowOverriden,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.currentShadowOverriden = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.currentShadowOverriden = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.currentShadowOverriden = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n staticClass: \"checkbox-label\",\n attrs: {\n \"for\": \"override\"\n }\n })]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn\",\n on: {\n \"click\": _vm.clearShadows\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.clear_all')))])]), _vm._v(\" \"), _c('shadow-control', {\n attrs: {\n \"ready\": !!_vm.currentShadowFallback,\n \"fallback\": _vm.currentShadowFallback\n },\n model: {\n value: (_vm.currentShadow),\n callback: function($$v) {\n _vm.currentShadow = $$v\n },\n expression: \"currentShadow\"\n }\n }), _vm._v(\" \"), (_vm.shadowSelected === 'avatar' || _vm.shadowSelected === 'avatarStatus') ? _c('div', [_c('i18n', {\n attrs: {\n \"path\": \"settings.style.shadows.filter_hint.always_drop_shadow\",\n \"tag\": \"p\"\n }\n }, [_c('code', [_vm._v(\"filter: drop-shadow()\")])]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.style.shadows.filter_hint.avatar_inset')))]), _vm._v(\" \"), _c('i18n', {\n attrs: {\n \"path\": \"settings.style.shadows.filter_hint.drop_shadow_syntax\",\n \"tag\": \"p\"\n }\n }, [_c('code', [_vm._v(\"drop-shadow\")]), _vm._v(\" \"), _c('code', [_vm._v(\"spread-radius\")]), _vm._v(\" \"), _c('code', [_vm._v(\"inset\")])]), _vm._v(\" \"), _c('i18n', {\n attrs: {\n \"path\": \"settings.style.shadows.filter_hint.inset_classic\",\n \"tag\": \"p\"\n }\n }, [_c('code', [_vm._v(\"box-shadow\")])]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.style.shadows.filter_hint.spread_zero')))])], 1) : _vm._e()], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"fonts-container\",\n attrs: {\n \"label\": _vm.$t('settings.style.fonts._tab_label')\n }\n }, [_c('div', {\n staticClass: \"tab-header\"\n }, [_c('p', [_vm._v(_vm._s(_vm.$t('settings.style.fonts.help')))]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn\",\n on: {\n \"click\": _vm.clearFonts\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.clear_all')))])]), _vm._v(\" \"), _c('FontControl', {\n attrs: {\n \"name\": \"ui\",\n \"label\": _vm.$t('settings.style.fonts.components.interface'),\n \"fallback\": _vm.previewTheme.fonts.interface,\n \"no-inherit\": \"1\"\n },\n model: {\n value: (_vm.fontsLocal.interface),\n callback: function($$v) {\n _vm.$set(_vm.fontsLocal, \"interface\", $$v)\n },\n expression: \"fontsLocal.interface\"\n }\n }), _vm._v(\" \"), _c('FontControl', {\n attrs: {\n \"name\": \"input\",\n \"label\": _vm.$t('settings.style.fonts.components.input'),\n \"fallback\": _vm.previewTheme.fonts.input\n },\n model: {\n value: (_vm.fontsLocal.input),\n callback: function($$v) {\n _vm.$set(_vm.fontsLocal, \"input\", $$v)\n },\n expression: \"fontsLocal.input\"\n }\n }), _vm._v(\" \"), _c('FontControl', {\n attrs: {\n \"name\": \"post\",\n \"label\": _vm.$t('settings.style.fonts.components.post'),\n \"fallback\": _vm.previewTheme.fonts.post\n },\n model: {\n value: (_vm.fontsLocal.post),\n callback: function($$v) {\n _vm.$set(_vm.fontsLocal, \"post\", $$v)\n },\n expression: \"fontsLocal.post\"\n }\n }), _vm._v(\" \"), _c('FontControl', {\n attrs: {\n \"name\": \"postCode\",\n \"label\": _vm.$t('settings.style.fonts.components.postCode'),\n \"fallback\": _vm.previewTheme.fonts.postCode\n },\n model: {\n value: (_vm.fontsLocal.postCode),\n callback: function($$v) {\n _vm.$set(_vm.fontsLocal, \"postCode\", $$v)\n },\n expression: \"fontsLocal.postCode\"\n }\n })], 1)])], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"apply-container\"\n }, [_c('button', {\n staticClass: \"btn submit\",\n attrs: {\n \"disabled\": !_vm.themeValid\n },\n on: {\n \"click\": _vm.setCustomTheme\n }\n }, [_vm._v(_vm._s(_vm.$t('general.apply')))]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn\",\n on: {\n \"click\": _vm.clearAll\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.reset')))])])], 1)\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-ba17cdd0\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/style_switcher/style_switcher.vue\n// module id = 727\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"who-to-follow-panel\"\n }, [_c('div', {\n staticClass: \"panel panel-default base01-background\"\n }, [_c('div', {\n staticClass: \"panel-heading timeline-heading base02-background base04\"\n }, [_c('div', {\n staticClass: \"title\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('who_to_follow.who_to_follow')) + \"\\n \")])]), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-body who-to-follow\"\n }, [_vm._l((_vm.usersToFollow), function(user) {\n return _c('span', [_c('img', {\n attrs: {\n \"src\": user.img\n }\n }), _vm._v(\" \"), _c('router-link', {\n attrs: {\n \"to\": _vm.userProfileLink(user.id, user.name)\n }\n }, [_vm._v(\"\\n \" + _vm._s(user.name) + \"\\n \")]), _c('br')], 1)\n }), _vm._v(\" \"), _c('img', {\n attrs: {\n \"src\": _vm.$store.state.instance.logo\n }\n }), _vm._v(\" \"), _c('router-link', {\n attrs: {\n \"to\": {\n name: 'who-to-follow'\n }\n }\n }, [_vm._v(_vm._s(_vm.$t('who_to_follow.more')))])], 2)])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-bf9ee3a8\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/who_to_follow_panel/who_to_follow_panel.vue\n// module id = 728\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"opacity-control style-control\",\n class: {\n disabled: !_vm.present || _vm.disabled\n }\n }, [_c('label', {\n staticClass: \"label\",\n attrs: {\n \"for\": _vm.name\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.common.opacity')) + \"\\n \")]), _vm._v(\" \"), (typeof _vm.fallback !== 'undefined') ? _c('input', {\n staticClass: \"opt exclude-disabled\",\n attrs: {\n \"id\": _vm.name + '-o',\n \"type\": \"checkbox\"\n },\n domProps: {\n \"checked\": _vm.present\n },\n on: {\n \"input\": function($event) {\n _vm.$emit('input', !_vm.present ? _vm.fallback : undefined)\n }\n }\n }) : _vm._e(), _vm._v(\" \"), (typeof _vm.fallback !== 'undefined') ? _c('label', {\n staticClass: \"opt-l\",\n attrs: {\n \"for\": _vm.name + '-o'\n }\n }) : _vm._e(), _vm._v(\" \"), _c('input', {\n staticClass: \"input-number\",\n attrs: {\n \"id\": _vm.name,\n \"type\": \"number\",\n \"disabled\": !_vm.present || _vm.disabled,\n \"max\": \"1\",\n \"min\": \"0\",\n \"step\": \".05\"\n },\n domProps: {\n \"value\": _vm.value || _vm.fallback\n },\n on: {\n \"input\": function($event) {\n _vm.$emit('input', $event.target.value)\n }\n }\n })])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-c69d01b4\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/opacity_input/opacity_input.vue\n// module id = 729\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"user-search panel panel-default\"\n }, [_c('div', {\n staticClass: \"panel-heading\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('nav.user_search')) + \"\\n \")]), _vm._v(\" \"), _c('div', {\n staticClass: \"user-search-input-container\"\n }, [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.username),\n expression: \"username\"\n }],\n ref: \"userSearchInput\",\n staticClass: \"user-finder-input\",\n attrs: {\n \"placeholder\": _vm.$t('finder.find_user')\n },\n domProps: {\n \"value\": (_vm.username)\n },\n on: {\n \"keyup\": function($event) {\n if (!('button' in $event) && _vm._k($event.keyCode, \"enter\", 13, $event.key, \"Enter\")) { return null; }\n _vm.newQuery(_vm.username)\n },\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.username = $event.target.value\n }\n }\n }), _vm._v(\" \"), _c('button', {\n staticClass: \"btn search-button\",\n on: {\n \"click\": function($event) {\n _vm.newQuery(_vm.username)\n }\n }\n }, [_c('i', {\n staticClass: \"icon-search\"\n })])]), _vm._v(\" \"), (_vm.loading) ? _c('div', {\n staticClass: \"text-center loading-icon\"\n }, [_c('i', {\n staticClass: \"icon-spin3 animate-spin\"\n })]) : _c('div', {\n staticClass: \"panel-body\"\n }, _vm._l((_vm.users), function(user) {\n return _c('FollowCard', {\n key: user.id,\n attrs: {\n \"user\": user\n }\n })\n }), 1)])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-c7873b1c\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/user_search/user_search.vue\n// module id = 730\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return (!_vm.hideStatus) ? _c('div', {\n staticClass: \"status-el\",\n class: [{\n 'status-el_focused': _vm.isFocused\n }, {\n 'status-conversation': _vm.inlineExpanded\n }]\n }, [(_vm.muted && !_vm.isPreview) ? [_c('div', {\n staticClass: \"media status container muted\"\n }, [_c('small', [_c('router-link', {\n attrs: {\n \"to\": _vm.userProfileLink\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.status.user.screen_name) + \"\\n \")])], 1), _vm._v(\" \"), _c('small', {\n staticClass: \"muteWords\"\n }, [_vm._v(_vm._s(_vm.muteWordHits.join(', ')))]), _vm._v(\" \"), _c('a', {\n staticClass: \"unmute\",\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.toggleMute($event)\n }\n }\n }, [_c('i', {\n staticClass: \"button-icon icon-eye-off\"\n })])])] : [(_vm.retweet && !_vm.noHeading) ? _c('div', {\n staticClass: \"media container retweet-info\",\n class: [_vm.repeaterClass, {\n highlighted: _vm.repeaterStyle\n }],\n style: ([_vm.repeaterStyle])\n }, [(_vm.retweet) ? _c('UserAvatar', {\n staticClass: \"media-left\",\n attrs: {\n \"betterShadow\": _vm.betterShadow,\n \"src\": _vm.statusoid.user.profile_image_url_original\n }\n }) : _vm._e(), _vm._v(\" \"), _c('div', {\n staticClass: \"media-body faint\"\n }, [_c('span', {\n staticClass: \"user-name\"\n }, [(_vm.retweeterHtml) ? _c('router-link', {\n attrs: {\n \"to\": _vm.retweeterProfileLink\n },\n domProps: {\n \"innerHTML\": _vm._s(_vm.retweeterHtml)\n }\n }) : _c('router-link', {\n attrs: {\n \"to\": _vm.retweeterProfileLink\n }\n }, [_vm._v(_vm._s(_vm.retweeter))])], 1), _vm._v(\" \"), _c('i', {\n staticClass: \"fa icon-retweet retweeted\",\n attrs: {\n \"title\": _vm.$t('tool_tip.repeat')\n }\n }), _vm._v(\"\\n \" + _vm._s(_vm.$t('timeline.repeated')) + \"\\n \")])], 1) : _vm._e(), _vm._v(\" \"), _c('div', {\n staticClass: \"media status\",\n class: [_vm.userClass, {\n highlighted: _vm.userStyle,\n 'is-retweet': _vm.retweet\n }],\n style: ([_vm.userStyle])\n }, [(!_vm.noHeading) ? _c('div', {\n staticClass: \"media-left\"\n }, [_c('router-link', {\n attrs: {\n \"to\": _vm.userProfileLink\n },\n nativeOn: {\n \"!click\": function($event) {\n $event.stopPropagation();\n $event.preventDefault();\n return _vm.toggleUserExpanded($event)\n }\n }\n }, [_c('UserAvatar', {\n attrs: {\n \"compact\": _vm.compact,\n \"betterShadow\": _vm.betterShadow,\n \"src\": _vm.status.user.profile_image_url_original\n }\n })], 1)], 1) : _vm._e(), _vm._v(\" \"), _c('div', {\n staticClass: \"status-body\"\n }, [(_vm.userExpanded) ? _c('div', {\n staticClass: \"usercard\"\n }, [_c('user-card-content', {\n attrs: {\n \"user\": _vm.status.user,\n \"switcher\": false\n }\n })], 1) : _vm._e(), _vm._v(\" \"), (!_vm.noHeading) ? _c('div', {\n staticClass: \"media-heading\"\n }, [_c('div', {\n staticClass: \"heading-name-row\"\n }, [_c('div', {\n staticClass: \"name-and-account-name\"\n }, [(_vm.status.user.name_html) ? _c('h4', {\n staticClass: \"user-name\",\n domProps: {\n \"innerHTML\": _vm._s(_vm.status.user.name_html)\n }\n }) : _c('h4', {\n staticClass: \"user-name\"\n }, [_vm._v(_vm._s(_vm.status.user.name))]), _vm._v(\" \"), _c('router-link', {\n staticClass: \"account-name\",\n attrs: {\n \"to\": _vm.userProfileLink\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.status.user.screen_name) + \"\\n \")])], 1), _vm._v(\" \"), _c('span', {\n staticClass: \"heading-right\"\n }, [_c('router-link', {\n staticClass: \"timeago faint-link\",\n attrs: {\n \"to\": {\n name: 'conversation',\n params: {\n id: _vm.status.id\n }\n }\n }\n }, [_c('timeago', {\n attrs: {\n \"since\": _vm.status.created_at,\n \"auto-update\": 60\n }\n })], 1), _vm._v(\" \"), (_vm.status.visibility) ? _c('div', {\n staticClass: \"button-icon visibility-icon\"\n }, [_c('i', {\n class: _vm.visibilityIcon(_vm.status.visibility),\n attrs: {\n \"title\": _vm._f(\"capitalize\")(_vm.status.visibility)\n }\n })]) : _vm._e(), _vm._v(\" \"), (!_vm.status.is_local && !_vm.isPreview) ? _c('a', {\n staticClass: \"source_url\",\n attrs: {\n \"href\": _vm.status.external_url,\n \"target\": \"_blank\",\n \"title\": \"Source\"\n }\n }, [_c('i', {\n staticClass: \"button-icon icon-link-ext-alt\"\n })]) : _vm._e(), _vm._v(\" \"), (_vm.expandable && !_vm.isPreview) ? [_c('a', {\n attrs: {\n \"href\": \"#\",\n \"title\": \"Expand\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.toggleExpanded($event)\n }\n }\n }, [_c('i', {\n staticClass: \"button-icon icon-plus-squared\"\n })])] : _vm._e(), _vm._v(\" \"), (_vm.unmuted) ? _c('a', {\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.toggleMute($event)\n }\n }\n }, [_c('i', {\n staticClass: \"button-icon icon-eye-off\"\n })]) : _vm._e()], 2)]), _vm._v(\" \"), _c('div', {\n staticClass: \"heading-reply-row\"\n }, [(_vm.isReply) ? _c('div', {\n staticClass: \"reply-to-and-accountname\"\n }, [_c('a', {\n staticClass: \"reply-to\",\n attrs: {\n \"href\": \"#\",\n \"aria-label\": _vm.$t('tool_tip.reply')\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n _vm.gotoOriginal(_vm.status.in_reply_to_status_id)\n },\n \"mouseenter\": function($event) {\n $event.preventDefault();\n $event.stopPropagation();\n _vm.replyEnter(_vm.status.in_reply_to_status_id, $event)\n },\n \"mouseleave\": function($event) {\n $event.preventDefault();\n $event.stopPropagation();\n _vm.replyLeave()\n }\n }\n }, [(!_vm.isPreview) ? _c('i', {\n staticClass: \"button-icon icon-reply\"\n }) : _vm._e(), _vm._v(\" \"), _c('span', {\n staticClass: \"faint-link reply-to-text\"\n }, [_vm._v(_vm._s(_vm.$t('status.reply_to')))])]), _vm._v(\" \"), _c('router-link', {\n attrs: {\n \"to\": _vm.replyProfileLink\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.replyToName) + \"\\n \")]), _vm._v(\" \"), (_vm.replies && _vm.replies.length) ? _c('span', {\n staticClass: \"faint replies-separator\"\n }, [_vm._v(\"\\n -\\n \")]) : _vm._e()], 1) : _vm._e(), _vm._v(\" \"), (_vm.inConversation && !_vm.isPreview) ? _c('div', {\n staticClass: \"replies\"\n }, [(_vm.replies && _vm.replies.length) ? _c('span', {\n staticClass: \"faint\"\n }, [_vm._v(_vm._s(_vm.$t('status.replies_list')))]) : _vm._e(), _vm._v(\" \"), _vm._l((_vm.replies), function(reply) {\n return (_vm.replies) ? _c('span', {\n staticClass: \"reply-link faint\"\n }, [_c('a', {\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n _vm.gotoOriginal(reply.id)\n },\n \"mouseenter\": function($event) {\n _vm.replyEnter(reply.id, $event)\n },\n \"mouseout\": function($event) {\n _vm.replyLeave()\n }\n }\n }, [_vm._v(_vm._s(reply.name))])]) : _vm._e()\n })], 2) : _vm._e()])]) : _vm._e(), _vm._v(\" \"), (_vm.showPreview) ? _c('div', {\n staticClass: \"status-preview-container\"\n }, [(_vm.preview) ? _c('status', {\n staticClass: \"status-preview\",\n attrs: {\n \"isPreview\": true,\n \"statusoid\": _vm.preview,\n \"compact\": true\n }\n }) : _c('div', {\n staticClass: \"status-preview status-preview-loading\"\n }, [_c('i', {\n staticClass: \"icon-spin4 animate-spin\"\n })])], 1) : _vm._e(), _vm._v(\" \"), (_vm.longSubject) ? _c('div', {\n staticClass: \"status-content-wrapper\",\n class: {\n 'tall-status': !_vm.showingLongSubject\n }\n }, [(!_vm.showingLongSubject) ? _c('a', {\n staticClass: \"tall-status-hider\",\n class: {\n 'tall-status-hider_focused': _vm.isFocused\n },\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n _vm.showingLongSubject = true\n }\n }\n }, [_vm._v(\"Show more\")]) : _vm._e(), _vm._v(\" \"), _c('div', {\n staticClass: \"status-content media-body\",\n domProps: {\n \"innerHTML\": _vm._s(_vm.status.statusnet_html)\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.linkClicked($event)\n }\n }\n }), _vm._v(\" \"), (_vm.showingLongSubject) ? _c('a', {\n staticClass: \"status-unhider\",\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n _vm.showingLongSubject = false\n }\n }\n }, [_vm._v(\"Show less\")]) : _vm._e()]) : _c('div', {\n staticClass: \"status-content-wrapper\",\n class: {\n 'tall-status': _vm.hideTallStatus\n }\n }, [(_vm.hideTallStatus) ? _c('a', {\n staticClass: \"tall-status-hider\",\n class: {\n 'tall-status-hider_focused': _vm.isFocused\n },\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.toggleShowMore($event)\n }\n }\n }, [_vm._v(\"Show more\")]) : _vm._e(), _vm._v(\" \"), (!_vm.hideSubjectStatus) ? _c('div', {\n staticClass: \"status-content media-body\",\n domProps: {\n \"innerHTML\": _vm._s(_vm.status.statusnet_html)\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.linkClicked($event)\n }\n }\n }) : _c('div', {\n staticClass: \"status-content media-body\",\n domProps: {\n \"innerHTML\": _vm._s(_vm.status.summary_html)\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.linkClicked($event)\n }\n }\n }), _vm._v(\" \"), (_vm.hideSubjectStatus) ? _c('a', {\n staticClass: \"cw-status-hider\",\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.toggleShowMore($event)\n }\n }\n }, [_vm._v(\"Show more\")]) : _vm._e(), _vm._v(\" \"), (_vm.showingMore) ? _c('a', {\n staticClass: \"status-unhider\",\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.toggleShowMore($event)\n }\n }\n }, [_vm._v(\"Show less\")]) : _vm._e()]), _vm._v(\" \"), (_vm.status.attachments && (!_vm.hideSubjectStatus || _vm.showingLongSubject)) ? _c('div', {\n staticClass: \"attachments media-body\"\n }, [_vm._l((_vm.nonGalleryAttachments), function(attachment) {\n return _c('attachment', {\n key: attachment.id,\n staticClass: \"non-gallery\",\n attrs: {\n \"size\": _vm.attachmentSize,\n \"nsfw\": _vm.nsfwClickthrough,\n \"attachment\": attachment,\n \"allowPlay\": true,\n \"setMedia\": _vm.setMedia()\n }\n })\n }), _vm._v(\" \"), (_vm.galleryAttachments.length > 0) ? _c('gallery', {\n attrs: {\n \"nsfw\": _vm.nsfwClickthrough,\n \"attachments\": _vm.galleryAttachments,\n \"setMedia\": _vm.setMedia()\n }\n }) : _vm._e()], 2) : _vm._e(), _vm._v(\" \"), (_vm.status.card && !_vm.hideSubjectStatus && !_vm.noHeading) ? _c('div', {\n staticClass: \"link-preview media-body\"\n }, [_c('link-preview', {\n attrs: {\n \"card\": _vm.status.card,\n \"size\": _vm.attachmentSize,\n \"nsfw\": _vm.nsfwClickthrough\n }\n })], 1) : _vm._e(), _vm._v(\" \"), (!_vm.noHeading && !_vm.isPreview) ? _c('div', {\n staticClass: \"status-actions media-body\"\n }, [(_vm.loggedIn) ? _c('div', [_c('a', {\n attrs: {\n \"href\": \"#\",\n \"title\": _vm.$t('tool_tip.reply')\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.toggleReplying($event)\n }\n }\n }, [_c('i', {\n staticClass: \"button-icon icon-reply\",\n class: {\n 'icon-reply-active': _vm.replying\n }\n })])]) : _vm._e(), _vm._v(\" \"), _c('retweet-button', {\n attrs: {\n \"visibility\": _vm.status.visibility,\n \"loggedIn\": _vm.loggedIn,\n \"status\": _vm.status\n }\n }), _vm._v(\" \"), _c('favorite-button', {\n attrs: {\n \"loggedIn\": _vm.loggedIn,\n \"status\": _vm.status\n }\n }), _vm._v(\" \"), _c('delete-button', {\n attrs: {\n \"status\": _vm.status\n }\n })], 1) : _vm._e()])]), _vm._v(\" \"), (_vm.replying) ? _c('div', {\n staticClass: \"container\"\n }, [_c('div', {\n staticClass: \"reply-left\"\n }), _vm._v(\" \"), _c('post-status-form', {\n staticClass: \"reply-body\",\n attrs: {\n \"reply-to\": _vm.status.id,\n \"attentions\": _vm.status.attentions,\n \"repliedUser\": _vm.status.user,\n \"copy-message-scope\": _vm.status.visibility,\n \"subject\": _vm.replySubject\n },\n on: {\n \"posted\": _vm.toggleReplying\n }\n })], 1) : _vm._e()]], 2) : _vm._e()\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-d221ac90\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/status/status.vue\n// module id = 731\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('Timeline', {\n attrs: {\n \"title\": _vm.$t('nav.dms'),\n \"timeline\": _vm.timeline,\n \"timeline-name\": 'dms'\n }\n })\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-d8bc97b0\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/dm_timeline/dm_timeline.vue\n// module id = 732\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n style: (_vm.bgAppStyle),\n attrs: {\n \"id\": \"app\"\n }\n }, [_c('div', {\n staticClass: \"app-bg-wrapper\",\n style: (_vm.bgStyle)\n }), _vm._v(\" \"), _c('nav', {\n staticClass: \"nav-bar container\",\n attrs: {\n \"id\": \"nav\"\n },\n on: {\n \"click\": function($event) {\n _vm.scrollToTop()\n }\n }\n }, [_c('div', {\n staticClass: \"logo\",\n style: (_vm.logoBgStyle)\n }, [_c('div', {\n staticClass: \"mask\",\n style: (_vm.logoMaskStyle)\n }), _vm._v(\" \"), _c('img', {\n style: (_vm.logoStyle),\n attrs: {\n \"src\": _vm.logo\n }\n })]), _vm._v(\" \"), _c('div', {\n staticClass: \"inner-nav\"\n }, [_c('div', {\n staticClass: \"item\"\n }, [_c('a', {\n staticClass: \"menu-button\",\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.stopPropagation();\n $event.preventDefault();\n _vm.toggleMobileSidebar()\n }\n }\n }, [_c('i', {\n staticClass: \"button-icon icon-menu\"\n }), _vm._v(\" \"), (_vm.unseenNotificationsCount) ? _c('div', {\n staticClass: \"alert-dot\"\n }) : _vm._e()]), _vm._v(\" \"), _c('router-link', {\n staticClass: \"site-name\",\n attrs: {\n \"to\": {\n name: 'root'\n },\n \"active-class\": \"home\"\n }\n }, [_vm._v(_vm._s(_vm.sitename))])], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"item right\"\n }, [_c('user-finder', {\n staticClass: \"button-icon nav-icon mobile-hidden\",\n on: {\n \"toggled\": _vm.onFinderToggled\n }\n }), _vm._v(\" \"), _c('router-link', {\n staticClass: \"mobile-hidden\",\n attrs: {\n \"to\": {\n name: 'settings'\n }\n }\n }, [_c('i', {\n staticClass: \"button-icon icon-cog nav-icon\",\n attrs: {\n \"title\": _vm.$t('nav.preferences')\n }\n })]), _vm._v(\" \"), (_vm.currentUser) ? _c('a', {\n staticClass: \"mobile-hidden\",\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.logout($event)\n }\n }\n }, [_c('i', {\n staticClass: \"button-icon icon-logout nav-icon\",\n attrs: {\n \"title\": _vm.$t('login.logout')\n }\n })]) : _vm._e()], 1)])]), _vm._v(\" \"), _c('div', {\n staticClass: \"container\",\n attrs: {\n \"id\": \"content\"\n }\n }, [_c('side-drawer', {\n ref: \"sideDrawer\",\n attrs: {\n \"logout\": _vm.logout\n }\n }), _vm._v(\" \"), _c('div', {\n staticClass: \"sidebar-flexer mobile-hidden\"\n }, [_c('div', {\n staticClass: \"sidebar-bounds\"\n }, [_c('div', {\n staticClass: \"sidebar-scroller\"\n }, [_c('div', {\n staticClass: \"sidebar\"\n }, [_c('user-panel'), _vm._v(\" \"), _c('nav-panel'), _vm._v(\" \"), (_vm.showInstanceSpecificPanel) ? _c('instance-specific-panel') : _vm._e(), _vm._v(\" \"), (!_vm.currentUser && _vm.showFeaturesPanel) ? _c('features-panel') : _vm._e(), _vm._v(\" \"), (_vm.currentUser && _vm.suggestionsEnabled) ? _c('who-to-follow-panel') : _vm._e(), _vm._v(\" \"), (_vm.currentUser) ? _c('notifications') : _vm._e()], 1)])])]), _vm._v(\" \"), _c('div', {\n staticClass: \"main\"\n }, [(!_vm.currentUser) ? _c('div', {\n staticClass: \"login-hint panel panel-default\"\n }, [_c('router-link', {\n staticClass: \"panel-body\",\n attrs: {\n \"to\": {\n name: 'login'\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"login.hint\")) + \"\\n \")])], 1) : _vm._e(), _vm._v(\" \"), _c('transition', {\n attrs: {\n \"name\": \"fade\"\n }\n }, [_c('router-view')], 1)], 1), _vm._v(\" \"), _c('media-modal')], 1), _vm._v(\" \"), (_vm.currentUser && _vm.chat) ? _c('chat-panel', {\n staticClass: \"floating-chat mobile-hidden\",\n attrs: {\n \"floating\": true\n }\n }) : _vm._e()], 1)\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-e918ada2\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/App.vue\n// module id = 733\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('basic-user-card', {\n attrs: {\n \"user\": _vm.user\n }\n }, [_c('template', {\n slot: \"secondary-area\"\n }, [(_vm.muted) ? _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": _vm.progress\n },\n on: {\n \"click\": _vm.unmuteUser\n }\n }, [(_vm.progress) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.unmute_progress')) + \"\\n \")] : [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.unmute')) + \"\\n \")]], 2) : _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": _vm.progress\n },\n on: {\n \"click\": _vm.muteUser\n }\n }, [(_vm.progress) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.mute_progress')) + \"\\n \")] : [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.mute')) + \"\\n \")]], 2)])], 2)\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-fd544d34\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/mute_card/mute_card.vue\n// module id = 734\n// module chunks = 2"],"sourceRoot":""} \ No newline at end of file diff --git a/priv/static/static/js/app.77434de4e756a5d79672.js b/priv/static/static/js/app.77434de4e756a5d79672.js new file mode 100644 index 000000000..df6755cb4 --- /dev/null +++ b/priv/static/static/js/app.77434de4e756a5d79672.js @@ -0,0 +1,18 @@ +webpackJsonp([2,0],[function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}var n=a(8),o=i(n),s=a(217),r=i(s),l=a(219),c=i(l),u=a(231),d=i(u),p=a(230),f=i(p),_=a(235),h=i(_),m=a(236),v=i(m),g=a(226),b=i(g),w=a(228),k=i(w),y=a(227),C=i(y),x=a(233),S=i(x),j=a(232),P=i(j),L=a(234),$=i(L),A=a(741),T=i(A),I=a(632),z=i(I),F=a(224),N=i(F),O=a(225),R=i(O),M=a(130),B=i(M),E=a(630),U=i(E),V=a(220),q=i(V),D=(window.navigator.language||"en").split("-")[0];o.default.use(c.default),o.default.use(r.default),o.default.use(T.default,{locale:"cs"===D?"cs":"ja"===D?"ja":"en",locales:{cs:a(457),en:a(458),ja:a(459)}}),o.default.use(z.default),o.default.use(U.default);var H=new z.default({locale:D,fallbackLocale:"en",messages:B.default}),G={paths:["config","users.lastLoginName","oauth"]};(0,N.default)(G).then(function(e){var t=new c.default.Store({modules:{interface:d.default,instance:f.default,statuses:h.default,users:v.default,api:b.default,config:k.default,chat:C.default,oauth:S.default,mediaViewer:P.default,oauthTokens:$.default},plugins:[e,R.default],strict:!1});(0,q.default)({store:t,i18n:H})}),window.___pleromafe_mode={NODE_ENV:"production"},window.___pleromafe_commit_hash="7c26435e\n",window.___pleromafe_dev_overrides=void 0},,,,,,,,,,,,,,,,,,function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(25),o=i(n),s=a(31),r=i(s),l=a(82),c=i(l),u=a(238);a(768);var d=a(239),p="/api/account/verify_credentials.json",f="/api/statuses/friends_timeline.json",_="/api/qvitter/allfollowing",h="/api/statuses/public_timeline.json",m="/api/statuses/public_and_external_timeline.json",v="/api/statusnet/tags/timeline",g="/api/favorites/create",b="/api/favorites/destroy",w="/api/statuses/retweet",k="/api/statuses/unretweet",y="/api/statuses/update.json",C="/api/statuses/destroy",x="/api/statuses/show",S="/api/statusnet/media/upload",j="/api/statusnet/conversation",P="/api/statuses/mentions.json",L="/api/statuses/dm_timeline.json",$="/api/statuses/followers.json",A="/api/statuses/friends.json",T="/api/statuses/blocks.json",I="/api/friendships/create.json",z="/api/friendships/destroy.json",F="/api/qvitter/set_profile_pref.json",N="/api/account/register.json",O="/api/qvitter/update_avatar.json",R="/api/qvitter/update_background_image.json",M="/api/account/update_profile_banner.json",B="/api/account/update_profile.json",E="/api/externalprofile/show.json",U="/api/qvitter/statuses/user_timeline.json",V="/api/qvitter/statuses/notifications.json",q="/api/qvitter/statuses/notifications/read.json",D="/api/blocks/create.json",H="/api/blocks/destroy.json",G="/api/users/show.json",W="/api/pleroma/follow_import",K="/api/pleroma/delete_account",Z="/api/pleroma/change_password",J="/api/pleroma/friend_requests",Y="/api/pleroma/friendships/approve",Q="/api/pleroma/friendships/deny",X="/api/v1/suggestions",ee="/api/v1/favourites",te=window.fetch,ae=function(e,t){t=t||{};var a="",i=a+e;return t.credentials="same-origin",te(i,t)},ie=function(e){var t=e.credentials,a=e.params,i=O,n=new FormData;return(0,c.default)(a,function(e,t){e&&n.append(t,e)}),ae(i,{headers:ce(t),method:"POST",body:n}).then(function(e){return e.json()})},ne=function(e){var t=e.credentials,a=e.params,i=R,n=new FormData;return(0,c.default)(a,function(e,t){e&&n.append(t,e)}),ae(i,{headers:ce(t),method:"POST",body:n}).then(function(e){return e.json()})},oe=function(e){var t=e.credentials,a=e.params,i=M,n=new FormData;return(0,c.default)(a,function(e,t){e&&n.append(t,e)}),ae(i,{headers:ce(t),method:"POST",body:n}).then(function(e){return e.json()})},se=function(e){var t=e.credentials,a=e.params,i=["description","locked","no_rich_text","hide_follows","hide_followers","show_role"],n=B,o=new FormData;return(0,c.default)(a,function(e,t){(i.includes(t)||e)&&o.append(t,e)}),ae(n,{headers:ce(t),method:"POST",body:o}).then(function(e){return e.json()})},re=function(e){var t=new FormData;return(0,c.default)(e,function(e,a){e&&t.append(a,e)}),ae(N,{method:"POST",body:t})},le=function(){return ae("/api/pleroma/captcha").then(function(e){return e.json()})},ce=function(e){return e?{Authorization:"Bearer "+e}:{}},ue=function(e){var t=e.profileUrl,a=e.credentials,i=E+"?profileurl="+t;return ae(i,{headers:ce(a),method:"GET"}).then(function(e){return e.json()})},de=function(e){var t=e.id,a=e.credentials,i=I+"?user_id="+t;return ae(i,{headers:ce(a),method:"POST"}).then(function(e){return e.json()})},pe=function(e){var t=e.id,a=e.credentials,i=z+"?user_id="+t;return ae(i,{headers:ce(a),method:"POST"}).then(function(e){return e.json()})},fe=function(e){var t=e.id,a=e.credentials,i=D+"?user_id="+t;return ae(i,{headers:ce(a),method:"POST"}).then(function(e){return e.json()})},_e=function(e){var t=e.id,a=e.credentials,i=H+"?user_id="+t;return ae(i,{headers:ce(a),method:"POST"}).then(function(e){return e.json()})},he=function(e){var t=e.id,a=e.credentials,i=Y+"?user_id="+t;return ae(i,{headers:ce(a),method:"POST"}).then(function(e){return e.json()})},me=function(e){var t=e.id,a=e.credentials,i=Q+"?user_id="+t;return ae(i,{headers:ce(a),method:"POST"}).then(function(e){return e.json()})},ve=function(e){var t=e.id,a=e.credentials,i=G+"?user_id="+t;return ae(i,{headers:ce(a)}).then(function(e){return new o.default(function(t,a){return e.json().then(function(n){return e.ok?t(n):a(new d.StatusCodeError(e.status,n,{url:i},e))})})}).then(function(e){return(0,u.parseUser)(e)})},ge=function(e){var t=e.id,a=e.page,i=e.credentials,n=A+"?user_id="+t;return a&&(n+="&page="+a),ae(n,{headers:ce(i)}).then(function(e){return e.json()}).then(function(e){return e.map(u.parseUser)})},be=function(e){var t=e.id,a=e.credentials,i=A+"?user_id="+t+"&all=true";return ae(i,{headers:ce(a)}).then(function(e){return e.json()}).then(function(e){return e.map(u.parseUser)})},we=function(e){var t=e.id,a=e.page,i=e.credentials,n=$+"?user_id="+t;return a&&(n+="&page="+a),ae(n,{headers:ce(i)}).then(function(e){return e.json()}).then(function(e){return e.map(u.parseUser)})},ke=function(e){var t=e.username,a=e.credentials,i=_+"/"+t+".json";return ae(i,{headers:ce(a)}).then(function(e){return e.json()}).then(function(e){return e.map(u.parseUser)})},ye=function(e){var t=e.credentials,a=J;return ae(a,{headers:ce(t)}).then(function(e){return e.json()})},Ce=function(e){var t=e.id,a=e.credentials,i=j+"/"+t+".json?count=100";return ae(i,{headers:ce(a)}).then(function(e){if(e.ok)return e;throw new Error("Error fetching timeline",e)}).then(function(e){return e.json()}).then(function(e){return e.map(u.parseStatus)})},xe=function(e){var t=e.id,a=e.credentials,i=x+"/"+t+".json";return ae(i,{headers:ce(a)}).then(function(e){if(e.ok)return e;throw new Error("Error fetching timeline",e)}).then(function(e){return e.json()}).then(function(e){return(0,u.parseStatus)(e)})},Se=function(e){var t=e.id,a=e.credentials,i=e.muted,n=void 0===i||i,o=new FormData,s=n?1:0;return o.append("namespace","qvitter"),o.append("data",s),o.append("topic","mute:"+t),ae(F,{method:"POST",headers:ce(a),body:o})},je=function(e){var t=e.timeline,a=e.credentials,i=e.since,n=void 0!==i&&i,o=e.until,s=void 0!==o&&o,l=e.userId,c=void 0!==l&&l,d=e.tag,p=void 0!==d&&d,_={public:h,friends:f,mentions:P,dms:L,notifications:V,publicAndExternal:m,user:U,media:U,favorites:ee,tag:v},g="notifications"===t,b=[],w=_[t];n&&b.push(["since_id",n]),s&&b.push(["max_id",s]),c&&b.push(["user_id",c]),p&&(w+="/"+p+".json"),"media"===t&&b.push(["only_media",1]),b.push(["count",20]);var k=(0,r.default)(b,function(e){return e[0]+"="+e[1]}).join("&");return w+="?"+k,ae(w,{headers:ce(a)}).then(function(e){if(e.ok)return e;throw new Error("Error fetching timeline",e)}).then(function(e){return e.json()}).then(function(e){return e.map(g?u.parseNotification:u.parseStatus)})},Pe=function(e){return ae(p,{method:"POST",headers:ce(e)}).then(function(e){return e.ok?e.json():{error:e}}).then(function(e){return e.error?e:(0,u.parseUser)(e)})},Le=function(e){var t=e.id,a=e.credentials;return ae(g+"/"+t+".json",{headers:ce(a),method:"POST"})},$e=function(e){var t=e.id,a=e.credentials;return ae(b+"/"+t+".json",{headers:ce(a),method:"POST"})},Ae=function(e){var t=e.id,a=e.credentials;return ae(w+"/"+t+".json",{headers:ce(a),method:"POST"})},Te=function(e){var t=e.id,a=e.credentials;return ae(k+"/"+t+".json",{headers:ce(a),method:"POST"})},Ie=function(e){var t=e.credentials,a=e.status,i=e.spoilerText,n=e.visibility,o=e.sensitive,s=e.mediaIds,r=e.inReplyToStatusId,l=e.contentType,c=e.noAttachmentLinks,d=s.join(","),p=new FormData;return p.append("status",a),p.append("source","Pleroma FE"),c&&p.append("no_attachment_links",c),i&&p.append("spoiler_text",i),n&&p.append("visibility",n),o&&p.append("sensitive",o),l&&p.append("content_type",l),p.append("media_ids",d),r&&p.append("in_reply_to_status_id",r),ae(y,{body:p,method:"POST",headers:ce(t)}).then(function(e){return e.ok?e.json():{error:e}}).then(function(e){return e.error?e:(0,u.parseStatus)(e)})},ze=function(e){var t=e.id,a=e.credentials;return ae(C+"/"+t+".json",{headers:ce(a),method:"POST"})},Fe=function(e){var t=e.formData,a=e.credentials;return ae(S,{body:t,method:"POST",headers:ce(a)}).then(function(e){return e.text()}).then(function(e){return(new DOMParser).parseFromString(e,"application/xml")})},Ne=function(e){var t=e.params,a=e.credentials;return ae(W,{body:t,method:"POST",headers:ce(a)}).then(function(e){return e.ok})},Oe=function(e){var t=e.credentials,a=e.password,i=new FormData;return i.append("password",a),ae(K,{body:i,method:"POST",headers:ce(t)}).then(function(e){return e.json()})},Re=function(e){var t=e.credentials,a=e.password,i=e.newPassword,n=e.newPasswordConfirmation,o=new FormData;return o.append("password",a),o.append("new_password",i),o.append("new_password_confirmation",n),ae(Z,{body:o,method:"POST",headers:ce(t)}).then(function(e){return e.json()})},Me=function(e){var t=e.credentials,a="/api/qvitter/mutes.json";return ae(a,{headers:ce(t)}).then(function(e){return e.json()})},Be=function(e){var t=(e.page,e.credentials);return ae(T,{headers:ce(t)}).then(function(e){if(e.ok)return e.json();throw new Error("Error fetching blocks",e)})},Ee=function(e){var t=e.credentials,a="/api/oauth_tokens.json";return ae(a,{headers:ce(t)}).then(function(e){return e.json()})},Ue=function(e){var t=e.id,a=e.credentials,i="/api/oauth_tokens/"+t;return ae(i,{headers:ce(a),method:"DELETE"})},Ve=function(e){var t=e.credentials;return ae(X,{headers:ce(t)}).then(function(e){return e.json()})},qe=function(e){var t=e.id,a=e.credentials,i=new FormData;return i.append("latest_id",t),ae(q,{body:i,headers:ce(a),method:"POST"}).then(function(e){return e.json()})},De={verifyCredentials:Pe,fetchTimeline:je,fetchConversation:Ce,fetchStatus:xe,fetchFriends:ge,exportFriends:be,fetchFollowers:we,followUser:de,unfollowUser:pe,blockUser:fe,unblockUser:_e,fetchUser:ve,favorite:Le,unfavorite:$e,retweet:Ae,unretweet:Te,postStatus:Ie,deleteStatus:ze,uploadMedia:Fe,fetchAllFollowing:ke,setUserMute:Se,fetchMutes:Me,fetchBlocks:Be,fetchOAuthTokens:Ee,revokeOAuthToken:Ue,register:re,getCaptcha:le,updateAvatar:ie,updateBg:ne,updateProfile:se,updateBanner:oe,externalProfile:ue,followImport:Ne,deleteAccount:Oe,changePassword:Re,fetchFollowRequests:ye,approveUser:he,denyUser:me,suggestions:Ve,markNotificationsAsSeen:qe};t.default=De},,,,,,,,,,,,,,,,function(e,t,a){a(389);var i=a(1)(a(297),a(679),null,null);e.exports=i.exports},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(597),o=i(n),s=function(e,t,a){var i=r(t)||(0,o.default)(a,t);return{name:i?"external-user-profile":"user-profile",params:i?{id:e}:{name:t}}},r=function(e){return e&&e.includes("@")};t.default=s},,,,,,,,function(e,t,a){a(431);var i=a(1)(a(299),a(739),null,null);e.exports=i.exports},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0}),t.alphaBlend=t.getContrastRatio=t.invert=t.mixrgb=t.hex2rgb=t.rgb2hex=void 0;var n=a(24),o=i(n),s=a(9),r=i(s),l=a(66),c=i(l),u=a(31),d=i(u),p=function(e,t,a){if(null!==e&&"undefined"!=typeof e){if("#"===e[0])return e;if("object"===("undefined"==typeof e?"undefined":(0,c.default)(e))){var i=e;e=i.r,t=i.g,a=i.b}var n=(0,d.default)([e,t,a],function(e){return e=Math.ceil(e),e=e<0?0:e,e=e>255?255:e}),o=(0,r.default)(n,3);return e=o[0],t=o[1],a=o[2],"#"+((1<<24)+(e<<16)+(t<<8)+a).toString(16).slice(1)}},f=function(e){var t=e/255;return t<.03928?t/12.92:Math.pow((t+.055)/1.055,2.4)},_=function(e){return"rgb".split("").reduce(function(t,a){return t[a]=f(e[a]),t},{})},h=function(e){var t=_(e),a=t.r,i=t.g,n=t.b;return.2126*a+.7152*i+.0722*n},m=function(e,t){var a=h(e),i=h(t),n=a>i?[a,i]:[i,a],o=(0,r.default)(n,2),s=o[0],l=o[1];return(s+.05)/(l+.05)},v=function(e,t,a){return 1===t||"undefined"==typeof t?e:"rgb".split("").reduce(function(i,n){return i[n]=e[n]*t+a[n]*(1-t),i},{})},g=function(e){return"rgb".split("").reduce(function(t,a){return t[a]=255-e[a],t},{})},b=function(e){var t=/^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(e);return t?{r:parseInt(t[1],16),g:parseInt(t[2],16),b:parseInt(t[3],16)}:null},w=function(e,t){return(0,o.default)(e).reduce(function(a,i){return a[i]=(e[i]+t[i])/2,a},{})};t.rgb2hex=p,t.hex2rgb=b,t.mixrgb=w,t.invert=g,t.getContrastRatio=m,t.alphaBlend=v},function(e,t){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var a=function(e){return e.match(/text\/html/)?"html":e.match(/image/)?"image":e.match(/video/)?"video":e.match(/audio/)?"audio":"unknown"},i=function(e,t){return e.some(function(e){return a(t.mimetype)===e})},n={fileType:a,fileMatchesSomeType:i};t.default=n},,,,,,,,,,,,,,,,,,function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0}),t.getCssShadowFilter=t.getCssShadow=t.composePreset=t.getThemes=t.generatePreset=t.generateFonts=t.generateShadows=t.generateRadii=t.generateColors=t.getTextColor=t.applyTheme=t.setPreset=t.setStyle=void 0;var n=a(25),o=i(n),s=a(9),r=i(s),l=a(23),c=i(l),u=a(37),d=i(u),p=a(66),f=i(p),_=a(36),h=i(_),m=a(616),v=i(m),g=a(319),b=a(44),w=function(e,t){var a=document.head,i=document.body;i.style.display="none";var n=document.createElement("link");n.setAttribute("rel","stylesheet"),n.setAttribute("href",e),a.appendChild(n);var o=function(){var e=document.createElement("div");i.appendChild(e);var t={};(0,v.default)(16,function(a){var i="base0"+a.toString(16).toUpperCase();e.setAttribute("class",i);var n=window.getComputedStyle(e).getPropertyValue("color");t[i]=n}),i.removeChild(e);var n=document.createElement("style");a.appendChild(n),i.style.display="initial"};n.addEventListener("load",o)},k=function(e){return"rgba("+e.r+", "+e.g+", "+e.b+", "+e.a+")"},y=function(e,t,a){var i=(0,g.convert)(e).hsl.l>50,n=(0,g.convert)(t).hsl.l>50;if(i&&n||!i&&!n){var o="undefined"!=typeof t.a?{a:t.a}:{},s=(0,h.default)(o,(0,g.invertLightness)(t).rgb);return!a&&(0,b.getContrastRatio)(e,s)<4.5?(0,g.contrastRatio)(e,t).rgb:s}return t},C=function(e,t){var a=I(e),i=a.rules,n=a.theme,o=document.head,s=document.body;s.style.display="none";var r=document.createElement("style");o.appendChild(r);var l=r.sheet;l.toString(),l.insertRule("body { "+i.radii+" }","index-max"),l.insertRule("body { "+i.colors+" }","index-max"),l.insertRule("body { "+i.shadows+" }","index-max"),l.insertRule("body { "+i.fonts+" }","index-max"),s.style.display="initial",t("setOption",{name:"customTheme",value:e}),t("setOption",{name:"colors",value:n.colors})},x=function(e,t){return 0===e.length?"none":e.filter(function(e){return t?e.inset:e}).map(function(e){return[e.x,e.y,e.blur,e.spread].map(function(e){return e+"px"}).concat([j(e.color,e.alpha),e.inset?"inset":""]).join(" ")}).join(", ")},S=function(e){return 0===e.length?"none":e.filter(function(e){return!e.inset&&0===Number(e.spread)}).map(function(e){return[e.x,e.y,e.blur/2].map(function(e){return e+"px"}).concat([j(e.color,e.alpha)]).join(" ")}).map(function(e){return"drop-shadow("+e+")"}).join(" ")},j=function(e,t){var a={};if("object"===("undefined"==typeof e?"undefined":(0,f.default)(e)))a=e;else if("string"==typeof e){if(!e.startsWith("#"))return e.startsWith("--")?"var("+e+")":e;a=(0,b.hex2rgb)(e)}return k((0,d.default)({},a,{a:t}))},P=function(e){var t={},a=(0,h.default)({alert:.5,input:.5,faint:.5},(0,c.default)(e.opacity||{}).reduce(function(e,t){var a=(0,r.default)(t,2),i=a[0],n=a[1];return"undefined"!=typeof n&&(e[i]=n),e},{})),i=(0,c.default)(e.colors||e).reduce(function(e,t){var a=(0,r.default)(t,2),i=a[0],n=a[1];return"object"===("undefined"==typeof n?"undefined":(0,f.default)(n))?e[i]=n:e[i]=(0,b.hex2rgb)(n),e},{}),n=(0,g.convert)(i.bg).hsl.l<(0,g.convert)(i.text).hsl.l,o=n?1:-1;t.text=i.text,t.lightText=(0,g.brightness)(20*o,t.text).rgb,t.link=i.link,t.faint=i.faint||(0,h.default)({},i.text),t.bg=i.bg,t.lightBg=i.lightBg||(0,g.brightness)(5,t.bg).rgb,t.fg=i.fg,t.fgText=i.fgText||y(t.fg,t.text),t.fgLink=i.fgLink||y(t.fg,t.link,!0),t.border=i.border||(0,g.brightness)(2*o,t.fg).rgb,t.btn=i.btn||(0,h.default)({},i.fg),t.btnText=i.btnText||y(t.btn,t.fgText),t.input=i.input||(0,h.default)({},i.fg),t.inputText=i.inputText||y(t.input,t.lightText),t.panel=i.panel||(0,h.default)({},i.fg),t.panelText=i.panelText||y(t.panel,t.fgText),t.panelLink=i.panelLink||y(t.panel,t.fgLink),t.panelFaint=i.panelFaint||y(t.panel,t.faint),t.topBar=i.topBar||(0,h.default)({},i.fg),t.topBarText=i.topBarText||y(t.topBar,t.fgText),t.topBarLink=i.topBarLink||y(t.topBar,t.fgLink),t.faintLink=i.faintLink||(0,h.default)({},i.link),t.icon=(0,b.mixrgb)(t.bg,t.text),t.cBlue=i.cBlue||(0,b.hex2rgb)("#0000FF"),t.cRed=i.cRed||(0,b.hex2rgb)("#FF0000"),t.cGreen=i.cGreen||(0,b.hex2rgb)("#00FF00"),t.cOrange=i.cOrange||(0,b.hex2rgb)("#E3FF00"),t.alertError=i.alertError||(0,h.default)({},t.cRed),t.alertErrorText=y((0,b.alphaBlend)(t.alertError,a.alert,t.bg),t.text),t.alertErrorPanelText=y((0,b.alphaBlend)(t.alertError,a.alert,t.panel),t.panelText),t.badgeNotification=i.badgeNotification||(0,h.default)({},t.cRed),t.badgeNotificationText=(0,g.contrastRatio)(t.badgeNotification).rgb,(0,c.default)(a).forEach(function(e){var a=(0,r.default)(e,2),i=a[0],n=a[1];if("undefined"!=typeof n){if("alert"===i)return void(t.alertError.a=n);"faint"===i&&(t[i+"Link"].a=n,t.panelFaint.a=n),"bg"===i&&(t.lightBg.a=n),t[i]?t[i].a=n:console.error("Wrong key "+i)}});var s=(0,c.default)(t).reduce(function(e,t){var a=(0,r.default)(t,2),i=a[0],n=a[1];return n?(e.solid[i]=(0,b.rgb2hex)(n),e.complete[i]="undefined"==typeof n.a?(0,b.rgb2hex)(n):k(n),e):e},{complete:{},solid:{}});return{rules:{colors:(0,c.default)(s.complete).filter(function(e){var t=(0,r.default)(e,2),a=(t[0],t[1]);return a}).map(function(e){var t=(0,r.default)(e,2),a=t[0],i=t[1];return"--"+a+": "+i}).join(";")},theme:{colors:s.solid,opacity:a}}},L=function(e){var t=e.radii||{};"undefined"!=typeof e.btnRadius&&(t=(0,c.default)(e).filter(function(e){var t=(0,r.default)(e,2),a=t[0];t[1];return a.endsWith("Radius")}).reduce(function(e,t){return e[t[0].split("Radius")[0]]=t[1],e},{}));var a=(0,c.default)(t).filter(function(e){var t=(0,r.default)(e,2),a=(t[0],t[1]);return a}).reduce(function(e,t){var a=(0,r.default)(t,2),i=a[0],n=a[1];return e[i]=n,e},{btn:4,input:4,checkbox:2,panel:10,avatar:5,avatarAlt:50,tooltip:2,attachment:5});return{rules:{radii:(0,c.default)(a).filter(function(e){var t=(0,r.default)(e,2),a=(t[0],t[1]);return a}).map(function(e){var t=(0,r.default)(e,2),a=t[0],i=t[1];return"--"+a+"Radius: "+i+"px"}).join(";")},theme:{radii:a}}},$=function(e){var t=(0,c.default)(e.fonts||{}).filter(function(e){var t=(0,r.default)(e,2),a=(t[0],t[1]);return a}).reduce(function(e,t){var a=(0,r.default)(t,2),i=a[0],n=a[1];return e[i]=(0,c.default)(n).filter(function(e){var t=(0,r.default)(e,2),a=(t[0],t[1]);return a}).reduce(function(e,t){var a=(0,r.default)(t,2),i=a[0],n=a[1];return e[i]=n,e},e[i]),e},{interface:{family:"sans-serif"},input:{family:"inherit"},post:{family:"inherit"},postCode:{family:"monospace"}});return{rules:{fonts:(0,c.default)(t).filter(function(e){var t=(0,r.default)(e,2),a=(t[0],t[1]);return a}).map(function(e){var t=(0,r.default)(e,2),a=t[0],i=t[1];return"--"+a+"Font: "+i.family}).join(";")},theme:{fonts:t}}},A=function(e){var t=function(e,t){return{x:0,y:e?1:-1,blur:0,spread:0,color:t?"#000000":"#FFFFFF",alpha:.2,inset:!0}},a=[t(!0,!1),t(!1,!0)],i=[t(!0,!0),t(!1,!1)],n={x:0,y:0,blur:4,spread:0,color:"--faint",alpha:1},o=(0,d.default)({panel:[{x:1,y:1,blur:4,spread:0,color:"#000000",alpha:.6}],topBar:[{x:0,y:0,blur:4,spread:0,color:"#000000",alpha:.6}],popup:[{x:2,y:2,blur:3,spread:0,color:"#000000",alpha:.5}],avatar:[{x:0,y:1,blur:8,spread:0,color:"#000000",alpha:.7}],avatarStatus:[],panelHeader:[],button:[{x:0,y:0,blur:2,spread:0,color:"#000000",alpha:1}].concat(a),buttonHover:[n].concat(a),buttonPressed:[n].concat(i),input:[].concat(i,[{x:0,y:0,blur:2,inset:!0,spread:0,color:"#000000",alpha:1}])},e.shadows||{});return{rules:{shadows:(0,c.default)(o).map(function(e){var t=(0,r.default)(e,2),a=t[0],i=t[1];return["--"+a+"Shadow: "+x(i),"--"+a+"ShadowFilter: "+S(i),"--"+a+"ShadowInset: "+x(i,!0)].join(";")}).join(";")},theme:{shadows:o}}},T=function(e,t,a,i){return{rules:(0,d.default)({},a.rules,e.rules,t.rules,i.rules),theme:(0,d.default)({},a.theme,e.theme,t.theme,i.theme)}},I=function(e){var t=A(e),a=P(e),i=L(e),n=$(e);return T(a,i,t,n)},z=function(){return window.fetch("/static/styles.json").then(function(e){return e.json()}).then(function(e){return o.default.all((0,c.default)(e).map(function(e){var t=(0,r.default)(e,2),a=t[0],i=t[1];return"object"===("undefined"==typeof i?"undefined":(0,f.default)(i))?o.default.resolve([a,i]):"string"==typeof i?window.fetch(i).then(function(e){return e.json()}).then(function(e){return[a,e]}).catch(function(e){return console.error(e),[]}):void 0}))}).then(function(e){return e.filter(function(e){var t=(0,r.default)(e,2),a=(t[0],t[1]);return a}).reduce(function(e,t){var a=(0,r.default)(t,2),i=a[0],n=a[1];return e[i]=n,e},{})})},F=function(e,t){return z().then(function(a){var i=a[e]?a[e]:a["pleroma-dark"],n=Array.isArray(i),o=n?{}:i.theme;if(n){var s=(0,b.hex2rgb)(i[1]),r=(0,b.hex2rgb)(i[2]),l=(0,b.hex2rgb)(i[3]),c=(0,b.hex2rgb)(i[4]),u=(0,b.hex2rgb)(i[5]||"#FF0000"),d=(0,b.hex2rgb)(i[6]||"#00FF00"),p=(0,b.hex2rgb)(i[7]||"#0000FF"),f=(0,b.hex2rgb)(i[8]||"#E3FF00");o.colors={bg:s,fg:r,text:l,link:c,cRed:u,cBlue:p,cGreen:d,cOrange:f}}window.themeLoaded||C(o,t)})};t.setStyle=w,t.setPreset=F,t.applyTheme=C,t.getTextColor=y,t.generateColors=P,t.generateRadii=L,t.generateShadows=A,t.generateFonts=$,t.generatePreset=I,t.getThemes=z,t.composePreset=T,t.getCssShadow=x,t.getCssShadowFilter=S},,,,,,,,,,,,,,,,,,,,,,,function(e,t,a){a(413);var i=a(1)(a(255),a(716),null,null);e.exports=i.exports},function(e,t,a){a(419);var i=a(1)(a(291),a(724),null,null);e.exports=i.exports},function(e,t,a){a(390);var i=a(1)(a(298),a(681),null,null);e.exports=i.exports},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(8),o=i(n);a(383),t.default=o.default.component("tab-switcher",{name:"TabSwitcher",props:["renderOnlyFocused"],data:function(){return{active:this.$slots.default.findIndex(function(e){return e.tag})}},methods:{activateTab:function(e){var t=this;return function(){t.active=e}}},beforeUpdate:function(){var e=this.$slots.default[this.active];e.tag||(this.active=this.$slots.default.findIndex(function(e){return e.tag}))},render:function(e){var t=this,a=this.$slots.default.map(function(a,i){if(a.tag){var n=["tab"],o=["tab-wrapper"];return i===t.active&&(n.push("active"),o.push("active")),e("div",{class:o.join(" ")},[e("button",{attrs:{disabled:a.data.attrs.disabled},on:{click:t.activateTab(i)},class:n.join(" ")},[a.data.attrs.label])])}}),i=this.$slots.default.map(function(a,i){if(a.tag){var n=i===t.active;return t.renderOnlyFocused?n?e("div",{class:"active"},[a]):e("div",{class:"hidden"}):e("div",{class:n?"active":"hidden"},[a])}});return e("div",{class:"tab-switcher"},[e("div",{class:"tabs"},[a]),e("div",{class:"contents"},[i])])}})},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(124),o=i(n),s=function(e){var t=(e.oauth,e.instance),a=t+"/api/v1/apps",i=new window.FormData;return i.append("client_name","PleromaFE_"+Math.random()),i.append("redirect_uris",window.location.origin+"/oauth-callback"),i.append("scopes","read write follow"),window.fetch(a,{method:"POST",body:i}).then(function(e){return e.json()})},r=function(e){s(e).then(function(t){e.commit("setClientData",t);var a={response_type:"code",client_id:t.client_id,redirect_uri:t.redirect_uri,scope:"read write follow"},i=(0,o.default)(a,function(e,t,a){var i=a+"="+encodeURIComponent(t);return e?e+"&"+i:i},!1),n=e.instance+"/oauth/authorize?"+i;window.location.href=n})},l=function(e){var t=e.app,a=e.instance,i=e.username,n=e.password,o=a+"/oauth/token",s=new window.FormData;return s.append("client_id",t.client_id),s.append("client_secret",t.client_secret),s.append("grant_type","password"),s.append("username",i),s.append("password",n),window.fetch(o,{method:"POST",body:s}).then(function(e){return e.json()})},c=function(e){var t=e.app,a=e.instance,i=e.code,n=a+"/oauth/token",o=new window.FormData;return o.append("client_id",t.client_id),o.append("client_secret",t.client_secret),o.append("grant_type","authorization_code"),o.append("code",i),o.append("redirect_uri",window.location.origin+"/oauth-callback"),window.fetch(n,{method:"POST",body:o}).then(function(e){return e.json()})},u={login:r,getToken:c,getTokenWithCredentials:l,getOrCreateApp:s};t.default=u},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0}),t.unseenNotificationsFromStore=t.visibleNotificationsFromStore=t.visibleTypes=t.notificationsFromStore=void 0;var n=a(65),o=i(n),s=a(612),r=i(s),l=a(58),c=i(l),u=t.notificationsFromStore=function(e){return e.state.statuses.notifications.data},d=t.visibleTypes=function(e){return[e.state.config.notificationVisibility.likes&&"like",e.state.config.notificationVisibility.mentions&&"mention",e.state.config.notificationVisibility.repeats&&"repeat",e.state.config.notificationVisibility.follows&&"follow"].filter(function(e){return e})},p=function(e,t){var a=Number(e.action.id),i=Number(t.action.id),n=!(0,o.default)(a),s=!(0,o.default)(i);return n&&s?a>i?-1:1:n&&!s?1:!n&&s?-1:e.action.id>t.action.id?-1:1},f=t.visibleNotificationsFromStore=function(e){var t=u(e).map(function(e){return e}).sort(p);return t=(0,r.default)(t,"seen"),t.filter(function(t){return d(e).includes(t.type)})};t.unseenNotificationsFromStore=function(e){return(0,c.default)(f(e),function(e){var t=e.seen;return!t})}},,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,function(e,t,a){a(396);var i=a(1)(a(264),a(689),null,null);e.exports=i.exports},function(e,t,a){a(391);var i=a(1)(a(283),a(682),null,null);e.exports=i.exports},function(e,t,a){a(416);var i=a(1)(a(293),a(721),null,null);e.exports=i.exports},,function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(37),o=i(n),s=a(8),r=i(s),l=a(31),c=i(l),u=a(121),d=i(u);a(384);var p=function(e){return{entry:e}},f=function(e){return e.id},_=function(e){var t=e.getEntryProps,a=void 0===t?p:t,i=e.getKey,n=void 0===i?f:i;return function(e){return r.default.component("withList",{props:["entries","entryProps","entryListeners"],render:function(t){var i=this,s=arguments[0];return s("div",{class:"with-list"},[(0,c.default)(this.entries,function(t,r){var l={key:n(t,r),props:(0,o.default)({},i.$props.entryProps,a(t,r)),on:i.$props.entryListeners};return s(e,l)}),(0,d.default)(this.entries)&&this.$slots.empty&&s("div",{class:"with-list-empty-content faint"},[this.$slots.empty])])}})}};t.default=_},function(e,t,a){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var i={ar:a(433),ca:a(434),cs:a(435),de:a(436),en:a(437),eo:a(438),es:a(439),et:a(440),fi:a(441),fr:a(442),ga:a(443),he:a(444),hu:a(445),it:a(446),ja:a(447),ko:a(448),nb:a(449),nl:a(450),oc:a(451),pl:a(452),pt:a(453),ro:a(454),ru:a(455),zh:a(456)};t.default=i},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(37),o=i(n),s=a(18),r=i(s),l=a(136),c=i(l),u=function(e){var t=function(t){var a=t.id;return r.default.fetchStatus({id:a,credentials:e})},a=function(t){var a=t.id;return r.default.fetchConversation({id:a,credentials:e})},i=function(t){var a=t.id,i=t.page;return r.default.fetchFriends({id:a,page:i,credentials:e})},n=function(t){var a=t.id;return r.default.exportFriends({id:a,credentials:e})},s=function(t){var a=t.id,i=t.page;return r.default.fetchFollowers({id:a,page:i,credentials:e})},l=function(t){var a=t.username;return r.default.fetchAllFollowing({username:a,credentials:e})},u=function(t){var a=t.id;return r.default.fetchUser({id:a,credentials:e})},d=function(t){return r.default.followUser({credentials:e,id:t})},p=function(t){return r.default.unfollowUser({credentials:e,id:t})},f=function(t){return r.default.blockUser({credentials:e,id:t})},_=function(t){return r.default.unblockUser({credentials:e,id:t})},h=function(t){return r.default.approveUser({credentials:e,id:t})},m=function(t){return r.default.denyUser({credentials:e,id:t})},v=function(t){var a=t.timeline,i=t.store,n=t.userId,o=void 0!==n&&n,s=t.tag;return c.default.startFetching({timeline:a,store:i,credentials:e,userId:o,tag:s})},g=function(t){var a=t.id,i=t.muted,n=void 0===i||i;return r.default.setUserMute({id:a,muted:n,credentials:e})},b=function(){return r.default.fetchMutes({credentials:e})},w=function(t){return r.default.fetchBlocks((0,o.default)({credentials:e},t))},k=function(){return r.default.fetchFollowRequests({credentials:e})},y=function(){return r.default.fetchOAuthTokens({credentials:e})},C=function(t){return r.default.revokeOAuthToken({id:t,credentials:e})},x=function(){return r.default.getCaptcha()},S=function(e){return r.default.register(e)},j=function(t){var a=t.params;return r.default.updateAvatar({credentials:e,params:a})},P=function(t){var a=t.params;return r.default.updateBg({credentials:e,params:a})},L=function(t){var a=t.params;return r.default.updateBanner({credentials:e,params:a})},$=function(t){var a=t.params;return r.default.updateProfile({credentials:e,params:a})},A=function(t){return r.default.externalProfile({profileUrl:t,credentials:e})},T=function(t){var a=t.params;return r.default.followImport({params:a,credentials:e})},I=function(t){var a=t.password;return r.default.deleteAccount({credentials:e,password:a})},z=function(t){var a=t.password,i=t.newPassword,n=t.newPasswordConfirmation;return r.default.changePassword({credentials:e,password:a,newPassword:i,newPasswordConfirmation:n})},F={fetchStatus:t,fetchConversation:a,fetchFriends:i,exportFriends:n,fetchFollowers:s,followUser:d,unfollowUser:p,blockUser:f,unblockUser:_,fetchUser:u,fetchAllFollowing:l,verifyCredentials:r.default.verifyCredentials,startFetching:v,setUserMute:g,fetchMutes:b,fetchBlocks:w,fetchOAuthTokens:y,revokeOAuthToken:C,register:S,getCaptcha:x,updateAvatar:j,updateBg:P,updateBanner:L,updateProfile:$,externalProfile:A,followImport:T,deleteAccount:I,changePassword:z,fetchFollowRequests:k,approveUser:h,denyUser:m};return F};t.default=u},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0}),t.getComponentProps=t.getComponentOptions=void 0;var n=a(84),o=i(n),s=function(e){return(0,o.default)(e)?e.options:e},r=function(e){return s(e).props};t.getComponentOptions=s,t.getComponentProps=r},function(e,t){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var a=function(e){var t,a,i=["B","KiB","MiB","GiB","TiB"];return e<1?e+" "+i[0]:(t=Math.min(Math.floor(Math.log(e)/Math.log(1024)),i.length-1), +e=1*(e/Math.pow(1024,t)).toFixed(2),a=i[t],{num:e,unit:a})},i={fileSizeFormat:a};t.default=i},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0}),t.requestUnfollow=t.requestFollow=void 0;var n=a(9),o=i(n),s=a(25),r=i(s),l=function e(t,a,i){return new r.default(function(e,n){setTimeout(function(){i.state.api.backendInteractor.fetchUser({id:a.id}).then(function(e){return i.commit("addNewUsers",[e])}).then(function(){return e([a.following,t])}).catch(function(e){return n(e)})},500)}).then(function(t){var n=(0,o.default)(t,2),s=n[0],r=n[1];return!s&&r<=3?e(++r,a,i):s})};t.requestFollow=function(e,t){return new r.default(function(a,i){t.state.api.backendInteractor.followUser(e.id).then(function(i){return t.commit("addNewUsers",[i]),i.locked&&a({sent:!0,updated:i}),i.following&&a({sent:!1,updated:i}),l(1,e,t).then(function(e){a(e?{sent:!1,updated:i}:{sent:!1,updated:i})})})})},t.requestUnfollow=function(e,t){return new r.default(function(a,i){t.state.api.backendInteractor.unfollowUser(e.id).then(function(e){t.commit("addNewUsers",[e]),a({updated:e})})})}},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(31),o=i(n),s=a(18),r=i(s),l=function(e){var t=e.store,a=e.status,i=e.spoilerText,n=e.visibility,s=e.sensitive,l=e.media,c=void 0===l?[]:l,u=e.inReplyToStatusId,d=void 0===u?void 0:u,p=e.contentType,f=void 0===p?"text/plain":p,_=(0,o.default)(c,"id");return r.default.postStatus({credentials:t.state.users.currentUser.credentials,status:a,spoilerText:i,visibility:n,sensitive:s,mediaIds:_,inReplyToStatusId:d,contentType:f,noAttachmentLinks:t.state.instance.noAttachmentLinks}).then(function(e){return e.error||t.dispatch("addNewStatuses",{statuses:[e],timeline:"friends",showImmediately:!0,noIdUpdate:!0}),e}).catch(function(e){return{error:e.message}})},c=function(e){var t=e.store,a=e.formData,i=t.state.users.currentUser.credentials;return r.default.uploadMedia({credentials:i,formData:a}).then(function(e){var t=e.getElementsByTagName("link");0===t.length&&(t=e.getElementsByTagName("atom:link")),t=t[0];var a={id:e.getElementsByTagName("media_id")[0].textContent,url:e.getElementsByTagName("media_url")[0].textContent,image:t.getAttribute("href"),mimetype:t.getAttribute("type")};return a})},u={postStatus:l,uploadMedia:c};t.default=u},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(585),o=i(n),s=a(18),r=i(s),l=function(e){var t=e.store,a=e.statuses,i=e.timeline,n=e.showImmediately,s=e.userId,r=(0,o.default)(i);t.dispatch("setError",{value:!1}),t.dispatch("addNewStatuses",{timeline:r,userId:s,statuses:a,showImmediately:n})},c=function(e){var t=e.store,a=e.credentials,i=e.timeline,n=void 0===i?"friends":i,s=e.older,c=void 0!==s&&s,u=e.showImmediately,d=void 0!==u&&u,p=e.userId,f=void 0!==p&&p,_=e.tag,h=void 0!==_&&_,m=e.until,v={timeline:n,credentials:a},g=t.rootState||t.state,b=g.statuses.timelines[(0,o.default)(n)];c?v.until=m||b.minId:v.since=b.maxId,v.userId=f,v.tag=h;var w=b.statuses.length;return r.default.fetchTimeline(v).then(function(e){return!c&&e.length>=20&&!b.loading&&w>0&&t.dispatch("queueFlush",{timeline:n,id:b.maxId}),l({store:t,statuses:e,timeline:n,showImmediately:d,userId:f}),e},function(){return t.dispatch("setError",{value:!0})})},u=function(e){var t=e.timeline,a=void 0===t?"friends":t,i=e.credentials,n=e.store,s=e.userId,r=void 0!==s&&s,l=e.tag,u=void 0!==l&&l,d=n.rootState||n.state,p=d.statuses.timelines[(0,o.default)(a)],f=0===p.visibleStatuses.length;p.userId=r,c({timeline:a,credentials:i,store:n,showImmediately:f,userId:r,tag:u});var _=function(){return c({timeline:a,credentials:i,store:n,userId:r,tag:u})};return setInterval(_,1e4)},d={fetchAndUpdate:c,startFetching:u};t.default=d},function(e,t,a){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.highlightStyle=t.highlightClass=void 0;var i=a(44),n=function(e){if(void 0!==e){var t=e.color,a=e.type;if("string"==typeof t){var n=(0,i.hex2rgb)(t);if(null!=n){var o="rgb("+Math.floor(n.r)+", "+Math.floor(n.g)+", "+Math.floor(n.b)+")",s="rgba("+Math.floor(n.r)+", "+Math.floor(n.g)+", "+Math.floor(n.b)+", .1)",r="rgba("+Math.floor(n.r)+", "+Math.floor(n.g)+", "+Math.floor(n.b)+", .2)";return"striped"===a?{backgroundImage:["repeating-linear-gradient(135deg,",s+" ,",s+" 20px,",r+" 20px,",r+" 40px"].join(" "),backgroundPosition:"0 0"}:"solid"===a?{backgroundColor:r}:"side"===a?{backgroundImage:["linear-gradient(to right,",o+" ,",o+" 2px,","transparent 6px"].join(" "),backgroundPosition:"0 0"}:void 0}}}},o=function(e){return"USER____"+e.screen_name.replace(/\./g,"_").replace(/@/g,"_AT_")};t.highlightClass=o,t.highlightStyle=n},,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,function(e,t,a){a(405);var i=a(1)(a(254),a(703),null,null);e.exports=i.exports},function(e,t,a){a(397);var i=a(1)(a(257),a(693),null,null);e.exports=i.exports},function(e,t,a){a(418);var i=a(1)(a(246),a(723),null,null);e.exports=i.exports},function(e,t,a){var i=a(1)(a(259),a(683),null,null);e.exports=i.exports},function(e,t,a){a(403);var i=a(1)(a(263),a(701),null,null);e.exports=i.exports},function(e,t,a){a(420);var i=a(1)(a(271),a(725),null,null);e.exports=i.exports},function(e,t,a){a(401);var i=a(1)(a(273),a(699),null,null);e.exports=i.exports},function(e,t,a){a(387);var i=a(1)(a(281),a(677),null,null);e.exports=i.exports},function(e,t,a){var i=a(1)(a(250),a(706),null,null);e.exports=i.exports},function(e,t,a){a(424);var i=a(1)(a(294),a(730),null,null);e.exports=i.exports},function(e,t,a){var i=a(1)(a(305),a(708),null,null);e.exports=i.exports},,,,function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(24),o=i(n),s=a(36),r=i(s),l=a(8),c=i(l),u=a(217),d=i(u),p=a(221),f=i(p),_=a(633),h=i(_),m=function(e){var t=e.store,a=e.i18n;window.fetch("/api/statusnet/config.json").then(function(e){return e.json()}).then(function(e){var i=e.site,n=i.name,o=i.closed,s=i.textlimit,l=i.uploadlimit,u=i.server,p=i.vapidPublicKey;t.dispatch("setInstanceOption",{name:"name",value:n}),t.dispatch("setInstanceOption",{name:"registrationOpen",value:"0"===o}),t.dispatch("setInstanceOption",{name:"textlimit",value:parseInt(s)}),t.dispatch("setInstanceOption",{name:"server",value:u}),l&&(t.dispatch("setInstanceOption",{name:"uploadlimit",value:parseInt(l.uploadlimit)}),t.dispatch("setInstanceOption",{name:"avatarlimit",value:parseInt(l.avatarlimit)}),t.dispatch("setInstanceOption",{name:"backgroundlimit",value:parseInt(l.backgroundlimit)}),t.dispatch("setInstanceOption",{name:"bannerlimit",value:parseInt(l.bannerlimit)})),p&&t.dispatch("setInstanceOption",{name:"vapidPublicKey",value:p});var _=e.site.pleromafe;window.fetch("/static/config.json").then(function(e){return e.json()}).catch(function(e){return console.warn("Failed to load static/config.json, continuing without it."),console.warn(e),{}}).then(function(e){var a=window.___pleromafe_dev_overrides||{},i=window.___pleromafe_mode.NODE_ENV,n={};a.staticConfigPreference&&"development"===i?(console.warn("OVERRIDING API CONFIG WITH STATIC CONFIG"),n=(0,r.default)({},_,e)):n=(0,r.default)({},e,_);var o=function(e){t.dispatch("setInstanceOption",{name:e,value:n[e]})};return o("nsfwCensorImage"),o("background"),o("hidePostStats"),o("hideUserStats"),o("hideFilteredStatuses"),o("logo"),t.dispatch("setInstanceOption",{name:"logoMask",value:"undefined"==typeof n.logoMask||n.logoMask}),t.dispatch("setInstanceOption",{name:"logoMargin",value:"undefined"==typeof n.logoMargin?0:n.logoMargin}),o("redirectRootNoLogin"),o("redirectRootLogin"),o("showInstanceSpecificPanel"),o("scopeOptionsEnabled"),o("formattingOptionsEnabled"),o("collapseMessageWithSubject"),o("loginMethod"),o("scopeCopy"),o("subjectLineBehavior"),o("postContentType"),o("alwaysShowSubjectInput"),o("noAttachmentLinks"),o("showFeaturesPanel"),n.chatDisabled&&t.dispatch("disableChat"),t.dispatch("setTheme",n.theme)}).then(function(){var e=new d.default({mode:"history",routes:(0,f.default)(t),scrollBehavior:function(e,t,a){return!e.matched.some(function(e){return e.meta.dontScroll})&&(a||{x:0,y:0})}});new c.default({router:e,store:t,i18n:a,el:"#app",render:function(e){return e(h.default)}})})}),window.fetch("/static/terms-of-service.html").then(function(e){return e.text()}).then(function(e){t.dispatch("setInstanceOption",{name:"tos",value:e})}),window.fetch("/api/pleroma/emoji.json").then(function(e){return e.json().then(function(e){var a=(0,o.default)(e).map(function(t){return{shortcode:t,image_url:e[t]}});t.dispatch("setInstanceOption",{name:"customEmoji",value:a}),t.dispatch("setInstanceOption",{name:"pleromaBackend",value:!0})},function(e){t.dispatch("setInstanceOption",{name:"pleromaBackend",value:!1})})},function(e){return console.log(e)}),window.fetch("/static/emoji.json").then(function(e){return e.json()}).then(function(e){var a=(0,o.default)(e).map(function(t){return{shortcode:t,image_url:!1,utf:e[t]}});t.dispatch("setInstanceOption",{name:"emoji",value:a})}),window.fetch("/instance/panel.html").then(function(e){return e.text()}).then(function(e){t.dispatch("setInstanceOption",{name:"instanceSpecificPanelContent",value:e})}),window.fetch("/nodeinfo/2.0.json").then(function(e){return e.json()}).then(function(e){var a=e.metadata,i=a.features;t.dispatch("setInstanceOption",{name:"mediaProxyAvailable",value:i.includes("media_proxy")}),t.dispatch("setInstanceOption",{name:"chatAvailable",value:i.includes("chat")}),t.dispatch("setInstanceOption",{name:"gopherAvailable",value:i.includes("gopher")}),t.dispatch("setInstanceOption",{name:"postFormats",value:a.postFormats}),t.dispatch("setInstanceOption",{name:"restrictedNicknames",value:a.restrictedNicknames});var n=a.suggestions;t.dispatch("setInstanceOption",{name:"suggestionsEnabled",value:n.enabled}),t.dispatch("setInstanceOption",{name:"suggestionsWeb",value:n.web})})};t.default=m},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(659),o=i(n),s=a(658),r=i(s),l=a(645),c=i(l),u=a(668),d=i(u),p=a(637),f=i(p),_=a(652),h=i(_),m=a(639),v=i(m),g=a(672),b=i(g),w=a(663),k=i(w),y=a(661),C=i(y),x=a(674),S=i(x),j=a(643),P=i(j),L=a(657),$=i(L),A=a(673),T=i(A),I=a(213),z=i(I),F=a(212),N=i(F),O=a(207),R=i(O),M=a(675),B=i(M),E=a(634),U=i(E);t.default=function(e){return[{name:"root",path:"/",redirect:function(t){return(e.state.users.currentUser?e.state.instance.redirectRootLogin:e.state.instance.redirectRootNoLogin)||"/main/all"}},{name:"public-external-timeline",path:"/main/all",component:r.default},{name:"public-timeline",path:"/main/public",component:o.default},{name:"friends",path:"/main/friends",component:c.default},{name:"tag-timeline",path:"/tag/:tag",component:d.default},{name:"conversation",path:"/notice/:id",component:f.default,meta:{dontScroll:!0}},{name:"external-user-profile",path:"/users/:id",component:b.default},{name:"mentions",path:"/users/:username/mentions",component:h.default},{name:"dms",path:"/users/:username/dms",component:v.default},{name:"settings",path:"/settings",component:k.default},{name:"registration",path:"/registration",component:C.default},{name:"registration-token",path:"/registration/:token",component:C.default},{name:"friend-requests",path:"/friend-requests",component:P.default},{name:"user-settings",path:"/user-settings",component:S.default},{name:"notifications",path:"/:username/notifications",component:z.default},{name:"login",path:"/login",component:N.default},{name:"chat",path:"/chat",component:R.default,props:function(){return{floating:!1}}},{name:"oauth-callback",path:"/oauth-callback",component:$.default,props:function(e){return{code:e.query.code}}},{name:"user-search",path:"/user-search",component:T.default,props:function(e){return{query:e.query.query}}},{name:"who-to-follow",path:"/who-to-follow",component:B.default},{name:"about",path:"/about",component:U.default},{name:"user-profile",path:"/(users/)?:name",component:b.default}]}},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(9),o=i(n),s=a(23),r=i(s),l=a(140),c=i(l),u=a(37),d=i(u),p=a(24),f=i(p),_=a(8),h=i(_),m=a(121),v=i(m),g=a(132);a(385);var b=function(e){var t=e.fetch,a=e.select,i=e.destroy,n=e.childPropName,s=void 0===n?"entries":n,l=e.additionalPropNames,u=void 0===l?[]:l;return function(e){var n=(0,f.default)((0,g.getComponentProps)(e)),l=n.filter(function(e){return e!==s}).concat(u);return h.default.component("withLoadMore",{render:function(t){var a=arguments[0],i={props:(0,d.default)({},this.$props,(0,c.default)({},s,this.entries)),on:this.$listeners,scopedSlots:this.$scopedSlots},n=(0,r.default)(this.$slots).map(function(e){var a=(0,o.default)(e,2),i=a[0],n=a[1];return t("template",{slot:i},n)});return a("div",{class:"with-load-more"},[a(e,i,[n]),a("div",{class:"with-load-more-footer"},[this.error&&a("a",{on:{click:this.fetchEntries},class:"alert error"},[this.$t("general.generic_error")]),!this.error&&this.loading&&a("i",{class:"icon-spin3 animate-spin"}),!this.error&&!this.loading&&!this.bottomedOut&&a("a",{on:{click:this.fetchEntries}},[this.$t("general.more")])])])},props:l,data:function(){return{loading:!1,bottomedOut:!1,error:!1}},computed:{entries:function(){return a(this.$props,this.$store)||[]}},created:function(){window.addEventListener("scroll",this.scrollLoad),0===this.entries.length&&this.fetchEntries()},destroyed:function(){window.removeEventListener("scroll",this.scrollLoad),i&&i(this.$props,this.$store)},methods:{fetchEntries:function(){var e=this;this.loading||(this.loading=!0,this.error=!1,t(this.$props,this.$store).then(function(t){e.loading=!1,e.bottomedOut=(0,v.default)(t)}).catch(function(){e.loading=!1,e.error=!0}))},scrollLoad:function(e){var t=document.body.getBoundingClientRect(),a=Math.max(t.height,-t.y);this.loading===!1&&this.bottomedOut===!1&&this.$el.offsetHeight>0&&window.innerHeight+window.pageYOffset>=a-750&&this.fetchEntries()}}})}};t.default=b},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(9),o=i(n),s=a(23),r=i(s),l=a(140),c=i(l),u=a(37),d=i(u),p=a(26),f=i(p),_=a(24),h=i(_),m=a(8),v=i(m),g=a(121),b=i(g),w=a(132);a(386);var k=function(e){var t=e.fetch,a=e.select,i=e.childPropName,n=void 0===i?"content":i,s=e.additionalPropNames,l=void 0===s?[]:s;return function(e){var i=(0,h.default)((0,w.getComponentProps)(e)),s=i.filter(function(e){return e!==n}).concat(l);return v.default.component("withSubscription",{props:[].concat((0,f.default)(s),["refresh"]),render:function(t){var a=arguments[0];if(this.error||this.loading)return a("div",{class:"with-subscription-loading"},[this.error?a("a",{on:{click:this.fetchData},class:"alert error"},[this.$t("general.generic_error")]):a("i",{class:"icon-spin3 animate-spin"})]);var i={props:(0,d.default)({},this.$props,(0,c.default)({},n,this.fetchedData)),on:this.$listeners,scopedSlots:this.$scopedSlots},s=(0,r.default)(this.$slots).map(function(e){var a=(0,o.default)(e,2),i=a[0],n=a[1];return t("template",{slot:i},n)});return a("div",{class:"with-subscription"},[a(e,i,[s])])},data:function(){return{loading:!1,error:!1}},computed:{fetchedData:function(){return a(this.$props,this.$store)}},created:function(){(this.refresh||(0,b.default)(this.fetchedData))&&this.fetchData()},methods:{fetchData:function(){var e=this;this.loading||(this.loading=!0,this.error=!1,t(this.$props,this.$store).then(function(){e.loading=!1}).catch(function(){e.error=!0,e.loading=!1}))}}})}};t.default=k},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}function n(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},t=e.key,a=void 0===t?"vuex-lz":t,i=e.paths,n=void 0===i?[]:i,o=e.getState,r=void 0===o?function(e,t){var a=t.getItem(e);return a}:o,c=e.setState,d=void 0===c?function(e,t,a){return v?a.setItem(e,t):(console.log("waiting for old state to be loaded..."),l.default.resolve())}:c,f=e.reducer,_=void 0===f?g:f,h=e.storage,m=void 0===h?w:h,k=e.subscriber,y=void 0===k?function(e){return function(t){return e.subscribe(t)}}:k;return r(a,m).then(function(e){return function(t){try{if(null!==e&&"object"===("undefined"==typeof e?"undefined":(0,s.default)(e))){var i=e.users||{};i.usersObject={};var o=i.users||[];(0,u.default)(o,function(e){i.usersObject[e.id]=e}),e.users=i,t.replaceState((0,p.default)({},t.state,e))}t.state.config.customTheme&&(window.themeLoaded=!0,t.dispatch("setOption",{name:"customTheme",value:t.state.config.customTheme})),t.state.oauth.token&&t.dispatch("loginUser",t.state.oauth.token),v=!0}catch(e){console.log("Couldn't load state"),console.error(e),v=!0}y(t)(function(e,i){try{b.includes(e.type)&&d(a,_(i,n),m).then(function(a){"undefined"!=typeof a&&("setOption"!==e.type&&"setCurrentUser"!==e.type||t.dispatch("settingsSaved",{success:a}))},function(a){"setOption"!==e.type&&"setCurrentUser"!==e.type||t.dispatch("settingsSaved",{error:a})})}catch(e){console.log("Couldn't persist state:"),console.log(e)}})}})}Object.defineProperty(t,"__esModule",{value:!0});var o=a(66),s=i(o),r=a(25),l=i(r),c=a(82),u=i(c);t.default=n;var d=a(472),p=i(d),f=a(623),_=i(f),h=a(460),m=i(h),v=!1,g=function(e,t){return 0===t.length?e:t.reduce(function(t,a){return _.default.set(t,a,_.default.get(e,a)),t},{})},b=["markNotificationsAsSeen","clearCurrentUser","setCurrentUser","setHighlight","setOption","setClientData","setToken"],w=function(){return m.default}()},function(e,t){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default=function(e){e.subscribe(function(t,a){var i=a.instance.vapidPublicKey,n=a.config.webPushNotifications,o="granted"===a.interface.notificationPermission,s=a.users.currentUser,r="setCurrentUser"===t.type,l="setInstanceOption"===t.type&&"vapidPublicKey"===t.payload.name,c="setNotificationPermission"===t.type&&"granted"===t.payload,u="setOption"===t.type&&"webPushNotifications"===t.payload.name,d="setOption"===t.type&&"notificationVisibility"===t.payload.name;if(r||l||c||u||d){if(s&&i&&o&&n)return e.dispatch("registerPushNotifications");if(u&&!n)return e.dispatch("unregisterPushNotifications")}})}},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(131),o=i(n),s=a(624),r={state:{backendInteractor:(0,o.default)(),fetchers:{},socket:null,chatDisabled:!1,followRequests:[]},mutations:{setBackendInteractor:function(e,t){e.backendInteractor=t},addFetcher:function(e,t){var a=t.timeline,i=t.fetcher;e.fetchers[a]=i},removeFetcher:function(e,t){var a=t.timeline;delete e.fetchers[a]},setWsToken:function(e,t){e.wsToken=t},setSocket:function(e,t){e.socket=t},setChatDisabled:function(e,t){e.chatDisabled=t},setFollowRequests:function(e,t){e.followRequests=t}},actions:{startFetching:function(e,t){var a=t.timeline,i=void 0===a?"friends":a,n=t.tag,o=void 0!==n&&n,s=t.userId,r=void 0!==s&&s;if(!e.state.fetchers[i]){var l=e.state.backendInteractor.startFetching({timeline:i,store:e,userId:r,tag:o});e.commit("addFetcher",{timeline:i,fetcher:l})}},stopFetching:function(e,t){var a=e.state.fetchers[t];window.clearInterval(a),e.commit("removeFetcher",{timeline:t})},setWsToken:function(e,t){e.commit("setWsToken",t)},initializeSocket:function(e){if(!e.state.chatDisabled){var t=e.state.wsToken,a=new s.Socket("/socket",{params:{token:t}});a.connect(),e.dispatch("initializeChat",a)}},disableChat:function(e){e.commit("setChatDisabled",!0)},removeFollowRequest:function(e,t){var a=e.state.followRequests.filter(function(e){return e!==t});e.commit("setFollowRequests",a)}}};t.default=r},function(e,t){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var a={state:{messages:[],channel:{state:""},socket:null},mutations:{setChannel:function(e,t){e.channel=t},setSocket:function(e,t){e.socket=t},addMessage:function(e,t){e.messages.push(t),e.messages=e.messages.slice(-19,20)},setMessages:function(e,t){e.messages=t.slice(-19,20)}},actions:{disconnectFromChat:function(e){e.state.socket.disconnect()},initializeChat:function(e,t){var a=t.channel("chat:public");e.commit("setSocket",t),a.on("new_msg",function(t){e.commit("addMessage",t)}),a.on("messages",function(t){var a=t.messages;e.commit("setMessages",a)}),a.join(),e.commit("setChannel",a)}}};t.default=a},function(e,t,a){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var i=a(8),n=a(63),o=(window.navigator.language||"en").split("-")[0],s={colors:{},collapseMessageWithSubject:void 0,hideAttachments:!1,hideAttachmentsInConv:!1,maxThumbnails:16,hideNsfw:!0,preloadImage:!0,loopVideo:!0,loopVideoSilentOnly:!0,autoLoad:!0,streaming:!1,hoverPreview:!0,pauseOnUnfocused:!0,stopGifs:!1,replyVisibility:"all",notificationVisibility:{follows:!0,mentions:!0,likes:!0,repeats:!0},webPushNotifications:!1,muteWords:[],highlight:{},interfaceLanguage:o,scopeCopy:void 0,subjectLineBehavior:void 0,alwaysShowSubjectInput:void 0,postContentType:void 0},r={state:s,mutations:{setOption:function(e,t){var a=t.name,n=t.value;(0,i.set)(e,a,n)},setHighlight:function(e,t){var a=t.user,n=t.color,o=t.type,s=this.state.config.highlight[a];n||o?(0,i.set)(e.highlight,a,{color:n||s.color,type:o||s.type}):(0,i.delete)(e.highlight,a)}},actions:{setHighlight:function(e,t){var a=e.commit,i=(e.dispatch,t.user),n=t.color,o=t.type;a("setHighlight",{user:i,color:n,type:o})},setOption:function(e,t){var a=e.commit,i=(e.dispatch,t.name),o=t.value;switch(a("setOption",{name:i,value:o}),i){case"theme":(0,n.setPreset)(o,a);break;case"customTheme":(0,n.applyTheme)(o,a)}}}};t.default=r},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}function n(e){return(0,u.default)(e).reduce(function(e,t){var a=(0,l.default)(t,2),i=a[0],n=a[1],o=n.reduce(function(e,t){var a=(0,p.default)(i.replace(/_/g," "));return e+[a,t].join(" ")+". "},"");return[].concat((0,s.default)(e),[o])},[])}Object.defineProperty(t,"__esModule",{value:!0});var o=a(26),s=i(o),r=a(9),l=i(r),c=a(23),u=i(c),d=a(198),p=i(d);t.humanizeErrors=n},function(e,t,a){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var i=a(8),n=a(63),o={name:"Pleroma FE",registrationOpen:!0,textlimit:5e3,server:"http://localhost:4040/",theme:"pleroma-dark",background:"/static/aurora_borealis.jpg",logo:"/static/logo.png",logoMask:!0,logoMargin:".2em",redirectRootNoLogin:"/main/all",redirectRootLogin:"/main/friends",showInstanceSpecificPanel:!1,scopeOptionsEnabled:!0,formattingOptionsEnabled:!1,alwaysShowSubjectInput:!0,collapseMessageWithSubject:!1,hidePostStats:!1,hideUserStats:!1,hideFilteredStatuses:!1,disableChat:!1,scopeCopy:!0,subjectLineBehavior:"email",postContentType:"text/plain",loginMethod:"password",nsfwCensorImage:void 0,vapidPublicKey:void 0,noAttachmentLinks:!1,showFeaturesPanel:!0,pleromaBackend:!0,emoji:[],customEmoji:[],restrictedNicknames:[],postFormats:[],mediaProxyAvailable:!1,chatAvailable:!1,gopherAvailable:!1,suggestionsEnabled:!1,suggestionsWeb:"",instanceSpecificPanelContent:"",tos:""},s={state:o,mutations:{setInstanceOption:function(e,t){var a=t.name,n=t.value;"undefined"!=typeof n&&(0,i.set)(e,a,n)}},actions:{setInstanceOption:function(e,t){var a=e.commit,i=e.dispatch,n=t.name,o=t.value;switch(a("setInstanceOption",{name:n,value:o}),n){case"name":i("setPageTitle")}},setTheme:function(e,t){var a=e.commit;return a("setInstanceOption",{name:"theme",value:t}),(0,n.setPreset)(t,a)}}};t.default=s},function(e,t,a){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var i=a(8),n={settings:{currentSaveStateNotice:null,noticeClearTimeout:null,notificationPermission:null},browserSupport:{cssFilter:window.CSS&&window.CSS.supports&&(window.CSS.supports("filter","drop-shadow(0 0)")||window.CSS.supports("-webkit-filter","drop-shadow(0 0)"))}},o={state:n,mutations:{settingsSaved:function(e,t){var a=t.success,n=t.error;a?(e.noticeClearTimeout&&clearTimeout(e.noticeClearTimeout),(0,i.set)(e.settings,"currentSaveStateNotice",{error:!1,data:a}),(0,i.set)(e.settings,"noticeClearTimeout",setTimeout(function(){return(0,i.delete)(e.settings,"currentSaveStateNotice")},2e3))):(0,i.set)(e.settings,"currentSaveStateNotice",{error:!0,errorData:n})},setNotificationPermission:function(e,t){e.notificationPermission=t}},actions:{setPageTitle:function(e){var t=e.rootState,a=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"";document.title=a+" "+t.instance.name},settingsSaved:function(e,t){var a=e.commit,i=(e.dispatch,t.success),n=t.error;a("settingsSaved",{success:i,error:n})},setNotificationPermission:function(e,t){var a=e.commit;a("setNotificationPermission",t)}}};t.default=o},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(45),o=i(n),s={state:{media:[],currentIndex:0,activated:!1},mutations:{setMedia:function(e,t){e.media=t},setCurrent:function(e,t){e.activated=!0,e.currentIndex=t},close:function(e){e.activated=!1}},actions:{setMedia:function(e,t){var a=e.commit,i=t.filter(function(e){var t=o.default.fileType(e.mimetype);return"image"===t||"video"===t});a("setMedia",i)},setCurrent:function(e,t){var a=e.commit,i=e.state,n=i.media.indexOf(t);a("setCurrent",n||0)},closeMediaViewer:function(e){var t=e.commit;t("close")}}};t.default=s},function(e,t){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var a={state:{client_id:!1,client_secret:!1,token:!1},mutations:{setClientData:function(e,t){e.client_id=t.client_id,e.client_secret=t.client_secret},setToken:function(e,t){e.token=t}}};t.default=a},function(e,t){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var a={state:{tokens:[]},actions:{fetchTokens:function(e){var t=e.rootState,a=e.commit;t.api.backendInteractor.fetchOAuthTokens().then(function(e){a("swapTokens",e)})},revokeToken:function(e,t){var a=e.rootState,i=e.commit,n=e.state;a.api.backendInteractor.revokeOAuthToken(t).then(function(e){201===e.status&&i("swapTokens",n.tokens.filter(function(e){return e.id!==t}))})}},mutations:{swapTokens:function(e,t){e.tokens=t}}};t.default=a},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0}),t.mutations=t.prepareStatus=t.defaultState=void 0;var n=a(9),o=i(n),s=a(23),r=i(s),l=a(65),c=i(l),u=a(138),d=i(u),p=a(4),f=i(p),_=a(123),h=i(_),m=a(593),v=i(m),g=a(200),b=i(g),w=a(603),k=i(w),y=a(601),C=i(y),x=a(59),S=i(x),j=a(82),P=i(j),L=a(611),$=i(L),A=a(609),T=i(A),I=a(18),z=i(I),F=function(){var e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0;return{statuses:[],statusesObject:{},faves:[],visibleStatuses:[],visibleStatusesObject:{},newStatusCount:0,maxId:0,minId:0,minVisibleId:0,loading:!1,followers:[],friends:[],userId:e,flushMarker:0}},N=t.defaultState=function(){return{allStatuses:[],allStatusesObject:{},maxId:0,notifications:{desktopNotificationSilence:!0,maxId:0,minId:Number.POSITIVE_INFINITY,data:[],idStore:{},loading:!1,error:!1,fetcherId:null},favorites:new d.default,error:!1,timelines:{mentions:F(),public:F(),user:F(),favorites:F(),media:F(),publicAndExternal:F(),friends:F(),tag:F(),dms:F()}}},O=t.prepareStatus=function(e){return e.deleted=!1,e.attachments=e.attachments||[],e},R=function(e){return[e.config.notificationVisibility.likes&&"like",e.config.notificationVisibility.mentions&&"mention",e.config.notificationVisibility.repeats&&"repeat",e.config.notificationVisibility.follows&&"follow"].filter(function(e){return e})},M=function(e,t,a){var i=t[a.id];return i?((0,b.default)(i,a),i.attachments.splice(i.attachments.length),{item:i,new:!1}):(O(a),e.push(a),t[a.id]=a,{item:a,new:!0})},B=function(e,t){var a=Number(e.id),i=Number(t.id),n=!(0,c.default)(a),o=!(0,c.default)(i);return n&&o?a>i?-1:1:n&&!o?1:!n&&o?-1:e.id>t.id?-1:1},E=function(e){return e.visibleStatuses=e.visibleStatuses.sort(B),e.statuses=e.statuses.sort(B),e.minVisibleId=((0,h.default)(e.visibleStatuses)||{}).id,e},U=function(e,t){var a=t.statuses,i=t.showImmediately,n=void 0!==i&&i,o=t.timeline,s=t.user,r=void 0===s?{}:s,l=t.noIdUpdate,c=void 0!==l&&l,u=t.userId;if(!(0,f.default)(a))return!1;var d=e.allStatuses,p=e.allStatusesObject,_=e.timelines[o],h=a.length>0?(0,C.default)(a,"id").id:0,m=a.length>0?(0,k.default)(a,"id").id:0,v=o&&h>_.maxId&&a.length>0,g=o&&(m<_.minId||0===_.minId)&&a.length>0;if(!c&&v&&(_.maxId=h),!c&&g&&(_.minId=m),"user"!==o&&"media"!==o||_.userId===u){var b=function(t,a){var i=!(arguments.length>2&&void 0!==arguments[2])||arguments[2],n=M(d,p,t),s=n.item;if(n.new){if("status"===s.type&&(0,S.default)(s.attentions,{id:r.id})){var l=e.timelines.mentions;_!==l&&(M(l.statuses,l.statusesObject,s),l.newStatusCount+=1,E(l))}if("direct"===s.visibility){var c=e.timelines.dms;M(c.statuses,c.statusesObject,s),c.newStatusCount+=1,E(c)}}var u=void 0;return o&&i&&(u=M(_.statuses,_.statusesObject,s)),o&&a?M(_.visibleStatuses,_.visibleStatusesObject,s):o&&i&&u.new&&(_.newStatusCount+=1),s},w=function(e,t){var a=(0,S.default)(d,{id:e.in_reply_to_status_id});return a&&(e.user.id===r.id?a.favorited=!0:a.fave_num+=1),a},y={status:function(e){b(e,n)},retweet:function e(t){var a=b(t.retweeted_status,!1,!1),e=void 0;e=o&&(0,S.default)(_.statuses,function(e){return e.retweeted_status?e.id===a.id||e.retweeted_status.id===a.id:e.id===a.id})?b(t,!1,!1):b(t,n),e.retweeted_status=a},favorite:function(t){e.favorites.has(t.id)||(e.favorites.add(t.id),w(t))},deletion:function(t){var a=t.uri,i=(0,S.default)(d,{uri:a});i&&((0,T.default)(e.notifications.data,function(e){var t=e.action.id;return t===i.id}),(0,T.default)(d,{uri:a}),o&&((0,T.default)(_.statuses,{uri:a}),(0,T.default)(_.visibleStatuses,{uri:a})))},follow:function(e){},default:function(e){console.log("unknown status type"),console.log(e)}};(0,P.default)(a,function(e){var t=e.type,a=y[t]||y.default;a(e)}),o&&E(_)}},V=function(e,t){var a=(t.dispatch,t.notifications),i=(t.older,t.visibleNotificationTypes),n=e.allStatuses,o=e.allStatusesObject;(0,P.default)(a,function(t){if(t.action=M(n,o,t.action).item,t.status=t.status&&M(n,o,t.status).item,e.notifications.idStore.hasOwnProperty(t.id))t.seen&&(e.notifications.idStore[t.id].seen=!0);else if(e.notifications.maxId=t.id>e.notifications.maxId?t.id:e.notifications.maxId,e.notifications.minId=t.id0&&!s.nsfw&&s.attachments[0].mimetype.startsWith("image/")&&(a.image=s.attachments[0].url),!t.seen&&!e.notifications.desktopNotificationSilence&&i.includes(t.type)){var l=new window.Notification(r,a);setTimeout(l.close.bind(l),5e3)}}})},q=function(e,t){var a=t.timeline,i=t.userId,n=e.timelines[a];i&&((0,T.default)(n.statuses,{user:{id:i}}),(0,T.default)(n.visibleStatuses,{user:{id:i}}),n.minVisibleId=n.visibleStatuses.length>0?(0,h.default)(n.visibleStatuses).id:0,n.maxId=n.statuses.length>0?(0,v.default)(n.statuses).id:0)},D=t.mutations={addNewStatuses:U,addNewNotifications:V,removeStatus:q,showNewStatuses:function(e,t){var a=t.timeline,i=e.timelines[a];i.newStatusCount=0,i.visibleStatuses=(0,$.default)(i.statuses,0,50),i.minVisibleId=(0,h.default)(i.visibleStatuses).id,i.minId=i.minVisibleId,i.visibleStatusesObject={},(0,P.default)(i.visibleStatuses,function(e){i.visibleStatusesObject[e.id]=e})},setNotificationFetcher:function(e,t){var a=t.fetcherId;e.notifications.fetcherId=a},resetStatuses:function(e){var t=N();(0,r.default)(t).forEach(function(t){var a=(0,o.default)(t,2),i=a[0],n=a[1];e[i]=n})},clearTimeline:function(e,t){var a=t.timeline;e.timelines[a]=F(e.timelines[a].userId)},setFavorited:function(e,t){ +var a=t.status,i=t.value,n=e.allStatusesObject[a.id];n.favorited=i},setFavoritedConfirm:function(e,t){var a=t.status,i=e.allStatusesObject[a.id];i.favorited=a.favorited,i.fave_num=a.fave_num},setRetweeted:function(e,t){var a=t.status,i=t.value,n=e.allStatusesObject[a.id];n.repeated=i},setDeleted:function(e,t){var a=t.status,i=e.allStatusesObject[a.id];i.deleted=!0},setLoading:function(e,t){var a=t.timeline,i=t.value;e.timelines[a].loading=i},setNsfw:function(e,t){var a=t.id,i=t.nsfw,n=e.allStatusesObject[a];n.nsfw=i},setError:function(e,t){var a=t.value;e.error=a},setNotificationsLoading:function(e,t){var a=t.value;e.notifications.loading=a},setNotificationsError:function(e,t){var a=t.value;e.notifications.error=a},setNotificationsSilence:function(e,t){var a=t.value;e.notifications.desktopNotificationSilence=a},markNotificationsAsSeen:function(e){(0,P.default)(e.notifications.data,function(e){e.seen=!0})},queueFlush:function(e,t){var a=t.timeline,i=t.id;e.timelines[a].flushMarker=i}},H={state:N(),actions:{addNewStatuses:function(e,t){var a=e.rootState,i=e.commit,n=t.statuses,o=t.showImmediately,s=void 0!==o&&o,r=t.timeline,l=void 0!==r&&r,c=t.noIdUpdate,u=void 0!==c&&c,d=t.userId;i("addNewStatuses",{statuses:n,showImmediately:s,timeline:l,noIdUpdate:u,user:a.users.currentUser,userId:d})},addNewNotifications:function(e,t){var a=e.rootState,i=e.commit,n=e.dispatch,o=t.notifications,s=t.older;i("addNewNotifications",{visibleNotificationTypes:R(a),dispatch:n,notifications:o,older:s})},setError:function(e,t){var a=(e.rootState,e.commit),i=t.value;a("setError",{value:i})},setNotificationsLoading:function(e,t){var a=(e.rootState,e.commit),i=t.value;a("setNotificationsLoading",{value:i})},setNotificationsError:function(e,t){var a=(e.rootState,e.commit),i=t.value;a("setNotificationsError",{value:i})},setNotificationsSilence:function(e,t){var a=(e.rootState,e.commit),i=t.value;a("setNotificationsSilence",{value:i})},stopFetchingNotifications:function(e){var t=e.rootState,a=e.commit;t.statuses.notifications.fetcherId&&window.clearInterval(t.statuses.notifications.fetcherId),a("setNotificationFetcher",{fetcherId:null})},deleteStatus:function(e,t){var a=e.rootState,i=e.commit;i("setDeleted",{status:t}),z.default.deleteStatus({id:t.id,credentials:a.users.currentUser.credentials})},favorite:function(e,t){var a=e.rootState,i=e.commit;i("setFavorited",{status:t,value:!0}),z.default.favorite({id:t.id,credentials:a.users.currentUser.credentials}).then(function(e){return e.ok?e.json():{}}).then(function(e){i("setFavoritedConfirm",{status:e})})},unfavorite:function(e,t){var a=e.rootState,i=e.commit;i("setFavorited",{status:t,value:!1}),z.default.unfavorite({id:t.id,credentials:a.users.currentUser.credentials}).then(function(e){return e.ok?e.json():{}}).then(function(e){i("setFavoritedConfirm",{status:e})})},retweet:function(e,t){var a=e.rootState,i=e.commit;i("setRetweeted",{status:t,value:!0}),z.default.retweet({id:t.id,credentials:a.users.currentUser.credentials})},unretweet:function(e,t){var a=e.rootState,i=e.commit;i("setRetweeted",{status:t,value:!1}),z.default.unretweet({id:t.id,credentials:a.users.currentUser.credentials})},queueFlush:function(e,t){var a=(e.rootState,e.commit),i=t.timeline,n=t.id;a("queueFlush",{timeline:i,id:n})},markNotificationsAsSeen:function(e){var t=e.rootState,a=e.commit;a("markNotificationsAsSeen"),z.default.markNotificationsAsSeen({id:t.statuses.notifications.maxId,credentials:t.users.currentUser.credentials})}},mutations:D};t.default=H},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0}),t.defaultState=t.getters=t.mutations=t.mergeOrAdd=void 0;var n=a(141),o=i(n),s=a(139),r=i(s),l=a(9),c=i(l),u=a(23),d=i(u),p=a(25),f=i(p),_=a(59),h=i(_),m=a(200),v=i(m),g=a(82),b=i(g),w=a(31),k=i(w),y=a(587),C=i(y),x=a(131),S=i(x),j=a(8),P=a(245),L=a(90),$=i(L),A=a(229),T=t.mergeOrAdd=function(e,t,a){if(!a)return!1;var i=t[a.id];return i?((0,v.default)(i,a),{item:i,new:!1}):(e.push(a),t[a.id]=a,a.screen_name&&!a.screen_name.includes("@")&&(t[a.screen_name]=a),{item:a,new:!0})},I=function(){var e=window.Notification;return e?"default"===e.permission?e.requestPermission():f.default.resolve(e.permission):f.default.resolve(null)},z=t.mutations={setMuted:function(e,t){var a=t.user.id,i=t.muted,n=e.usersObject[a];(0,j.set)(n,"muted",i)},setCurrentUser:function(e,t){e.lastLoginName=t.screen_name,e.currentUser=(0,v.default)(e.currentUser||{},t)},clearCurrentUser:function(e){e.currentUser=!1,e.lastLoginName=!1},beginLogin:function(e){e.loggingIn=!0},endLogin:function(e){e.loggingIn=!1},addFriends:function(e,t){var a=t.id,i=t.friends,n=t.page,o=e.usersObject[a];(0,b.default)(i,function(e){(0,h.default)(o.friends,{id:e.id})||o.friends.push(e)}),o.friendsPage=n+1},addFollowers:function(e,t){var a=t.id,i=t.followers,n=t.page,o=e.usersObject[a];(0,b.default)(i,function(e){(0,h.default)(o.followers,{id:e.id})||o.followers.push(e)}),o.followersPage=n+1},clearFriends:function(e,t){var a=e.usersObject[t];a&&(a.friends=[],a.friendsPage=0)},clearFollowers:function(e,t){var a=e.usersObject[t];a&&(a.followers=[],a.followersPage=0)},addNewUsers:function(e,t){(0,b.default)(t,function(t){return T(e.users,e.usersObject,t)})},saveBlocks:function(e,t){e.currentUser.blockIds=t},saveMutes:function(e,t){e.currentUser.muteIds=t},setUserForStatus:function(e,t){t.user=e.usersObject[t.user.id]},setUserForNotification:function(e,t){t.action.user=e.usersObject[t.action.user.id],t.from_profile=e.usersObject[t.action.user.id]},setColor:function(e,t){var a=t.user.id,i=t.highlighted,n=e.usersObject[a];(0,j.set)(n,"highlight",i)},signUpPending:function(e){e.signUpPending=!0,e.signUpErrors=[]},signUpSuccess:function(e){e.signUpPending=!1},signUpFailure:function(e,t){e.signUpPending=!1,e.signUpErrors=t}},F=t.getters={userById:function(e){return function(t){return e.users.find(function(e){return e.id===t})}},userByName:function(e){return function(t){return e.users.find(function(e){return e.screen_name&&e.screen_name.toLowerCase()===t.toLowerCase()})}}},N=t.defaultState={loggingIn:!1,lastLoginName:!1,currentUser:!1,users:[],usersObject:{},signUpPending:!1,signUpErrors:[]},O={state:N,mutations:z,getters:F,actions:{fetchUser:function(e,t){return e.rootState.api.backendInteractor.fetchUser({id:t}).then(function(t){return e.commit("addNewUsers",[t])})},fetchBlocks:function(e){return e.rootState.api.backendInteractor.fetchBlocks().then(function(t){return e.commit("saveBlocks",(0,k.default)(t,"id")),e.commit("addNewUsers",t),t})},blockUser:function(e,t){return e.rootState.api.backendInteractor.blockUser(t).then(function(t){return e.commit("addNewUsers",[t])})},unblockUser:function(e,t){return e.rootState.api.backendInteractor.unblockUser(t).then(function(t){return e.commit("addNewUsers",[t])})},fetchMutes:function(e){return e.rootState.api.backendInteractor.fetchMutes().then(function(t){(0,b.default)(t,function(e){e.muted=!0}),e.commit("addNewUsers",t),e.commit("saveMutes",(0,k.default)(t,"id"))})},muteUser:function(e,t){return e.state.api.backendInteractor.setUserMute({id:t,muted:!0}).then(function(t){return e.commit("addNewUsers",[t])})},unmuteUser:function(e,t){return e.state.api.backendInteractor.setUserMute({id:t,muted:!1}).then(function(t){return e.commit("addNewUsers",[t])})},addFriends:function(e,t){var a=e.rootState,i=e.commit;return new f.default(function(e,n){var o=a.users.usersObject[t],s=o.friendsPage||1;a.api.backendInteractor.fetchFriends({id:o.id,page:s}).then(function(t){i("addFriends",{id:o.id,friends:t,page:s}),e(t)}).catch(function(){n()})})},addFollowers:function(e,t){var a=e.rootState,i=e.commit,n=a.users.usersObject[t],o=n.followersPage||1;return a.api.backendInteractor.fetchFollowers({id:n.id,page:o}).then(function(e){return i("addFollowers",{id:n.id,followers:e,page:o}),e})},clearFriends:function(e,t){var a=e.commit;a("clearFriends",t)},clearFollowers:function(e,t){var a=e.commit;a("clearFollowers",t)},registerPushNotifications:function(e){var t=e.state.currentUser.credentials,a=e.rootState.instance.vapidPublicKey,i=e.rootState.config.webPushNotifications,n=e.rootState.config.notificationVisibility;(0,P.registerPushNotifications)(i,a,t,n)},unregisterPushNotifications:function(e){var t=e.state.currentUser.credentials;(0,P.unregisterPushNotifications)(t)},addNewStatuses:function(e,t){var a=t.statuses,i=(0,k.default)(a,"user"),n=(0,C.default)((0,k.default)(a,"retweeted_status.user"));e.commit("addNewUsers",i),e.commit("addNewUsers",n),(0,b.default)(a,function(t){e.commit("setUserForStatus",t)}),(0,b.default)((0,C.default)((0,k.default)(a,"retweeted_status")),function(t){e.commit("setUserForStatus",t)})},addNewNotifications:function(e,t){var a=t.notifications,i=(0,k.default)(a,"from_profile"),n=a.map(function(e){return e.id});e.commit("addNewUsers",i);var o=e.rootState.statuses.notifications.idStore,s=(0,d.default)(o).filter(function(e){var t=(0,c.default)(e,2),a=t[0];t[1];return n.includes(a)}).map(function(e){var t=(0,c.default)(e,2),a=(t[0],t[1]);return a});(0,b.default)(s,function(t){e.commit("setUserForNotification",t)})},signUp:function(){function e(e,a){return t.apply(this,arguments)}var t=(0,r.default)(o.default.mark(function e(t,a){var i,n,s,r,l,c,u;return o.default.wrap(function(e){for(;;)switch(e.prev=e.next){case 0:return t.commit("signUpPending"),i=t.rootState,e.next=4,i.api.backendInteractor.register(a);case 4:if(n=e.sent,!n.ok){e.next=18;break}return s={oauth:i.oauth,instance:i.instance.server},e.next=9,$.default.getOrCreateApp(s);case 9:return r=e.sent,e.next=12,$.default.getTokenWithCredentials({app:r,instance:s.instance,username:a.username,password:a.password});case 12:l=e.sent,t.commit("signUpSuccess"),t.commit("setToken",l.access_token),t.dispatch("loginUser",l.access_token),e.next=26;break;case 18:return e.next=20,n.json();case 20:throw c=e.sent,u=JSON.parse(c.error),u.ap_id&&(u.username=u.ap_id,delete u.ap_id),u=(0,A.humanizeErrors)(u),t.commit("signUpFailure",u),Error(u);case 26:case"end":return e.stop()}},e,this)}));return e}(),getCaptcha:function(){function e(e){return t.apply(this,arguments)}var t=(0,r.default)(o.default.mark(function e(t){return o.default.wrap(function(e){for(;;)switch(e.prev=e.next){case 0:return e.next=2,t.rootState.api.backendInteractor.getCaptcha();case 2:return e.abrupt("return",e.sent);case 3:case"end":return e.stop()}},e,this)}));return e}(),logout:function(e){e.commit("clearCurrentUser"),e.dispatch("disconnectFromChat"),e.commit("setToken",!1),e.dispatch("stopFetching","friends"),e.commit("setBackendInteractor",(0,S.default)()),e.dispatch("stopFetchingNotifications"),e.commit("resetStatuses")},loginUser:function(e,t){return new f.default(function(a,i){var n=e.commit;n("beginLogin"),e.rootState.api.backendInteractor.verifyCredentials(t).then(function(o){if(o.error){var s=o.error;n("endLogin"),i(401===s.status?"Wrong username or password":"An error occurred, please try again")}else{var r=o;r.credentials=t,r.blockIds=[],r.muteIds=[],n("setCurrentUser",r),n("addNewUsers",[r]),I().then(function(e){return n("setNotificationPermission",e)}),n("setBackendInteractor",(0,S.default)(t)),r.token&&(e.dispatch("setWsToken",r.token),e.dispatch("initializeSocket")),e.dispatch("startFetching",{timeline:"friends"}),e.dispatch("fetchMutes"),e.rootState.api.backendInteractor.fetchFriends({id:r.id}).then(function(e){return n("addNewUsers",e)})}n("endLogin"),a()}).catch(function(e){console.log(e),n("endLogin"),i("Failed to connect to server, try again")})})}}};t.default=O},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0}),t.splitIntoWords=t.addPositionToWords=t.wordAtPosition=t.replaceWord=void 0;var n=a(59),o=i(n),s=a(124),r=i(s),l=t.replaceWord=function(e,t,a){return e.slice(0,t.start)+a+e.slice(t.end)},c=t.wordAtPosition=function(e,t){var a=d(e),i=u(a);return(0,o.default)(i,function(e){var a=e.start,i=e.end;return a<=t&&i>t})},u=t.addPositionToWords=function(e){return(0,r.default)(e,function(e,t){var a={word:t,start:0,end:t.length};if(e.length>0){var i=e.pop();a.start+=i.end,a.end+=i.end,e.push(i)}return e.push(a),e},[])},d=t.splitIntoWords=function(e){var t=/\b/,a=/[@#:]+$/,i=e.split(t),n=(0,r.default)(i,function(e,t){if(e.length>0){var i=e.pop(),n=i.match(a);n&&(i=i.replace(a,""),t=n[0]+t),e.push(i)}return e.push(t),e},[]);return n},p={wordAtPosition:c,addPositionToWords:u,splitIntoWords:d,replaceWord:l};t.default=p},function(e,t){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var a=function(e){return e.is_post_verb?"status":e.retweeted_status?"retweet":"string"==typeof e.uri&&e.uri.match(/(fave|objectType=Favourite)/)||"string"==typeof e.text&&e.text.match(/favorited/)?"favorite":e.text.match(/deleted notice {{tag/)||e.qvitter_delete_notice?"deletion":e.text.match(/started following/)||"follow"===e.activity_type?"follow":"unknown"},i=t.parseUser=function(e){var t={},a=e.hasOwnProperty("acct"),i=a&&!e.hasOwnProperty("avatar");if(t.id=String(e.id),a){if(t.screen_name=e.acct,i)return t;if(t.name=null,t.name_html=e.display_name,t.description=null,t.description_html=e.note,t.profile_image_url=e.avatar,t.profile_image_url_original=e.avatar,t.cover_photo=e.header,t.friends_count=e.following_count,t.bot=e.bot,t.statusnet_profile_url=e.url,e.pleroma){var n=e.pleroma;t.follows_you=n.follows_you,t.statusnet_blocking=n.statusnet_blocking,t.muted=n.muted}t.is_local=!t.screen_name.includes("@")}else t.screen_name=e.screen_name,t.name=e.name,t.name_html=e.name_html,t.description=e.description,t.description_html=e.description_html,t.profile_image_url=e.profile_image_url,t.profile_image_url_original=e.profile_image_url_original,t.cover_photo=e.cover_photo,t.friends_count=e.friends_count,t.bot=null,t.statusnet_profile_url=e.statusnet_profile_url,t.statusnet_blocking=e.statusnet_blocking,t.is_local=e.is_local,t.role=e.role,t.show_role=e.show_role,t.follows_you=e.follows_you,t.muted=e.muted,t.rights=e.rights,t.no_rich_text=e.no_rich_text,t.default_scope=e.default_scope,t.hide_follows=e.hide_follows,t.hide_followers=e.hide_followers,t.background_image=e.background_image,t.following=e.following,t.token=e.token;return t.created_at=new Date(e.created_at),t.locked=e.locked,t.followers_count=e.followers_count,t.statuses_count=e.statuses_count,t.friends=[],t.followers=[],e.pleroma&&(t.follow_request_count=e.pleroma.follow_request_count),t},n=function(e){var t={},a=!e.hasOwnProperty("oembed");return a?(t.mimetype=e.type,t.meta=e.meta):(t.mimetype=e.mimetype,t.meta=null),t.url=e.url,t.description=e.description,t},o=t.parseStatus=function e(t){var o={},r=t.hasOwnProperty("account");r?(o.favorited=t.favourited,o.fave_num=t.favourites_count,o.repeated=t.reblogged,o.repeat_num=t.reblogs_count,o.type=t.reblog?"retweet":"status",o.nsfw=t.sensitive,o.statusnet_html=t.content,o.text=t.content,o.in_reply_to_status_id=t.in_reply_to_id,o.in_reply_to_user_id=t.in_reply_to_account_id,o.in_reply_to_screen_name=null,o.statusnet_conversation_id=t.id,"retweet"===o.type&&(o.retweeted_status=e(t.reblog)),o.summary=t.spoiler_text,o.summary_html=t.spoiler_text,o.external_url=t.url,o.is_local=!1):(o.favorited=t.favorited,o.fave_num=t.fave_num,o.repeated=t.repeated,o.repeat_num=t.repeat_num,o.type=a(t),void 0===t.nsfw?(o.nsfw=s(t),t.retweeted_status&&(o.nsfw=t.retweeted_status.nsfw)):o.nsfw=t.nsfw,o.statusnet_html=t.statusnet_html,o.text=t.text,o.in_reply_to_status_id=t.in_reply_to_status_id,o.in_reply_to_user_id=t.in_reply_to_user_id,o.in_reply_to_screen_name=t.in_reply_to_screen_name,o.statusnet_conversation_id=t.statusnet_conversation_id,"retweet"===o.type&&(o.retweeted_status=e(t.retweeted_status)),o.summary=t.summary,o.summary_html=t.summary_html,o.external_url=t.external_url,o.is_local=t.is_local),o.id=String(t.id),o.visibility=t.visibility,o.card=t.card,o.created_at=new Date(t.created_at),o.in_reply_to_status_id=o.in_reply_to_status_id?String(o.in_reply_to_status_id):null,o.in_reply_to_user_id=o.in_reply_to_user_id?String(o.in_reply_to_user_id):null,o.user=i(r?t.account:t.user),o.attentions=((r?t.mentions:t.attentions)||[]).map(i),o.attachments=((r?t.media_attachments:t.attachments)||[]).map(n);var l=r?t.reblog:t.retweeted_status;return l&&(o.retweeted_status=e(l)),o},s=(t.parseNotification=function(e){var t={favourite:"like",reblog:"repeat"},a=!e.hasOwnProperty("ntype"),n={};if(a)n.type=t[e.type]||e.type,n.seen=null,n.status=o(e.status),n.action=n.status,n.from_profile=i(e.account);else{var s=o(e.notice);n.type=e.ntype,n.seen=Boolean(e.is_seen),n.status="like"===n.type?o(e.notice.favorited_status):s,n.action=s,n.from_profile=i(e.from_profile)}return n.created_at=new Date(e.created_at),n.id=e.id,n},function(e){var t=/#nsfw/i;return(e.tags||[]).includes("nsfw")||!!e.text.match(t)})},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}function n(e,t,a,i){this.name="StatusCodeError",this.statusCode=e,this.message=e+" - "+(JSON&&l.default?(0,l.default)(t):t),this.error=t,this.options=a,this.response=i,Error.captureStackTrace&&Error.captureStackTrace(this)}Object.defineProperty(t,"__esModule",{value:!0});var o=a(311),s=i(o),r=a(64),l=i(r);t.StatusCodeError=n,n.prototype=(0,s.default)(Error.prototype),n.prototype.constructor=n},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(18),o=i(n),s=function(e){var t=e.store,a=e.credentials;return o.default.fetchFollowRequests({credentials:a}).then(function(e){t.commit("setFollowRequests",e)},function(){}).catch(function(){})},r=function(e){var t=e.credentials,a=e.store;s({credentials:t,store:a});var i=function(){return s({credentials:t,store:a})};return setInterval(i,1e4)},l={startFetching:r};t.default=l},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0}),t.extractTagFromUrl=t.mentionMatchesUrl=void 0;var n=a(9),o=i(n);t.mentionMatchesUrl=function(e,t){if(t===e.statusnet_profile_url)return!0;var a=e.screen_name.split("@"),i=(0,o.default)(a,2),n=i[0],s=i[1],r=new RegExp("://"+s+"/.*"+n+"$","g");return!!t.match(r)},t.extractTagFromUrl=function(e){var t=/tag[s]*\/(\w+)$/g,a=t.exec(e);return!!a&&a[1]}},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(243),o=i(n),s=function(e){var t=e.query,a=e.store;return o.default.request({store:a,url:"/api/pleroma/search_user",params:{query:t}}).then(function(e){return e.json()})},r={search:s};t.default=r},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(24),o=i(n),s=function(e){return(0,o.default)(e).map(function(t){return encodeURIComponent(t)+"="+encodeURIComponent(e[t])}).join("&")},r=function(e){var t=e.state.oauth.token;return t?{Authorization:"Bearer "+t}:{}},l=function(e){var t=e.method,a=void 0===t?"GET":t,i=e.url,n=e.params,o=e.store,l=o.state.instance.server,c=""+l+i;return"GET"===a&&n&&(c+="?"+s(n)),window.fetch(c,{method:a,headers:r(o),credentials:"same-origin"})},c={queryParams:s,request:l};t.default=c},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(26),o=i(n),s=a(18),r=i(s),l=function(e){var t=e.store,a=e.notifications,i=e.older;t.dispatch("setNotificationsError",{value:!1}),t.dispatch("addNewNotifications",{notifications:a,older:i})},c=function(e){var t=e.store,a=e.credentials,i=e.older,n=void 0!==i&&i,s={credentials:a},c=t.rootState||t.state,u=c.statuses.notifications;if(n)u.minId!==Number.POSITIVE_INFINITY&&(s.until=u.minId);else{var d=u.data,p=d.filter(function(e){return!e.seen}).map(function(e){return e.id});p.length?(s.since=Math.min.apply(Math,(0,o.default)(p))-1,u.maxId!==Math.max.apply(Math,(0,o.default)(p))&&(s.until=Math.max.apply(Math,(0,o.default)(p).concat([s.since+20])))):s.since=u.maxId}return s.timeline="notifications",r.default.fetchTimeline(s).then(function(e){return l({store:t,notifications:e,older:n}),e},function(){return t.dispatch("setNotificationsError",{value:!0})}).catch(function(){return t.dispatch("setNotificationsError",{value:!0})})},u=function(e){var t=e.credentials,a=e.store;c({credentials:t,store:a});var i=function(){return c({credentials:t,store:a})};return setTimeout(function(){return a.dispatch("setNotificationsSilence",!1)},1e4),setInterval(i,1e4)},d={fetchAndUpdate:c,startFetching:u};t.default=d},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}function n(e){var t="=".repeat((4-e.length%4)%4),a=(e+t).replace(/-/g,"+").replace(/_/g,"/"),i=window.atob(a);return Uint8Array.from([].concat((0,w.default)(i)).map(function(e){return e.charCodeAt(0)}))}function o(){return"serviceWorker"in navigator&&"PushManager"in window}function s(){return y.default.register().catch(function(e){return console.error("Unable to get or create a service worker.",e)})}function r(e,t,a){if(!t)return g.default.reject(new Error("Web Push is disabled in config"));if(!a)return g.default.reject(new Error("VAPID public key is not found"));var i={userVisibleOnly:!0,applicationServerKey:n(a)};return e.pushManager.subscribe(i)}function l(e){return e.pushManager.getSubscription().then(function(e){if(null!==e)return e.unsubscribe()})}function c(e){return window.fetch("/api/v1/push/subscription/",{method:"DELETE",headers:{"Content-Type":"application/json",Authorization:"Bearer "+e}}).then(function(e){if(!e.ok)throw new Error("Bad status code from server.");return e})}function u(e,t,a){return window.fetch("/api/v1/push/subscription/",{method:"POST",headers:{"Content-Type":"application/json",Authorization:"Bearer "+t},body:(0,m.default)({subscription:e,data:{alerts:{follow:a.follows,favourite:a.likes,mention:a.mentions,reblog:a.repeats}}})}).then(function(e){if(!e.ok)throw new Error("Bad status code from server.");return e.json()}).then(function(e){if(!e.id)throw new Error("Bad response from server.");return e})}function d(e,t,a,i){o()&&s().then(function(a){return r(a,e,t)}).then(function(e){return u(e,a,i)}).catch(function(e){return console.warn("Failed to setup Web Push Notifications: "+e.message)})}function p(e){o()&&g.default.all([c(e),s().then(function(e){return l(e).then(function(t){return[e,t]})}).then(function(e){var t=(0,_.default)(e,2),a=t[0],i=t[1];return i||console.warn("Push subscription cancellation wasn't successful, killing SW anyway..."),a.unregister().then(function(e){e||console.warn("Failed to kill SW")})})]).catch(function(e){return console.warn("Failed to disable Web Push Notifications: "+e.message)})}Object.defineProperty(t,"__esModule",{value:!0});var f=a(9),_=i(f),h=a(64),m=i(h),v=a(25),g=i(v),b=a(26),w=i(b);t.registerPushNotifications=d,t.unregisterPushNotifications=p;var k=a(626),y=i(k)},function(e,t){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default={props:["name","label","value","fallback","disabled"],computed:{present:function(){return"undefined"!=typeof this.value}}}},function(e,t){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default={props:["large","contrast"],computed:{hint:function(){var e=this.contrast.aaa?"aaa":this.contrast.aa?"aa":"bad",t=this.$t("settings.style.common.contrast.level."+e),a=this.$t("settings.style.common.contrast.context.text"),i=this.contrast.text;return this.$t("settings.style.common.contrast.hint",{level:t,context:a,ratio:i})},hint_18pt:function(){var e=this.contrast.laaa?"aaa":this.contrast.laa?"aa":"bad",t=this.$t("settings.style.common.contrast.level."+e),a=this.$t("settings.style.common.contrast.context.18pt"),i=this.contrast.text;return this.$t("settings.style.common.contrast.hint",{level:t,context:a,ratio:i})}}}},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(64),o=i(n);t.default={props:["exportObject","importLabel","exportLabel","importFailedText","validator","onImport","onImportFailure"],data:function(){return{importFailed:!1}},methods:{exportData:function(){var e=(0,o.default)(this.exportObject),t=document.createElement("a");t.setAttribute("download","pleroma_theme.json"),t.setAttribute("href","data:application/json;base64,"+window.btoa(e)),t.style.display="none",document.body.appendChild(t),t.click(),document.body.removeChild(t)},importData:function(){var e=this;this.importFailed=!1;var t=document.createElement("input");t.setAttribute("type","file"),t.setAttribute("accept",".json"),t.addEventListener("change",function(t){if(t.target.files[0]){var a=new FileReader;a.onload=function(t){var a=t.target;try{var i=JSON.parse(a.result),n=e.validator(i);n?e.onImport(i):e.importFailed=!0}catch(t){e.importFailed=!0}},a.readAsText(t.target.files[0])}}),document.body.appendChild(t),t.click(),document.body.removeChild(t)}}}},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(24),o=i(n),s=a(31),r=i(s),l=a(130),c=i(l),u=a(432),d=i(u);t.default={computed:{languageCodes:function(){return(0,o.default)(c.default)},languageNames:function(){return(0,r.default)(this.languageCodes,d.default.getName)},language:{get:function(){return this.$store.state.config.interfaceLanguage},set:function(e){this.$store.dispatch("setOption",{name:"interfaceLanguage",value:e}),this.$i18n.locale=e}}}}},function(e,t){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default={props:["name","value","fallback","disabled"],computed:{present:function(){return"undefined"!=typeof this.value}}}},function(e,t){"use strict";Object.defineProperty(t,"__esModule",{value:!0}),t.default={props:["name","value","fallback","disabled","label","max","min","step","hardMin","hardMax"],computed:{present:function(){return"undefined"!=typeof this.value}}}},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(36),o=i(n),s=a(671),r=i(s),l=a(655),c=i(l),u=a(213),d=i(u),p=a(670),f=i(p),_=a(211),h=i(_),m=a(210),v=i(m),g=a(676),b=i(g),w=a(207),k=i(w),y=a(650),C=i(y),x=a(665),S=i(x),j=a(653),P=i(j),L=a(91);t.default={name:"app",components:{UserPanel:r.default,NavPanel:c.default,Notifications:d.default,UserFinder:f.default,InstanceSpecificPanel:h.default,FeaturesPanel:v.default,WhoToFollowPanel:b.default,ChatPanel:k.default,MediaModal:C.default,SideDrawer:S.default,MobilePostStatusModal:P.default},data:function(){return{mobileActivePanel:"timeline",finderHidden:!0,supportsMask:window.CSS&&window.CSS.supports&&(window.CSS.supports("mask-size","contain")||window.CSS.supports("-webkit-mask-size","contain")||window.CSS.supports("-moz-mask-size","contain")||window.CSS.supports("-ms-mask-size","contain")||window.CSS.supports("-o-mask-size","contain"))}},created:function(){this.$i18n.locale=this.$store.state.config.interfaceLanguage},computed:{currentUser:function(){return this.$store.state.users.currentUser},background:function(){return this.currentUser.background_image||this.$store.state.instance.background},enableMask:function(){return this.supportsMask&&this.$store.state.instance.logoMask},logoStyle:function(){return{visibility:this.enableMask?"hidden":"visible"}},logoMaskStyle:function(){return this.enableMask?{"mask-image":"url("+this.$store.state.instance.logo+")"}:{"background-color":this.enableMask?"":"transparent"}},logoBgStyle:function(){return(0,o.default)({margin:this.$store.state.instance.logoMargin+" 0",opacity:this.finderHidden?1:0},this.enableMask?{}:{"background-color":this.enableMask?"":"transparent"})},logo:function(){return this.$store.state.instance.logo},bgStyle:function(){return{"background-image":"url("+this.background+")"}},bgAppStyle:function(){return{"--body-background-image":"url("+this.background+")"}},sitename:function(){return this.$store.state.instance.name},chat:function(){return"joined"===this.$store.state.chat.channel.state},suggestionsEnabled:function(){return this.$store.state.instance.suggestionsEnabled},showInstanceSpecificPanel:function(){return this.$store.state.instance.showInstanceSpecificPanel},unseenNotifications:function(){return(0,L.unseenNotificationsFromStore)(this.$store)},unseenNotificationsCount:function(){return this.unseenNotifications.length},showFeaturesPanel:function(){return this.$store.state.instance.showFeaturesPanel}},methods:{scrollToTop:function(){window.scrollTo(0,0)},logout:function(){this.$router.replace("/main/public"),this.$store.dispatch("logout")},onFinderToggled:function(e){this.finderHidden=e},toggleMobileSidebar:function(){this.$refs.sideDrawer.toggleDrawer()}}}},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(211),o=i(n),s=a(210),r=i(s),l=a(669),c=i(l),u={components:{InstanceSpecificPanel:o.default,FeaturesPanel:r.default,TermsOfServicePanel:c.default},computed:{showFeaturesPanel:function(){return this.$store.state.instance.showFeaturesPanel}}};t.default=u},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(127),o=i(n),s=a(216),r=i(s),l=a(629),c=i(l),u=a(45),d=i(u),p={props:["attachment","nsfw","statusId","size","allowPlay","setMedia"],data:function(){return{nsfwImage:this.$store.state.instance.nsfwCensorImage||c.default,hideNsfwLocal:this.$store.state.config.hideNsfw,preloadImage:this.$store.state.config.preloadImage,loading:!1,img:"image"===d.default.fileType(this.attachment.mimetype)&&document.createElement("img"),modalOpen:!1,showHidden:!1}},components:{StillImage:o.default,VideoAttachment:r.default},computed:{usePlaceHolder:function(){return"hide"===this.size||"unknown"===this.type},referrerpolicy:function(){return this.$store.state.instance.mediaProxyAvailable?"":"no-referrer"},type:function(){return d.default.fileType(this.attachment.mimetype)},hidden:function(){return this.nsfw&&this.hideNsfwLocal&&!this.showHidden},isEmpty:function(){return"html"===this.type&&!this.attachment.oembed||"unknown"===this.type},isSmall:function(){return"small"===this.size},fullwidth:function(){return"html"===this.type||"audio"===this.type}},methods:{linkClicked:function(e){var t=e.target;"A"===t.tagName&&window.open(t.href,"_blank")},openModal:function(e){var t=this.$store.state.config.playVideosInModal?["image","video"]:["image"];(d.default.fileMatchesSomeType(t,this.attachment)||this.usePlaceHolder)&&(e.stopPropagation(),e.preventDefault(),this.setMedia(),this.$store.dispatch("setCurrent",this.attachment))},toggleHidden:function(e){var t=this;return this.$store.state.config.useOneClickNsfw&&!this.showHidden?void this.openModal(e):void(this.img&&!this.preloadImage?this.img.onload?this.img.onload():(this.loading=!0,this.img.src=this.attachment.url,this.img.onload=function(){t.loading=!1,t.showHidden=!t.showHidden}):this.showHidden=!this.showHidden)}}};t.default=p},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(43),o=i(n),s=a(88),r=i(s),l=a(35),c=i(l),u={props:["user"],data:function(){return{userExpanded:!1}},components:{UserCard:o.default,UserAvatar:r.default},methods:{toggleUserExpanded:function(){this.userExpanded=!this.userExpanded},userProfileLink:function(e){return(0,c.default)(e.id,e.screen_name,this.$store.state.instance.restrictedNicknames)}}};t.default=u},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(86),o=i(n),s={props:["userId"],data:function(){return{progress:!1}},computed:{user:function(){return this.$store.getters.userById(this.userId)},blocked:function(){return this.user.statusnet_blocking}},components:{BasicUserCard:o.default},methods:{unblockUser:function(){var e=this;this.progress=!0, +this.$store.dispatch("unblockUser",this.user.id).then(function(){e.progress=!1})},blockUser:function(){var e=this;this.progress=!0,this.$store.dispatch("blockUser",this.user.id).then(function(){e.progress=!1})}}};t.default=s},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(35),o=i(n),s={props:["floating"],data:function(){return{currentMessage:"",channel:null,collapsed:!0}},computed:{messages:function(){return this.$store.state.chat.messages}},methods:{submit:function(e){this.$store.state.chat.channel.push("new_msg",{text:e},1e4),this.currentMessage=""},togglePanel:function(){this.collapsed=!this.collapsed},userProfileLink:function(e){return(0,o.default)(e.id,e.username,this.$store.state.instance.restrictedNicknames)}}};t.default=s},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(59),o=i(n),s=a(209),r=i(s),l={components:{Conversation:r.default},computed:{statusoid:function(){var e=this.$route.params.id,t=this.$store.state.statuses.allStatuses,a=(0,o.default)(t,{id:e});return a}}};t.default=l},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(65),o=i(n),s=a(58),r=i(s),l=a(124),c=i(l),u=a(87),d=i(u),p=function(e,t){var a=Number(e.id),i=Number(t.id),n=!(0,o.default)(a),s=!(0,o.default)(i);return n&&s?a1){var t=(0,r.default)(e)[0],a=(0,o.default)(e);return(0,r.default)(a).push(t),a}return e},rowHeight:function(){var e=this;return function(t){return{height:e.width/(t+.6)+"px"}}},useContainFit:function(){return this.$store.state.config.useContainFit}},methods:{resize:function(){var e=10*Math.floor(this.$el.getBoundingClientRect().width/10);this.width!==e&&(this.width=e)}}};t.default=p},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(66),o=i(n),s=a(381),r=i(s);a(382);var l={props:{trigger:{type:[String,window.Element],required:!0},submitHandler:{type:Function,required:!0},cropperOptions:{type:Object,default:function(){return{aspectRatio:1,autoCropArea:1,viewMode:1,movable:!1,zoomable:!1,guides:!1}}},mimes:{type:String,default:"image/png, image/gif, image/jpeg, image/bmp, image/x-icon"},saveButtonLabel:{type:String},cancelButtonLabel:{type:String}},data:function(){return{cropper:void 0,dataUrl:void 0,filename:void 0,submitting:!1,submitError:null}},computed:{saveText:function(){return this.saveButtonLabel||this.$t("image_cropper.save")},cancelText:function(){return this.cancelButtonLabel||this.$t("image_cropper.cancel")},submitErrorMsg:function(){return this.submitError&&this.submitError instanceof Error?this.submitError.toString():this.submitError}},methods:{destroy:function(){this.cropper&&this.cropper.destroy(),this.$refs.input.value="",this.dataUrl=void 0,this.$emit("close")},submit:function(){var e=this;this.submitting=!0,this.avatarUploadError=null,this.submitHandler(this.cropper,this.file).then(function(){return e.destroy()}).catch(function(t){e.submitError=t}).finally(function(){e.submitting=!1})},pickImage:function(){this.$refs.input.click()},createCropper:function(){this.cropper=new r.default(this.$refs.img,this.cropperOptions)},getTriggerDOM:function(){return"object"===(0,o.default)(this.trigger)?this.trigger:document.querySelector(this.trigger)},readFile:function(){var e=this,t=this.$refs.input;if(null!=t.files&&null!=t.files[0]){this.file=t.files[0];var a=new window.FileReader;a.onload=function(t){e.dataUrl=t.target.result,e.$emit("open")},a.readAsDataURL(this.file),this.$emit("changed",this.file,a)}},clearError:function(){this.submitError=null}},mounted:function(){var e=this.getTriggerDOM();e?e.addEventListener("click",this.pickImage):this.$emit("error","No image make trigger found.","user");var t=this.$refs.input;t.addEventListener("change",this.readFile)},beforeDestroy:function(){var e=this.getTriggerDOM();e&&e.removeEventListener("click",this.pickImage);var t=this.$refs.input;t.removeEventListener("change",this.readFile)}};t.default=l},function(e,t){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var a={computed:{instanceSpecificPanelContent:function(){return this.$store.state.instance.instanceSpecificPanelContent},show:function(){return!this.$store.state.config.hideISP}}};t.default=a},function(e,t){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var a={name:"LinkPreview",props:["card","size","nsfw"],computed:{useImage:function(){return this.card.image&&!this.nsfw&&"hide"!==this.size},useDescription:function(){return this.card.description&&/\S/.test(this.card.description)}}};t.default=a},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(90),o=i(n),s={data:function(){return{user:{},authError:!1}},computed:{loginMethod:function(){return this.$store.state.instance.loginMethod},loggingIn:function(){return this.$store.state.users.loggingIn},registrationOpen:function(){return this.$store.state.instance.registrationOpen}},methods:{oAuthLogin:function(){o.default.login({oauth:this.$store.state.oauth,instance:this.$store.state.instance.server,commit:this.$store.commit})},submit:function(){var e=this,t={oauth:this.$store.state.oauth,instance:this.$store.state.instance.server};this.clearError(),o.default.getOrCreateApp(t).then(function(a){o.default.getTokenWithCredentials({app:a,instance:t.instance,username:e.user.username,password:e.user.password}).then(function(t){return t.error?(e.authError=t.error,void(e.user.password="")):(e.$store.commit("setToken",t.access_token),e.$store.dispatch("loginUser",t.access_token),void e.$router.push({name:"friends"}))})})},clearError:function(){this.authError=!1}}};t.default=s},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(127),o=i(n),s=a(216),r=i(s),l=a(45),c=i(l),u={components:{StillImage:o.default,VideoAttachment:r.default},computed:{showing:function(){return this.$store.state.mediaViewer.activated},media:function(){return this.$store.state.mediaViewer.media},currentIndex:function(){return this.$store.state.mediaViewer.currentIndex},currentMedia:function(){return this.media[this.currentIndex]},canNavigate:function(){return this.media.length>1},type:function(){return this.currentMedia?c.default.fileType(this.currentMedia.mimetype):null}},methods:{hide:function(){this.$store.dispatch("closeMediaViewer")},goPrev:function(){if(this.canNavigate){var e=0===this.currentIndex?this.media.length-1:this.currentIndex-1;this.$store.dispatch("setCurrent",this.media[e])}},goNext:function(){if(this.canNavigate){var e=this.currentIndex===this.media.length-1?0:this.currentIndex+1;this.$store.dispatch("setCurrent",this.media[e])}},handleKeyupEvent:function(e){this.showing&&27===e.keyCode&&this.hide()},handleKeydownEvent:function(e){this.showing&&(39===e.keyCode?this.goNext():37===e.keyCode&&this.goPrev())}},mounted:function(){document.addEventListener("keyup",this.handleKeyupEvent),document.addEventListener("keydown",this.handleKeydownEvent)},destroyed:function(){document.removeEventListener("keyup",this.handleKeyupEvent),document.removeEventListener("keydown",this.handleKeydownEvent)}};t.default=u},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(135),o=i(n),s=a(133),r=i(s),l={data:function(){return{uploading:!1,uploadReady:!0}},methods:{uploadFile:function(e){var t=this,a=this.$store;if(e.size>a.state.instance.uploadlimit){var i=r.default.fileSizeFormat(e.size),n=r.default.fileSizeFormat(a.state.instance.uploadlimit);return void t.$emit("upload-failed","file_too_big",{filesize:i.num,filesizeunit:i.unit,allowedsize:n.num,allowedsizeunit:n.unit})}var s=new FormData;s.append("media",e),t.$emit("uploading"),t.uploading=!0,o.default.uploadMedia({store:a,formData:s}).then(function(e){t.$emit("uploaded",e),t.uploading=!1},function(e){t.$emit("upload-failed","default"),t.uploading=!1})},fileDrop:function(e){e.dataTransfer.files.length>0&&(e.preventDefault(),this.uploadFile(e.dataTransfer.files[0]))},fileDrag:function(e){var t=e.dataTransfer.types;t.contains("Files")?e.dataTransfer.dropEffect="copy":e.dataTransfer.dropEffect="none"},clearFile:function(){var e=this;this.uploadReady=!1,this.$nextTick(function(){e.uploadReady=!0})},change:function(e){for(var t=e.target,a=0;a0;t!==this.scrollingDown?(this.amountScrolled=0,this.scrollingDown=t,t||(this.hidden=!1)):t&&(this.amountScrolled+=e,this.amountScrolled>100&&!this.hidden&&(this.hidden=!0)),this.oldScrollPos=window.scrollY,this.scrollingDown=t},100)}};t.default=l},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(86),o=i(n),s={props:["userId"],data:function(){return{progress:!1}},computed:{user:function(){return this.$store.getters.userById(this.userId)},muted:function(){return this.user.muted}},components:{BasicUserCard:o.default},methods:{unmuteUser:function(){var e=this;this.progress=!0,this.$store.dispatch("unmuteUser",this.user.id).then(function(){e.progress=!1})},muteUser:function(){var e=this;this.progress=!0,this.$store.dispatch("muteUser",this.user.id).then(function(){e.progress=!1})}}};t.default=s},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(240),o=i(n),s={created:function(){if(this.currentUser&&this.currentUser.locked){var e=this.$store,t=e.state.users.currentUser.credentials;o.default.startFetching({store:e,credentials:t})}},computed:{currentUser:function(){return this.$store.state.users.currentUser},chat:function(){return this.$store.state.chat.channel},followRequestCount:function(){return this.$store.state.api.followRequests.length}}};t.default=s},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(87),o=i(n),s=a(88),r=i(s),l=a(43),c=i(l),u=a(137),d=a(35),p=i(d),f={data:function(){return{userExpanded:!1,betterShadow:this.$store.state.interface.browserSupport.cssFilter}},props:["notification"],components:{Status:o.default,UserAvatar:r.default,UserCard:c.default},methods:{toggleUserExpanded:function(){this.userExpanded=!this.userExpanded},userProfileLink:function(e){return(0,p.default)(e.id,e.screen_name,this.$store.state.instance.restrictedNicknames)}},computed:{userClass:function(){return(0,u.highlightClass)(this.notification.action.user)},userStyle:function(){var e=this.$store.state.config.highlight,t=this.notification.action.user;return(0,u.highlightStyle)(e[t.screen_name])}}};t.default=f},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(656),o=i(n),s=a(244),r=i(s),l=a(91),c={created:function(){var e=this.$store,t=e.state.users.currentUser.credentials,a=r.default.startFetching({store:e,credentials:t});this.$store.commit("setNotificationFetcher",{fetcherId:a})},data:function(){return{bottomedOut:!1}},computed:{notifications:function(){return(0,l.notificationsFromStore)(this.$store)},error:function(){return this.$store.state.statuses.notifications.error},unseenNotifications:function(){return(0,l.unseenNotificationsFromStore)(this.$store)},visibleNotifications:function(){return(0,l.visibleNotificationsFromStore)(this.$store)},unseenCount:function(){return this.unseenNotifications.length},loading:function(){return this.$store.state.statuses.notifications.loading}},components:{Notification:o.default},watch:{unseenCount:function(e){e>0?this.$store.dispatch("setPageTitle","("+e+")"):this.$store.dispatch("setPageTitle","")}},methods:{markAsSeen:function(){this.$store.dispatch("markNotificationsAsSeen",this.visibleNotifications)},fetchOlderNotifications:function(){var e=this,t=this.$store,a=t.state.users.currentUser.credentials;t.commit("setNotificationsLoading",{value:!0}),r.default.fetchAndUpdate({store:t,credentials:a,older:!0}).then(function(a){t.commit("setNotificationsLoading",{value:!1}),0===a.length&&(e.bottomedOut=!0)})}}};t.default=c},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(90),o=i(n),s={props:["code"],mounted:function(){var e=this;this.code&&o.default.getToken({app:this.$store.state.oauth,instance:this.$store.state.instance.server,code:this.code}).then(function(t){e.$store.commit("setToken",t.access_token),e.$store.dispatch("loginUser",t.access_token),e.$router.push({name:"friends"})})}};t.default=s},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(26),o=i(n),s=a(620),r=i(s),l=a(31),c=i(l),u=a(608),d=i(u),p=a(58),f=i(p),_=a(615),h=i(_),m=a(135),v=i(m),g=a(651),b=i(g),w=a(45),k=i(w),y=a(237),C=i(y),x=function(e,t){var a=e.user,i=e.attentions,n=[].concat((0,o.default)(i));n.unshift(a),n=(0,r.default)(n,"id"),n=(0,d.default)(n,{id:t.id});var s=(0,c.default)(n,function(e){return"@"+e.screen_name});return s.length>0?s.join(" ")+" ":""},S={props:["replyTo","repliedUser","attentions","copyMessageScope","subject"],components:{MediaUpload:b.default},mounted:function(){this.resize(this.$refs.textarea);var e=this.$refs.textarea.value.length;this.$refs.textarea.setSelectionRange(e,e),this.replyTo&&this.$refs.textarea.focus()},data:function(){var e=this.$route.query.message,t=e||"",a="undefined"==typeof this.$store.state.config.scopeCopy?this.$store.state.instance.scopeCopy:this.$store.state.config.scopeCopy;if(this.replyTo){var i=this.$store.state.users.currentUser;t=x({user:this.repliedUser,attentions:this.attentions},i)}var n=this.copyMessageScope&&a||"direct"===this.copyMessageScope?this.copyMessageScope:this.$store.state.users.currentUser.default_scope,o="undefined"==typeof this.$store.state.config.postContentType?this.$store.state.instance.postContentType:this.$store.state.config.postContentType;return{dropFiles:[],submitDisabled:!1,error:null,posting:!1,highlighted:0,newStatus:{spoilerText:this.subject||"",status:t,nsfw:!1,files:[],visibility:n,contentType:o},caret:0}},computed:{vis:function(){return{public:{selected:"public"===this.newStatus.visibility},unlisted:{selected:"unlisted"===this.newStatus.visibility},private:{selected:"private"===this.newStatus.visibility},direct:{selected:"direct"===this.newStatus.visibility}}},candidates:function(){var e=this,t=this.textAtCaret.charAt(0);if("@"===t){var a=this.textAtCaret.slice(1).toUpperCase(),i=(0,f.default)(this.users,function(e){return e.screen_name.toUpperCase().startsWith(a)||e.name&&e.name.toUpperCase().startsWith(a)});return!(i.length<=0)&&(0,c.default)((0,h.default)(i,5),function(t,a){var i=t.screen_name,n=t.name,o=t.profile_image_url_original;return{screen_name:"@"+i,name:n,img:o,highlighted:a===e.highlighted}})}if(":"===t){if(":"===this.textAtCaret)return;var n=(0,f.default)(this.emoji.concat(this.customEmoji),function(t){return t.shortcode.startsWith(e.textAtCaret.slice(1))});return!(n.length<=0)&&(0,c.default)((0,h.default)(n,5),function(t,a){var i=t.shortcode,n=t.image_url,o=t.utf;return{screen_name:":"+i+":",name:"",utf:o||"",img:o?"":e.$store.state.instance.server+n,highlighted:a===e.highlighted}})}return!1},textAtCaret:function(){return(this.wordAtCaret||{}).word||""},wordAtCaret:function(){var e=C.default.wordAtPosition(this.newStatus.status,this.caret-1)||{};return e},users:function(){return this.$store.state.users.users},emoji:function(){return this.$store.state.instance.emoji||[]},customEmoji:function(){return this.$store.state.instance.customEmoji||[]},statusLength:function(){return this.newStatus.status.length},spoilerTextLength:function(){return this.newStatus.spoilerText.length},statusLengthLimit:function(){return this.$store.state.instance.textlimit},hasStatusLengthLimit:function(){return this.statusLengthLimit>0},charactersLeft:function(){return this.statusLengthLimit-(this.statusLength+this.spoilerTextLength)},isOverLengthLimit:function(){return this.hasStatusLengthLimit&&this.charactersLeft<0},scopeOptionsEnabled:function(){return this.$store.state.instance.scopeOptionsEnabled},alwaysShowSubject:function(){return"undefined"!=typeof this.$store.state.config.alwaysShowSubjectInput?this.$store.state.config.alwaysShowSubjectInput:"undefined"!=typeof this.$store.state.instance.alwaysShowSubjectInput?this.$store.state.instance.alwaysShowSubjectInput:this.$store.state.instance.scopeOptionsEnabled},formattingOptionsEnabled:function(){return this.$store.state.instance.formattingOptionsEnabled},postFormats:function(){return this.$store.state.instance.postFormats||[]}},methods:{replace:function(e){this.newStatus.status=C.default.replaceWord(this.newStatus.status,this.wordAtCaret,e);var t=this.$el.querySelector("textarea");t.focus(),this.caret=0},replaceCandidate:function(e){var t=this.candidates.length||0;if(":"!==this.textAtCaret&&!e.ctrlKey&&t>0){e.preventDefault();var a=this.candidates[this.highlighted],i=a.utf||a.screen_name+" ";this.newStatus.status=C.default.replaceWord(this.newStatus.status,this.wordAtCaret,i);var n=this.$el.querySelector("textarea");n.focus(),this.caret=0,this.highlighted=0}},cycleBackward:function(e){var t=this.candidates.length||0;t>0?(e.preventDefault(),this.highlighted-=1,this.highlighted<0&&(this.highlighted=this.candidates.length-1)):this.highlighted=0},cycleForward:function(e){var t=this.candidates.length||0;if(t>0){if(e.shiftKey)return;e.preventDefault(),this.highlighted+=1,this.highlighted>=t&&(this.highlighted=0)}else this.highlighted=0},onKeydown:function(e){e.stopPropagation()},setCaret:function(e){var t=e.target.selectionStart;this.caret=t},postStatus:function(e){var t=this;if(!this.posting&&!this.submitDisabled){if(""===this.newStatus.status){if(!(this.newStatus.files.length>0))return void(this.error="Cannot post an empty status with no files");this.newStatus.status="​"}this.posting=!0,v.default.postStatus({status:e.status,spoilerText:e.spoilerText||null,visibility:e.visibility,sensitive:e.nsfw,media:e.files,store:this.$store,inReplyToStatusId:this.replyTo,contentType:e.contentType}).then(function(a){if(a.error)t.error=a.error;else{t.newStatus={status:"",spoilerText:"",files:[],visibility:e.visibility,contentType:e.contentType},t.$refs.mediaUpload.clearFile(),t.$emit("posted");var i=t.$el.querySelector("textarea");i.style.height="auto",i.style.height=void 0,t.error=null}t.posting=!1})}},addMediaFile:function(e){this.newStatus.files.push(e),this.enableSubmit()},removeMediaFile:function(e){var t=this.newStatus.files.indexOf(e);this.newStatus.files.splice(t,1)},uploadFailed:function(e,t){t=t||{},this.error=this.$t("upload.error.base")+" "+this.$t("upload.error."+e,t),this.enableSubmit()},disableSubmit:function(){this.submitDisabled=!0},enableSubmit:function(){this.submitDisabled=!1},type:function(e){return k.default.fileType(e.mimetype)},paste:function(e){e.clipboardData.files.length>0&&(this.dropFiles=[e.clipboardData.files[0]])},fileDrop:function(e){e.dataTransfer.files.length>0&&(e.preventDefault(),this.dropFiles=e.dataTransfer.files)},fileDrag:function(e){e.dataTransfer.dropEffect="copy"},resize:function(e){var t=e.target||e;if(t instanceof window.Element){var a=Number(window.getComputedStyle(t)["padding-top"].substr(0,1))+Number(window.getComputedStyle(t)["padding-bottom"].substr(0,1));t.style.height="auto",t.style.height=t.scrollHeight-a+"px",""===t.value&&(t.style.height=null)}},clearError:function(){this.error=null},changeVis:function(e){this.newStatus.visibility=e}}};t.default=S},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(34),o=i(n),s={components:{Timeline:o.default},computed:{timeline:function(){return this.$store.state.statuses.timelines.publicAndExternal}},created:function(){this.$store.dispatch("startFetching",{timeline:"publicAndExternal"})},destroyed:function(){this.$store.dispatch("stopFetching","publicAndExternal")}};t.default=s},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(34),o=i(n),s={components:{Timeline:o.default},computed:{timeline:function(){return this.$store.state.statuses.timelines.public}},created:function(){this.$store.dispatch("startFetching",{timeline:"public"})},destroyed:function(){this.$store.dispatch("stopFetching","public")}};t.default=s},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(141),o=i(n),s=a(139),r=i(s),l=a(37),c=i(l),u=a(742),d=a(749),p=a(219),f={mixins:[u.validationMixin],data:function(){return{user:{email:"",fullname:"",username:"",password:"",confirm:""},captcha:{}}},validations:{user:{email:{required:d.required},username:{required:d.required},fullname:{required:d.required},password:{required:d.required},confirm:{required:d.required,sameAsPassword:(0,d.sameAs)("password")}}},created:function(){(!this.registrationOpen&&!this.token||this.signedIn)&&this.$router.push({name:"root"}),this.setCaptcha()},computed:(0,c.default)({token:function(){return this.$route.params.token}},(0,p.mapState)({registrationOpen:function(e){return e.instance.registrationOpen},signedIn:function(e){return!!e.users.currentUser},isPending:function(e){return e.users.signUpPending},serverValidationErrors:function(e){return e.users.signUpErrors},termsOfService:function(e){return e.instance.tos}})),methods:(0,c.default)({},(0,p.mapActions)(["signUp","getCaptcha"]),{submit:function(){function e(){return t.apply(this,arguments)}var t=(0,r.default)(o.default.mark(function e(){return o.default.wrap(function(e){for(;;)switch(e.prev=e.next){case 0:if(this.user.nickname=this.user.username,this.user.token=this.token,this.user.captcha_solution=this.captcha.solution,this.user.captcha_token=this.captcha.token,this.user.captcha_answer_data=this.captcha.answer_data,this.$v.$touch(),this.$v.$invalid){e.next=16;break}return e.prev=7,e.next=10,this.signUp(this.user);case 10:this.$router.push({name:"friends"}),e.next=16;break;case 13:e.prev=13,e.t0=e.catch(7),console.warn("Registration failed: "+e.t0);case 16:case"end":return e.stop()}},e,this,[[7,13]])}));return e}(),setCaptcha:function(){var e=this;this.getCaptcha().then(function(t){e.captcha=t})}})};t.default=f},function(e,t){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var a={props:["status","loggedIn","visibility"],data:function(){return{hidePostStatsLocal:"undefined"==typeof this.$store.state.config.hidePostStats?this.$store.state.instance.hidePostStats:this.$store.state.config.hidePostStats,animated:!1}},methods:{retweet:function(){var e=this;this.status.repeated?this.$store.dispatch("unretweet",{id:this.status.id}):this.$store.dispatch("retweet",{id:this.status.id}),this.animated=!0,setTimeout(function(){e.animated=!1},500)}},computed:{classes:function(){ +return{retweeted:this.status.repeated,"retweeted-empty":!this.status.repeated,"animate-spin":this.animated}}}};t.default=a},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(313),o=i(n),s=a(619),r=i(s),l=a(58),c=i(l),u=a(89),d=i(u),p=a(215),f=i(p),_=a(648),h=i(_),m={data:function(){var e=this.$store.state.config,t=this.$store.state.instance;return{hideAttachmentsLocal:e.hideAttachments,hideAttachmentsInConvLocal:e.hideAttachmentsInConv,maxThumbnails:e.maxThumbnails,hideNsfwLocal:e.hideNsfw,useOneClickNsfw:e.useOneClickNsfw,hideISPLocal:e.hideISP,preloadImage:e.preloadImage,hidePostStatsLocal:"undefined"==typeof e.hidePostStats?t.hidePostStats:e.hidePostStats,hidePostStatsDefault:this.$t("settings.values."+t.hidePostStats),hideUserStatsLocal:"undefined"==typeof e.hideUserStats?t.hideUserStats:e.hideUserStats,hideUserStatsDefault:this.$t("settings.values."+t.hideUserStats),hideFilteredStatusesLocal:"undefined"==typeof e.hideFilteredStatuses?t.hideFilteredStatuses:e.hideFilteredStatuses,hideFilteredStatusesDefault:this.$t("settings.values."+t.hideFilteredStatuses),notificationVisibilityLocal:e.notificationVisibility,replyVisibilityLocal:e.replyVisibility,loopVideoLocal:e.loopVideo,muteWordsString:e.muteWords.join("\n"),autoLoadLocal:e.autoLoad,streamingLocal:e.streaming,pauseOnUnfocusedLocal:e.pauseOnUnfocused,hoverPreviewLocal:e.hoverPreview,collapseMessageWithSubjectLocal:"undefined"==typeof e.collapseMessageWithSubject?t.collapseMessageWithSubject:e.collapseMessageWithSubject,collapseMessageWithSubjectDefault:this.$t("settings.values."+t.collapseMessageWithSubject),subjectLineBehaviorLocal:"undefined"==typeof e.subjectLineBehavior?t.subjectLineBehavior:e.subjectLineBehavior,subjectLineBehaviorDefault:t.subjectLineBehavior,postContentTypeLocal:"undefined"==typeof e.postContentType?t.postContentType:e.postContentType,postContentTypeDefault:t.postContentType,alwaysShowSubjectInputLocal:"undefined"==typeof e.alwaysShowSubjectInput?t.alwaysShowSubjectInput:e.alwaysShowSubjectInput,alwaysShowSubjectInputDefault:t.alwaysShowSubjectInput,scopeCopyLocal:"undefined"==typeof e.scopeCopy?t.scopeCopy:e.scopeCopy,scopeCopyDefault:this.$t("settings.values."+t.scopeCopy),stopGifs:e.stopGifs,webPushNotificationsLocal:e.webPushNotifications,loopVideoSilentOnlyLocal:e.loopVideosSilentOnly,loopSilentAvailable:(0,o.default)(HTMLVideoElement.prototype,"mozHasAudio")||(0,o.default)(HTMLMediaElement.prototype,"webkitAudioDecodedByteCount")||(0,o.default)(HTMLMediaElement.prototype,"audioTracks"),playVideosInModal:e.playVideosInModal,useContainFit:e.useContainFit}},components:{TabSwitcher:d.default,StyleSwitcher:f.default,InterfaceLanguageSwitcher:h.default},computed:{user:function(){return this.$store.state.users.currentUser},currentSaveStateNotice:function(){return this.$store.state.interface.settings.currentSaveStateNotice},postFormats:function(){return this.$store.state.instance.postFormats||[]},instanceSpecificPanelPresent:function(){return this.$store.state.instance.showInstanceSpecificPanel}},watch:{hideAttachmentsLocal:function(e){this.$store.dispatch("setOption",{name:"hideAttachments",value:e})},hideAttachmentsInConvLocal:function(e){this.$store.dispatch("setOption",{name:"hideAttachmentsInConv",value:e})},hidePostStatsLocal:function(e){this.$store.dispatch("setOption",{name:"hidePostStats",value:e})},hideUserStatsLocal:function(e){this.$store.dispatch("setOption",{name:"hideUserStats",value:e})},hideFilteredStatusesLocal:function(e){this.$store.dispatch("setOption",{name:"hideFilteredStatuses",value:e})},hideNsfwLocal:function(e){this.$store.dispatch("setOption",{name:"hideNsfw",value:e})},useOneClickNsfw:function(e){this.$store.dispatch("setOption",{name:"useOneClickNsfw",value:e})},preloadImage:function(e){this.$store.dispatch("setOption",{name:"preloadImage",value:e})},hideISPLocal:function(e){this.$store.dispatch("setOption",{name:"hideISP",value:e})},"notificationVisibilityLocal.likes":function(e){this.$store.dispatch("setOption",{name:"notificationVisibility",value:this.$store.state.config.notificationVisibility})},"notificationVisibilityLocal.follows":function(e){this.$store.dispatch("setOption",{name:"notificationVisibility",value:this.$store.state.config.notificationVisibility})},"notificationVisibilityLocal.repeats":function(e){this.$store.dispatch("setOption",{name:"notificationVisibility",value:this.$store.state.config.notificationVisibility})},"notificationVisibilityLocal.mentions":function(e){this.$store.dispatch("setOption",{name:"notificationVisibility",value:this.$store.state.config.notificationVisibility})},replyVisibilityLocal:function(e){this.$store.dispatch("setOption",{name:"replyVisibility",value:e})},loopVideoLocal:function(e){this.$store.dispatch("setOption",{name:"loopVideo",value:e})},loopVideoSilentOnlyLocal:function(e){this.$store.dispatch("setOption",{name:"loopVideoSilentOnly",value:e})},autoLoadLocal:function(e){this.$store.dispatch("setOption",{name:"autoLoad",value:e})},streamingLocal:function(e){this.$store.dispatch("setOption",{name:"streaming",value:e})},pauseOnUnfocusedLocal:function(e){this.$store.dispatch("setOption",{name:"pauseOnUnfocused",value:e})},hoverPreviewLocal:function(e){this.$store.dispatch("setOption",{name:"hoverPreview",value:e})},muteWordsString:function(e){e=(0,c.default)(e.split("\n"),function(e){return(0,r.default)(e).length>0}),this.$store.dispatch("setOption",{name:"muteWords",value:e})},collapseMessageWithSubjectLocal:function(e){this.$store.dispatch("setOption",{name:"collapseMessageWithSubject",value:e})},scopeCopyLocal:function(e){this.$store.dispatch("setOption",{name:"scopeCopy",value:e})},alwaysShowSubjectInputLocal:function(e){this.$store.dispatch("setOption",{name:"alwaysShowSubjectInput",value:e})},subjectLineBehaviorLocal:function(e){this.$store.dispatch("setOption",{name:"subjectLineBehavior",value:e})},postContentTypeLocal:function(e){this.$store.dispatch("setOption",{name:"postContentType",value:e})},stopGifs:function(e){this.$store.dispatch("setOption",{name:"stopGifs",value:e})},webPushNotificationsLocal:function(e){this.$store.dispatch("setOption",{name:"webPushNotifications",value:e}),e&&this.$store.dispatch("registerPushNotifications")},playVideosInModal:function(e){this.$store.dispatch("setOption",{name:"playVideosInModal",value:e})},useContainFit:function(e){this.$store.dispatch("setOption",{name:"useContainFit",value:e})},maxThumbnails:function(e){e=this.maxThumbnails=Math.floor(Math.max(e,0)),this.$store.dispatch("setOption",{name:"maxThumbnails",value:e})}}};t.default=m},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(36),o=i(n),s=a(208),r=i(s),l=a(214),c=i(l),u=a(63),d=a(44);t.default={props:["value","fallback","ready"],data:function(){return{selectedId:0,cValue:this.value||this.fallback||[]}},components:{ColorInput:r.default,OpacityInput:c.default},methods:{add:function(){this.cValue.push((0,o.default)({},this.selected)),this.selectedId=this.cValue.length-1},del:function(){this.cValue.splice(this.selectedId,1),this.selectedId=0===this.cValue.length?void 0:this.selectedId-1},moveUp:function(){var e=this.cValue.splice(this.selectedId,1)[0];this.cValue.splice(this.selectedId-1,0,e),this.selectedId-=1},moveDn:function(){var e=this.cValue.splice(this.selectedId,1)[0];this.cValue.splice(this.selectedId+1,0,e),this.selectedId+=1}},beforeUpdate:function(){this.cValue=this.value||this.fallback},computed:{selected:function(){return this.ready&&this.cValue.length>0?this.cValue[this.selectedId]:{x:0,y:0,blur:0,spread:0,inset:!1,color:"#000000",alpha:1}},moveUpValid:function(){return this.ready&&this.selectedId>0},moveDnValid:function(){return this.ready&&this.selectedId0)},hideFilteredStatuses:function(){return"undefined"==typeof this.$store.state.config.hideFilteredStatuses?this.$store.state.instance.hideFilteredStatuses:this.$store.state.config.hideFilteredStatuses},hideStatus:function(){return this.hideReply||this.deleted||this.muted&&this.hideFilteredStatuses},isFocused:function(){return!!this.focused||!!this.inConversation&&this.status.id===this.highlight},tallStatus:function(){var e=this.status.statusnet_html.split(/20},longSubject:function(){return this.status.summary.length>900},isReply:function(){return!(!this.status.in_reply_to_status_id||!this.status.in_reply_to_user_id)},replyToName:function(){var e=this.$store.state.users.usersObject[this.status.in_reply_to_user_id];return e?e.screen_name:this.status.in_reply_to_screen_name},hideReply:function(){if("all"===this.$store.state.config.replyVisibility)return!1;if(this.inlineExpanded||this.expanded||this.inConversation||!this.isReply)return!1;if(this.status.user.id===this.$store.state.users.currentUser.id)return!1;if("retweet"===this.status.type)return!1;for(var e="following"===this.$store.state.config.replyVisibility,t=0;t0},hideSubjectStatus:function(){return!(this.tallStatus&&!this.localCollapseSubjectDefault)&&(!this.expandingSubject&&this.status.summary)},hideTallStatus:function(){return(!this.status.summary||!this.localCollapseSubjectDefault)&&(!this.showingTall&&this.tallStatus)},showingMore:function(){return this.tallStatus&&this.showingTall||this.status.summary&&this.expandingSubject},nsfwClickthrough:function(){return!!this.status.nsfw&&(!this.status.summary||!this.localCollapseSubjectDefault)},replySubject:function(){if(!this.status.summary)return"";var e=(0,o.default)(this.status.summary),t="undefined"==typeof this.$store.state.config.subjectLineBehavior?this.$store.state.instance.subjectLineBehavior:this.$store.state.config.subjectLineBehavior,a=e.match(/^re[: ]/i);return"noop"!==t&&a||"masto"===t?e:"email"===t?"re: ".concat(e):"noop"===t?"":void 0},attachmentSize:function(){return this.$store.state.config.hideAttachments&&!this.inConversation||this.$store.state.config.hideAttachmentsInConv&&this.inConversation||this.status.attachments.length>this.maxThumbnails?"hide":this.compact?"small":"normal"},galleryTypes:function(){return"hide"===this.attachmentSize?[]:this.$store.state.config.playVideosInModal?["image","video"]:["image"]},galleryAttachments:function(){var e=this;return this.status.attachments.filter(function(t){return T.default.fileMatchesSomeType(e.galleryTypes,t)})},nonGalleryAttachments:function(){var e=this;return this.status.attachments.filter(function(t){return!T.default.fileMatchesSomeType(e.galleryTypes,t)})},maxThumbnails:function(){return this.$store.state.config.maxThumbnails}},components:{Attachment:d.default,FavoriteButton:f.default,RetweetButton:h.default,DeleteButton:v.default,PostStatusForm:b.default,UserCard:k.default,UserAvatar:C.default,Gallery:S.default,LinkPreview:P.default},methods:{visibilityIcon:function(e){switch(e){case"private":return"icon-lock";case"unlisted":return"icon-lock-open-alt";case"direct":return"icon-mail-alt";default:return"icon-globe"}},linkClicked:function(e){var t=e.target;if("SPAN"===t.tagName&&(t=t.parentNode),"A"===t.tagName){if(t.className.match(/mention/)){var a=t.href,i=this.status.attentions.find(function(e){return(0,z.mentionMatchesUrl)(e,a)});if(i){e.stopPropagation(),e.preventDefault();var n=this.generateUserProfileLink(i.id,i.screen_name);return void this.$router.push(n)}}if(t.className.match(/hashtag/)){var o=(0,z.extractTagFromUrl)(t.href);if(o){var s=this.generateTagLink(o);return void this.$router.push(s)}}window.open(t.href,"_blank")}},toggleReplying:function(){this.replying=!this.replying},gotoOriginal:function(e){this.inConversation&&this.$emit("goto",e)},toggleExpanded:function(){this.$emit("toggleExpanded")},toggleMute:function(){this.unmuted=!this.unmuted},toggleUserExpanded:function(){this.userExpanded=!this.userExpanded},toggleShowMore:function(){this.showingTall?this.showingTall=!1:this.expandingSubject&&this.status.summary?this.expandingSubject=!1:this.hideTallStatus?this.showingTall=!0:this.hideSubjectStatus&&this.status.summary&&(this.expandingSubject=!0)},replyEnter:function(e,t){var a=this;this.showPreview=!0;var i=e,n=this.$store.state.statuses.allStatuses;this.preview?this.preview.id!==i&&(this.preview=(0,r.default)(n,{id:i})):(this.preview=(0,r.default)(n,{id:i}),this.preview||this.$store.state.api.backendInteractor.fetchStatus({id:e}).then(function(e){a.preview=e}))},replyLeave:function(){this.showPreview=!1},generateUserProfileLink:function(e,t){return(0,$.default)(e,t,this.$store.state.instance.restrictedNicknames)},generateTagLink:function(e){return"/tag/"+e},setMedia:function(){var e=this,t="hide"===this.attachmentSize?this.status.attachments:this.galleryAttachments;return function(){return e.$store.dispatch("setMedia",t)}}},watch:{highlight:function(e){if(this.status.id===e){var t=this.$el.getBoundingClientRect();t.top<100?window.scrollBy(0,t.top-100):t.height>=window.innerHeight-50?window.scrollBy(0,t.top-100):t.bottom>window.innerHeight-50&&window.scrollBy(0,t.bottom-window.innerHeight+50)}}},filters:{capitalize:function(e){return e.charAt(0).toUpperCase()+e.slice(1)}}};t.default=F},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(87),o=i(n),s=a(209),r=i(s),l={props:["statusoid"],data:function(){return{expanded:!1}},components:{Status:o.default,Conversation:r.default},methods:{toggleExpanded:function(){this.expanded=!this.expanded}}};t.default=l},function(e,t){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var a={props:["src","referrerpolicy","mimetype","imageLoadError"],data:function(){return{stopGifs:this.$store.state.config.stopGifs}},computed:{animated:function(){return this.stopGifs&&("image/gif"===this.mimetype||this.src.endsWith(".gif"))}},methods:{onLoad:function(){var e=this.$refs.canvas;if(e){var t=this.$refs.src.naturalWidth,a=this.$refs.src.naturalHeight;e.width=t,e.height=a,e.getContext("2d").drawImage(this.$refs.src,0,0,t,a)}},onError:function(){this.imageLoadError&&this.imageLoadError()}}};t.default=a},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(65),o=i(n),s=a(138),r=i(s),l=a(36),c=i(l),u=a(24),d=i(u),p=a(314),f=i(p),_=a(26),h=i(_),m=a(9),v=i(m),g=a(23),b=i(g),w=a(44),k=a(8),y=a(63),C=a(208),x=i(C),S=a(660),j=i(S),P=a(214),L=i(P),$=a(664),A=i($),T=a(644),I=i(T),z=a(636),F=i(z),N=a(89),O=i(N),R=a(667),M=i(R),B=a(640),E=i(B),U=["bg","fg","text","link","cRed","cGreen","cBlue","cOrange"].map(function(e){return e+"ColorLocal"});t.default={data:function(){return{availableStyles:[],selected:this.$store.state.config.theme,previewShadows:{},previewColors:{},previewRadii:{},previewFonts:{},shadowsInvalid:!0,colorsInvalid:!0,radiiInvalid:!0,keepColor:!1,keepShadows:!1,keepOpacity:!1,keepRoundness:!1,keepFonts:!1,textColorLocal:"",linkColorLocal:"",bgColorLocal:"",bgOpacityLocal:void 0,fgColorLocal:"",fgTextColorLocal:void 0,fgLinkColorLocal:void 0,btnColorLocal:void 0,btnTextColorLocal:void 0,btnOpacityLocal:void 0,inputColorLocal:void 0,inputTextColorLocal:void 0,inputOpacityLocal:void 0,panelColorLocal:void 0,panelTextColorLocal:void 0,panelLinkColorLocal:void 0,panelFaintColorLocal:void 0,panelOpacityLocal:void 0,topBarColorLocal:void 0,topBarTextColorLocal:void 0,topBarLinkColorLocal:void 0,alertErrorColorLocal:void 0,badgeOpacityLocal:void 0,badgeNotificationColorLocal:void 0,borderColorLocal:void 0,borderOpacityLocal:void 0,faintColorLocal:void 0,faintOpacityLocal:void 0,faintLinkColorLocal:void 0,cRedColorLocal:"",cBlueColorLocal:"",cGreenColorLocal:"",cOrangeColorLocal:"",shadowSelected:void 0,shadowsLocal:{},fontsLocal:{},btnRadiusLocal:"",inputRadiusLocal:"",checkboxRadiusLocal:"",panelRadiusLocal:"",avatarRadiusLocal:"",avatarAltRadiusLocal:"",attachmentRadiusLocal:"",tooltipRadiusLocal:""}},created:function(){var e=this;(0,y.getThemes)().then(function(t){e.availableStyles=t})},mounted:function(){this.normalizeLocalState(this.$store.state.config.customTheme),"undefined"==typeof this.shadowSelected&&(this.shadowSelected=this.shadowsAvailable[0])},computed:{selectedVersion:function(){return Array.isArray(this.selected)?1:2},currentColors:function(){return{bg:this.bgColorLocal,text:this.textColorLocal,link:this.linkColorLocal,fg:this.fgColorLocal,fgText:this.fgTextColorLocal,fgLink:this.fgLinkColorLocal,panel:this.panelColorLocal,panelText:this.panelTextColorLocal,panelLink:this.panelLinkColorLocal,panelFaint:this.panelFaintColorLocal,input:this.inputColorLocal,inputText:this.inputTextColorLocal,topBar:this.topBarColorLocal,topBarText:this.topBarTextColorLocal,topBarLink:this.topBarLinkColorLocal,btn:this.btnColorLocal,btnText:this.btnTextColorLocal,alertError:this.alertErrorColorLocal,badgeNotification:this.badgeNotificationColorLocal,faint:this.faintColorLocal,faintLink:this.faintLinkColorLocal,border:this.borderColorLocal,cRed:this.cRedColorLocal,cBlue:this.cBlueColorLocal,cGreen:this.cGreenColorLocal,cOrange:this.cOrangeColorLocal}},currentOpacity:function(){return{bg:this.bgOpacityLocal,btn:this.btnOpacityLocal,input:this.inputOpacityLocal,panel:this.panelOpacityLocal,topBar:this.topBarOpacityLocal,border:this.borderOpacityLocal,faint:this.faintOpacityLocal}},currentRadii:function(){return{btn:this.btnRadiusLocal,input:this.inputRadiusLocal,checkbox:this.checkboxRadiusLocal,panel:this.panelRadiusLocal,avatar:this.avatarRadiusLocal,avatarAlt:this.avatarAltRadiusLocal,tooltip:this.tooltipRadiusLocal,attachment:this.attachmentRadiusLocal}},preview:function(){return(0,y.composePreset)(this.previewColors,this.previewRadii,this.previewShadows,this.previewFonts)},previewTheme:function(){return this.preview.theme.colors?this.preview.theme:{colors:{},opacity:{},radii:{},shadows:{},fonts:{}}},previewContrast:function(){if(!this.previewTheme.colors.bg)return{};var e=this.previewTheme.colors,t=this.previewTheme.opacity;if(!e.bg)return{};var a=function(e){return{text:e.toPrecision(3)+":1",aa:e>=4.5,aaa:e>=7,laa:e>=3,laaa:e>=4.5}},i={text:(0,w.hex2rgb)(e.text),panelText:(0,w.hex2rgb)(e.panelText),panelLink:(0,w.hex2rgb)(e.panelLink),btnText:(0,w.hex2rgb)(e.btnText),topBarText:(0,w.hex2rgb)(e.topBarText),inputText:(0,w.hex2rgb)(e.inputText),link:(0,w.hex2rgb)(e.link),topBarLink:(0,w.hex2rgb)(e.topBarLink),red:(0,w.hex2rgb)(e.cRed),green:(0,w.hex2rgb)(e.cGreen),blue:(0,w.hex2rgb)(e.cBlue),orange:(0,w.hex2rgb)(e.cOrange)},n={bg:(0,w.hex2rgb)(e.bg),btn:(0,w.hex2rgb)(e.btn),panel:(0,w.hex2rgb)(e.panel),topBar:(0,w.hex2rgb)(e.topBar),input:(0,w.hex2rgb)(e.input),alertError:(0,w.hex2rgb)(e.alertError),badgeNotification:(0,w.hex2rgb)(e.badgeNotification)},o={bgText:(0,w.getContrastRatio)((0,w.alphaBlend)(n.bg,t.bg,i.text),i.text),bgLink:(0,w.getContrastRatio)((0,w.alphaBlend)(n.bg,t.bg,i.link),i.link),bgRed:(0,w.getContrastRatio)((0,w.alphaBlend)(n.bg,t.bg,i.red),i.red),bgGreen:(0,w.getContrastRatio)((0,w.alphaBlend)(n.bg,t.bg,i.green),i.green),bgBlue:(0,w.getContrastRatio)((0,w.alphaBlend)(n.bg,t.bg,i.blue),i.blue),bgOrange:(0,w.getContrastRatio)((0,w.alphaBlend)(n.bg,t.bg,i.orange),i.orange),tintText:(0,w.getContrastRatio)((0,w.alphaBlend)(n.bg,.5,i.panelText),i.text),panelText:(0,w.getContrastRatio)((0,w.alphaBlend)(n.panel,t.panel,i.panelText),i.panelText),panelLink:(0,w.getContrastRatio)((0,w.alphaBlend)(n.panel,t.panel,i.panelLink),i.panelLink),btnText:(0,w.getContrastRatio)((0,w.alphaBlend)(n.btn,t.btn,i.btnText),i.btnText),inputText:(0,w.getContrastRatio)((0,w.alphaBlend)(n.input,t.input,i.inputText),i.inputText),topBarText:(0,w.getContrastRatio)((0,w.alphaBlend)(n.topBar,t.topBar,i.topBarText),i.topBarText),topBarLink:(0,w.getContrastRatio)((0,w.alphaBlend)(n.topBar,t.topBar,i.topBarLink),i.topBarLink)};return(0,b.default)(o).reduce(function(e,t){var i=(0,v.default)(t,2),n=i[0],o=i[1];return e[n]=a(o),e},{})},previewRules:function(){return this.preview.rules?[].concat((0,h.default)((0,f.default)(this.preview.rules)),["color: var(--text)","font-family: var(--interfaceFont, sans-serif)"]).join(";"):""},shadowsAvailable:function(){return(0,d.default)(this.previewTheme.shadows).sort()},currentShadowOverriden:{get:function(){return!!this.currentShadow},set:function(e){e?(0,k.set)(this.shadowsLocal,this.shadowSelected,this.currentShadowFallback.map(function(e){return(0,c.default)({},e)})):(0,k.delete)(this.shadowsLocal,this.shadowSelected)}},currentShadowFallback:function(){return this.previewTheme.shadows[this.shadowSelected]},currentShadow:{get:function(){return this.shadowsLocal[this.shadowSelected]},set:function(e){(0,k.set)(this.shadowsLocal,this.shadowSelected,e)}},themeValid:function(){return!this.shadowsInvalid&&!this.colorsInvalid&&!this.radiiInvalid},exportedTheme:function(){var e=!(this.keepFonts||this.keepShadows||this.keepOpacity||this.keepRoundness||this.keepColor),t={};return(this.keepFonts||e)&&(t.fonts=this.fontsLocal),(this.keepShadows||e)&&(t.shadows=this.shadowsLocal),(this.keepOpacity||e)&&(t.opacity=this.currentOpacity),(this.keepColor||e)&&(t.colors=this.currentColors),(this.keepRoundness||e)&&(t.radii=this.currentRadii),{_pleroma_theme_version:2,theme:t}}},components:{ColorInput:x.default,OpacityInput:L.default,RangeInput:j.default,ContrastRatio:F.default,ShadowControl:A.default,FontControl:I.default,TabSwitcher:O.default,Preview:M.default,ExportImport:E.default},methods:{setCustomTheme:function(){this.$store.dispatch("setOption",{name:"customTheme",value:{shadows:this.shadowsLocal,fonts:this.fontsLocal,opacity:this.currentOpacity,colors:this.currentColors,radii:this.currentRadii}})},onImport:function(e){1===e._pleroma_theme_version?this.normalizeLocalState(e,1):2===e._pleroma_theme_version&&this.normalizeLocalState(e.theme,2)},importValidator:function(e){var t=e._pleroma_theme_version;return t>=1||t<=2},clearAll:function(){var e=this.$store.state.config.customTheme,t=e.colors?2:"l1";this.normalizeLocalState(this.$store.state.config.customTheme,t)},clearV1:function(){var e=this;(0,d.default)(this.$data).filter(function(e){return e.endsWith("ColorLocal")||e.endsWith("OpacityLocal")}).filter(function(e){return!U.includes(e)}).forEach(function(t){(0,k.set)(e.$data,t,void 0)})},clearRoundness:function(){var e=this;(0,d.default)(this.$data).filter(function(e){return e.endsWith("RadiusLocal")}).forEach(function(t){(0,k.set)(e.$data,t,void 0)})},clearOpacity:function(){var e=this;(0,d.default)(this.$data).filter(function(e){return e.endsWith("OpacityLocal")}).forEach(function(t){(0,k.set)(e.$data,t,void 0)})},clearShadows:function(){this.shadowsLocal={}},clearFonts:function(){this.fontsLocal={}},normalizeLocalState:function(e){var t=this,a=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,i=e.colors||e,n=e.radii||e,s=e.opacity,l=e.shadows||{},c=e.fonts||{};if(0===a&&(e.version&&(a=e.version),"undefined"==typeof i.text&&"undefined"!=typeof i.fg&&(a=1),"undefined"!=typeof i.text&&"undefined"!=typeof i.fg&&(a=2)),1===a&&(this.fgColorLocal=(0,w.rgb2hex)(i.btn),this.textColorLocal=(0,w.rgb2hex)(i.fg)),!this.keepColor){this.clearV1();var u=new r.default(1!==a?(0,d.default)(i):[]);1!==a&&"l1"!==a||u.add("bg").add("link").add("cRed").add("cBlue").add("cGreen").add("cOrange"),u.forEach(function(e){t[e+"ColorLocal"]=(0,w.rgb2hex)(i[e])})}this.keepRoundness||(this.clearRoundness(),(0,b.default)(n).forEach(function(e){var a=(0,v.default)(e,2),i=a[0],n=a[1],o=i.endsWith("Radius")?i.split("Radius")[0]:i;t[o+"RadiusLocal"]=n})),this.keepShadows||(this.clearShadows(),this.shadowsLocal=l,this.shadowSelected=this.shadowsAvailable[0]),this.keepFonts||(this.clearFonts(),this.fontsLocal=c),s&&!this.keepOpacity&&(this.clearOpacity(),(0,b.default)(s).forEach(function(e){var a=(0,v.default)(e,2),i=a[0],n=a[1];"undefined"==typeof n||null===n||(0,o.default)(n)||(t[i+"OpacityLocal"]=n)}))}},watch:{currentRadii:function(){try{this.previewRadii=(0,y.generateRadii)({radii:this.currentRadii}),this.radiiInvalid=!1}catch(e){this.radiiInvalid=!0,console.warn(e)}},shadowsLocal:{handler:function(){try{this.previewShadows=(0,y.generateShadows)({shadows:this.shadowsLocal}),this.shadowsInvalid=!1}catch(e){this.shadowsInvalid=!0,console.warn(e)}},deep:!0},fontsLocal:{handler:function(){try{this.previewFonts=(0,y.generateFonts)({fonts:this.fontsLocal}),this.fontsInvalid=!1}catch(e){this.fontsInvalid=!0,console.warn(e)}},deep:!0},currentColors:function(){try{this.previewColors=(0,y.generateColors)({opacity:this.currentOpacity,colors:this.currentColors}),this.colorsInvalid=!1}catch(e){this.colorsInvalid=!0,console.warn(e)}},currentOpacity:function(){try{this.previewColors=(0,y.generateColors)({opacity:this.currentOpacity,colors:this.currentColors})}catch(e){console.warn(e)}},selected:function(){1===this.selectedVersion?(this.keepRoundness||this.clearRoundness(),this.keepShadows||this.clearShadows(),this.keepOpacity||this.clearOpacity(),this.keepColor||(this.clearV1(),this.bgColorLocal=this.selected[1],this.fgColorLocal=this.selected[2],this.textColorLocal=this.selected[3],this.linkColorLocal=this.selected[4],this.cRedColorLocal=this.selected[5],this.cGreenColorLocal=this.selected[6],this.cBlueColorLocal=this.selected[7],this.cOrangeColorLocal=this.selected[8])):this.selectedVersion>=2&&this.normalizeLocalState(this.selected.theme,2)}}}},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(34),o=i(n),s={created:function(){this.$store.commit("clearTimeline",{timeline:"tag"}),this.$store.dispatch("startFetching",{timeline:"tag",tag:this.tag})},components:{Timeline:o.default},computed:{tag:function(){return this.$route.params.tag},timeline:function(){return this.$store.state.statuses.timelines.tag}},watch:{tag:function(){this.$store.commit("clearTimeline",{timeline:"tag"}),this.$store.dispatch("startFetching",{timeline:"tag",tag:this.tag})}},destroyed:function(){this.$store.dispatch("stopFetching","tag")}};t.default=s},function(e,t){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var a={computed:{content:function(){return this.$store.state.instance.tos}}};t.default=a},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(201),o=i(n),s=a(87),r=i(s),l=a(136),c=i(l),u=a(666),d=i(u),p={props:["timeline","timelineName","title","userId","tag","embedded","count"],data:function(){return{paused:!1,unfocused:!1,bottomedOut:!1}},computed:{timelineError:function(){return this.$store.state.statuses.error},newStatusCount:function(){return this.timeline.newStatusCount},newStatusCountStr:function(){return 0!==this.timeline.flushMarker?"":" ("+this.newStatusCount+")"},classes:function(){return{root:["timeline"].concat(this.embedded?[]:["panel","panel-default"]),header:["timeline-heading"].concat(this.embedded?[]:["panel-heading"]),body:["timeline-body"].concat(this.embedded?[]:["panel-body"]),footer:["timeline-footer"].concat(this.embedded?[]:["panel-footer"])}}},components:{Status:r.default,StatusOrConversation:d.default},created:function(){var e=this.$store,t=e.state.users.currentUser.credentials,a=0===this.timeline.visibleStatuses.length; +return window.addEventListener("scroll",this.scrollLoad),!("friends"===this.timelineName&&!t)&&void c.default.fetchAndUpdate({store:e,credentials:t,timeline:this.timelineName,showImmediately:a,userId:this.userId,tag:this.tag})},mounted:function(){"undefined"!=typeof document.hidden&&(document.addEventListener("visibilitychange",this.handleVisibilityChange,!1),this.unfocused=document.hidden),window.addEventListener("keydown",this.handleShortKey)},destroyed:function(){window.removeEventListener("scroll",this.scrollLoad),window.removeEventListener("keydown",this.handleShortKey),"undefined"!=typeof document.hidden&&document.removeEventListener("visibilitychange",this.handleVisibilityChange,!1),this.$store.commit("setLoading",{timeline:this.timelineName,value:!1})},methods:{handleShortKey:function(e){"."===e.key&&this.showNewStatuses()},showNewStatuses:function(){0!==this.newStatusCount&&(0!==this.timeline.flushMarker?(this.$store.commit("clearTimeline",{timeline:this.timelineName}),this.$store.commit("queueFlush",{timeline:this.timelineName,id:0}),this.fetchOlderStatuses()):(this.$store.commit("showNewStatuses",{timeline:this.timelineName}),this.paused=!1))},fetchOlderStatuses:(0,o.default)(function(){var e=this,t=this.$store,a=t.state.users.currentUser.credentials;t.commit("setLoading",{timeline:this.timelineName,value:!0}),c.default.fetchAndUpdate({store:t,credentials:a,timeline:this.timelineName,older:!0,showImmediately:!0,userId:this.userId,tag:this.tag}).then(function(a){t.commit("setLoading",{timeline:e.timelineName,value:!1}),a&&0===a.length&&(e.bottomedOut=!0)})},1e3,void 0),scrollLoad:function(e){var t=document.body.getBoundingClientRect(),a=Math.max(t.height,-t.y);this.timeline.loading===!1&&this.$store.state.config.autoLoad&&this.$el.offsetHeight>0&&window.innerHeight+window.pageYOffset>=a-750&&this.fetchOlderStatuses()},handleVisibilityChange:function(){this.unfocused=document.hidden}},watch:{newStatusCount:function(e){if(this.$store.state.config.streaming&&e>0){var t=document.documentElement,a=(window.pageYOffset||t.scrollTop)-(t.clientTop||0);!(a<15)||this.paused||this.unfocused&&this.$store.state.config.pauseOnUnfocused?this.paused=!0:this.showNewStatuses()}}}};t.default=p},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(127),o=i(n),s={props:["src","betterShadow","compact"],data:function(){return{showPlaceholder:!1}},components:{StillImage:o.default},computed:{imgSrc:function(){return this.showPlaceholder?"/images/avi.png":this.src}},methods:{imageLoadError:function(){this.showPlaceholder=!0}}};t.default=s},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(88),o=i(n),s=a(44),r=a(134),l=a(35),c=i(l);t.default={props:["user","switcher","selected","hideBio","rounded","bordered"],data:function(){return{followRequestInProgress:!1,followRequestSent:!1,hideUserStatsLocal:"undefined"==typeof this.$store.state.config.hideUserStats?this.$store.state.instance.hideUserStats:this.$store.state.config.hideUserStats,betterShadow:this.$store.state.interface.browserSupport.cssFilter}},computed:{classes:function(){return[{"user-card-rounded-t":"top"===this.rounded,"user-card-rounded":this.rounded===!0,"user-card-bordered":this.bordered===!0}]},style:function(){var e=this.$store.state.config.customTheme.colors?this.$store.state.config.customTheme.colors.bg:this.$store.state.config.colors.bg;if(e){var t="string"==typeof e?(0,s.hex2rgb)(e):e,a="rgba("+Math.floor(t.r)+", "+Math.floor(t.g)+", "+Math.floor(t.b)+", .5)",i=[[a,this.hideBio?"60%":""],this.hideBio?[e,"100%"]:[a,""]].map(function(e){return e.join(" ")}).join(", ");return{backgroundColor:"rgb("+Math.floor(.53*t.r)+", "+Math.floor(.56*t.g)+", "+Math.floor(.59*t.b)+")",backgroundImage:["linear-gradient(to bottom, "+i+")","url("+this.user.cover_photo+")"].join(", ")}}},isOtherUser:function(){return this.user.id!==this.$store.state.users.currentUser.id},subscribeUrl:function(){var e=new URL(this.user.statusnet_profile_url);return e.protocol+"//"+e.host+"/main/ostatus"},loggedIn:function(){return this.$store.state.users.currentUser},dailyAvg:function(){var e=Math.ceil((new Date-new Date(this.user.created_at))/864e5);return Math.round(this.user.statuses_count/e)},userHighlightType:{get:function(){var e=this.$store.state.config.highlight[this.user.screen_name];return e&&e.type||"disabled"},set:function(e){var t=this.$store.state.config.highlight[this.user.screen_name];"disabled"!==e?this.$store.dispatch("setHighlight",{user:this.user.screen_name,color:t&&t.color||"#FFFFFF",type:e}):this.$store.dispatch("setHighlight",{user:this.user.screen_name,color:void 0})}},userHighlightColor:{get:function(){var e=this.$store.state.config.highlight[this.user.screen_name];return e&&e.color},set:function(e){this.$store.dispatch("setHighlight",{user:this.user.screen_name,color:e})}},visibleRole:function(){var e="admin"===this.user.role||"moderator"===this.user.role,t=this.isOtherUser||this.user.show_role;return e&&t&&this.user.role}},components:{UserAvatar:o.default},methods:{followUser:function(){var e=this,t=this.$store;this.followRequestInProgress=!0,(0,r.requestFollow)(this.user,t).then(function(t){var a=t.sent;e.followRequestInProgress=!1,e.followRequestSent=a})},unfollowUser:function(){var e=this,t=this.$store;this.followRequestInProgress=!0,(0,r.requestUnfollow)(this.user,t).then(function(){e.followRequestInProgress=!1,t.commit("removeStatus",{timeline:"friends",userId:e.user.id})})},blockUser:function(){var e=this,t=this.$store;t.state.api.backendInteractor.blockUser(this.user.id).then(function(a){t.commit("addNewUsers",[a]),t.commit("removeStatus",{timeline:"friends",userId:e.user.id}),t.commit("removeStatus",{timeline:"public",userId:e.user.id}),t.commit("removeStatus",{timeline:"publicAndExternal",userId:e.user.id})})},unblockUser:function(){var e=this.$store;e.state.api.backendInteractor.unblockUser(this.user.id).then(function(t){return e.commit("addNewUsers",[t])})},toggleMute:function(){var e=this.$store;e.commit("setMuted",{user:this.user,muted:!this.user.muted}),e.state.api.backendInteractor.setUserMute(this.user)},setProfileView:function(e){if(this.switcher){var t=this.$store;t.commit("setProfileView",{v:e})}},linkClicked:function(e){var t=e.target;"SPAN"===t.tagName&&(t=t.parentNode),"A"===t.tagName&&window.open(t.href,"_blank")},userProfileLink:function(e){return(0,c.default)(e.id,e.screen_name,this.$store.state.instance.restrictedNicknames)}}}},function(e,t){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var a={data:function(){return{username:void 0,hidden:!0,error:!1,loading:!1}},methods:{findUser:function(e){this.$router.push({name:"user-search",query:{query:e}}),this.$refs.userSearchInput.focus()},toggleHidden:function(){this.hidden=!this.hidden,this.$emit("toggled",this.hidden)}}};t.default=a},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(212),o=i(n),s=a(126),r=i(s),l=a(43),c=i(l),u={computed:{user:function(){return this.$store.state.users.currentUser}},components:{LoginForm:o.default,PostStatusForm:r.default,UserCard:c.default}};t.default=u},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(205),o=a(120),s=i(o),r=a(43),l=i(r),c=a(125),u=i(c),d=a(34),p=i(d),f=a(222),_=i(f),h=a(129),m=i(h),v=(0,n.compose)((0,_.default)({fetch:function(e,t){return t.dispatch("addFollowers",e.userId)},select:function(e,t){return(0,s.default)(t.getters.userById(e.userId),"followers",[])},destory:function(e,t){return t.dispatch("clearFollowers",e.userId)},childPropName:"entries",additionalPropNames:["userId"]}),(0,m.default)({getEntryProps:function(e){return{user:e}}}))(u.default),g=(0,n.compose)((0,_.default)({fetch:function(e,t){return t.dispatch("addFriends",e.userId)},select:function(e,t){return(0,s.default)(t.getters.userById(e.userId),"friends",[])},destory:function(e,t){return t.dispatch("clearFriends",e.userId)},childPropName:"entries",additionalPropNames:["userId"]}),(0,m.default)({getEntryProps:function(e){return{user:e}}}))(u.default),b={data:function(){return{error:!1}},created:function(){var e=this;this.$store.commit("clearTimeline",{timeline:"user"}),this.$store.commit("clearTimeline",{timeline:"favorites"}),this.$store.commit("clearTimeline",{timeline:"media"}),this.$store.dispatch("startFetching",{timeline:"user",userId:this.fetchBy}),this.$store.dispatch("startFetching",{timeline:"media",userId:this.fetchBy}),this.startFetchFavorites(),this.user.id||this.$store.dispatch("fetchUser",this.fetchBy).catch(function(t){var a=(0,s.default)(t,"error.error");"No user with such user_id"===a?e.error=e.$t("user_profile.profile_does_not_exist"):a?e.error=a:e.error=e.$t("user_profile.profile_loading_error")})},destroyed:function(){this.cleanUp()},computed:{timeline:function(){return this.$store.state.statuses.timelines.user},favorites:function(){return this.$store.state.statuses.timelines.favorites},media:function(){return this.$store.state.statuses.timelines.media},userId:function(){return this.$route.params.id||this.user.id},userName:function(){return this.$route.params.name||this.user.screen_name},isUs:function(){return this.userId&&this.$store.state.users.currentUser.id&&this.userId===this.$store.state.users.currentUser.id},userInStore:function(){return this.isExternal?this.$store.getters.userById(this.userId):this.$store.getters.userByName(this.userName)},user:function(){return this.timeline.statuses[0]?this.timeline.statuses[0].user:this.userInStore?this.userInStore:{}},fetchBy:function(){return this.isExternal?this.userId:this.userName},isExternal:function(){return"external-user-profile"===this.$route.name},followsTabVisible:function(){return this.isUs||!this.user.hide_follows},followersTabVisible:function(){return this.isUs||!this.user.hide_followers}},methods:{startFetchFavorites:function(){this.isUs&&this.$store.dispatch("startFetching",{timeline:"favorites",userId:this.fetchBy})},startUp:function(){this.$store.dispatch("startFetching",{timeline:"user",userId:this.fetchBy}),this.$store.dispatch("startFetching",{timeline:"media",userId:this.fetchBy}),this.startFetchFavorites()},cleanUp:function(){this.$store.dispatch("stopFetching","user"),this.$store.dispatch("stopFetching","favorites"),this.$store.dispatch("stopFetching","media"),this.$store.commit("clearTimeline",{timeline:"user"}),this.$store.commit("clearTimeline",{timeline:"favorites"}),this.$store.commit("clearTimeline",{timeline:"media"})}},watch:{userName:function(){this.isExternal||(this.cleanUp(),this.startUp())},userId:function(){this.isExternal&&(this.cleanUp(),this.startUp())},$route:function(){this.$refs.tabSwitcher.activateTab(0)()}},components:{UserCard:l.default,Timeline:p.default,FollowerList:v,FriendList:g}};t.default=b},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(125),o=i(n),s=a(242),r=i(s),l={components:{FollowCard:o.default},props:["query"],data:function(){return{username:"",users:[],loading:!1}},mounted:function(){this.search(this.query)},watch:{query:function(e){this.search(e)}},methods:{newQuery:function(e){this.$router.push({name:"user-search",query:{query:e}}),this.$refs.userSearchInput.focus()},search:function(e){var t=this;return e?(this.loading=!0,void r.default.search({query:e,store:this.$store}).then(function(e){t.loading=!1,t.users=e})):void(this.users=[])}}};t.default=l},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(64),o=i(n),s=a(205),r=a(203),l=i(r),c=a(120),u=i(c),d=a(89),p=i(d),f=a(647),_=i(f),h=a(215),m=i(h),v=a(133),g=i(v),b=a(635),w=i(b),k=a(654),y=i(k),C=a(223),x=i(C),S=a(129),j=i(S),P=(0,s.compose)((0,x.default)({fetch:function(e,t){return t.dispatch("fetchBlocks")},select:function(e,t){return(0,u.default)(t.state.users.currentUser,"blockIds",[])},childPropName:"entries"}),(0,j.default)({getEntryProps:function(e){return{userId:e}}}))(w.default),L=(0,s.compose)((0,x.default)({fetch:function(e,t){return t.dispatch("fetchMutes")},select:function(e,t){return(0,u.default)(t.state.users.currentUser,"muteIds",[])},childPropName:"entries"}),(0,j.default)({getEntryProps:function(e){return{userId:e}}}))(y.default),$={data:function(){return{newName:this.$store.state.users.currentUser.name,newBio:(0,l.default)(this.$store.state.users.currentUser.description),newLocked:this.$store.state.users.currentUser.locked,newNoRichText:this.$store.state.users.currentUser.no_rich_text,newDefaultScope:this.$store.state.users.currentUser.default_scope,hideFollows:this.$store.state.users.currentUser.hide_follows,hideFollowers:this.$store.state.users.currentUser.hide_followers,showRole:this.$store.state.users.currentUser.show_role,role:this.$store.state.users.currentUser.role,followList:null,followImportError:!1,followsImported:!1,enableFollowsExport:!0,pickAvatarBtnVisible:!0,bannerUploading:!1,backgroundUploading:!1,followListUploading:!1,bannerPreview:null,backgroundPreview:null,bannerUploadError:null,backgroundUploadError:null,deletingAccount:!1,deleteAccountConfirmPasswordInput:"",deleteAccountError:!1,changePasswordInputs:["","",""],changedPassword:!1,changePasswordError:!1,activeTab:"profile"}},created:function(){this.$store.dispatch("fetchTokens")},components:{StyleSwitcher:m.default,TabSwitcher:p.default,ImageCropper:_.default,BlockList:P,MuteList:L},computed:{user:function(){return this.$store.state.users.currentUser},pleromaBackend:function(){return this.$store.state.instance.pleromaBackend},scopeOptionsEnabled:function(){return this.$store.state.instance.scopeOptionsEnabled},vis:function(){return{public:{selected:"public"===this.newDefaultScope},unlisted:{selected:"unlisted"===this.newDefaultScope},private:{selected:"private"===this.newDefaultScope},direct:{selected:"direct"===this.newDefaultScope}}},currentSaveStateNotice:function(){return this.$store.state.interface.settings.currentSaveStateNotice},oauthTokens:function(){return this.$store.state.oauthTokens.tokens.map(function(e){return{id:e.id,appName:e.app_name,validUntil:new Date(e.valid_until).toLocaleDateString()}})}},methods:{updateProfile:function(){var e=this,t=this.newName,a=this.newBio,i=this.newLocked,n=this.newDefaultScope,o=this.newNoRichText,s=this.hideFollows,r=this.hideFollowers,l=this.showRole;this.$store.state.api.backendInteractor.updateProfile({params:{name:t,description:a,locked:i,default_scope:n,no_rich_text:o,hide_follows:s,hide_followers:r,show_role:l}}).then(function(t){t.error||(e.$store.commit("addNewUsers",[t]),e.$store.commit("setCurrentUser",t))})},changeVis:function(e){this.newDefaultScope=e},uploadFile:function(e,t){var a=this,i=t.target.files[0];if(i){if(i.size>this.$store.state.instance[e+"limit"]){var n=g.default.fileSizeFormat(i.size),o=g.default.fileSizeFormat(this.$store.state.instance[e+"limit"]);return void(this[e+"UploadError"]=this.$t("upload.error.base")+" "+this.$t("upload.error.file_too_big",{filesize:n.num,filesizeunit:n.unit,allowedsize:o.num,allowedsizeunit:o.unit}))}var s=new FileReader;s.onload=function(t){var i=t.target,n=i.result;a[e+"Preview"]=n},s.readAsDataURL(i)}},submitAvatar:function(e,t){var a=this,i=e.getCroppedCanvas().toDataURL(t.type);return this.$store.state.api.backendInteractor.updateAvatar({params:{img:i}}).then(function(e){if(e.error)throw new Error(a.$t("upload.error.base")+e.error);a.$store.commit("addNewUsers",[e]),a.$store.commit("setCurrentUser",e)})},clearUploadError:function(e){this[e+"UploadError"]=null},submitBanner:function(){var e=this;if(this.bannerPreview){var t=this.bannerPreview,a=new Image,i=void 0,n=void 0,s=void 0,r=void 0;a.src=t,s=a.width,r=a.height,i=0,n=0,this.bannerUploading=!0,this.$store.state.api.backendInteractor.updateBanner({params:{banner:t,offset_top:i,offset_left:n,width:s,height:r}}).then(function(t){if(t.error)e.bannerUploadError=e.$t("upload.error.base")+t.error;else{var a=JSON.parse((0,o.default)(e.$store.state.users.currentUser));a.cover_photo=t.url,e.$store.commit("addNewUsers",[a]),e.$store.commit("setCurrentUser",a),e.bannerPreview=null}e.bannerUploading=!1})}},submitBg:function(){var e=this;if(this.backgroundPreview){var t=this.backgroundPreview,a=new Image,i=void 0,n=void 0,s=void 0,r=void 0;a.src=t,i=0,n=0,s=a.width,r=a.width,this.backgroundUploading=!0,this.$store.state.api.backendInteractor.updateBg({params:{img:t,cropX:i,cropY:n,cropW:s,cropH:r}}).then(function(t){if(t.error)e.backgroundUploadError=e.$t("upload.error.base")+t.error;else{var a=JSON.parse((0,o.default)(e.$store.state.users.currentUser));a.background_image=t.url,e.$store.commit("addNewUsers",[a]),e.$store.commit("setCurrentUser",a),e.backgroundPreview=null}e.backgroundUploading=!1})}},importFollows:function(){var e=this;this.followListUploading=!0;var t=this.followList;this.$store.state.api.backendInteractor.followImport({params:t}).then(function(t){t?e.followsImported=!0:e.followImportError=!0,e.followListUploading=!1})},exportPeople:function(e,t){var a=e.map(function(e){return e&&e.is_local&&(e.screen_name+="@"+location.hostname),e.screen_name}).join("\n"),i=document.createElement("a");i.setAttribute("href","data:text/plain;charset=utf-8,"+encodeURIComponent(a)),i.setAttribute("download",t),i.style.display="none",document.body.appendChild(i),i.click(),document.body.removeChild(i)},exportFollows:function(){var e=this;this.enableFollowsExport=!1,this.$store.state.api.backendInteractor.exportFriends({id:this.$store.state.users.currentUser.id}).then(function(t){e.exportPeople(t,"friends.csv"),setTimeout(function(){e.enableFollowsExport=!0},2e3)})},followListChange:function(){var e=new FormData;e.append("list",this.$refs.followlist.files[0]),this.followList=e},dismissImported:function(){this.followsImported=!1,this.followImportError=!1},confirmDelete:function(){this.deletingAccount=!0},deleteAccount:function(){var e=this;this.$store.state.api.backendInteractor.deleteAccount({password:this.deleteAccountConfirmPasswordInput}).then(function(t){"success"===t.status?(e.$store.dispatch("logout"),e.$router.push({name:"root"})):e.deleteAccountError=t.error})},changePassword:function(){var e=this,t={password:this.changePasswordInputs[0],newPassword:this.changePasswordInputs[1],newPasswordConfirmation:this.changePasswordInputs[2]};this.$store.state.api.backendInteractor.changePassword(t).then(function(t){"success"===t.status?(e.changedPassword=!0,e.changePasswordError=!1,e.logout()):(e.changedPassword=!1,e.changePasswordError=t.error)})},activateTab:function(e){this.activeTab=e},logout:function(){this.$store.dispatch("logout"),this.$router.replace("/")},revokeToken:function(e){window.confirm(this.$i18n.t("settings.revoke_token")+"?")&&this.$store.dispatch("revokeToken",e)}}};t.default=$},function(e,t){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var a={props:["attachment","controls"],data:function(){return{loopVideo:this.$store.state.config.loopVideo}},methods:{onVideoDataLoad:function(e){var t=e.srcElement||e.target;"undefined"!=typeof t.webkitAudioDecodedByteCount?t.webkitAudioDecodedByteCount>0&&(this.loopVideo=this.loopVideo&&!this.$store.state.config.loopVideoSilentOnly):"undefined"!=typeof t.mozHasAudio?t.mozHasAudio&&(this.loopVideo=this.loopVideo&&!this.$store.state.config.loopVideoSilentOnly):"undefined"!=typeof t.audioTracks&&t.audioTracks.length>0&&(this.loopVideo=this.loopVideo&&!this.$store.state.config.loopVideoSilentOnly)}}};t.default=a},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}Object.defineProperty(t,"__esModule",{value:!0});var n=a(18),o=i(n),s=a(125),r=i(s),l={components:{FollowCard:r.default},data:function(){return{users:[]}},mounted:function(){this.getWhoToFollow()},methods:{showWhoToFollow:function(e){var t=this;e.forEach(function(e,a){var i={id:0,name:e.display_name,screen_name:e.acct,profile_image_url:e.avatar||"/images/avi.png"};t.users.push(i),t.$store.state.api.backendInteractor.externalProfile(i.screen_name).then(function(e){e.error||(t.$store.commit("addNewUsers",[e]),i.id=e.id)})})},getWhoToFollow:function(){var e=this,t=this.$store.state.users.currentUser.credentials;t&&o.default.suggestions({credentials:t}).then(function(t){e.showWhoToFollow(t)})}}};t.default=l},function(e,t,a){"use strict";function i(e){return e&&e.__esModule?e:{default:e}}function n(e,t){var a=(0,r.default)(t);e.usersToFollow.forEach(function(t,i){var n=a[i],o=n.avatar||"/images/avi.png",s=n.acct;t.img=o,t.name=s,e.$store.state.api.backendInteractor.externalProfile(s).then(function(a){a.error||(e.$store.commit("addNewUsers",[a]),t.id=a.id)})})}function o(e){var t=e.$store.state.users.currentUser.credentials;t&&(e.usersToFollow.forEach(function(e){e.name="Loading..."}),c.default.suggestions({credentials:t}).then(function(t){n(e,t)}))}Object.defineProperty(t,"__esModule",{value:!0});var s=a(610),r=i(s),l=a(18),c=i(l),u=a(35),d=i(u),p={data:function(){return{usersToFollow:new Array(3).fill().map(function(e){return{img:"/images/avi.png",name:"",id:0}})}},computed:{user:function(){return this.$store.state.users.currentUser.screen_name},suggestionsEnabled:function(){return this.$store.state.instance.suggestionsEnabled}},methods:{userProfileLink:function(e,t){return(0,d.default)(e,t,this.$store.state.instance.restrictedNicknames)}},watch:{user:function(e,t){this.suggestionsEnabled&&o(this)}},mounted:function(){this.suggestionsEnabled&&o(this)}};t.default=p},,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},function(e,t){},,function(e,t){e.exports={chat:{title:"الدردشة"},features_panel:{chat:"الدردشة",gopher:"غوفر",media_proxy:"بروكسي الوسائط",scope_options:"",text_limit:"الحد الأقصى للنص",title:"الميّزات",who_to_follow:"للمتابعة"},finder:{error_fetching_user:"خطأ أثناء جلب صفحة المستخدم",find_user:"البحث عن مستخدِم"},general:{apply:"تطبيق",submit:"إرسال"},login:{login:"تسجيل الدخول",logout:"الخروج",password:"الكلمة السرية",placeholder:"مثال lain",register:"انشاء حساب",username:"إسم المستخدم"},nav:{chat:"الدردشة المحلية",friend_requests:"طلبات المتابَعة",mentions:"الإشارات",public_tl:"الخيط الزمني العام",timeline:"الخيط الزمني",twkn:"كافة الشبكة المعروفة"},notifications:{broken_favorite:"منشور مجهول، جارٍ البحث عنه…",favorited_you:"أعجِب بمنشورك",followed_you:"يُتابعك",load_older:"تحميل الإشعارات الأقدم",notifications:"الإخطارات",read:"مقروء!",repeated_you:"شارَك منشورك"},post_status:{account_not_locked_warning:"",account_not_locked_warning_link:"مقفل",attachments_sensitive:"اعتبر المرفقات كلها كمحتوى حساس",content_type:{plain_text:"نص صافٍ"},content_warning:"الموضوع (اختياري)",default:"وصلت للتوّ إلى لوس أنجلس.",direct_warning:"",posting:"النشر",scope:{direct:"",private:"",public:"علني - يُنشر على الخيوط الزمنية العمومية",unlisted:"غير مُدرَج - لا يُنشَر على الخيوط الزمنية العمومية"}},registration:{bio:"السيرة الذاتية",email:"عنوان البريد الإلكتروني",fullname:"الإسم المعروض",password_confirm:"تأكيد الكلمة السرية",registration:"التسجيل",token:"رمز الدعوة"},settings:{attachmentRadius:"المُرفَقات",attachments:"المُرفَقات",autoload:"",avatar:"الصورة الرمزية",avatarAltRadius:"الصور الرمزية (الإشعارات)",avatarRadius:"الصور الرمزية",background:"الخلفية",bio:"السيرة الذاتية",btnRadius:"الأزرار",cBlue:"أزرق (الرد، المتابَعة)",cGreen:"أخضر (إعادة النشر)",cOrange:"برتقالي (مفضلة)",cRed:"أحمر (إلغاء)",change_password:"تغيير كلمة السر",change_password_error:"وقع هناك خلل أثناء تعديل كلمتك السرية.",changed_password:"تم تغيير كلمة المرور بنجاح!",collapse_subject:"",confirm_new_password:"تأكيد كلمة السر الجديدة",current_avatar:"صورتك الرمزية الحالية",current_password:"كلمة السر الحالية",current_profile_banner:"الرأسية الحالية لصفحتك الشخصية",data_import_export_tab:"تصدير واستيراد البيانات",default_vis:"أسلوب العرض الافتراضي",delete_account:"حذف الحساب",delete_account_description:"حذف حسابك و كافة منشوراتك نهائيًا.",delete_account_error:"",delete_account_instructions:"يُرجى إدخال كلمتك السرية أدناه لتأكيد عملية حذف الحساب.",export_theme:"حفظ النموذج",filtering:"التصفية",filtering_explanation:"سيتم إخفاء كافة المنشورات التي تحتوي على هذه الكلمات، كلمة واحدة في كل سطر",follow_export:"تصدير الاشتراكات",follow_export_button:"تصدير الاشتراكات كملف csv",follow_export_processing:"التصدير جارٍ، سوف يُطلَب منك تنزيل ملفك بعد حين",follow_import:"استيراد الاشتراكات",follow_import_error:"خطأ أثناء استيراد المتابِعين",follows_imported:"",foreground:"الأمامية",general:"الإعدادات العامة",hide_attachments_in_convo:"إخفاء المرفقات على المحادثات",hide_attachments_in_tl:"إخفاء المرفقات على الخيط الزمني",hide_post_stats:"",hide_user_stats:"",import_followers_from_a_csv_file:"",import_theme:"تحميل نموذج",inputRadius:"",instance_default:"",interfaceLanguage:"لغة الواجهة",invalid_theme_imported:"",limited_availability:"غير متوفر على متصفحك",links:"الروابط",lock_account_description:"",loop_video:"",loop_video_silent_only:"",name:"الاسم",name_bio:"الاسم والسيرة الذاتية",new_password:"كلمة السر الجديدة",no_rich_text_description:"",notification_visibility:"نوع الإشعارات التي تريد عرضها",notification_visibility_follows:"يتابع",notification_visibility_likes:"الإعجابات",notification_visibility_mentions:"الإشارات",notification_visibility_repeats:"",nsfw_clickthrough:"",oauth_tokens:"رموز OAuth",token:"رمز",refresh_token:"رمز التحديث",valid_until:"صالح حتى",revoke_token:"سحب",panelRadius:"",pause_on_unfocused:"",presets:"النماذج",profile_background:"خلفية الصفحة الشخصية",profile_banner:"رأسية الصفحة الشخصية",profile_tab:"الملف الشخصي",radii_help:"",replies_in_timeline:"الردود على الخيط الزمني",reply_link_preview:"",reply_visibility_all:"عرض كافة الردود",reply_visibility_following:"",reply_visibility_self:"",saving_err:"خطأ أثناء حفظ الإعدادات",saving_ok:"تم حفظ الإعدادات",security_tab:"الأمان",set_new_avatar:"اختيار صورة رمزية جديدة",set_new_profile_background:"اختيار خلفية جديدة للملف الشخصي",set_new_profile_banner:"اختيار رأسية جديدة للصفحة الشخصية",settings:"الإعدادات",stop_gifs:"",streaming:"",text:"النص",theme:"المظهر",theme_help:"",tooltipRadius:"",user_settings:"إعدادات المستخدم",values:{false:"لا",true:"نعم"}},timeline:{collapse:"",conversation:"محادثة",error_fetching:"خطأ أثناء جلب التحديثات",load_older:"تحميل المنشورات القديمة",no_retweet_hint:"",repeated:"",show_new:"عرض الجديد",up_to_date:"تم تحديثه"},user_card:{approve:"قبول",block:"حظر",blocked:"تم حظره!",deny:"رفض",follow:"اتبع",followees:"",followers:"مُتابِعون",following:"",follows_you:"يتابعك!",mute:"كتم",muted:"تم كتمه",per_day:"في اليوم",remote_follow:"مُتابَعة عن بُعد",statuses:"المنشورات"},user_profile:{timeline_title:"الخيط الزمني للمستخدم"},who_to_follow:{more:"المزيد",who_to_follow:"للمتابعة"}}},function(e,t){e.exports={chat:{title:"Xat"},features_panel:{chat:"Xat",gopher:"Gopher",media_proxy:"Proxy per multimèdia",scope_options:"Opcions d'abast i visibilitat",text_limit:"Límit de text",title:"Funcionalitats",who_to_follow:"A qui seguir"},finder:{error_fetching_user:"No s'ha pogut carregar l'usuari/a",find_user:"Find user"},general:{apply:"Aplica",submit:"Desa"},login:{login:"Inicia sessió",logout:"Tanca la sessió",password:"Contrasenya",placeholder:"p.ex.: Maria",register:"Registra't",username:"Nom d'usuari/a"},nav:{chat:"Xat local públic",friend_requests:"Soŀlicituds de connexió",mentions:"Mencions",public_tl:"Flux públic del node",timeline:"Flux personal",twkn:"Flux de la xarxa coneguda"},notifications:{broken_favorite:"No es coneix aquest estat. S'està cercant.",favorited_you:"ha marcat un estat teu",followed_you:"ha començat a seguir-te",load_older:"Carrega més notificacions",notifications:"Notificacions",read:"Read!",repeated_you:"ha repetit el teu estat"},post_status:{account_not_locked_warning:"El teu compte no està {0}. Qualsevol persona pot seguir-te per llegir les teves entrades reservades només a seguidores.",account_not_locked_warning_link:"bloquejat",attachments_sensitive:"Marca l'adjunt com a delicat",content_type:{plain_text:"Text pla"},content_warning:"Assumpte (opcional)",default:"Em sento…",direct_warning:"Aquesta entrada només serà visible per les usuràries que etiquetis",posting:"Publicació",scope:{direct:"Directa - Publica només per les usuàries etiquetades",private:"Només seguidors/es - Publica només per comptes que et segueixin",public:"Pública - Publica als fluxos públics",unlisted:"Silenciosa - No la mostris en fluxos públics"}},registration:{bio:"Presentació",email:"Correu",fullname:"Nom per mostrar",password_confirm:"Confirma la contrasenya",registration:"Registra't",token:"Codi d'invitació"},settings:{attachmentRadius:"Adjunts",attachments:"Adjunts",autoload:"Recarrega automàticament en arribar a sota de tot.",avatar:"Avatar",avatarAltRadius:"Avatars en les notificacions",avatarRadius:"Avatars",background:"Fons de pantalla",bio:"Presentació",btnRadius:"Botons",cBlue:"Blau (respon, segueix)",cGreen:"Verd (republica)",cOrange:"Taronja (marca com a preferit)",cRed:"Vermell (canceŀla)",change_password:"Canvia la contrasenya",change_password_error:"No s'ha pogut canviar la contrasenya",changed_password:"S'ha canviat la contrasenya",collapse_subject:"Replega les entrades amb títol",confirm_new_password:"Confirma la nova contrasenya",current_avatar:"L'avatar actual",current_password:"La contrasenya actual",current_profile_banner:"El fons de perfil actual",data_import_export_tab:"Importa o exporta dades",default_vis:"Abast per defecte de les entrades",delete_account:"Esborra el compte",delete_account_description:"Esborra permanentment el teu compte i tots els missatges",delete_account_error:"No s'ha pogut esborrar el compte. Si continua el problema, contacta amb l'administració del node",delete_account_instructions:"Confirma que vols esborrar el compte escrivint la teva contrasenya aquí sota",export_theme:"Desa el tema",filtering:"Filtres",filtering_explanation:"Es silenciaran totes les entrades que continguin aquestes paraules. Separa-les per línies",follow_export:"Exporta la llista de contactes",follow_export_button:"Exporta tots els comptes que segueixes a un fitxer CSV",follow_export_processing:"S'està processant la petició. Aviat podràs descarregar el fitxer",follow_import:"Importa els contactes",follow_import_error:"No s'ha pogut importar els contactes",follows_imported:"S'han importat els contactes. Trigaran una estoneta en ser processats.",foreground:"Primer pla",general:"General",hide_attachments_in_convo:"Amaga els adjunts en les converses",hide_attachments_in_tl:"Amaga els adjunts en el flux d'entrades",import_followers_from_a_csv_file:"Importa els contactes des d'un fitxer CSV",import_theme:"Carrega un tema",inputRadius:"Caixes d'entrada de text",instance_default:"(default: {value})",interfaceLanguage:"Llengua de la interfície",invalid_theme_imported:"No s'ha entès l'arxiu carregat perquè no és un tema vàlid de Pleroma. No s'ha fet cap canvi als temes actuals.",limited_availability:"No està disponible en aquest navegador",links:"Enllaços",lock_account_description:"Restringeix el teu compte només a seguidores aprovades.", +loop_video:"Reprodueix els vídeos en bucle",loop_video_silent_only:'Reprodueix en bucles només els vídeos sense so (com els "GIF" de Mastodon)',name:"Nom",name_bio:"Nom i presentació",new_password:"Contrasenya nova",notification_visibility:"Notifica'm quan algú",notification_visibility_follows:"Comença a seguir-me",notification_visibility_likes:"Marca com a preferida una entrada meva",notification_visibility_mentions:"Em menciona",notification_visibility_repeats:"Republica una entrada meva",no_rich_text_description:"Neteja el formatat de text de totes les entrades",nsfw_clickthrough:"Amaga el contingut NSFW darrer d'una imatge clicable",oauth_tokens:"Llistats OAuth",token:"Token",refresh_token:"Actualitza el token",valid_until:"Vàlid fins",revoke_token:"Revocar",panelRadius:"Panells",pause_on_unfocused:"Pausa la reproducció en continu quan la pestanya perdi el focus",presets:"Temes",profile_background:"Fons de pantalla",profile_banner:"Fons de perfil",profile_tab:"Perfil",radii_help:"Configura l'arrodoniment de les vores (en píxels)",replies_in_timeline:"Replies in timeline",reply_link_preview:"Mostra el missatge citat en passar el ratolí per sobre de l'enllaç de resposta",reply_visibility_all:"Mostra totes les respostes",reply_visibility_following:"Mostra només les respostes a entrades meves o d'usuàries que jo segueixo",reply_visibility_self:"Mostra només les respostes a entrades meves",saving_err:"No s'ha pogut desar la configuració",saving_ok:"S'ha desat la configuració",security_tab:"Seguretat",set_new_avatar:"Canvia l'avatar",set_new_profile_background:"Canvia el fons de pantalla",set_new_profile_banner:"Canvia el fons del perfil",settings:"Configuració",stop_gifs:"Anima els GIF només en passar-hi el ratolí per sobre",streaming:"Carrega automàticament entrades noves quan estigui a dalt de tot",text:"Text",theme:"Tema",theme_help:"Personalitza els colors del tema. Escriu-los en format RGB hexadecimal (#rrggbb)",tooltipRadius:"Missatges sobreposats",user_settings:"Configuració personal",values:{false:"no",true:"sí"}},timeline:{collapse:"Replega",conversation:"Conversa",error_fetching:"S'ha produït un error en carregar les entrades",load_older:"Carrega entrades anteriors",no_retweet_hint:'L\'entrada és només per a seguidores o és "directa", i per tant no es pot republicar',repeated:"republicat",show_new:"Mostra els nous",up_to_date:"Actualitzat"},user_card:{approve:"Aprova",block:"Bloqueja",blocked:"Bloquejat!",deny:"Denega",follow:"Segueix",followees:"Segueixo",followers:"Seguidors/es",following:"Seguint!",follows_you:"Et segueix!",mute:"Silencia",muted:"Silenciat",per_day:"per dia",remote_follow:"Seguiment remot",statuses:"Estats"},user_profile:{timeline_title:"Flux personal"},who_to_follow:{more:"More",who_to_follow:"A qui seguir"}}},function(e,t){e.exports={chat:{title:"Chat"},features_panel:{chat:"Chat",gopher:"Gopher",media_proxy:"Mediální proxy",scope_options:"Možnosti rozsahů",text_limit:"Textový limit",title:"Vlastnosti",who_to_follow:"Koho sledovat"},finder:{error_fetching_user:"Chyba při načítání uživatele",find_user:"Najít uživatele"},general:{apply:"Použít",submit:"Odeslat",more:"Více",generic_error:"Vyskytla se chyba",optional:"volitelné"},image_cropper:{crop_picture:"Oříznout obrázek",save:"Uložit",cancel:"Zrušit"},login:{login:"Přihlásit",description:"Přihlásit pomocí OAuth",logout:"Odhlásit",password:"Heslo",placeholder:"např. lain",register:"Registrovat",username:"Uživatelské jméno",hint:"Chcete-li se přidat do diskuze, přihlaste se"},media_modal:{previous:"Předchozí",next:"Další"},nav:{about:"O instanci",back:"Zpět",chat:"Místní chat",friend_requests:"Požadavky o sledování",mentions:"Zmínky",dms:"Přímé zprávy",public_tl:"Veřejná časová osa",timeline:"Časová osa",twkn:"Celá známá síť",user_search:"Hledání uživatelů",who_to_follow:"Koho sledovat",preferences:"Předvolby"},notifications:{broken_favorite:"Neznámý příspěvek, hledám jej…",favorited_you:"si oblíbil/a váš příspěvek",followed_you:"vás nyní sleduje",load_older:"Načíst starší oznámení",notifications:"Oznámení",read:"Číst!",repeated_you:"zopakoval/a váš příspěvek",no_more_notifications:"Žádná další oznámení"},post_status:{new_status:"Napsat nový příspěvek",account_not_locked_warning:"Váš účet není {0}. Kdokoliv vás může sledovat a vidět vaše příspěvky pouze pro sledující.",account_not_locked_warning_link:"uzamčen",attachments_sensitive:"Označovat přílohy jako citlivé",content_type:{plain_text:"Prostý text","text/html":"HTML","text/markdown":"Markdown"},content_warning:"Předmět (volitelný)",default:"Právě jsem přistál v L.A.",direct_warning:"Tento příspěvek uvidí pouze všichni zmínění uživatelé.",posting:"Přispívání",scope:{direct:"Přímý - Poslat pouze zmíněným uživatelům",private:"Pouze pro sledující - Poslat pouze sledujícím",public:"Veřejný - Poslat na veřejné časové osy",unlisted:"Neuvedený - Neposlat na veřejné časové osy"}},registration:{bio:"O vás",email:"E-mail",fullname:"Zobrazované jméno",password_confirm:"Potvrzení hesla",registration:"Registrace",token:"Token pozvánky",captcha:"CAPTCHA",new_captcha:"Kliknutím na obrázek získáte novou CAPTCHA",username_placeholder:"např. lain",fullname_placeholder:"např. Lain Iwakura",bio_placeholder:"např.\nNazdar, jsem Lain\nJsem anime dívka žijící v příměstském Japonsku. Možná mě znáte z Wired.",validations:{username_required:"nemůže být prázdné",fullname_required:"nemůže být prázdné",email_required:"nemůže být prázdný",password_required:"nemůže být prázdné",password_confirmation_required:"nemůže být prázdné",password_confirmation_match:"musí být stejné jako heslo"}},settings:{app_name:"Název aplikace",attachmentRadius:"Přílohy",attachments:"Přílohy",autoload:"Povolit automatické načítání při rolování dolů",avatar:"Avatar",avatarAltRadius:"Avatary (oznámení)",avatarRadius:"Avatary",background:"Pozadí",bio:"O vás",blocks_tab:"Blokování",btnRadius:"Tlačítka",cBlue:"Modrá (Odpovědět, sledovat)",cGreen:"Zelená (Zopakovat)",cOrange:"Oranžová (Oblíbit)",cRed:"Červená (Zrušit)",change_password:"Změnit heslo",change_password_error:"Při změně vašeho hesla se vyskytla chyba.",changed_password:"Heslo bylo úspěšně změněno!",collapse_subject:"Zabalit příspěvky s předměty",composing:"Komponování",confirm_new_password:"Potvrďte nové heslo",current_avatar:"Váš současný avatar",current_password:"Současné heslo",current_profile_banner:"Váš současný profilový banner",data_import_export_tab:"Import/export dat",default_vis:"Výchozí rozsah viditelnosti",delete_account:"Smazat účet",delete_account_description:"Trvale smaže váš účet a všechny vaše příspěvky.",delete_account_error:"Při mazání vašeho účtu nastala chyba. Pokud tato chyba bude trvat, kontaktujte prosím admministrátora vaší instance.",delete_account_instructions:"Pro potvrzení smazání účtu napište své heslo do pole níže.",avatar_size_instruction:"Doporučená minimální velikost pro avatarové obrázky je 150x150 pixelů.",export_theme:"Uložit přednastavení",filtering:"Filtrování",filtering_explanation:"Všechny příspěvky obsahující tato slova budou skryty. Napište jedno slovo na každý řádek",follow_export:"Export sledovaných",follow_export_button:"Exportovat vaše sledované do souboru CSV",follow_export_processing:"Zpracovávám, brzy si budete moci stáhnout váš soubor",follow_import:"Import sledovaných",follow_import_error:"Chyba při importování sledovaných",follows_imported:"Sledovaní importováni! Jejich zpracování bude chvilku trvat.",foreground:"Popředí",general:"Obecné",hide_attachments_in_convo:"Skrývat přílohy v konverzacích",hide_attachments_in_tl:"Skrývat přílohy v časové ose",max_thumbnails:"Maximální počet miniatur na příspěvek",hide_isp:"Skrýt panel specifický pro instanci",preload_images:"Přednačítat obrázky",use_one_click_nsfw:"Otevírat citlivé přílohy pouze jedním kliknutím",hide_post_stats:"Skrývat statistiky příspěvků (např. počet oblíbení)",hide_user_stats:"Skrývat statistiky uživatelů (např. počet sledujících)",hide_filtered_statuses:"Skrývat filtrované příspěvky",import_followers_from_a_csv_file:"Importovat sledované ze souboru CSV",import_theme:"Načíst přednastavení",inputRadius:"Vstupní pole",checkboxRadius:"Zaškrtávací pole",instance_default:"(výchozí: {value})",instance_default_simple:"(výchozí)",interface:"Rozhraní",interfaceLanguage:"Jazyk rozhraní",invalid_theme_imported:"Zvolený soubor není podporovaný motiv Pleroma. Nebyly provedeny žádné změny s vaším motivem.",limited_availability:"Nedostupné ve vašem prohlížeči",links:"Odkazy",lock_account_description:"Omezit váš účet pouze na schválené sledující",loop_video:"Opakovat videa",loop_video_silent_only:"Opakovat pouze videa beze zvuku (t.j. „GIFy“ na Mastodonu)",mutes_tab:"Ignorování",play_videos_in_modal:"Přehrávat videa přímo v prohlížeči médií",use_contain_fit:"Neořezávat přílohu v miniaturách",name:"Jméno",name_bio:"Jméno a popis",new_password:"Nové heslo",notification_visibility:"Typy oznámení k zobrazení",notification_visibility_follows:"Sledující",notification_visibility_likes:"Oblíbení",notification_visibility_mentions:"Zmínky",notification_visibility_repeats:"Zopakování",no_rich_text_description:"Odstranit ze všech příspěvků formátování textu",no_blocks:"Žádná blokování",no_mutes:"Žádná ignorování",hide_follows_description:"Nezobrazovat, koho sleduji",hide_followers_description:"Nezobrazovat, kdo mě sleduje",show_admin_badge:"Zobrazovat v mém profilu odznak administrátora",show_moderator_badge:"Zobrazovat v mém profilu odznak moderátora",nsfw_clickthrough:"Povolit prokliknutelné skrývání citlivých příloh",oauth_tokens:"Tokeny OAuth",token:"Token",refresh_token:"Obnovit token",valid_until:"Platný do",revoke_token:"Odvolat",panelRadius:"Panely",pause_on_unfocused:"Pozastavit streamování, pokud není záložka prohlížeče v soustředění",presets:"Přednastavení",profile_background:"Profilové pozadí",profile_banner:"Profilový banner",profile_tab:"Profil",radii_help:"Nastavit zakulacení rohů rozhraní (v pixelech)",replies_in_timeline:"Odpovědi v časové ose",reply_link_preview:"Povolit náhledy odkazu pro odpověď při přejetí myši",reply_visibility_all:"Zobrazit všechny odpovědi",reply_visibility_following:"Zobrazit pouze odpovědi směřované na mě nebo uživatele, které sleduji",reply_visibility_self:"Zobrazit pouze odpovědi směřované na mě",saving_err:"Chyba při ukládání nastavení",saving_ok:"Nastavení uložena",security_tab:"Bezpečnost",scope_copy:"Kopírovat rozsah při odpovídání (přímé zprávy jsou vždy kopírovány)",set_new_avatar:"Nastavit nový avatar",set_new_profile_background:"Nastavit nové profilové pozadí",set_new_profile_banner:"Nastavit nový profilový banner",settings:"Nastavení",subject_input_always_show:"Vždy zobrazit pole pro předmět",subject_line_behavior:"Kopírovat předmět při odpovídání",subject_line_email:"Jako u e-mailu: „re: předmět“",subject_line_mastodon:"Jako u Mastodonu: zkopírovat tak, jak je",subject_line_noop:"Nekopírovat",post_status_content_type:"Publikovat typ obsahu příspěvku",stop_gifs:"Přehrávat GIFy při přejetí myši",streaming:"Povolit automatické streamování nových příspěvků při rolování nahoru",text:"Text",theme:"Motiv",theme_help:"Použijte hexadecimální barevné kódy (#rrggbb) pro přizpůsobení vašeho barevného motivu.",theme_help_v2_1:"Zaškrtnutím pole můžete také přepsat barvy a průhlednost některých komponentů, pro smazání všech přednastavení použijte tlačítko „Smazat vše“.",theme_help_v2_2:"Ikony pod některými položkami jsou indikátory kontrastu pozadí/textu, pro detailní informace nad nimi přejeďte myší. Prosím berte na vědomí, že při používání kontrastu průhlednosti ukazují indikátory nejhorší možný případ.",tooltipRadius:"Popisky/upozornění",upload_a_photo:"Nahrát fotku",user_settings:"Uživatelská nastavení",values:{false:"ne",true:"ano"},notifications:"Oznámení",enable_web_push_notifications:"Povolit webová push oznámení",style:{switcher:{keep_color:"Ponechat barvy",keep_shadows:"Ponechat stíny",keep_opacity:"Ponechat průhlednost",keep_roundness:"Ponechat kulatost",keep_fonts:"Keep fonts",save_load_hint:"Možnosti „Ponechat“ dočasně ponechávají aktuálně nastavené možností při volení či nahrávání motivů, také tyto možnosti ukládají při exportování motivu. Pokud není žádné pole zaškrtnuto, uloží export motivu všechno.",reset:"Resetovat",clear_all:"Vymazat vše",clear_opacity:"Vymazat průhlednost"},common:{color:"Barva",opacity:"Průhlednost",contrast:{hint:"Poměr kontrastu je {ratio}, {level} {context}",level:{aa:"splňuje směrnici úrovně AA (minimální)",aaa:"splňuje směrnici úrovně AAA (doporučováno)",bad:"nesplňuje žádné směrnice přístupnosti"},context:{"18pt":"pro velký (18+ bodů) text",text:"pro text"}}},common_colors:{_tab_label:"Obvyklé",main:"Obvyklé barvy",foreground_hint:"Pro detailnější kontrolu viz záložka „Pokročilé“",rgbo:"Ikony, odstíny, odznaky"},advanced_colors:{_tab_label:"Pokročilé",alert:"Pozadí upozornění",alert_error:"Chyba",badge:"Pozadí odznaků",badge_notification:"Oznámení",panel_header:"Záhlaví panelu",top_bar:"Vrchní pruh",borders:"Okraje",buttons:"Tlačítka",inputs:"Vstupní pole",faint_text:"Vybledlý text"},radii:{_tab_label:"Kulatost"},shadows:{_tab_label:"Stín a osvětlení",component:"Komponent",override:"Přepsat",shadow_id:"Stín #{value}",blur:"Rozmazání",spread:"Rozsah",inset:"Vsazení",hint:"Pro stíny můžete také použít --variable jako hodnotu barvy pro použití proměnných CSS3. Prosím berte na vědomí, že nastavení průhlednosti v tomto případě nebude fungovat.",filter_hint:{always_drop_shadow:"Varování, tento stín vždy používá {0}, když to prohlížeč podporuje.",drop_shadow_syntax:"{0} nepodporuje parametr {1} a klíčové slovo {2}.",avatar_inset:"Prosím berte na vědomí, že kombinování vsazených i nevsazených stínů u avatarů může u průhledných avatarů dát neočekávané výsledky.",spread_zero:"Stíny s rozsahem > 0 se zobrazí, jako kdyby byl rozsah nastaven na nulu",inset_classic:"Vsazené stíny budou používat {0}"},components:{panel:"Panel",panelHeader:"Záhlaví panelu",topBar:"Vrchní pruh",avatar:"Avatar uživatele (v zobrazení profilu)",avatarStatus:"Avatar uživatele (v zobrazení příspěvku)",popup:"Vyskakovací okna a popisky",button:"Tlačítko",buttonHover:"Tlačítko (přejetí myši)",buttonPressed:"Tlačítko (stisknuto)",buttonPressedHover:"Button (stisknuto+přejetí myši)",input:"Vstupní pole"}},fonts:{_tab_label:"Písma",help:"Zvolte písmo, které bude použito pro prvky rozhraní. U možnosti „vlastní“ musíte zadat přesný název písma tak, jak se zobrazuje v systému.",components:{interface:"Rozhraní",input:"Vstupní pole",post:"Text příspěvků",postCode:"Neproporcionální text v příspěvku (formátovaný text)"},family:"Název písma",size:"Velikost (v pixelech)",weight:"Tloušťka",custom:"Vlastní"},preview:{header:"Náhled",content:"Obsah",error:"Příklad chyby",button:"Tlačítko",text:"Spousta dalšího {0} a {1}",mono:"obsahu",input:"Právě jsem přistál v L.A.",faint_link:"pomocný manuál",fine_print:"Přečtěte si náš {0} a nenaučte se nic užitečného!",header_faint:"Tohle je v pohodě",checkbox:"Pročetl/a jsem podmínky používání",link:"hezký malý odkaz"}}},timeline:{collapse:"Zabalit",conversation:"Konverzace",error_fetching:"Chyba při načítání aktualizací",load_older:"Načíst starší příspěvky",no_retweet_hint:"Příspěvek je označen jako pouze pro sledující či přímý a nemůže být zopakován",repeated:"zopakoval/a",show_new:"Zobrazit nové",up_to_date:"Aktuální",no_more_statuses:"Žádné další příspěvky",no_statuses:"Žádné příspěvky"},status:{reply_to:"Odpověď uživateli",replies_list:"Odpovědi:"},user_card:{approve:"Schválit",block:"Blokovat",blocked:"Blokován/a!",deny:"Zamítnout",favorites:"Oblíbené",follow:"Sledovat",follow_sent:"Požadavek odeslán!",follow_progress:"Odeslílám požadavek…",follow_again:"Odeslat požadavek znovu?",follow_unfollow:"Přestat sledovat",followees:"Sledovaní",followers:"Sledující",following:"Sledujete!",follows_you:"Sleduje vás!",its_you:"Jste to vy!",media:"Média",mute:"Ignorovat",muted:"Ignorován/a",per_day:"za den",remote_follow:"Vzdálené sledování",statuses:"Příspěvky",unblock:"Odblokovat",unblock_progress:"Odblokuji…",block_progress:"Blokuji…",unmute:"Přestat ignorovat",unmute_progress:"Ruším ignorování…",mute_progress:"Ignoruji…"},user_profile:{timeline_title:"Uživatelská časová osa",profile_does_not_exist:"Omlouváme se, tento profil neexistuje.",profile_loading_error:"Omlouváme se, při načítání tohoto profilu se vyskytla chyba."},who_to_follow:{more:"Více",who_to_follow:"Koho sledovat"},tool_tip:{media_upload:"Nahrát média",repeat:"Zopakovat",reply:"Odpovědět",favorite:"Oblíbit",user_settings:"Uživatelské nastavení"},upload:{error:{base:"Nahrávání selhalo.",file_too_big:"Soubor je příliš velký [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]",default:"Zkuste to znovu později"},file_size_units:{B:"B",KiB:"KiB",MiB:"MiB",GiB:"GiB",TiB:"TiB"}}}},function(e,t){e.exports={chat:{title:"Chat"},features_panel:{chat:"Chat",gopher:"Gopher",media_proxy:"Media Proxy",scope_options:"Reichweitenoptionen",text_limit:"Textlimit",title:"Features",who_to_follow:"Who to follow"},finder:{error_fetching_user:"Fehler beim Suchen des Benutzers",find_user:"Finde Benutzer"},general:{apply:"Anwenden",submit:"Absenden"},login:{login:"Anmelden",description:"Mit OAuth anmelden",logout:"Abmelden",password:"Passwort",placeholder:"z.B. lain",register:"Registrieren",username:"Benutzername"},nav:{back:"Zurück",chat:"Lokaler Chat",friend_requests:"Followanfragen",mentions:"Erwähnungen",dms:"Direktnachrichten",public_tl:"Öffentliche Zeitleiste",timeline:"Zeitleiste",twkn:"Das gesamte bekannte Netzwerk",user_search:"Benutzersuche",preferences:"Voreinstellungen"},notifications:{broken_favorite:"Unbekannte Nachricht, suche danach...",favorited_you:"favorisierte deine Nachricht",followed_you:"folgt dir",load_older:"Ältere Benachrichtigungen laden",notifications:"Benachrichtigungen",read:"Gelesen!",repeated_you:"wiederholte deine Nachricht"},post_status:{new_status:"Neuen Status veröffentlichen",account_not_locked_warning:"Dein Profil ist nicht {0}. Wer dir folgen will, kann das jederzeit tun und dann auch deine privaten Beiträge sehen.",account_not_locked_warning_link:"gesperrt",attachments_sensitive:"Anhänge als heikel markieren",content_type:{plain_text:"Nur Text"},content_warning:"Betreff (optional)",default:"Sitze gerade im Hofbräuhaus.",direct_warning:"Dieser Beitrag wird nur für die erwähnten Nutzer sichtbar sein.",posting:"Veröffentlichen",scope:{direct:"Direkt - Beitrag nur an erwähnte Profile",private:"Nur Follower - Beitrag nur für Follower sichtbar",public:"Öffentlich - Beitrag an öffentliche Zeitleisten",unlisted:"Nicht gelistet - Nicht in öffentlichen Zeitleisten anzeigen"}},registration:{bio:"Bio",email:"Email",fullname:"Angezeigter Name",password_confirm:"Passwort bestätigen",registration:"Registrierung",token:"Einladungsschlüssel",captcha:"CAPTCHA",new_captcha:"Zum Erstellen eines neuen Captcha auf das Bild klicken.",validations:{username_required:"darf nicht leer sein",fullname_required:"darf nicht leer sein",email_required:"darf nicht leer sein",password_required:"darf nicht leer sein",password_confirmation_required:"darf nicht leer sein",password_confirmation_match:"sollte mit dem Passwort identisch sein."}},settings:{attachmentRadius:"Anhänge",attachments:"Anhänge",autoload:"Aktiviere automatisches Laden von älteren Beiträgen beim scrollen",avatar:"Avatar",avatarAltRadius:"Avatare (Benachrichtigungen)",avatarRadius:"Avatare",background:"Hintergrund",bio:"Bio",btnRadius:"Buttons",cBlue:"Blau (Antworten, Folgt dir)",cGreen:"Grün (Retweet)",cOrange:"Orange (Favorisieren)",cRed:"Rot (Abbrechen)",change_password:"Passwort ändern",change_password_error:"Es gab ein Problem bei der Änderung des Passworts.",changed_password:"Passwort erfolgreich geändert!",collapse_subject:"Beiträge mit Betreff einklappen",composing:"Verfassen",confirm_new_password:"Neues Passwort bestätigen",current_avatar:"Dein derzeitiger Avatar",current_password:"Aktuelles Passwort",current_profile_banner:"Der derzeitige Banner deines Profils",data_import_export_tab:"Datenimport/-export",default_vis:"Standard-Sichtbarkeitsumfang",delete_account:"Account löschen",delete_account_description:"Lösche deinen Account und alle deine Nachrichten unwiderruflich.",delete_account_error:"Es ist ein Fehler beim Löschen deines Accounts aufgetreten. Tritt dies weiterhin auf, wende dich an den Administrator der Instanz.",delete_account_instructions:"Tippe dein Passwort unten in das Feld ein, um die Löschung deines Accounts zu bestätigen.",export_theme:"Farbschema speichern",filtering:"Filtern",filtering_explanation:"Alle Beiträge die diese Wörter enthalten werden ausgeblendet. Ein Wort pro Zeile.",follow_export:"Follower exportieren",follow_export_button:"Exportiere deine Follows in eine csv-Datei",follow_export_processing:"In Bearbeitung. Die Liste steht gleich zum herunterladen bereit.",follow_import:"Followers importieren",follow_import_error:"Fehler beim importieren der Follower",follows_imported:"Followers importiert! Die Bearbeitung kann eine Zeit lang dauern.",foreground:"Vordergrund",general:"Allgemein",hide_attachments_in_convo:"Anhänge in Unterhaltungen ausblenden",hide_attachments_in_tl:"Anhänge in der Zeitleiste ausblenden",hide_isp:"Instanz-spezifisches Panel ausblenden",preload_images:"Bilder vorausladen",hide_post_stats:"Beitragsstatistiken verbergen (z.B. die Anzahl der Favoriten)",hide_user_stats:"Benutzerstatistiken verbergen (z.B. die Anzahl der Follower)",hide_filtered_statuses:"Gefilterte Beiträge verbergen",import_followers_from_a_csv_file:"Importiere Follower, denen du folgen möchtest, aus einer CSV-Datei",import_theme:"Farbschema laden",inputRadius:"Eingabefelder",checkboxRadius:"Auswahlfelder",instance_default:"(Standard: {value})",instance_default_simple:"(Standard)",interface:"Oberfläche",interfaceLanguage:"Sprache der Oberfläche",invalid_theme_imported:"Die ausgewählte Datei ist kein unterstütztes Pleroma-Theme. Keine Änderungen wurden vorgenommen.",limited_availability:"In deinem Browser nicht verfügbar",links:"Links",lock_account_description:"Sperre deinen Account, um neue Follower zu genehmigen oder abzulehnen",loop_video:"Videos wiederholen",loop_video_silent_only:'Nur Videos ohne Ton wiederholen (z.B. Mastodons "gifs")',name:"Name",name_bio:"Name & Bio",new_password:"Neues Passwort",notification_visibility:"Benachrichtigungstypen, die angezeigt werden sollen",notification_visibility_follows:"Follows",notification_visibility_likes:"Favoriten",notification_visibility_mentions:"Erwähnungen",notification_visibility_repeats:"Wiederholungen",no_rich_text_description:"Rich-Text Formatierungen von allen Beiträgen entfernen",hide_follows_description:"Zeige nicht, wem ich folge",hide_followers_description:"Zeige nicht, wer mir folgt",nsfw_clickthrough:"Aktiviere ausblendbares Overlay für Anhänge, die als NSFW markiert sind",oauth_tokens:"OAuth-Token",token:"Zeichen",refresh_token:"Token aktualisieren",valid_until:"Gültig bis",revoke_token:"Widerrufen",panelRadius:"Panel",pause_on_unfocused:"Streaming pausieren, wenn das Tab nicht fokussiert ist",presets:"Voreinstellungen",profile_background:"Profilhintergrund",profile_banner:"Profilbanner",profile_tab:"Profil",radii_help:"Kantenrundung (in Pixel) der Oberfläche anpassen",replies_in_timeline:"Antworten in der Zeitleiste",reply_link_preview:"Antwortlink-Vorschau beim Überfahren mit der Maus aktivieren",reply_visibility_all:"Alle Antworten zeigen",reply_visibility_following:"Zeige nur Antworten an mich oder an Benutzer, denen ich folge",reply_visibility_self:"Nur Antworten an mich anzeigen",saving_err:"Fehler beim Speichern der Einstellungen",saving_ok:"Einstellungen gespeichert",security_tab:"Sicherheit",scope_copy:"Reichweite beim Antworten übernehmen (Direktnachrichten werden immer kopiert)",set_new_avatar:"Setze einen neuen Avatar",set_new_profile_background:"Setze einen neuen Hintergrund für dein Profil",set_new_profile_banner:"Setze einen neuen Banner für dein Profil",settings:"Einstellungen",subject_input_always_show:"Betreff-Feld immer anzeigen",subject_line_behavior:"Betreff beim Antworten kopieren",subject_line_email:'Wie Email: "re: Betreff"',subject_line_mastodon:"Wie Mastodon: unverändert kopieren",subject_line_noop:"Nicht kopieren",stop_gifs:"Play-on-hover GIFs",streaming:"Aktiviere automatisches Laden (Streaming) von neuen Beiträgen",text:"Text",theme:"Farbschema",theme_help:"Benutze HTML-Farbcodes (#rrggbb) um dein Farbschema anzupassen",theme_help_v2_1:'Du kannst auch die Farben und die Deckkraft bestimmter Komponenten überschreiben, indem du das Kontrollkästchen umschaltest. Verwende die Schaltfläche "Alle löschen", um alle Überschreibungen zurückzusetzen.',theme_help_v2_2:"Unter einigen Einträgen befinden sich Symbole für Hintergrund-/Textkontrastindikatoren, für detaillierte Informationen fahre mit der Maus darüber. Bitte beachte, dass bei der Verwendung von Transparenz Kontrastindikatoren den schlechtest möglichen Fall darstellen.",tooltipRadius:"Tooltips/Warnungen",user_settings:"Benutzereinstellungen",values:{false:"nein",true:"Ja"},notifications:"Benachrichtigungen",enable_web_push_notifications:"Web-Pushbenachrichtigungen aktivieren",style:{switcher:{keep_color:"Farben beibehalten",keep_shadows:"Schatten beibehalten",keep_opacity:"Deckkraft beibehalten",keep_roundness:"Abrundungen beibehalten",keep_fonts:"Schriften beibehalten",save_load_hint:'Die "Beibehalten"-Optionen behalten die aktuell eingestellten Optionen beim Auswählen oder Laden von Designs bei, sie speichern diese Optionen auch beim Exportieren eines Designs. Wenn alle Kontrollkästchen deaktiviert sind, wird beim Exportieren des Designs alles gespeichert.',reset:"Zurücksetzen",clear_all:"Alles leeren",clear_opacity:"Deckkraft leeren"},common:{color:"Farbe",opacity:"Deckkraft",contrast:{hint:"Das Kontrastverhältnis ist {ratio}, es {level} {context}",level:{aa:"entspricht Level AA Richtlinie (minimum)",aaa:"entspricht Level AAA Richtlinie (empfohlen)",bad:"entspricht keiner Richtlinien zur Barrierefreiheit"},context:{"18pt":"für großen (18pt+) Text",text:"für Text"}}},common_colors:{_tab_label:"Allgemein",main:"Allgemeine Farben",foreground_hint:'Siehe Reiter "Erweitert" für eine detailliertere Einstellungen',rgbo:"Symbole, Betonungen, Kennzeichnungen"},advanced_colors:{_tab_label:"Erweitert",alert:"Warnhinweis-Hintergrund",alert_error:"Fehler",badge:"Kennzeichnungs-Hintergrund",badge_notification:"Benachrichtigung",panel_header:"Panel-Kopf",top_bar:"Obere Leiste",borders:"Rahmen",buttons:"Schaltflächen",inputs:"Eingabefelder",faint_text:"Verblasster Text"},radii:{_tab_label:"Abrundungen"},shadows:{_tab_label:"Schatten und Beleuchtung",component:"Komponente",override:"Überschreiben",shadow_id:"Schatten #{value}",blur:"Unschärfe",spread:"Streuung",inset:"Einsatz",hint:"Für Schatten kannst du auch --variable als Farbwert verwenden, um CSS3-Variablen zu verwenden. Bitte beachte, dass die Einstellung der Deckkraft in diesem Fall nicht funktioniert.",filter_hint:{always_drop_shadow:"Achtung, dieser Schatten verwendet immer {0}, wenn der Browser dies unterstützt.",drop_shadow_syntax:"{0} unterstützt Parameter {1} und Schlüsselwort {2} nicht.",avatar_inset:"Bitte beachte, dass die Kombination von eingesetzten und nicht eingesetzten Schatten auf Avataren zu unerwarteten Ergebnissen bei transparenten Avataren führen kann.",spread_zero:"Schatten mit einer Streuung > 0 erscheinen so, als ob sie auf Null gesetzt wären.",inset_classic:"Eingesetzte Schatten werden mit {0} verwendet"},components:{panel:"Panel",panelHeader:"Panel-Kopf",topBar:"Obere Leiste",avatar:"Benutzer-Avatar (in der Profilansicht)",avatarStatus:"Benutzer-Avatar (in der Beitragsanzeige)",popup:"Dialogfenster und Hinweistexte",button:"Schaltfläche",buttonHover:"Schaltfläche (hover)",buttonPressed:"Schaltfläche (gedrückt)",buttonPressedHover:"Schaltfläche (gedrückt+hover)",input:"Input field"}},fonts:{_tab_label:"Schriften",help:'Wähl die Schriftart, die für Elemente der Benutzeroberfläche verwendet werden soll. Für " Benutzerdefiniert" musst du den genauen Schriftnamen eingeben, wie er im System angezeigt wird.',components:{interface:"Oberfläche",input:"Eingabefelder",post:"Beitragstext",postCode:"Dicktengleicher Text in einem Beitrag (Rich-Text)"},family:"Schriftname",size:"Größe (in px)",weight:"Gewicht (Dicke)",custom:"Benutzerdefiniert"},preview:{header:"Vorschau",content:"Inhalt",error:"Beispielfehler",button:"Schaltfläche",text:"Ein Haufen mehr von {0} und {1}",mono:"Inhalt",input:"Sitze gerade im Hofbräuhaus.",faint_link:"Hilfreiche Anleitung",fine_print:"Lies unser {0}, um nichts Nützliches zu lernen!",header_faint:"Das ist in Ordnung",checkbox:"Ich habe die Allgemeinen Geschäftsbedingungen überflogen",link:"ein netter kleiner Link"}}},timeline:{collapse:"Einklappen",conversation:"Unterhaltung",error_fetching:"Fehler beim Laden",load_older:"Lade ältere Beiträge",no_retweet_hint:"Der Beitrag ist als nur-für-Follower oder als Direktnachricht markiert und kann nicht wiederholt werden.",repeated:"wiederholte",show_new:"Zeige Neuere",up_to_date:"Aktuell"},user_card:{approve:"Genehmigen",block:"Blockieren",blocked:"Blockiert!",deny:"Ablehnen",follow:"Folgen",follow_sent:"Anfrage gesendet!",follow_progress:"Anfragen…",follow_again:"Anfrage erneut senden?",follow_unfollow:"Folgen beenden",followees:"Folgt",followers:"Followers",following:"Folgst du!",follows_you:"Folgt dir!",its_you:"Das bist du!",mute:"Stummschalten",muted:"Stummgeschaltet",per_day:"pro Tag",remote_follow:"Folgen",statuses:"Beiträge"},user_profile:{timeline_title:"Beiträge"},who_to_follow:{more:"Mehr",who_to_follow:"Wem soll ich folgen"},tool_tip:{media_upload:"Medien hochladen",repeat:"Wiederholen",reply:"Antworten",favorite:"Favorisieren",user_settings:"Benutzereinstellungen"},upload:{error:{base:"Hochladen fehlgeschlagen.",file_too_big:"Datei ist zu groß [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]",default:"Bitte versuche es später erneut"},file_size_units:{B:"B",KiB:"KiB",MiB:"MiB",GiB:"GiB",TiB:"TiB"}}}},function(e,t){e.exports={chat:{title:"Chat"},features_panel:{chat:"Chat",gopher:"Gopher",media_proxy:"Media proxy",scope_options:"Scope options",text_limit:"Text limit",title:"Features",who_to_follow:"Who to follow"},finder:{error_fetching_user:"Error fetching user",find_user:"Find user"},general:{apply:"Apply",submit:"Submit",more:"More",generic_error:"An error occured",optional:"optional"},image_cropper:{crop_picture:"Crop picture",save:"Save",cancel:"Cancel"},login:{login:"Log in",description:"Log in with OAuth",logout:"Log out",password:"Password",placeholder:"e.g. lain",register:"Register",username:"Username",hint:"Log in to join the discussion"},media_modal:{previous:"Previous",next:"Next"},nav:{about:"About",back:"Back",chat:"Local Chat",friend_requests:"Follow Requests",mentions:"Mentions",dms:"Direct Messages",public_tl:"Public Timeline",timeline:"Timeline",twkn:"The Whole Known Network",user_search:"User Search",who_to_follow:"Who to follow",preferences:"Preferences"},notifications:{broken_favorite:"Unknown status, searching for it...",favorited_you:"favorited your status",followed_you:"followed you",load_older:"Load older notifications",notifications:"Notifications",read:"Read!",repeated_you:"repeated your status",no_more_notifications:"No more notifications"},post_status:{new_status:"Post new status",account_not_locked_warning:"Your account is not {0}. Anyone can follow you to view your follower-only posts.",account_not_locked_warning_link:"locked",attachments_sensitive:"Mark attachments as sensitive",content_type:{"text/plain":"Plain text","text/html":"HTML","text/markdown":"Markdown"},content_warning:"Subject (optional)",default:"Just landed in L.A.",direct_warning:"This post will only be visible to all the mentioned users.",posting:"Posting",scope:{direct:"Direct - Post to mentioned users only",private:"Followers-only - Post to followers only",public:"Public - Post to public timelines",unlisted:"Unlisted - Do not post to public timelines"}},registration:{ +bio:"Bio",email:"Email",fullname:"Display name",password_confirm:"Password confirmation",registration:"Registration",token:"Invite token",captcha:"CAPTCHA",new_captcha:"Click the image to get a new captcha",username_placeholder:"e.g. lain",fullname_placeholder:"e.g. Lain Iwakura",bio_placeholder:"e.g.\nHi, I'm Lain\nI’m an anime girl living in suburban Japan. You may know me from the Wired.",validations:{username_required:"cannot be left blank",fullname_required:"cannot be left blank",email_required:"cannot be left blank",password_required:"cannot be left blank",password_confirmation_required:"cannot be left blank",password_confirmation_match:"should be the same as password"}},settings:{app_name:"App name",attachmentRadius:"Attachments",attachments:"Attachments",autoload:"Enable automatic loading when scrolled to the bottom",avatar:"Avatar",avatarAltRadius:"Avatars (Notifications)",avatarRadius:"Avatars",background:"Background",bio:"Bio",blocks_tab:"Blocks",btnRadius:"Buttons",cBlue:"Blue (Reply, follow)",cGreen:"Green (Retweet)",cOrange:"Orange (Favorite)",cRed:"Red (Cancel)",change_password:"Change Password",change_password_error:"There was an issue changing your password.",changed_password:"Password changed successfully!",collapse_subject:"Collapse posts with subjects",composing:"Composing",confirm_new_password:"Confirm new password",current_avatar:"Your current avatar",current_password:"Current password",current_profile_banner:"Your current profile banner",data_import_export_tab:"Data Import / Export",default_vis:"Default visibility scope",delete_account:"Delete Account",delete_account_description:"Permanently delete your account and all your messages.",delete_account_error:"There was an issue deleting your account. If this persists please contact your instance administrator.",delete_account_instructions:"Type your password in the input below to confirm account deletion.",avatar_size_instruction:"The recommended minimum size for avatar images is 150x150 pixels.",export_theme:"Save preset",filtering:"Filtering",filtering_explanation:"All statuses containing these words will be muted, one per line",follow_export:"Follow export",follow_export_button:"Export your follows to a csv file",follow_export_processing:"Processing, you'll soon be asked to download your file",follow_import:"Follow import",follow_import_error:"Error importing followers",follows_imported:"Follows imported! Processing them will take a while.",foreground:"Foreground",general:"General",hide_attachments_in_convo:"Hide attachments in conversations",hide_attachments_in_tl:"Hide attachments in timeline",max_thumbnails:"Maximum amount of thumbnails per post",hide_isp:"Hide instance-specific panel",preload_images:"Preload images",use_one_click_nsfw:"Open NSFW attachments with just one click",hide_post_stats:"Hide post statistics (e.g. the number of favorites)",hide_user_stats:"Hide user statistics (e.g. the number of followers)",hide_filtered_statuses:"Hide filtered statuses",import_followers_from_a_csv_file:"Import follows from a csv file",import_theme:"Load preset",inputRadius:"Input fields",checkboxRadius:"Checkboxes",instance_default:"(default: {value})",instance_default_simple:"(default)",interface:"Interface",interfaceLanguage:"Interface language",invalid_theme_imported:"The selected file is not a supported Pleroma theme. No changes to your theme were made.",limited_availability:"Unavailable in your browser",links:"Links",lock_account_description:"Restrict your account to approved followers only",loop_video:"Loop videos",loop_video_silent_only:'Loop only videos without sound (i.e. Mastodon\'s "gifs")',mutes_tab:"Mutes",play_videos_in_modal:"Play videos directly in the media viewer",use_contain_fit:"Don't crop the attachment in thumbnails",name:"Name",name_bio:"Name & Bio",new_password:"New password",notification_visibility:"Types of notifications to show",notification_visibility_follows:"Follows",notification_visibility_likes:"Likes",notification_visibility_mentions:"Mentions",notification_visibility_repeats:"Repeats",no_rich_text_description:"Strip rich text formatting from all posts",no_blocks:"No blocks",no_mutes:"No mutes",hide_follows_description:"Don't show who I'm following",hide_followers_description:"Don't show who's following me",show_admin_badge:"Show Admin badge in my profile",show_moderator_badge:"Show Moderator badge in my profile",nsfw_clickthrough:"Enable clickthrough NSFW attachment hiding",oauth_tokens:"OAuth tokens",token:"Token",refresh_token:"Refresh Token",valid_until:"Valid Until",revoke_token:"Revoke",panelRadius:"Panels",pause_on_unfocused:"Pause streaming when tab is not focused",presets:"Presets",profile_background:"Profile Background",profile_banner:"Profile Banner",profile_tab:"Profile",radii_help:"Set up interface edge rounding (in pixels)",replies_in_timeline:"Replies in timeline",reply_link_preview:"Enable reply-link preview on mouse hover",reply_visibility_all:"Show all replies",reply_visibility_following:"Only show replies directed at me or users I'm following",reply_visibility_self:"Only show replies directed at me",saving_err:"Error saving settings",saving_ok:"Settings saved",security_tab:"Security",scope_copy:"Copy scope when replying (DMs are always copied)",set_new_avatar:"Set new avatar",set_new_profile_background:"Set new profile background",set_new_profile_banner:"Set new profile banner",settings:"Settings",subject_input_always_show:"Always show subject field",subject_line_behavior:"Copy subject when replying",subject_line_email:'Like email: "re: subject"',subject_line_mastodon:"Like mastodon: copy as is",subject_line_noop:"Do not copy",post_status_content_type:"Post status content type",stop_gifs:"Play-on-hover GIFs",streaming:"Enable automatic streaming of new posts when scrolled to the top",text:"Text",theme:"Theme",theme_help:"Use hex color codes (#rrggbb) to customize your color theme.",theme_help_v2_1:'You can also override certain component\'s colors and opacity by toggling the checkbox, use "Clear all" button to clear all overrides.',theme_help_v2_2:"Icons underneath some entries are background/text contrast indicators, hover over for detailed info. Please keep in mind that when using transparency contrast indicators show the worst possible case.",tooltipRadius:"Tooltips/alerts",upload_a_photo:"Upload a photo",user_settings:"User Settings",values:{false:"no",true:"yes"},notifications:"Notifications",enable_web_push_notifications:"Enable web push notifications",style:{switcher:{keep_color:"Keep colors",keep_shadows:"Keep shadows",keep_opacity:"Keep opacity",keep_roundness:"Keep roundness",keep_fonts:"Keep fonts",save_load_hint:'"Keep" options preserve currently set options when selecting or loading themes, it also stores said options when exporting a theme. When all checkboxes unset, exporting theme will save everything.',reset:"Reset",clear_all:"Clear all",clear_opacity:"Clear opacity"},common:{color:"Color",opacity:"Opacity",contrast:{hint:"Contrast ratio is {ratio}, it {level} {context}",level:{aa:"meets Level AA guideline (minimal)",aaa:"meets Level AAA guideline (recommended)",bad:"doesn't meet any accessibility guidelines"},context:{"18pt":"for large (18pt+) text",text:"for text"}}},common_colors:{_tab_label:"Common",main:"Common colors",foreground_hint:'See "Advanced" tab for more detailed control',rgbo:"Icons, accents, badges"},advanced_colors:{_tab_label:"Advanced",alert:"Alert background",alert_error:"Error",badge:"Badge background",badge_notification:"Notification",panel_header:"Panel header",top_bar:"Top bar",borders:"Borders",buttons:"Buttons",inputs:"Input fields",faint_text:"Faded text"},radii:{_tab_label:"Roundness"},shadows:{_tab_label:"Shadow and lighting",component:"Component",override:"Override",shadow_id:"Shadow #{value}",blur:"Blur",spread:"Spread",inset:"Inset",hint:"For shadows you can also use --variable as a color value to use CSS3 variables. Please note that setting opacity won't work in this case.",filter_hint:{always_drop_shadow:"Warning, this shadow always uses {0} when browser supports it.",drop_shadow_syntax:"{0} does not support {1} parameter and {2} keyword.",avatar_inset:"Please note that combining both inset and non-inset shadows on avatars might give unexpected results with transparent avatars.",spread_zero:"Shadows with spread > 0 will appear as if it was set to zero",inset_classic:"Inset shadows will be using {0}"},components:{panel:"Panel",panelHeader:"Panel header",topBar:"Top bar",avatar:"User avatar (in profile view)",avatarStatus:"User avatar (in post display)",popup:"Popups and tooltips",button:"Button",buttonHover:"Button (hover)",buttonPressed:"Button (pressed)",buttonPressedHover:"Button (pressed+hover)",input:"Input field"}},fonts:{_tab_label:"Fonts",help:'Select font to use for elements of UI. For "custom" you have to enter exact font name as it appears in system.',components:{interface:"Interface",input:"Input fields",post:"Post text",postCode:"Monospaced text in a post (rich text)"},family:"Font name",size:"Size (in px)",weight:"Weight (boldness)",custom:"Custom"},preview:{header:"Preview",content:"Content",error:"Example error",button:"Button",text:"A bunch of more {0} and {1}",mono:"content",input:"Just landed in L.A.",faint_link:"helpful manual",fine_print:"Read our {0} to learn nothing useful!",header_faint:"This is fine",checkbox:"I have skimmed over terms and conditions",link:"a nice lil' link"}}},timeline:{collapse:"Collapse",conversation:"Conversation",error_fetching:"Error fetching updates",load_older:"Load older statuses",no_retweet_hint:"Post is marked as followers-only or direct and cannot be repeated",repeated:"repeated",show_new:"Show new",up_to_date:"Up-to-date",no_more_statuses:"No more statuses",no_statuses:"No statuses"},status:{reply_to:"Reply to",replies_list:"Replies:"},user_card:{approve:"Approve",block:"Block",blocked:"Blocked!",deny:"Deny",favorites:"Favorites",follow:"Follow",follow_sent:"Request sent!",follow_progress:"Requesting…",follow_again:"Send request again?",follow_unfollow:"Unfollow",followees:"Following",followers:"Followers",following:"Following!",follows_you:"Follows you!",its_you:"It's you!",media:"Media",mute:"Mute",muted:"Muted",per_day:"per day",remote_follow:"Remote follow",statuses:"Statuses",unblock:"Unblock",unblock_progress:"Unblocking...",block_progress:"Blocking...",unmute:"Unmute",unmute_progress:"Unmuting...",mute_progress:"Muting..."},user_profile:{timeline_title:"User Timeline",profile_does_not_exist:"Sorry, this profile does not exist.",profile_loading_error:"Sorry, there was an error loading this profile."},who_to_follow:{more:"More",who_to_follow:"Who to follow"},tool_tip:{media_upload:"Upload Media",repeat:"Repeat",reply:"Reply",favorite:"Favorite",user_settings:"User Settings"},upload:{error:{base:"Upload failed.",file_too_big:"File too big [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]",default:"Try again later"},file_size_units:{B:"B",KiB:"KiB",MiB:"MiB",GiB:"GiB",TiB:"TiB"}}}},function(e,t){e.exports={chat:{title:"Babilejo"},features_panel:{chat:"Babilejo",gopher:"Gopher",media_proxy:"Aŭdvidaĵa prokurilo",scope_options:"Agordoj de amplekso",text_limit:"Teksta limo",title:"Funkcioj",who_to_follow:"Kiun aboni"},finder:{error_fetching_user:"Eraro alportante uzanton",find_user:"Trovi uzanton"},general:{apply:"Apliki",submit:"Sendi",more:"Pli",generic_error:"Eraro okazis",optional:"Malnepra"},image_cropper:{crop_picture:"Tondi bildon",save:"Konservi",cancel:"Nuligi"},login:{login:"Saluti",description:"Saluti per OAuth",logout:"Adiaŭi",password:"Pasvorto",placeholder:"ekz. lain",register:"Registriĝi",username:"Salutnomo",hint:"Salutu por partopreni la diskutadon"},media_modal:{previous:"Antaŭa",next:"Sekva"},nav:{about:"Pri",back:"Reen",chat:"Loka babilejo",friend_requests:"Abonaj petoj",mentions:"Mencioj",dms:"Rektaj mesaĝoj",public_tl:"Publika tempolinio",timeline:"Tempolinio",twkn:"La tuta konata reto",user_search:"Serĉi uzantojn",who_to_follow:"Kiun aboni",preferences:"Agordoj"},notifications:{broken_favorite:"Nekonata stato, serĉante ĝin…",favorited_you:"ŝatis vian staton",followed_you:"ekabonis vin",load_older:"Enlegi pli malnovajn sciigojn",notifications:"Sciigoj",read:"Legite!",repeated_you:"ripetis vian staton",no_more_notifications:"Neniuj pliaj sciigoj"},post_status:{new_status:"Afiŝi novan staton",account_not_locked_warning:"Via konto ne estas {0}. Iu ajn povas vin aboni por vidi viajn afiŝoj nur por abonantoj.",account_not_locked_warning_link:"ŝlosita",attachments_sensitive:"Marki kunsendaĵojn kiel konsternajn",content_type:{plain_text:"Plata teksto"},content_warning:"Temo (malnepra)",default:"Ĵus alvenis al la Universala Kongreso!",direct_warning:"Ĉi tiu afiŝo estos videbla nur por ĉiuj menciitaj uzantoj.",posting:"Afiŝante",scope:{direct:"Rekta – Afiŝi nur al menciitaj uzantoj",private:"Nur abonantoj – Afiŝi nur al abonantoj",public:"Publika – Afiŝi al publikaj tempolinioj",unlisted:"Nelistigita – Ne afiŝi al publikaj tempolinioj"}},registration:{bio:"Priskribo",email:"Retpoŝtadreso",fullname:"Vidiga nomo",password_confirm:"Konfirmo de pasvorto",registration:"Registriĝo",token:"Invita ĵetono",captcha:"TESTO DE HOMECO",new_captcha:"Alklaku la bildon por akiri novan teston",username_placeholder:"ekz. lain",fullname_placeholder:"ekz. Lain Iwakura",bio_placeholder:"ekz.\nSaluton, mi estas Lain\nMi estas animea knabino vivante en Japanujo. Eble vi konas min de la retejo « Wired ».",validations:{username_required:"ne povas resti malplena",fullname_required:"ne povas resti malplena",email_required:"ne povas resti malplena",password_required:"ne povas resti malplena",password_confirmation_required:"ne povas resti malplena",password_confirmation_match:"samu la pasvorton"}},settings:{app_name:"Nomo de aplikaĵo",attachmentRadius:"Kunsendaĵoj",attachments:"Kunsendaĵoj",autoload:"Ŝalti memfaran enlegadon ĉe subo de paĝo",avatar:"Profilbildo",avatarAltRadius:"Profilbildoj (sciigoj)",avatarRadius:"Profilbildoj",background:"Fono",bio:"Priskribo",blocks_tab:"Baroj",btnRadius:"Butonoj",cBlue:"Blua (Respondo, abono)",cGreen:"Verda (Kunhavigo)",cOrange:"Oranĝa (Ŝato)",cRed:"Ruĝa (Nuligo)",change_password:"Ŝanĝi pasvorton",change_password_error:"Okazis eraro dum ŝanĝo de via pasvorto.",changed_password:"Pasvorto sukcese ŝanĝiĝis!",collapse_subject:"Maletendi afiŝojn kun temoj",composing:"Verkante",confirm_new_password:"Konfirmu novan pasvorton",current_avatar:"Via nuna profilbildo",current_password:"Nuna pasvorto",current_profile_banner:"Via nuna profila rubando",data_import_export_tab:"Enporto / Elporto de datenoj",default_vis:"Implicita videbleca amplekso",delete_account:"Forigi konton",delete_account_description:"Por ĉiam forigi vian konton kaj ĉiujn viajn mesaĝojn",delete_account_error:"Okazis eraro dum forigo de via kanto. Se tio daŭre okazados, bonvolu kontakti la administranton de via nodo.",delete_account_instructions:"Entajpu sube vian pasvorton por konfirmi forigon de konto.",avatar_size_instruction:"La rekomendata malpleja grando de profilbildoj estas 150×150 bilderoj.",export_theme:"Konservi antaŭagordon",filtering:"Filtrado",filtering_explanation:"Ĉiuj statoj kun tiuj ĉi vortoj silentiĝos, po unu linio",follow_export:"Abona elporto",follow_export_button:"Elporti viajn abonojn al CSV-dosiero",follow_export_processing:"Traktante; baldaŭ vi ricevos peton elŝuti la dosieron",follow_import:"Abona enporto",follow_import_error:"Eraro enportante abonojn",follows_imported:"Abonoj enportiĝis! Traktado daŭros iom.",foreground:"Malfono",general:"Ĝenerala",hide_attachments_in_convo:"Kaŝi kunsendaĵojn en interparoloj",hide_attachments_in_tl:"Kaŝi kunsendaĵojn en tempolinio",max_thumbnails:"Plej multa nombro da bildetoj po afiŝo",hide_isp:"Kaŝi nodo-propran breton",preload_images:"Antaŭ-enlegi bildojn",use_one_click_nsfw:"Malfermi konsternajn kunsendaĵojn per nur unu klako",hide_post_stats:"Kaŝi statistikon de afiŝoj (ekz. nombron da ŝatoj)",hide_user_stats:"Kaŝi statistikon de uzantoj (ekz. nombron da abonantoj)",hide_filtered_statuses:"Kaŝi filtritajn statojn",import_followers_from_a_csv_file:"Enporti abonojn el CSV-dosiero",import_theme:"Enlegi antaŭagordojn",inputRadius:"Enigaj kampoj",checkboxRadius:"Markbutonoj",instance_default:"(implicita: {value})",instance_default_simple:"(implicita)",interface:"Fasado",interfaceLanguage:"Lingvo de fasado",invalid_theme_imported:"La elektita dosiero ne estas subtenata haŭto de Pleromo. Neniuj ŝanĝoj al via haŭto okazis.",limited_availability:"Nehavebla en via foliumilo",links:"Ligiloj",lock_account_description:"Limigi vian konton al nur abonantoj aprobitaj",loop_video:"Ripetadi filmojn",loop_video_silent_only:'Ripetadi nur filmojn sen sono (ekz. la "GIF-ojn" de Mastodon)',mutes_tab:"Silentigoj",play_videos_in_modal:"Ludi filmojn rekte en la aŭdvidaĵa spektilo",use_contain_fit:"Ne tondi la kunsendaĵon en bildetoj",name:"Nomo",name_bio:"Nomo kaj priskribo",new_password:"Nova pasvorto",notification_visibility:"Montrotaj specoj de sciigoj",notification_visibility_follows:"Abonoj",notification_visibility_likes:"Ŝatoj",notification_visibility_mentions:"Mencioj",notification_visibility_repeats:"Ripetoj",no_rich_text_description:"Forigi riĉtekstajn formojn de ĉiuj afiŝoj",no_blocks:"Neniuj baroj",no_mutes:"Neniuj silentigoj",hide_follows_description:"Ne montri kiun mi sekvas",hide_followers_description:"Ne montri kiu min sekvas",show_admin_badge:"Montri la insignon de administranto en mia profilo",show_moderator_badge:"Montri la insignon de kontrolanto en mia profilo",nsfw_clickthrough:"Ŝalti traklakan kaŝon de konsternaj kunsendaĵoj",oauth_tokens:"Ĵetonoj de OAuth",token:"Ĵetono",refresh_token:"Ĵetono de novigo",valid_until:"Valida ĝis",revoke_token:"Senvalidigi",panelRadius:"Bretoj",pause_on_unfocused:"Paŭzigi elsendfluon kiam langeto ne estas fokusata",presets:"Antaŭagordoj",profile_background:"Profila fono",profile_banner:"Profila rubando",profile_tab:"Profilo",radii_help:"Agordi fasadan rondigon de randoj (bildere)",replies_in_timeline:"Respondoj en tempolinio",reply_link_preview:"Ŝalti respond-ligilan antaŭvidon dum musa ŝvebo",reply_visibility_all:"Montri ĉiujn respondojn",reply_visibility_following:"Montri nur respondojn por mi aŭ miaj abonatoj",reply_visibility_self:"Montri nur respondojn por mi",saving_err:"Eraro dum konservo de agordoj",saving_ok:"Agordoj konserviĝis",security_tab:"Sekureco",scope_copy:"Kopii amplekson por respondo (rektaj mesaĝoj ĉiam kopiiĝas)",set_new_avatar:"Agordi novan profilbildon",set_new_profile_background:"Agordi novan profilan fonon",set_new_profile_banner:"Agordi novan profilan rubandon",settings:"Agordoj",subject_input_always_show:"Ĉiam montri teman kampon",subject_line_behavior:"Kopii temon por respondo",subject_line_email:'Kiel retpoŝto: "re: temo"',subject_line_mastodon:"Kiel Mastodon: kopii senŝanĝe",subject_line_noop:"Ne kopii",post_status_content_type:"Afiŝi specon de la enhavo de la stato",stop_gifs:"Movi GIF-bildojn dum musa ŝvebo",streaming:"Ŝalti memfaran fluigon de novaj afiŝoj ĉe la supro de la paĝo",text:"Teksto",theme:"Haŭto",theme_help:"Uzu deksesumajn kolorkodojn (#rrvvbb) por adapti vian koloran haŭton.",theme_help_v2_1:'Vi ankaŭ povas superagordi la kolorojn kaj travideblecon de kelkaj eroj per marko de la markbutono; uzu la butonon "Vakigi ĉion" por forigi ĉîujn superagordojn.',theme_help_v2_2:"Bildsimboloj sub kelkaj eroj estas indikiloj de kontrasto inter fono kaj teksto; muse ŝvebu por detalaj informoj. Bonvolu memori, ke la indikilo montras la plej malbonan okazeblon dum sia uzo.",tooltipRadius:"Ŝpruchelpiloj/avertoj",upload_a_photo:"Alŝuti foton",user_settings:"Agordoj de uzanto",values:{false:"ne",true:"jes"},notifications:"Sciigoj",enable_web_push_notifications:"Ŝalti retajn puŝajn sciigojn",style:{switcher:{keep_color:"Konservi kolorojn",keep_shadows:"Konservi ombrojn",keep_opacity:"Konservi maltravideblecon",keep_roundness:"Konservi rondecon",keep_fonts:"Konservi tiparojn",save_load_hint:'Elektebloj de "konservi" konservas la nuntempajn agordojn dum elektado aŭ enlegado de haŭtoj. Ĝi ankaŭ konservas tiujn agordojn dum elportado de haŭto. Kun ĉiuj markbutonoj nemarkitaj, elporto de la haŭto ĉion konservos.',reset:"Restarigi",clear_all:"Vakigi ĉion",clear_opacity:"Vakigi maltravideblecon"},common:{color:"Koloro",opacity:"Maltravidebleco",contrast:{hint:"Proporcio de kontrasto estas {ratio}, ĝi {level} {context}",level:{aa:"plenumas la gvidilon je nivelo AA (malpleja)",aaa:"plenumas la gvidilon je nivela AAA (rekomendita)",bad:"plenumas neniujn faciluzajn gvidilojn"},context:{"18pt":"por granda (18pt+) teksto",text:"por teksto"}}},common_colors:{_tab_label:"Komunaj",main:"Komunaj koloroj",foreground_hint:'Vidu langeton "Specialaj" por pli detalaj agordoj',rgbo:"Bildsimboloj, emfazoj, insignoj"},advanced_colors:{_tab_label:"Specialaj",alert:"Averta fono",alert_error:"Eraro",badge:"Insigna fono",badge_notification:"Sciigo",panel_header:"Kapo de breto",top_bar:"Supra breto",borders:"Limoj",buttons:"Butonoj",inputs:"Enigaj kampoj",faint_text:"Malvigla teksto"},radii:{_tab_label:"Rondeco"},shadows:{_tab_label:"Ombro kaj lumo",component:"Ero",override:"Transpasi",shadow_id:"Ombro #{value}",blur:"Malklarigo",spread:"Vastigo",inset:"Internigo",hint:"Por ombroj vi ankaŭ povas uzi --variable kiel koloran valoron, por uzi variantojn de CSS3. Bonvolu rimarki, ke tiuokaze agordoj de maltravidebleco ne funkcios.",filter_hint:{always_drop_shadow:"Averto: ĉi tiu ombro ĉiam uzas {0} kiam la foliumilo ĝin subtenas.",drop_shadow_syntax:"{0} ne subtenas parametron {1} kaj ŝlosilvorton {2}.",avatar_inset:"Bonvolu rimarki, ke agordi ambaŭ internajn kaj eksterajn ombrojn por profilbildoj povas redoni neatenditajn rezultojn ĉe profilbildoj travideblaj.",spread_zero:"Ombroj kun vastigo > 0 aperos kvazaŭ ĝi estus fakte nulo",inset_classic:"Internaj ombroj uzos {0}"},components:{panel:"Breto",panelHeader:"Kapo de breto",topBar:"Supra breto",avatar:"Profilbildo de uzanto (en profila vido)",avatarStatus:"Profilbildo de uzanto (en afiŝa vido)",popup:"Ŝprucaĵoj",button:"Butono",buttonHover:"Butono (je ŝvebo)",buttonPressed:"Butono (premita)",buttonPressedHover:"Butono (premita je ŝvebo)",input:"Eniga kampo"}},fonts:{_tab_label:"Tiparoj",help:'Elektu tiparon uzotan por eroj de la fasado. Por "propra" vi devas enigi la precizan nomon de tiparo tiel, kiel ĝi aperas en la sistemo',components:{interface:"Fasado",input:"Enigaj kampoj",post:"Teksto de afiŝo",postCode:"Egallarĝa teksto en afiŝo (riĉteksto)"},family:"Nomo de tiparo",size:"Grando (en bilderoj)",weight:"Pezo (graseco)",custom:"Propra"},preview:{header:"Antaŭrigardo",content:"Enhavo",error:"Ekzempla eraro",button:"Butono",text:"Kelko da pliaj {0} kaj {1}",mono:"enhavo",input:"Ĵus alvenis al la Universala Kongreso!",faint_link:"helpan manlibron",fine_print:"Legu nian {0} por nenion utilan ekscii!",header_faint:"Tio estas en ordo",checkbox:"Mi legetis la kondiĉojn de uzado",link:"bela eta ligil’"}}},timeline:{collapse:"Maletendi",conversation:"Interparolo",error_fetching:"Eraro dum ĝisdatigo",load_older:"Montri pli malnovajn statojn",no_retweet_hint:"Afiŝo estas markita kiel rekta aŭ nur por abonantoj, kaj ne eblas ĝin ripeti",repeated:"ripetita",show_new:"Montri novajn",up_to_date:"Ĝisdata",no_more_statuses:"Neniuj pliaj statoj",no_statuses:"Neniuj statoj"},user_card:{approve:"Aprobi",block:"Bari",blocked:"Barita!",deny:"Rifuzi",favorites:"Ŝatataj",follow:"Aboni",follow_sent:"Peto sendiĝis!",follow_progress:"Petanta…",follow_again:"Ĉu sendi peton denove?",follow_unfollow:"Malaboni",followees:"Abonatoj",followers:"Abonantoj",following:"Abonanta!",follows_you:"Abonas vin!",its_you:"Tio estas vi!",media:"Aŭdvidaĵoj",mute:"Silentigi",muted:"Silentigitaj",per_day:"tage",remote_follow:"Fore aboni",statuses:"Statoj",unblock:"Malbari",unblock_progress:"Malbaranta…",block_progress:"Baranta…",unmute:"Malsilentigi",unmute_progress:"Malsilentiganta…",mute_progress:"Silentiganta…"},user_profile:{timeline_title:"Uzanta tempolinio",profile_does_not_exist:"Pardonu, ĉi tiu profilo ne ekzistas.",profile_loading_error:"Pardonu, eraro okazis dum enlegado de ĉi tiu profilo."},who_to_follow:{more:"Pli",who_to_follow:"Kiun aboni"},tool_tip:{media_upload:"Alŝuti aŭdvidaĵon",repeat:"Ripeti",reply:"Respondi",favorite:"Ŝati",user_settings:"Agordoj de uzanto"},upload:{error:{base:"Alŝuto malsukcesis.",file_too_big:"Dosiero estas tro granda [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]",default:"Reprovu pli poste"},file_size_units:{B:"B",KiB:"KiB",MiB:"MiB",GiB:"GiB",TiB:"TiB"}}}},function(e,t){e.exports={chat:{title:"Chat"},features_panel:{chat:"Chat",gopher:"Gopher",media_proxy:"Media proxy",scope_options:"Opciones del alcance de la visibilidad",text_limit:"Límite de carácteres",title:"Características",who_to_follow:"A quién seguir"},finder:{error_fetching_user:"Error al buscar usuario",find_user:"Encontrar usuario"},general:{apply:"Aplicar",submit:"Enviar",more:"Más",generic_error:"Ha ocurrido un error"},login:{login:"Identificación",description:"Identificación con OAuth",logout:"Salir",password:"Contraseña",placeholder:"p.ej. lain",register:"Registrar",username:"Usuario",hint:"Inicia sesión para unirte a la discusión"},nav:{about:"Sobre",back:"Volver",chat:"Chat Local",friend_requests:"Solicitudes de amistad",mentions:"Menciones",dms:"Mensajes Directo",public_tl:"Línea Temporal Pública",timeline:"Línea Temporal",twkn:"Toda La Red Conocida",user_search:"Búsqueda de Usuarios",who_to_follow:"A quién seguir",preferences:"Preferencias"},notifications:{broken_favorite:"Estado desconocido, buscándolo...",favorited_you:"le gusta tu estado",followed_you:"empezó a seguirte",load_older:"Cargar notificaciones antiguas",notifications:"Notificaciones",read:"¡Leído!",repeated_you:"repite tu estado",no_more_notifications:"No hay más notificaciones"},post_status:{new_status:"Publicar un nuevo estado",account_not_locked_warning:"Tu cuenta no está {0}. Cualquiera puede seguirte y leer las entradas para Solo-Seguidores.",account_not_locked_warning_link:"bloqueada",attachments_sensitive:"Contenido sensible",content_type:{plain_text:"Texto Plano"},content_warning:"Tema (opcional)",default:"Acabo de aterrizar en L.A.",direct_warning:"Esta entrada solo será visible para los usuarios mencionados.",posting:"Publicando",scope:{direct:"Directo - Solo para los usuarios mencionados.",private:"Solo-Seguidores - Solo tus seguidores leeran la entrada",public:"Público - Entradas visibles en las Líneas Temporales Públicas",unlisted:"Sin Listar - Entradas no visibles en las Líneas Temporales Públicas"}},registration:{bio:"Biografía",email:"Correo electrónico",fullname:"Nombre a mostrar",password_confirm:"Confirmación de contraseña",registration:"Registro",token:"Token de invitación",captcha:"CAPTCHA",new_captcha:"Click en la imagen para obtener un nuevo captca",validations:{username_required:"no puede estar vacío",fullname_required:"no puede estar vacío",email_required:"no puede estar vacío",password_required:"no puede estar vacío",password_confirmation_required:"no puede estar vacío",password_confirmation_match:"la contraseña no coincide"}},settings:{attachmentRadius:"Adjuntos",attachments:"Adjuntos",autoload:"Activar carga automática al llegar al final de la página",avatar:"Avatar",avatarAltRadius:"Avatares (Notificaciones)",avatarRadius:"Avatares",background:"Fondo",bio:"Biografía",btnRadius:"Botones",cBlue:"Azul (Responder, seguir)",cGreen:"Verde (Retweet)",cOrange:"Naranja (Favorito)",cRed:"Rojo (Cancelar)",change_password:"Cambiar contraseña",change_password_error:"Hubo un problema cambiando la contraseña.",changed_password:"Contraseña cambiada correctamente!",collapse_subject:"Colapsar entradas con tema",composing:"Redactando",confirm_new_password:"Confirmar la nueva contraseña",current_avatar:"Tu avatar actual",current_password:"Contraseña actual",current_profile_banner:"Tu cabecera actual",data_import_export_tab:"Importar / Exportar Datos",default_vis:"Alcance de visibilidad por defecto",delete_account:"Eliminar la cuenta",delete_account_description:"Eliminar para siempre la cuenta y todos los mensajes.",delete_account_error:"Hubo un error al eliminar tu cuenta. Si el fallo persiste, ponte en contacto con el administrador de tu instancia.",delete_account_instructions:"Escribe tu contraseña para confirmar la eliminación de tu cuenta.",avatar_size_instruction:"El tamaño mínimo recomendado para el avatar es de 150X150 píxeles.",export_theme:"Exportar tema",filtering:"Filtros",filtering_explanation:"Todos los estados que contengan estas palabras serán silenciados, una por línea",follow_export:"Exportar personas que tú sigues",follow_export_button:"Exporta tus seguidores a un archivo csv",follow_export_processing:"Procesando, en breve se te preguntará para guardar el archivo",follow_import:"Importar personas que tú sigues",follow_import_error:"Error al importal el archivo",follows_imported:"¡Importado! Procesarlos llevará tiempo.",foreground:"Primer plano",general:"General",hide_attachments_in_convo:"Ocultar adjuntos en las conversaciones",hide_attachments_in_tl:"Ocultar adjuntos en la línea temporal",hide_isp:"Ocultar el panel específico de la instancia",preload_images:"Precargar las imágenes",use_one_click_nsfw:"Abrir los adjuntos NSFW con un solo click.",hide_post_stats:"Ocultar las estadísticas de las entradas (p.ej. el número de favoritos)",hide_user_stats:"Ocultar las estadísticas del usuario (p.ej. el número de seguidores)",hide_filtered_statuses:"Ocultar estados filtrados",import_followers_from_a_csv_file:"Importar personas que tú sigues a partir de un archivo csv",import_theme:"Importar tema",inputRadius:"Campos de entrada",checkboxRadius:"Casillas de verificación",instance_default:"(por defecto: {value})",instance_default_simple:"(por defecto)",interface:"Interfaz",interfaceLanguage:"Idioma",invalid_theme_imported:"El archivo importado no es un tema válido de Pleroma. No se han realizado cambios.",limited_availability:"No disponible en tu navegador",links:"Enlaces",lock_account_description:"Restringir el acceso a tu cuenta solo a seguidores admitidos",loop_video:"Vídeos en bucle",loop_video_silent_only:'Bucle solo en vídeos sin sonido (p.ej. "gifs" de Mastodon)',play_videos_in_modal:"Reproducir los vídeos directamente en el visor de medios",use_contain_fit:"No recortar los adjuntos en miniaturas",name:"Nombre",name_bio:"Nombre y Biografía",new_password:"Nueva contraseña",notification_visibility:"Tipos de notificaciones a mostrar",notification_visibility_follows:"Nuevos seguidores",notification_visibility_likes:"Me gustan (Likes)",notification_visibility_mentions:"Menciones",notification_visibility_repeats:"Repeticiones (Repeats)",no_rich_text_description:"Eliminar el formato de texto enriquecido de todas las entradas",hide_follows_description:"No mostrar a quién sigo",hide_followers_description:"No mostrar quién me sigue",show_admin_badge:"Mostrar la placa de administrador en mi perfil",show_moderator_badge:"Mostrar la placa de moderador en mi perfil",nsfw_clickthrough:"Activar el clic para ocultar los adjuntos NSFW",oauth_tokens:"Tokens de OAuth",token:"Token",refresh_token:"Actualizar el token",valid_until:"Válido hasta",revoke_token:"Revocar",panelRadius:"Paneles",pause_on_unfocused:"Parar la transmisión cuando no estés en foco.",presets:"Por defecto",profile_background:"Fondo del Perfil",profile_banner:"Cabecera del Perfil",profile_tab:"Perfil",radii_help:"Estable el redondeo de las esquinas del interfaz (en píxeles)",replies_in_timeline:"Réplicas en la línea temporal",reply_link_preview:"Activar la previsualización del enlace de responder al pasar el ratón por encim",reply_visibility_all:"Mostrar todas las réplicas",reply_visibility_following:"Solo mostrar réplicas para mí o usuarios a los que sigo",reply_visibility_self:"Solo mostrar réplicas para mí",saving_err:"Error al guardar los ajustes",saving_ok:"Ajustes guardados",security_tab:"Seguridad",scope_copy:"Copiar la visibilidad cuando contestamos (En los mensajes directos (MDs) siempre se copia)", +set_new_avatar:"Cambiar avatar",set_new_profile_background:"Cambiar fondo del perfil",set_new_profile_banner:"Cambiar cabecera del perfil",settings:"Ajustes",subject_input_always_show:"Mostrar siempre el campo del tema",subject_line_behavior:"Copiar el tema en las contestaciones",subject_line_email:'Tipo email: "re: tema"',subject_line_mastodon:"Tipo mastodon: copiar como es",subject_line_noop:"No copiar",post_status_content_type:"Formato de publicación",stop_gifs:"Iniciar GIFs al pasar el ratón",streaming:"Habilite la transmisión automática de nuevas publicaciones cuando se desplaza hacia la parte superior",text:"Texto",theme:"Tema",theme_help:"Use códigos de color hexadecimales (#rrggbb) para personalizar su tema de colores.",theme_help_v2_1:'También puede invalidar los colores y la opacidad de ciertos componentes si activa la casilla de verificación, use el botón "Borrar todo" para deshacer los cambios.',theme_help_v2_2:"Los iconos debajo de algunas entradas son indicadores de contraste de fondo/texto, desplace el ratón para obtener información detallada. Tenga en cuenta que cuando se utilizan indicadores de contraste de transparencia se muestra el peor caso posible.",tooltipRadius:"Información/alertas",user_settings:"Ajustes de Usuario",values:{false:"no",true:"sí"},notifications:"Notificaciones",enable_web_push_notifications:"Habilitar las notificiaciones en el navegador",style:{switcher:{keep_color:"Mantener colores",keep_shadows:"Mantener sombras",keep_opacity:"Mantener opacidad",keep_roundness:"Mantener redondeces",keep_fonts:"Mantener fuentes",save_load_hint:'Las opciones "Mantener" conservan las opciones configuradas actualmente al seleccionar o cargar temas, también almacena dichas opciones al exportar un tema. Cuando se desactiven todas las casillas de verificación, el tema de exportación lo guardará todo.',reset:"Reiniciar",clear_all:"Limpiar todo",clear_opacity:"Limpiar opacidad"},common:{color:"Color",opacity:"Opacidad",contrast:{hint:"El ratio de contraste es {ratio}. {level} {context}",level:{aa:"Cumple con la pauta de nivel AA (mínimo)",aaa:"Cumple con la pauta de nivel AAA (recomendado)",bad:"No cumple con las pautas de accesibilidad"},context:{"18pt":"para textos grandes (+18pt)",text:"para textos"}}},common_colors:{_tab_label:"Común",main:"Colores comunes",foreground_hint:'Vea la pestaña "Avanzado" para un control más detallado',rgbo:"Iconos, acentos, insignias"},advanced_colors:{_tab_label:"Avanzado",alert:"Fondo de Alertas",alert_error:"Error",badge:"Fondo de Insignias",badge_notification:"Notificaciones",panel_header:"Cabecera del panel",top_bar:"Barra superior",borders:"Bordes",buttons:"Botones",inputs:"Campos de entrada",faint_text:"Texto desvanecido"},radii:{_tab_label:"Redondez"},shadows:{_tab_label:"Sombra e iluminación",component:"Componente",override:"Sobreescribir",shadow_id:"Sombra #{value}",blur:"Difuminar",spread:"Cantidad",inset:"Insertada",hint:"Para las sombras, también puede usar --variable como un valor de color para usar las variables CSS3. Tenga en cuenta que establecer la opacidad no funcionará en este caso.",filter_hint:{always_drop_shadow:"Advertencia, esta sombra siempre usa {0} cuando el navegador lo soporta.",drop_shadow_syntax:"{0} no soporta el parámetro {1} y la palabra clave {2}.",avatar_inset:"Tenga en cuenta que la combinación de sombras insertadas como no-insertadas en los avatares, puede dar resultados inesperados con los avatares transparentes.",spread_zero:"Sombras con una cantidad > 0 aparecerá como si estuviera puesto a cero",inset_classic:"Las sombras insertadas estarán usando {0}"},components:{panel:"Panel",panelHeader:"Cabecera del panel",topBar:"Barra superior",avatar:"Avatar del usuario (en la vista del perfil)",avatarStatus:"Avatar del usuario (en la vista de la entrada)",popup:"Ventanas y textos emergentes (popups & tooltips)",button:"Botones",buttonHover:"Botón (encima)",buttonPressed:"Botón (presionado)",buttonPressedHover:"Botón (presionado+encima)",input:"Campo de entrada"}},fonts:{_tab_label:"Fuentes",help:'Seleccione la fuente para utilizar para los elementos de la interfaz de usuario. Para "personalizado", debe ingresar el nombre exacto de la fuente tal como aparece en el sistema.',components:{interface:"Interfaz",input:"Campos de entrada",post:"Texto de publicaciones",postCode:"Texto monoespaciado en publicación (texto enriquecido)"},family:"Nombre de la fuente",size:"Tamaño (en px)",weight:"Peso (negrita)",custom:"Personalizado"},preview:{header:"Vista previa",content:"Contenido",error:"Ejemplo de error",button:"Botón",text:"Un montón de {0} y {1}",mono:"contenido",input:"Acaba de aterrizar en L.A.",faint_link:"manual útil",fine_print:"¡Lea nuestro {0} para aprender nada útil!",header_faint:"Esto está bien",checkbox:"He revisado los términos y condiciones",link:"un bonito enlace"}}},timeline:{collapse:"Colapsar",conversation:"Conversación",error_fetching:"Error al cargar las actualizaciones",load_older:"Cargar actualizaciones anteriores",no_retweet_hint:"La publicación está marcada como solo para seguidores o directa y no se puede repetir",repeated:"repetida",show_new:"Mostrar lo nuevo",up_to_date:"Actualizado",no_more_statuses:"No hay más estados"},user_card:{approve:"Aprovar",block:"Bloquear",blocked:"¡Bloqueado!",deny:"Denegar",favorites:"Favoritos",follow:"Seguir",follow_sent:"¡Solicitud enviada!",follow_progress:"Solicitando…",follow_again:"¿Enviar solicitud de nuevo?",follow_unfollow:"Dejar de seguir",followees:"Siguiendo",followers:"Seguidores",following:"¡Siguiendo!",follows_you:"¡Te sigue!",its_you:"¡Eres tú!",media:"Media",mute:"Silenciar",muted:"Silenciado",per_day:"por día",remote_follow:"Seguir",statuses:"Estados"},user_profile:{timeline_title:"Linea temporal del usuario"},who_to_follow:{more:"Más",who_to_follow:"A quién seguir"},tool_tip:{media_upload:"Subir Medios",repeat:"Repetir",reply:"Contestar",favorite:"Favorito",user_settings:"Ajustes de usuario"},upload:{error:{base:"Subida fallida.",file_too_big:"Archivo demasiado grande [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]",default:"Inténtalo más tarde"},file_size_units:{B:"B",KiB:"KiB",MiB:"MiB",GiB:"GiB",TiB:"TiB"}}}},function(e,t){e.exports={finder:{error_fetching_user:"Viga kasutaja leidmisel",find_user:"Otsi kasutajaid"},general:{submit:"Postita"},login:{login:"Logi sisse",logout:"Logi välja",password:"Parool",placeholder:"nt lain",register:"Registreeru",username:"Kasutajanimi"},nav:{mentions:"Mainimised",public_tl:"Avalik Ajajoon",timeline:"Ajajoon",twkn:"Kogu Teadaolev Võrgustik"},notifications:{followed_you:"alustas sinu jälgimist",notifications:"Teavitused",read:"Loe!"},post_status:{default:"Just sõitsin elektrirongiga Tallinnast Pääskülla.",posting:"Postitan"},registration:{bio:"Bio",email:"E-post",fullname:"Kuvatav nimi",password_confirm:"Parooli kinnitamine",registration:"Registreerimine"},settings:{attachments:"Manused",autoload:"Luba ajajoone automaatne uuendamine kui ajajoon on põhja keritud",avatar:"Profiilipilt",bio:"Bio",current_avatar:"Sinu praegune profiilipilt",current_profile_banner:"Praegune profiilibänner",filtering:"Sisu filtreerimine",filtering_explanation:"Kõiki staatuseid, mis sisaldavad neid sõnu, ei kuvata. Üks sõna reale.",hide_attachments_in_convo:"Peida manused vastlustes",hide_attachments_in_tl:"Peida manused ajajoonel",name:"Nimi",name_bio:"Nimi ja Bio",nsfw_clickthrough:"Peida tööks-mittesobivad(NSFW) manuste hiireklõpsu taha",profile_background:"Profiilitaust",profile_banner:"Profiilibänner",reply_link_preview:"Luba algpostituse kuvamine vastustes",set_new_avatar:"Vali uus profiilipilt",set_new_profile_background:"Vali uus profiilitaust",set_new_profile_banner:"Vali uus profiilibänner",settings:"Sätted",theme:"Teema",user_settings:"Kasutaja sätted"},timeline:{conversation:"Vestlus",error_fetching:"Viga uuenduste laadimisel",load_older:"Kuva vanemaid staatuseid",show_new:"Näita uusi",up_to_date:"Uuendatud"},user_card:{block:"Blokeeri",blocked:"Blokeeritud!",follow:"Jälgi",followees:"Jälgitavaid",followers:"Jälgijaid",following:"Jälgin!",follows_you:"Jälgib sind!",mute:"Vaigista",muted:"Vaigistatud",per_day:"päevas",statuses:"Staatuseid"}}},function(e,t){e.exports={chat:{title:"Chat"},features_panel:{chat:"Chat",gopher:"Gopher",media_proxy:"Media-välityspalvelin",scope_options:"Näkyvyyden rajaus",text_limit:"Tekstin pituusraja",title:"Ominaisuudet",who_to_follow:"Seurausehdotukset"},finder:{error_fetching_user:"Virhe hakiessa käyttäjää",find_user:"Hae käyttäjä"},general:{apply:"Aseta",submit:"Lähetä",more:"Lisää",generic_error:"Virhe tapahtui"},login:{login:"Kirjaudu sisään",description:"Kirjaudu sisään OAuthilla",logout:"Kirjaudu ulos",password:"Salasana",placeholder:"esim. Seppo",register:"Rekisteröidy",username:"Käyttäjänimi"},nav:{about:"Tietoja",back:"Takaisin",chat:"Paikallinen Chat",friend_requests:"Seurauspyynnöt",mentions:"Maininnat",dms:"Yksityisviestit",public_tl:"Julkinen Aikajana",timeline:"Aikajana",twkn:"Koko Tunnettu Verkosto",user_search:"Käyttäjähaku",who_to_follow:"Seurausehdotukset",preferences:"Asetukset"},notifications:{broken_favorite:"Viestiä ei löydetty...",favorited_you:"tykkäsi viestistäsi",followed_you:"seuraa sinua",load_older:"Lataa vanhempia ilmoituksia",notifications:"Ilmoitukset",read:"Lue!",repeated_you:"toisti viestisi",no_more_notifications:"Ei enempää ilmoituksia"},post_status:{new_status:"Uusi viesti",account_not_locked_warning:"Tilisi ei ole {0}. Kuka vain voi seurata sinua nähdäksesi 'vain-seuraajille' -viestisi",account_not_locked_warning_link:"lukittu",attachments_sensitive:"Merkkaa liitteet arkaluonteisiksi",content_type:{plain_text:"Tavallinen teksti"},content_warning:"Aihe (valinnainen)",default:"Tulin juuri saunasta.",direct_warning:"Tämä viesti näkyy vain mainituille käyttäjille.",posting:"Lähetetään",scope:{direct:"Yksityisviesti - Näkyy vain mainituille käyttäjille",private:"Vain-seuraajille - Näkyy vain seuraajillesi",public:"Julkinen - Näkyy julkisilla aikajanoilla",unlisted:"Listaamaton - Ei näy julkisilla aikajanoilla"}},registration:{bio:"Kuvaus",email:"Sähköposti",fullname:"Koko nimi",password_confirm:"Salasanan vahvistaminen",registration:"Rekisteröityminen",token:"Kutsuvaltuus",captcha:"Varmenne",new_captcha:"Paina kuvaa saadaksesi uuden varmenteen",validations:{username_required:"ei voi olla tyhjä",fullname_required:"ei voi olla tyhjä",email_required:"ei voi olla tyhjä",password_required:"ei voi olla tyhjä",password_confirmation_required:"ei voi olla tyhjä",password_confirmation_match:"pitää vastata salasanaa"}},settings:{attachmentRadius:"Liitteet",attachments:"Liitteet",autoload:"Lataa vanhempia viestejä automaattisesti ruudun pohjalla",avatar:"Profiilikuva",avatarAltRadius:"Profiilikuvat (ilmoitukset)",avatarRadius:"Profiilikuvat",background:"Tausta",bio:"Kuvaus",btnRadius:"Napit",cBlue:"Sininen (Vastaukset, seuraukset)",cGreen:"Vihreä (Toistot)",cOrange:"Oranssi (Tykkäykset)",cRed:"Punainen (Peruminen)",change_password:"Vaihda salasana",change_password_error:"Virhe vaihtaessa salasanaa.",changed_password:"Salasana vaihdettu!",collapse_subject:"Minimoi viestit, joille on asetettu aihe",composing:"Viestien laatiminen",confirm_new_password:"Vahvista uusi salasana",current_avatar:"Nykyinen profiilikuvasi",current_password:"Nykyinen salasana",current_profile_banner:"Nykyinen julisteesi",data_import_export_tab:"Tietojen tuonti / vienti",default_vis:"Oletusnäkyvyysrajaus",delete_account:"Poista tili",delete_account_description:"Poista tilisi ja viestisi pysyvästi.",delete_account_error:"Virhe poistaessa tiliäsi. Jos virhe jatkuu, ota yhteyttä palvelimesi ylläpitoon.",delete_account_instructions:"Syötä salasanasi vahvistaaksesi tilin poiston.",export_theme:"Tallenna teema",filtering:"Suodatus",filtering_explanation:"Kaikki viestit, jotka sisältävät näitä sanoja, suodatetaan. Yksi sana per rivi.",follow_export:"Seurausten vienti",follow_export_button:"Vie seurauksesi CSV-tiedostoon",follow_export_processing:"Käsitellään, sinua pyydetään lataamaan tiedosto hetken päästä",follow_import:"Seurausten tuonti",follow_import_error:"Virhe tuodessa seuraksia",follows_imported:"Seuraukset tuotu! Niiden käsittely vie hetken.",foreground:"Korostus",general:"Yleinen",hide_attachments_in_convo:"Piilota liitteet keskusteluissa",hide_attachments_in_tl:"Piilota liitteet aikajanalla",max_thumbnails:"Suurin sallittu määrä liitteitä esikatselussa",hide_isp:"Piilota palvelimenkohtainen ruutu",preload_images:"Esilataa kuvat",use_one_click_nsfw:"Avaa NSFW-liitteet yhdellä painalluksella",hide_post_stats:"Piilota viestien statistiikka (esim. tykkäysten määrä)",hide_user_stats:"Piilota käyttäjien statistiikka (esim. seuraajien määrä)",import_followers_from_a_csv_file:"Tuo seuraukset CSV-tiedostosta",import_theme:"Tuo tallennettu teema",inputRadius:"Syöttökentät",checkboxRadius:"Valintalaatikot",instance_default:"(oletus: {value})",instance_default_simple:"(oletus)",interface:"Käyttöliittymä",interfaceLanguage:"Käyttöliittymän kieli",invalid_theme_imported:"Tuotu tallennettu teema on epäkelpo, muutoksia ei tehty nykyiseen teemaasi.",limited_availability:"Ei saatavilla selaimessasi",links:"Linkit",lock_account_description:"Vain erikseen hyväksytyt käyttäjät voivat seurata tiliäsi",loop_video:"Uudelleentoista videot",loop_video_silent_only:'Uudelleentoista ainoastaan äänettömät videot (Video-"giffit")',play_videos_in_modal:"Toista videot modaalissa",use_contain_fit:"Älä rajaa liitteitä esikatselussa",name:"Nimi",name_bio:"Nimi ja kuvaus",new_password:"Uusi salasana",notification_visibility:"Ilmoitusten näkyvyys",notification_visibility_follows:"Seuraukset",notification_visibility_likes:"Tykkäykset",notification_visibility_mentions:"Maininnat",notification_visibility_repeats:"Toistot",no_rich_text_description:"Älä näytä tekstin muotoilua.",hide_network_description:"Älä näytä seurauksiani tai seuraajiani",nsfw_clickthrough:"Piilota NSFW liitteet klikkauksen taakse",oauth_tokens:"OAuth-merkit",token:"Token",refresh_token:"Päivitä token",valid_until:"Voimassa asti",revoke_token:"Peruuttaa",panelRadius:"Ruudut",pause_on_unfocused:"Pysäytä automaattinen viestien näyttö välilehden ollessa pois fokuksesta",presets:"Valmiit teemat",profile_background:"Taustakuva",profile_banner:"Juliste",profile_tab:"Profiili",radii_help:"Aseta reunojen pyöristys (pikseleinä)",replies_in_timeline:"Keskustelut aikajanalla",reply_link_preview:"Keskusteluiden vastauslinkkien esikatselu",reply_visibility_all:"Näytä kaikki vastaukset",reply_visibility_following:"Näytä vain vastaukset minulle tai seuraamilleni käyttäjille",reply_visibility_self:"Näytä vain vastaukset minulle",saving_err:"Virhe tallentaessa asetuksia",saving_ok:"Asetukset tallennettu",security_tab:"Tietoturva",scope_copy:"Kopioi näkyvyysrajaus vastatessa (Yksityisviestit aina kopioivat)",set_new_avatar:"Aseta uusi profiilikuva",set_new_profile_background:"Aseta uusi taustakuva",set_new_profile_banner:"Aseta uusi juliste",settings:"Asetukset",subject_input_always_show:"Näytä aihe-kenttä",subject_line_behavior:"Aihe-kentän kopiointi",subject_line_email:'Kuten sähköposti: "re: aihe"',subject_line_mastodon:"Kopioi sellaisenaan",subject_line_noop:"Älä kopioi",stop_gifs:"Toista giffit vain kohdistaessa",streaming:"Näytä uudet viestit automaattisesti ollessasi ruudun huipulla",text:"Teksti",theme:"Teema",theme_help:"Käytä heksadesimaalivärejä muokataksesi väriteemaasi.",theme_help_v2_1:'Voit asettaa tiettyjen osien värin tai läpinäkyvyyden täyttämällä valintalaatikon, käytä "Tyhjennä kaikki"-nappia tyhjentääksesi kaiken.',theme_help_v2_2:"Ikonit kenttien alla ovat kontrasti-indikaattoreita, lisätietoa kohdistamalla. Käyttäessä läpinäkyvyyttä ne näyttävät pahimman skenaarion.",tooltipRadius:"Ohje- tai huomioviestit",user_settings:"Käyttäjän asetukset",values:{false:"pois päältä",true:"päällä"}},timeline:{collapse:"Sulje",conversation:"Keskustelu",error_fetching:"Virhe ladatessa viestejä",load_older:"Lataa vanhempia viestejä",no_retweet_hint:"Viesti ei ole julkinen, eikä sitä voi toistaa",repeated:"toisti",show_new:"Näytä uudet",up_to_date:"Ajantasalla",no_more_statuses:"Ei enempää viestejä"},status:{reply_to:"Vastaus",replies_list:"Vastaukset:"},user_card:{approve:"Hyväksy",block:"Estä",blocked:"Estetty!",deny:"Älä hyväksy",follow:"Seuraa",follow_sent:"Pyyntö lähetetty!",follow_progress:"Pyydetään...",follow_again:"Lähetä pyyntö uudestaan",follow_unfollow:"Älä seuraa",followees:"Seuraa",followers:"Seuraajat",following:"Seuraat!",follows_you:"Seuraa sinua!",its_you:"Sinun tili!",mute:"Hiljennä",muted:"Hiljennetty",per_day:"päivässä",remote_follow:"Seuraa muualta",statuses:"Viestit"},user_profile:{timeline_title:"Käyttäjän aikajana"},who_to_follow:{more:"Lisää",who_to_follow:"Seurausehdotukset"},tool_tip:{media_upload:"Lataa tiedosto",repeat:"Toista",reply:"Vastaa",favorite:"Tykkää",user_settings:"Käyttäjäasetukset"},upload:{error:{base:"Lataus epäonnistui.",file_too_big:"Tiedosto liian suuri [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]",default:"Yritä uudestaan myöhemmin"},file_size_units:{B:"tavua",KiB:"kt",MiB:"Mt",GiB:"Gt",TiB:"Tt"}}}},function(e,t){e.exports={chat:{title:"Chat"},features_panel:{chat:"Chat",gopher:"Gopher",media_proxy:"Proxy média",scope_options:"Options de visibilité",text_limit:"Limite du texte",title:"Caractéristiques",who_to_follow:"Qui s'abonner"},finder:{error_fetching_user:"Erreur lors de la recherche de l'utilisateur",find_user:"Chercher un utilisateur"},general:{apply:"Appliquer",submit:"Envoyer"},login:{login:"Connexion",description:"Connexion avec OAuth",logout:"Déconnexion",password:"Mot de passe",placeholder:"p.e. lain",register:"S'inscrire",username:"Identifiant"},nav:{chat:"Chat local",friend_requests:"Demandes d'ami",dms:"Messages adressés",mentions:"Notifications",public_tl:"Statuts locaux",timeline:"Journal",twkn:"Le réseau connu"},notifications:{broken_favorite:"Chargement d'un message inconnu ...",favorited_you:"a aimé votre statut",followed_you:"a commencé à vous suivre",load_older:"Charger les notifications précédentes",notifications:"Notifications",read:"Lu !",repeated_you:"a partagé votre statut"},post_status:{account_not_locked_warning:"Votre compte n'est pas {0}. N'importe qui peut vous suivre pour voir vos billets en Abonné·e·s uniquement.",account_not_locked_warning_link:"verrouillé",attachments_sensitive:"Marquer le média comme sensible",content_type:{plain_text:"Texte brut"},content_warning:"Sujet (optionnel)",default:"Écrivez ici votre prochain statut.",direct_warning:"Ce message sera visible à toutes les personnes mentionnées.",posting:"Envoi en cours",scope:{direct:"Direct - N'envoyer qu'aux personnes mentionnées",private:"Abonné·e·s uniquement - Seul·e·s vos abonné·e·s verront vos billets",public:"Publique - Afficher dans les fils publics",unlisted:"Non-Listé - Ne pas afficher dans les fils publics"}},registration:{bio:"Biographie",email:"Adresse email",fullname:"Pseudonyme",password_confirm:"Confirmation du mot de passe",registration:"Inscription",token:"Jeton d'invitation"},settings:{attachmentRadius:"Pièces jointes",attachments:"Pièces jointes",autoload:"Charger la suite automatiquement une fois le bas de la page atteint",avatar:"Avatar",avatarAltRadius:"Avatars (Notifications)",avatarRadius:"Avatars",background:"Arrière-plan",bio:"Biographie",btnRadius:"Boutons",cBlue:"Bleu (Répondre, suivre)",cGreen:"Vert (Partager)",cOrange:"Orange (Aimer)",cRed:"Rouge (Annuler)",change_password:"Changez votre mot de passe",change_password_error:"Il y a eu un problème pour changer votre mot de passe.",changed_password:"Mot de passe modifié avec succès !",collapse_subject:"Réduire les messages avec des sujets",confirm_new_password:"Confirmation du nouveau mot de passe",current_avatar:"Avatar actuel",current_password:"Mot de passe actuel",current_profile_banner:"Bannière de profil actuelle",data_import_export_tab:"Import / Export des Données",default_vis:"Portée de visibilité par défaut",delete_account:"Supprimer le compte",delete_account_description:"Supprimer définitivement votre compte et tous vos statuts.",delete_account_error:"Il y a eu un problème lors de la tentative de suppression de votre compte. Si le problème persiste, contactez l'administrateur de cette instance.",delete_account_instructions:"Indiquez votre mot de passe ci-dessous pour confirmer la suppression de votre compte.",export_theme:"Enregistrer le thème",filtering:"Filtre",filtering_explanation:"Tous les statuts contenant ces mots seront masqués. Un mot par ligne",follow_export:"Exporter les abonnements",follow_export_button:"Exporter les abonnements en csv",follow_export_processing:"Exportation en cours…",follow_import:"Importer des abonnements",follow_import_error:"Erreur lors de l'importation des abonnements",follows_imported:"Abonnements importés ! Le traitement peut prendre un moment.",foreground:"Premier plan",general:"Général",hide_attachments_in_convo:"Masquer les pièces jointes dans les conversations",hide_attachments_in_tl:"Masquer les pièces jointes dans le journal",hide_post_stats:"Masquer les statistiques de publication (le nombre de favoris)",hide_user_stats:"Masquer les statistiques de profil (le nombre d'amis)",import_followers_from_a_csv_file:"Importer des abonnements depuis un fichier csv",import_theme:"Charger le thème",inputRadius:"Champs de texte",instance_default:"(default: {value})",instance_default_simple:"(default)",interfaceLanguage:"Langue de l'interface",invalid_theme_imported:"Le fichier sélectionné n'est pas un thème Pleroma pris en charge. Aucun changement n'a été apporté à votre thème.",limited_availability:"Non disponible dans votre navigateur",links:"Liens",lock_account_description:"Limitez votre compte aux abonnés acceptés uniquement",loop_video:"Vidéos en boucle",loop_video_silent_only:"Boucle uniquement les vidéos sans le son (les «gifs» de Mastodon)",name:"Nom",name_bio:"Nom & Bio",new_password:"Nouveau mot de passe",no_rich_text_description:"Ne formatez pas le texte",notification_visibility:"Types de notifications à afficher",notification_visibility_follows:"Abonnements",notification_visibility_likes:"J’aime",notification_visibility_mentions:"Mentionnés",notification_visibility_repeats:"Partages",nsfw_clickthrough:"Masquer les images marquées comme contenu adulte ou sensible",oauth_tokens:"Jetons OAuth",token:"Jeton",refresh_token:"Refresh Token",valid_until:"Valable jusque",revoke_token:"Révoquer",panelRadius:"Fenêtres",pause_on_unfocused:"Suspendre le streaming lorsque l'onglet n'est pas centré",presets:"Thèmes prédéfinis",profile_background:"Image de fond",profile_banner:"Bannière de profil",profile_tab:"Profil",radii_help:"Vous pouvez ici choisir le niveau d'arrondi des angles de l'interface (en pixels)",replies_in_timeline:"Réponses au journal",reply_link_preview:"Afficher un aperçu lors du survol de liens vers une réponse",reply_visibility_all:"Montrer toutes les réponses",reply_visibility_following:"Afficher uniquement les réponses adressées à moi ou aux utilisateurs que je suis",reply_visibility_self:"Afficher uniquement les réponses adressées à moi",saving_err:"Erreur lors de l'enregistrement des paramètres",saving_ok:"Paramètres enregistrés",security_tab:"Sécurité",set_new_avatar:"Changer d'avatar",set_new_profile_background:"Changer d'image de fond",set_new_profile_banner:"Changer de bannière",settings:"Paramètres",stop_gifs:"N'animer les GIFS que lors du survol du curseur de la souris",streaming:"Charger automatiquement les nouveaux statuts lorsque vous êtes au haut de la page",text:"Texte",theme:"Thème",theme_help:"Spécifiez des codes couleur hexadécimaux (#rrvvbb) pour personnaliser les couleurs du thème.",tooltipRadius:"Info-bulles/alertes",user_settings:"Paramètres utilisateur",values:{false:"non",true:"oui"}},timeline:{collapse:"Fermer",conversation:"Conversation",error_fetching:"Erreur en cherchant les mises à jour",load_older:"Afficher plus",no_retweet_hint:"Le message est marqué en abonnés-seulement ou direct et ne peut pas être répété",repeated:"a partagé",show_new:"Afficher plus",up_to_date:"À jour"},user_card:{approve:"Accepter",block:"Bloquer",blocked:"Bloqué !",deny:"Rejeter",follow:"Suivre",followees:"Suivis",followers:"Vous suivent",following:"Suivi !",follows_you:"Vous suit !",mute:"Masquer",muted:"Masqué",per_day:"par jour",remote_follow:"Suivre d'une autre instance",statuses:"Statuts"},user_profile:{timeline_title:"Journal de l'utilisateur"},who_to_follow:{more:"Plus",who_to_follow:"Qui s'abonner"}}},function(e,t){e.exports={chat:{title:"Comhrá"},features_panel:{chat:"Comhrá",gopher:"Gófar",media_proxy:"Seachfhreastalaí meáin",scope_options:"Rogha scóip",text_limit:"Teorainn Téacs",title:"Gnéithe",who_to_follow:"Daoine le leanúint"},finder:{error_fetching_user:"Earráid a aimsiú d'úsáideoir",find_user:"Aimsigh úsáideoir"},general:{apply:"Feidhmigh",submit:"Deimhnigh"},login:{login:"Logáil isteach",logout:"Logáil amach",password:"Pasfhocal",placeholder:"m.sh. Daire",register:"Clárú",username:"Ainm Úsáideora"},nav:{chat:"Comhrá Áitiúil",friend_requests:"Iarratas ar Cairdeas",mentions:"Tagairt",public_tl:"Amlíne Poiblí",timeline:"Amlíne",twkn:"An Líonra Iomlán"},notifications:{broken_favorite:"Post anaithnid. Cuardach dó...",favorited_you:"toghadh le do phost",followed_you:"lean tú",load_older:"Luchtaigh fógraí aosta",notifications:"Fógraí",read:"Léigh!",repeated_you:"athphostáil tú"},post_status:{account_not_locked_warning:"Níl do chuntas {0}. Is féidir le duine ar bith a leanúint leat chun do phoist leantacha amháin a fheiceáil.",account_not_locked_warning_link:"faoi glas",attachments_sensitive:"Marcáil ceangaltán mar íogair",content_type:{plain_text:"Gnáth-théacs"},content_warning:"Teideal (roghnach)",default:"Lá iontach anseo i nGaillimh",direct_warning:"Ní bheidh an post seo le feiceáil ach amháin do na húsáideoirí atá luaite.",posting:"Post nua",scope:{direct:"Díreach - Post chuig úsáideoirí luaite amháin",private:"Leanúna amháin - Post chuig lucht leanúna amháin",public:"Poiblí - Post chuig amlínte poiblí",unlisted:"Neamhliostaithe - Ná cuir post chuig amlínte poiblí"}},registration:{bio:"Scéal saoil",email:"Ríomhphost",fullname:"Ainm taispeána'",password_confirm:"Deimhnigh do pasfhocal",registration:"Clárú",token:"Cód cuireadh"},settings:{attachmentRadius:"Ceangaltáin",attachments:"Ceangaltáin",autoload:"Cumasaigh luchtú uathoibríoch nuair a scrollaítear go bun",avatar:"Phictúir phrófíle",avatarAltRadius:"Phictúirí phrófíle (Fograí)",avatarRadius:"Phictúirí phrófíle",background:"Cúlra",bio:"Scéal saoil",btnRadius:"Cnaipí",cBlue:"Gorm (Freagra, lean)",cGreen:"Glas (Athphóstail)",cOrange:"Oráiste (Cosúil)",cRed:"Dearg (Cealaigh)",change_password:"Athraigh do pasfhocal",change_password_error:"Bhí fadhb ann ag athrú do pasfhocail",changed_password:"Athraigh an pasfhocal go rathúil!",collapse_subject:"Poist a chosc le teidil",confirm_new_password:"Deimhnigh do pasfhocal nua",current_avatar:"Phictúir phrófíle",current_password:"Pasfhocal reatha",current_profile_banner:"Phictúir ceanntáisc",data_import_export_tab:"Iompórtáil / Easpórtáil Sonraí",default_vis:"Scóip infheicthe réamhshocraithe",delete_account:"Scrios cuntas",delete_account_description:"Do chuntas agus do chuid teachtaireachtaí go léir a scriosadh go buan.",delete_account_error:"Bhí fadhb ann a scriosadh do chuntas. Má leanann sé seo, téigh i dteagmháil le do riarthóir.",delete_account_instructions:"Scríobh do phasfhocal san ionchur thíos chun deimhniú a scriosadh.",export_theme:"Sábháil Téama",filtering:"Scagadh",filtering_explanation:"Beidh gach post ina bhfuil na focail seo i bhfolach, ceann in aghaidh an líne",follow_export:"Easpórtáil do leanann",follow_export_button:"Easpórtáil do leanann chuig comhad csv",follow_export_processing:"Próiseáil. Iarrtar ort go luath an comhad a íoslódáil.",follow_import:"Iompórtáil do leanann",follow_import_error:"Earráid agus do leanann a iompórtáil",follows_imported:"Do leanann iompórtáil! Tógfaidh an próiseas iad le tamall.",foreground:"Tulra",general:"Ginearálta",hide_attachments_in_convo:"Folaigh ceangaltáin i comhráite",hide_attachments_in_tl:"Folaigh ceangaltáin sa amlíne",hide_post_stats:"Folaigh staitisticí na bpost (m.sh. líon na n-athrá)",hide_user_stats:"Folaigh na staitisticí úsáideora (m.sh. líon na leantóiri)",import_followers_from_a_csv_file:"Iompórtáil leanann ó chomhad csv",import_theme:"Luchtaigh Téama",inputRadius:"Limistéar iontrála",instance_default:"(Réamhshocrú: {value})",interfaceLanguage:"Teanga comhéadain",invalid_theme_imported:"Ní téama bailí é an comhad dícheangailte. Níor rinneadh aon athruithe.",limited_availability:"Níl sé ar fáil i do bhrabhsálaí",links:"Naisc",lock_account_description:"Srian a chur ar do chuntas le lucht leanúna ceadaithe amháin",loop_video:"Lúb físeáin",loop_video_silent_only:'Lúb físeáin amháin gan fuaim (i.e. Mastodon\'s "gifs")',name:"Ainm",name_bio:"Ainm ⁊ Scéal",new_password:"Pasfhocal nua'",notification_visibility:"Cineálacha fógraí a thaispeáint",notification_visibility_follows:"Leana",notification_visibility_likes:"Thaithin",notification_visibility_mentions:"Tagairt",notification_visibility_repeats:"Atphostáil",no_rich_text_description:"Bain formáidiú téacs saibhir ó gach post",nsfw_clickthrough:"Cumasaigh an ceangaltán NSFW cliceáil ar an gcnaipe",oauth_tokens:"Tocanna OAuth",token:"Token",refresh_token:"Athnuachan Comórtas",valid_until:"Bailí Go dtí",revoke_token:"Athghairm",panelRadius:"Painéil",pause_on_unfocused:"Sruthú ar sos nuair a bhíonn an fócas caillte",presets:"Réamhshocruithe",profile_background:"Cúlra Próifíl",profile_banner:"Phictúir Ceanntáisc",profile_tab:"Próifíl",radii_help:"Cruinniú imeall comhéadan a chumrú (i bpicteilíní)",replies_in_timeline:"Freagraí sa amlíne",reply_link_preview:"Cumasaigh réamhamharc nasc freagartha ar chlár na luiche",reply_visibility_all:"Taispeáin gach freagra",reply_visibility_following:"Taispeáin freagraí amháin atá dírithe ar mise nó ar úsáideoirí atá mé ag leanúint",reply_visibility_self:"Taispeáin freagraí amháin atá dírithe ar mise",saving_err:"Earráid socruithe a shábháil",saving_ok:"Socruithe sábháilte",security_tab:"Slándáil",set_new_avatar:"Athraigh do phictúir phrófíle",set_new_profile_background:"Athraigh do cúlra próifíl",set_new_profile_banner:"Athraigh do phictúir ceanntáisc",settings:"Socruithe",stop_gifs:"Seinn GIFs ar an scáileán",streaming:"Cumasaigh post nua a shruthú uathoibríoch nuair a scrollaítear go barr an leathanaigh",text:"Téacs",theme:"Téama",theme_help:"Úsáid cód daith hex (#rrggbb) chun do schéim a saincheapadh",tooltipRadius:"Bileoga eolais",user_settings:"Socruithe úsáideora",values:{false:"níl",true:"tá"}},timeline:{collapse:"Folaigh",conversation:"Cómhra",error_fetching:"Earráid a thabhairt cothrom le dáta",load_older:"Luchtaigh níos mó",no_retweet_hint:"Tá an post seo marcáilte mar lucht leanúna amháin nó díreach agus ní féidir é a athphostáil",repeated:"athphostáil",show_new:"Taispeáin nua",up_to_date:"Nuashonraithe"},user_card:{approve:"Údaraigh",block:"Cosc",blocked:"Cuireadh coisc!",deny:"Diúltaigh",follow:"Lean",followees:"Leantóirí",followers:"Á Leanúint",following:"Á Leanúint",follows_you:"Leanann tú",mute:"Cuir i mód ciúin",muted:"Mód ciúin",per_day:"laethúil",remote_follow:"Leaníunt iargúlta",statuses:"Poist"},user_profile:{timeline_title:"Amlíne úsáideora"},who_to_follow:{more:"Feach uile",who_to_follow:"Daoine le leanúint"}}},function(e,t){e.exports={chat:{title:"צ'אט"},features_panel:{chat:"צ'אט",gopher:"גופר",media_proxy:"מדיה פרוקסי",scope_options:"אפשרויות טווח",text_limit:"מגבלת טקסט",title:"מאפיינים",who_to_follow:"אחרי מי לעקוב"},finder:{error_fetching_user:"שגיאה במציאת משתמש",find_user:"מציאת משתמש"},general:{apply:"החל",submit:"שלח"},login:{login:"התחבר",logout:"התנתק",password:"סיסמה",placeholder:"למשל lain",register:"הירשם",username:"שם המשתמש"},nav:{chat:"צ'אט מקומי",friend_requests:"בקשות עקיבה",mentions:"אזכורים",public_tl:"ציר הזמן הציבורי",timeline:"ציר הזמן",twkn:"כל הרשת הידועה"},notifications:{ +broken_favorite:"סטאטוס לא ידוע, מחפש...",favorited_you:"אהב את הסטטוס שלך",followed_you:"עקב אחריך!",load_older:"טען התראות ישנות",notifications:"התראות",read:"קרא!",repeated_you:"חזר על הסטטוס שלך"},post_status:{account_not_locked_warning:"המשתמש שלך אינו {0}. כל אחד יכול לעקוב אחריך ולראות את ההודעות לעוקבים-בלבד שלך.",account_not_locked_warning_link:"נעול",attachments_sensitive:"סמן מסמכים מצורפים כלא בטוחים לצפייה",content_type:{plain_text:"טקסט פשוט"},content_warning:"נושא (נתון לבחירה)",default:"הרגע נחת ב-ל.א.",direct_warning:"הודעה זו תהיה זמינה רק לאנשים המוזכרים.",posting:"מפרסם",scope:{direct:"ישיר - שלח לאנשים המוזכרים בלבד",private:"עוקבים-בלבד - שלח לעוקבים בלבד",public:"ציבורי - שלח לציר הזמן הציבורי",unlisted:"מחוץ לרשימה - אל תשלח לציר הזמן הציבורי"}},registration:{bio:"אודות",email:"אימייל",fullname:"שם תצוגה",password_confirm:"אישור סיסמה",registration:"הרשמה",token:"טוקן הזמנה"},settings:{attachmentRadius:"צירופים",attachments:"צירופים",autoload:"החל טעינה אוטומטית בגלילה לתחתית הדף",avatar:"תמונת פרופיל",avatarAltRadius:"תמונות פרופיל (התראות)",avatarRadius:"תמונות פרופיל",background:"רקע",bio:"אודות",btnRadius:"כפתורים",cBlue:"כחול (תגובה, עקיבה)",cGreen:"ירוק (חזרה)",cOrange:"כתום (לייק)",cRed:"אדום (ביטול)",change_password:"שנה סיסמה",change_password_error:"הייתה בעיה בשינוי סיסמתך.",changed_password:"סיסמה שונתה בהצלחה!",collapse_subject:"מזער הודעות עם נושאים",confirm_new_password:"אשר סיסמה",current_avatar:"תמונת הפרופיל הנוכחית שלך",current_password:"סיסמה נוכחית",current_profile_banner:"כרזת הפרופיל הנוכחית שלך",data_import_export_tab:"ייבוא או ייצוא מידע",default_vis:"ברירת מחדל לטווח הנראות",delete_account:"מחק משתמש",delete_account_description:"מחק לצמיתות את המשתמש שלך ואת כל הודעותיך.",delete_account_error:"הייתה בעיה במחיקת המשתמש. אם זה ממשיך, אנא עדכן את מנהל השרת שלך.",delete_account_instructions:"הכנס את סיסמתך בקלט למטה על מנת לאשר מחיקת משתמש.",export_theme:"שמור ערכים",filtering:"סינון",filtering_explanation:"כל הסטטוסים הכוללים את המילים הללו יושתקו, אחד לשורה",follow_export:"יצוא עקיבות",follow_export_button:"ייצא את הנעקבים שלך לקובץ csv",follow_export_processing:"טוען. בקרוב תתבקש להוריד את הקובץ את הקובץ שלך",follow_import:"יבוא עקיבות",follow_import_error:"שגיאה בייבוא נעקבים.",follows_imported:"נעקבים יובאו! ייקח זמן מה לעבד אותם.",foreground:"חזית",hide_attachments_in_convo:"החבא צירופים בשיחות",hide_attachments_in_tl:"החבא צירופים בציר הזמן",import_followers_from_a_csv_file:"ייבא את הנעקבים שלך מקובץ csv",import_theme:"טען ערכים",inputRadius:"שדות קלט",interfaceLanguage:"שפת הממשק",invalid_theme_imported:'הקובץ הנבחר אינו תמה הנתמכת ע"י פלרומה. שום שינויים לא נעשו לתמה שלך.',limited_availability:"לא זמין בדפדפן שלך",links:"לינקים",lock_account_description:"הגבל את המשתמש לעוקבים מאושרים בלבד",loop_video:"נגן סרטונים ללא הפסקה",loop_video_silent_only:"נגן רק סרטונים חסרי קול ללא הפסקה",name:"שם",name_bio:"שם ואודות",new_password:"סיסמה חדשה",notification_visibility:"סוג ההתראות שתרצו לראות",notification_visibility_follows:"עקיבות",notification_visibility_likes:"לייקים",notification_visibility_mentions:"אזכורים",notification_visibility_repeats:"חזרות",nsfw_clickthrough:"החל החבאת צירופים לא בטוחים לצפיה בעת עבודה בעזרת לחיצת עכבר",oauth_tokens:"אסימוני OAuth",token:"אסימון",refresh_token:"רענון האסימון",valid_until:"בתוקף עד",revoke_token:"בטל",panelRadius:"פאנלים",pause_on_unfocused:"השהה זרימת הודעות כשהחלון לא בפוקוס",presets:"ערכים קבועים מראש",profile_background:"רקע הפרופיל",profile_banner:"כרזת הפרופיל",profile_tab:"פרופיל",radii_help:"קבע מראש עיגול פינות לממשק (בפיקסלים)",replies_in_timeline:"תגובות בציר הזמן",reply_link_preview:"החל תצוגה מקדימה של לינק-תגובה בעת ריחוף עם העכבר",reply_visibility_all:"הראה את כל התגובות",reply_visibility_following:"הראה תגובות שמופנות אליי או לעקובים שלי בלבד",reply_visibility_self:"הראה תגובות שמופנות אליי בלבד",security_tab:"ביטחון",set_new_avatar:"קבע תמונת פרופיל חדשה",set_new_profile_background:"קבע רקע פרופיל חדש",set_new_profile_banner:"קבע כרזת פרופיל חדשה",settings:"הגדרות",stop_gifs:"נגן-בעת-ריחוף GIFs",streaming:"החל זרימת הודעות אוטומטית בעת גלילה למעלה הדף",text:"טקסט",theme:"תמה",theme_help:"השתמש בקודי צבע הקס (#אדום-אדום-ירוק-ירוק-כחול-כחול) על מנת להתאים אישית את תמת הצבע שלך.",tooltipRadius:"טולטיפ \\ התראות",user_settings:"הגדרות משתמש"},timeline:{collapse:"מוטט",conversation:"שיחה",error_fetching:"שגיאה בהבאת הודעות",load_older:"טען סטטוסים חדשים",no_retweet_hint:'ההודעה מסומנת כ"לעוקבים-בלבד" ולא ניתן לחזור עליה',repeated:"חזר",show_new:"הראה חדש",up_to_date:"עדכני"},user_card:{approve:"אשר",block:"חסימה",blocked:"חסום!",deny:"דחה",follow:"עקוב",followees:"נעקבים",followers:"עוקבים",following:"עוקב!",follows_you:"עוקב אחריך!",mute:"השתק",muted:"מושתק",per_day:"ליום",remote_follow:"עקיבה מרחוק",statuses:"סטטוסים"},user_profile:{timeline_title:"ציר זמן המשתמש"},who_to_follow:{more:"עוד",who_to_follow:"אחרי מי לעקוב"}}},function(e,t){e.exports={finder:{error_fetching_user:"Hiba felhasználó beszerzésével",find_user:"Felhasználó keresése"},general:{submit:"Elküld"},login:{login:"Bejelentkezés",logout:"Kijelentkezés",password:"Jelszó",placeholder:"e.g. lain",register:"Feliratkozás",username:"Felhasználó név"},nav:{mentions:"Említéseim",public_tl:"Publikus Idővonal",timeline:"Idővonal",twkn:"Az Egész Ismert Hálózat"},notifications:{followed_you:"követ téged",notifications:"Értesítések",read:"Olvasva!"},post_status:{default:"Most érkeztem L.A.-be",posting:"Küldés folyamatban"},registration:{bio:"Bio",email:"Email",fullname:"Teljes név",password_confirm:"Jelszó megerősítése",registration:"Feliratkozás"},settings:{attachments:"Csatolmányok",autoload:"Autoatikus betöltés engedélyezése lap aljára görgetéskor",avatar:"Avatár",bio:"Bio",current_avatar:"Jelenlegi avatár",current_profile_banner:"Jelenlegi profil banner",filtering:"Szűrés",filtering_explanation:"Minden tartalom mely ezen szavakat tartalmazza némítva lesz, soronként egy",hide_attachments_in_convo:"Csatolmányok elrejtése a társalgásokban",hide_attachments_in_tl:"Csatolmányok elrejtése az idővonalon",name:"Név",name_bio:"Név és Bio",nsfw_clickthrough:"NSFW átkattintási tartalom elrejtésének engedélyezése",profile_background:"Profil háttérkép",profile_banner:"Profil Banner",reply_link_preview:"Válasz-link előzetes mutatása egér rátételkor",set_new_avatar:"Új avatár",set_new_profile_background:"Új profil háttér beállítása",set_new_profile_banner:"Új profil banner",settings:"Beállítások",theme:"Téma",user_settings:"Felhasználói beállítások"},timeline:{conversation:"Társalgás",error_fetching:"Hiba a frissítések beszerzésénél",load_older:"Régebbi állapotok betöltése",show_new:"Újak mutatása",up_to_date:"Naprakész"},user_card:{block:"Letilt",blocked:"Letiltva!",follow:"Követ",followees:"Követettek",followers:"Követők",following:"Követve!",follows_you:"Követ téged!",mute:"Némít",muted:"Némított",per_day:"naponta",statuses:"Állapotok"}}},function(e,t){e.exports={general:{submit:"Invia",apply:"Applica"},nav:{mentions:"Menzioni",public_tl:"Sequenza temporale pubblica",timeline:"Sequenza temporale",twkn:"L'intera rete conosciuta",chat:"Chat Locale",friend_requests:"Richieste di Seguirti"},notifications:{followed_you:"ti segue",notifications:"Notifiche",read:"Leggi!",broken_favorite:"Stato sconosciuto, lo sto cercando...",favorited_you:"ha messo mi piace al tuo stato",load_older:"Carica notifiche più vecchie",repeated_you:"ha condiviso il tuo stato"},settings:{attachments:"Allegati",autoload:"Abilita caricamento automatico quando si raggiunge fondo pagina",avatar:"Avatar",bio:"Introduzione",current_avatar:"Il tuo avatar attuale",current_profile_banner:"Il tuo banner attuale",filtering:"Filtri",filtering_explanation:"Tutti i post contenenti queste parole saranno silenziati, uno per linea",hide_attachments_in_convo:"Nascondi gli allegati presenti nelle conversazioni",hide_attachments_in_tl:"Nascondi gli allegati presenti nella sequenza temporale",name:"Nome",name_bio:"Nome & Introduzione",nsfw_clickthrough:"Abilita il click per visualizzare gli allegati segnati come NSFW",profile_background:"Sfondo della tua pagina",profile_banner:"Banner del tuo profilo",reply_link_preview:"Abilita il link per la risposta al passaggio del mouse",set_new_avatar:"Scegli un nuovo avatar",set_new_profile_background:"Scegli un nuovo sfondo per la tua pagina",set_new_profile_banner:"Scegli un nuovo banner per il tuo profilo",settings:"Impostazioni",theme:"Tema",user_settings:"Impostazioni Utente",attachmentRadius:"Allegati",avatarAltRadius:"Avatar (Notifiche)",avatarRadius:"Avatar",background:"Sfondo",btnRadius:"Pulsanti",cBlue:"Blu (Rispondere, seguire)",cGreen:"Verde (Condividi)",cOrange:"Arancio (Mi piace)",cRed:"Rosso (Annulla)",change_password:"Cambia Password",change_password_error:"C'è stato un problema durante il cambiamento della password.",changed_password:"Password cambiata correttamente!",collapse_subject:"Riduci post che hanno un oggetto",confirm_new_password:"Conferma la nuova password",current_password:"Password attuale",data_import_export_tab:"Importa / Esporta Dati",default_vis:"Visibilità predefinita dei post",delete_account:"Elimina Account",delete_account_description:"Elimina definitivamente il tuo account e tutti i tuoi messaggi.",delete_account_error:"C'è stato un problema durante l'eliminazione del tuo account. Se il problema persiste contatta l'amministratore della tua istanza.",delete_account_instructions:"Digita la tua password nel campo sottostante per confermare l'eliminazione dell'account.",export_theme:"Salva settaggi",follow_export:"Esporta la lista di chi segui",follow_export_button:"Esporta la lista di chi segui in un file csv",follow_export_processing:"Sto elaborando, presto ti sarà chiesto di scaricare il tuo file",follow_import:"Importa la lista di chi segui",follow_import_error:"Errore nell'importazione della lista di chi segui",follows_imported:"Importazione riuscita! L'elaborazione richiederà un po' di tempo.",foreground:"In primo piano",general:"Generale",hide_post_stats:"Nascondi statistiche dei post (es. il numero di mi piace)",hide_user_stats:"Nascondi statistiche dell'utente (es. il numero di chi ti segue)",import_followers_from_a_csv_file:"Importa una lista di chi segui da un file csv",import_theme:"Carica settaggi",inputRadius:"Campi di testo",instance_default:"(predefinito: {value})",interfaceLanguage:"Linguaggio dell'interfaccia",invalid_theme_imported:"Il file selezionato non è un file di tema per Pleroma supportato. Il tuo tema non è stato modificato.",limited_availability:"Non disponibile nel tuo browser",links:"Collegamenti",lock_account_description:"Limita il tuo account solo per contatti approvati",loop_video:"Riproduci video in ciclo continuo",loop_video_silent_only:"Riproduci solo video senza audio in ciclo continuo (es. le gif di Mastodon)",new_password:"Nuova password",notification_visibility:"Tipi di notifiche da mostrare",notification_visibility_follows:"Nuove persone ti seguono",notification_visibility_likes:"Mi piace",notification_visibility_mentions:"Menzioni",notification_visibility_repeats:"Condivisioni",no_rich_text_description:"Togli la formattazione del testo da tutti i post",oauth_tokens:"Token OAuth",token:"Token",refresh_token:"Aggiorna token",valid_until:"Valido fino a",revoke_token:"Revocare",panelRadius:"Pannelli",pause_on_unfocused:"Metti in pausa l'aggiornamento continuo quando la scheda non è in primo piano",presets:"Valori predefiniti",profile_tab:"Profilo",radii_help:"Imposta l'arrotondamento dei bordi (in pixel)",replies_in_timeline:"Risposte nella sequenza temporale",reply_visibility_all:"Mostra tutte le risposte",reply_visibility_following:"Mostra solo le risposte dirette a me o agli utenti che seguo",reply_visibility_self:"Mostra solo risposte dirette a me",saving_err:"Errore nel salvataggio delle impostazioni",saving_ok:"Impostazioni salvate",security_tab:"Sicurezza",stop_gifs:"Riproduci GIF al passaggio del cursore del mouse",streaming:"Abilita aggiornamento automatico dei nuovi post quando si è in alto alla pagina",text:"Testo",theme_help:"Usa codici colore esadecimali (#rrggbb) per personalizzare il tuo schema di colori.",tooltipRadius:"Descrizioni/avvisi",values:{false:"no",true:"si"}},timeline:{error_fetching:"Errore nel prelievo aggiornamenti",load_older:"Carica messaggi più vecchi",show_new:"Mostra nuovi",up_to_date:"Aggiornato",collapse:"Riduci",conversation:"Conversazione",no_retweet_hint:"La visibilità del post è impostata solo per chi ti segue o messaggio diretto e non può essere condiviso",repeated:"condiviso"},user_card:{follow:"Segui",followees:"Chi stai seguendo",followers:"Chi ti segue",following:"Lo stai seguendo!",follows_you:"Ti segue!",mute:"Silenzia",muted:"Silenziato",per_day:"al giorno",statuses:"Messaggi",approve:"Approva",block:"Blocca",blocked:"Bloccato!",deny:"Nega",remote_follow:"Segui da remoto"},chat:{title:"Chat"},features_panel:{chat:"Chat",gopher:"Gopher",media_proxy:"Media proxy",scope_options:"Opzioni di visibilità",text_limit:"Lunghezza limite",title:"Caratteristiche",who_to_follow:"Chi seguire"},finder:{error_fetching_user:"Errore nel recupero dell'utente",find_user:"Trova utente"},login:{login:"Accedi",logout:"Disconnettiti",password:"Password",placeholder:"es. lain",register:"Registrati",username:"Nome utente"},post_status:{account_not_locked_warning:"Il tuo account non è {0}. Chiunque può seguirti e vedere i tuoi post riservati a chi ti segue.",account_not_locked_warning_link:"bloccato",attachments_sensitive:"Segna allegati come sensibili",content_type:{plain_text:"Testo normale"},content_warning:"Oggetto (facoltativo)",default:"Appena atterrato in L.A.",direct_warning:"Questo post sarà visibile solo dagli utenti menzionati.",posting:"Pubblica",scope:{direct:"Diretto - Pubblicato solo per gli utenti menzionati",private:"Solo per chi ti segue - Visibile solo da chi ti segue",public:"Pubblico - Visibile sulla sequenza temporale pubblica",unlisted:"Non elencato - Non visibile sulla sequenza temporale pubblica"}},registration:{bio:"Introduzione",email:"Email",fullname:"Nome visualizzato",password_confirm:"Conferma password",registration:"Registrazione",token:"Codice d'invito"},user_profile:{timeline_title:"Sequenza Temporale dell'Utente"},who_to_follow:{more:"Più",who_to_follow:"Chi seguire"}}},function(e,t){e.exports={chat:{title:"チャット"},features_panel:{chat:"チャット",gopher:"Gopher",media_proxy:"メディアプロクシ",scope_options:"こうかいはんいせんたく",text_limit:"もじのかず",title:"ゆうこうなきのう",who_to_follow:"おすすめユーザー"},finder:{error_fetching_user:"ユーザーけんさくがエラーになりました。",find_user:"ユーザーをさがす"},general:{apply:"てきよう",submit:"そうしん",more:"つづき",generic_error:"エラーになりました"},login:{login:"ログイン",description:"OAuthでログイン",logout:"ログアウト",password:"パスワード",placeholder:"れい: lain",register:"はじめる",username:"ユーザーめい",hint:"はなしあいにくわわるには、ログインしてください"},nav:{about:"これはなに?",back:"もどる",chat:"ローカルチャット",friend_requests:"フォローリクエスト",mentions:"メンション",dms:"ダイレクトメッセージ",public_tl:"パブリックタイムライン",timeline:"タイムライン",twkn:"つながっているすべてのネットワーク",user_search:"ユーザーをさがす",who_to_follow:"おすすめユーザー",preferences:"せってい"},notifications:{broken_favorite:"ステータスがみつかりません。さがしています...",favorited_you:"あなたのステータスがおきにいりされました",followed_you:"フォローされました",load_older:"ふるいつうちをみる",notifications:"つうち",read:"よんだ!",repeated_you:"あなたのステータスがリピートされました",no_more_notifications:"つうちはありません"},post_status:{new_status:"とうこうする",account_not_locked_warning:"あなたのアカウントは {0} ではありません。あなたをフォローすれば、だれでも、フォロワーげんていのステータスをよむことができます。",account_not_locked_warning_link:"ロックされたアカウント",attachments_sensitive:"ファイルをNSFWにする",content_type:{plain_text:"プレーンテキスト"},content_warning:"せつめい (かかなくてもよい)",default:"はねだくうこうに、つきました。",direct_warning:"このステータスは、メンションされたユーザーだけが、よむことができます。",posting:"とうこう",scope:{direct:"ダイレクト: メンションされたユーザーのみにとどきます。",private:"フォロワーげんてい: フォロワーのみにとどきます。",public:"パブリック: パブリックタイムラインにとどきます。",unlisted:"アンリステッド: パブリックタイムラインにとどきません。"}},registration:{bio:"プロフィール",email:"Eメール",fullname:"スクリーンネーム",password_confirm:"パスワードのかくにん",registration:"はじめる",token:"しょうたいトークン",captcha:"CAPTCHA",new_captcha:"もじがよめないときは、がぞうをクリックすると、あたらしいがぞうになります",validations:{username_required:"なにかかいてください",fullname_required:"なにかかいてください",email_required:"なにかかいてください",password_required:"なにかかいてください",password_confirmation_required:"なにかかいてください",password_confirmation_match:"パスワードがちがいます"}},settings:{attachmentRadius:"ファイル",attachments:"ファイル",autoload:"したにスクロールしたとき、じどうてきによみこむ。",avatar:"アバター",avatarAltRadius:"つうちのアバター",avatarRadius:"アバター",background:"バックグラウンド",bio:"プロフィール",btnRadius:"ボタン",cBlue:"リプライとフォロー",cGreen:"リピート",cOrange:"おきにいり",cRed:"キャンセル",change_password:"パスワードをかえる",change_password_error:"パスワードをかえることが、できなかったかもしれません。",changed_password:"パスワードが、かわりました!",collapse_subject:"せつめいのあるとうこうをたたむ",composing:"とうこう",confirm_new_password:"あたらしいパスワードのかくにん",current_avatar:"いまのアバター",current_password:"いまのパスワード",current_profile_banner:"いまのプロフィールバナー",data_import_export_tab:"インポートとエクスポート",default_vis:"デフォルトのこうかいはんい",delete_account:"アカウントをけす",delete_account_description:"あなたのアカウントとメッセージが、きえます。",delete_account_error:"アカウントをけすことが、できなかったかもしれません。インスタンスのかんりしゃに、れんらくしてください。",delete_account_instructions:"ほんとうにアカウントをけしてもいいなら、パスワードをかいてください。",avatar_size_instruction:"アバターのおおきさは、150×150ピクセルか、それよりもおおきくするといいです。",export_theme:"セーブ",filtering:"フィルタリング",filtering_explanation:"これらのことばをふくむすべてのものがミュートされます。1ぎょうに1つのことばをかいてください。",follow_export:"フォローのエクスポート",follow_export_button:"エクスポート",follow_export_processing:"おまちください。まもなくファイルをダウンロードできます。",follow_import:"フォローインポート",follow_import_error:"フォローのインポートがエラーになりました。",follows_imported:"フォローがインポートされました! すこしじかんがかかるかもしれません。",foreground:"フォアグラウンド",general:"ぜんぱん",hide_attachments_in_convo:"スレッドのファイルをかくす",hide_attachments_in_tl:"タイムラインのファイルをかくす",hide_isp:"インスタンススペシフィックパネルをかくす",preload_images:"がぞうをさきよみする",use_one_click_nsfw:"NSFWなファイルを1クリックでひらく",hide_post_stats:"とうこうのとうけいをかくす (れい: おきにいりのかず)",hide_user_stats:"ユーザーのとうけいをかくす (れい: フォロワーのかず)",hide_filtered_statuses:"フィルターされたとうこうをかくす",import_followers_from_a_csv_file:"CSVファイルからフォローをインポートする",import_theme:"ロード",inputRadius:"インプットフィールド",checkboxRadius:"チェックボックス",instance_default:"(デフォルト: {value})",instance_default_simple:"(デフォルト)",interface:"インターフェース",interfaceLanguage:"インターフェースのことば",invalid_theme_imported:"このファイルはPleromaのテーマではありません。テーマはへんこうされませんでした。",limited_availability:"あなたのブラウザではできません",links:"リンク",lock_account_description:"あなたがみとめたひとだけ、あなたのアカウントをフォローできる",loop_video:"ビデオをくりかえす",loop_video_silent_only:"おとのないビデオだけくりかえす",play_videos_in_modal:"ビデオをメディアビューアーでみる",use_contain_fit:"がぞうのサムネイルを、きりぬかない",name:"なまえ",name_bio:"なまえとプロフィール",new_password:"あたらしいパスワード",notification_visibility:"ひょうじするつうち",notification_visibility_follows:"フォロー",notification_visibility_likes:"おきにいり",notification_visibility_mentions:"メンション",notification_visibility_repeats:"リピート",no_rich_text_description:"リッチテキストをつかわない",hide_follows_description:"フォローしているひとをみせない",hide_followers_description:"フォロワーをみせない",show_admin_badge:"アドミンのしるしをみる",show_moderator_badge:"モデレーターのしるしをみる",nsfw_clickthrough:"NSFWなファイルをかくす",oauth_tokens:"OAuthトークン",token:"トークン",refresh_token:"トークンを更新",valid_until:"まで有効",revoke_token:"取り消す",panelRadius:"パネル",pause_on_unfocused:"タブにフォーカスがないときストリーミングをとめる",presets:"プリセット",profile_background:"プロフィールのバックグラウンド",profile_banner:"プロフィールバナー",profile_tab:"プロフィール",radii_help:"インターフェースのまるさをせっていする。",replies_in_timeline:"タイムラインのリプライ",reply_link_preview:"カーソルをかさねたとき、リプライのプレビューをみる",reply_visibility_all:"すべてのリプライをみる",reply_visibility_following:"わたしにあてられたリプライと、フォローしているひとからのリプライをみる",reply_visibility_self:"わたしにあてられたリプライをみる",saving_err:"せっていをセーブできませんでした",saving_ok:"せっていをセーブしました",security_tab:"セキュリティ",scope_copy:"リプライするとき、こうかいはんいをコピーする (DMのこうかいはんいは、つねにコピーされます)",set_new_avatar:"あたらしいアバターをせっていする",set_new_profile_background:"あたらしいプロフィールのバックグラウンドをせっていする",set_new_profile_banner:"あたらしいプロフィールバナーを設定する",settings:"せってい",subject_input_always_show:"サブジェクトフィールドをいつでもひょうじする",subject_line_behavior:"リプライするときサブジェクトをコピーする",subject_line_email:'メールふう: "re: サブジェクト"',subject_line_mastodon:"マストドンふう: そのままコピー",subject_line_noop:"コピーしない",post_status_content_type:"とうこうのコンテントタイプ",stop_gifs:"カーソルをかさねたとき、GIFをうごかす",streaming:"うえまでスクロールしたとき、じどうてきにストリーミングする",text:"もじ",theme:"テーマ",theme_help:"カラーテーマをカスタマイズできます",theme_help_v2_1:"チェックボックスをONにすると、コンポーネントごとに、いろと、とうめいどを、オーバーライドできます。「すべてクリア」ボタンをおすと、すべてのオーバーライドを、やめます。",theme_help_v2_2:"バックグラウンドとテキストのコントラストをあらわすアイコンがあります。マウスをホバーすると、くわしいせつめいがでます。とうめいないろをつかっているときは、もっともわるいばあいのコントラストがしめされます。",tooltipRadius:"ツールチップとアラート",user_settings:"ユーザーせってい",values:{false:"いいえ",true:"はい"},notifications:"つうち",enable_web_push_notifications:"ウェブプッシュつうちをゆるす",style:{switcher:{keep_color:"いろをのこす",keep_shadows:"かげをのこす",keep_opacity:"とうめいどをのこす",keep_roundness:"まるさをのこす",keep_fonts:"フォントをのこす",save_load_hint:"「のこす」オプションをONにすると、テーマをえらんだときとロードしたとき、いまのせっていをのこします。また、テーマをエクスポートするとき、これらのオプションをストアします。すべてのチェックボックスをOFFにすると、テーマをエクスポートしたとき、すべてのせっていをセーブします。",reset:"リセット",clear_all:"すべてクリア",clear_opacity:"とうめいどをクリア"},common:{color:"いろ",opacity:"とうめいど",contrast:{hint:"コントラストは {ratio} です。{level}。({context})",level:{aa:"AAレベルガイドライン (ミニマル) をみたします",aaa:"AAAレベルガイドライン (レコメンデッド) をみたします。",bad:"ガイドラインをみたしません。"},context:{"18pt":"おおきい (18ポイントいじょう) テキスト",text:"テキスト"}}},common_colors:{_tab_label:"きょうつう",main:"きょうつうのいろ",foreground_hint:"「くわしく」タブで、もっとこまかくせっていできます",rgbo:"アイコンとアクセントとバッジ"},advanced_colors:{_tab_label:"くわしく",alert:"アラートのバックグラウンド",alert_error:"エラー",badge:"バッジのバックグラウンド",badge_notification:"つうち",panel_header:"パネルヘッダー",top_bar:"トップバー",borders:"さかいめ",buttons:"ボタン",inputs:"インプットフィールド",faint_text:"うすいテキスト"},radii:{_tab_label:"まるさ"},shadows:{_tab_label:"ひかりとかげ",component:"コンポーネント",override:"オーバーライド",shadow_id:"かげ #{value}",blur:"ぼかし",spread:"ひろがり",inset:"うちがわ",hint:"かげのせっていでは、いろのあたいとして --variable をつかうことができます。これはCSS3へんすうです。ただし、とうめいどのせっていは、きかなくなります。",filter_hint:{always_drop_shadow:"ブラウザーがサポートしていれば、つねに {0} がつかわれます。",drop_shadow_syntax:"{0} は、{1} パラメーターと {2} キーワードをサポートしていません。",avatar_inset:"うちがわのかげと、そとがわのかげを、いっしょにつかうと、とうめいなアバターが、へんなみためになります。",spread_zero:"ひろがりが 0 よりもおおきなかげは、0 とおなじです。",inset_classic:"うちがわのかげは {0} をつかいます。"},components:{panel:"パネル",panelHeader:"パネルヘッダー",topBar:"トップバー",avatar:"ユーザーアバター (プロフィール)",avatarStatus:"ユーザーアバター (とうこう)",popup:"ポップアップとツールチップ",button:"ボタン",buttonHover:"ボタン (ホバー)",buttonPressed:"ボタン (おされているとき)",buttonPressedHover:"ボタン (ホバー、かつ、おされているとき)",input:"インプットフィールド"}},fonts:{_tab_label:"フォント",help:"「カスタム」をえらんだときは、システムにあるフォントのなまえを、ただしくにゅうりょくしてください。",components:{interface:"インターフェース",input:"インプットフィールド",post:"とうこう",postCode:"モノスペース (とうこうがリッチテキストであるとき)"},family:"フォントめい",size:"おおきさ (px)",weight:"ふとさ",custom:"カスタム"},preview:{header:"プレビュー",content:"ほんぶん",error:"エラーのれい",button:"ボタン",text:"これは{0}と{1}のれいです。",mono:"monospace",input:"はねだくうこうに、つきました。",faint_link:"とてもたすけになるマニュアル",fine_print:"わたしたちの{0}を、よまないでください!",header_faint:"エラーではありません",checkbox:"りようきやくを、よみました",link:"ハイパーリンク"}}},timeline:{collapse:"たたむ",conversation:"スレッド",error_fetching:"よみこみがエラーになりました",load_older:"ふるいステータス",no_retweet_hint:"とうこうを「フォロワーのみ」または「ダイレクト」にすると、リピートできなくなります",repeated:"リピート",show_new:"よみこみ",up_to_date:"さいしん",no_more_statuses:"これでおわりです"},user_card:{approve:"うけいれ",block:"ブロック",blocked:"ブロックしています!",deny:"おことわり",favorites:"おきにいり",follow:"フォロー",follow_sent:"リクエストを、おくりました!",follow_progress:"リクエストしています…",follow_again:"ふたたびリクエストをおくりますか?",follow_unfollow:"フォローをやめる",followees:"フォロー",followers:"フォロワー",following:"フォローしています!",follows_you:"フォローされました!",its_you:"これはあなたです!",media:"メディア",mute:"ミュート",muted:"ミュートしています!",per_day:"/日",remote_follow:"リモートフォロー",statuses:"ステータス"},user_profile:{timeline_title:"ユーザータイムライン"},who_to_follow:{more:"くわしく",who_to_follow:"おすすめユーザー"},tool_tip:{media_upload:"メディアをアップロード",repeat:"リピート",reply:"リプライ",favorite:"おきにいり",user_settings:"ユーザーせってい"},upload:{error:{base:"アップロードにしっぱいしました。",file_too_big:"ファイルがおおきすぎます [{filesize} {filesizeunit} / {allowedsize} {allowedsizeunit}]",default:"しばらくしてから、ためしてください"},file_size_units:{B:"B",KiB:"KiB",MiB:"MiB",GiB:"GiB",TiB:"TiB"}}}},function(e,t){e.exports={chat:{title:"챗"},features_panel:{chat:"챗",gopher:"고퍼",media_proxy:"미디어 프록시",scope_options:"범위 옵션",text_limit:"텍스트 제한",title:"기능",who_to_follow:"팔로우 추천"},finder:{error_fetching_user:"사용자 정보 불러오기 실패",find_user:"사용자 찾기"},general:{apply:"적용",submit:"보내기"},login:{login:"로그인",description:"OAuth로 로그인",logout:"로그아웃",password:"암호",placeholder:"예시: lain",register:"가입",username:"사용자 이름"},nav:{about:"About",back:"뒤로",chat:"로컬 챗",friend_requests:"팔로우 요청",mentions:"멘션",dms:"다이렉트 메시지",public_tl:"공개 타임라인",timeline:"타임라인",twkn:"모든 알려진 네트워크",user_search:"사용자 검색",preferences:"환경설정"},notifications:{broken_favorite:"알 수 없는 게시물입니다, 검색 합니다...",favorited_you:"당신의 게시물을 즐겨찾기",followed_you:"당신을 팔로우",load_older:"오래 된 알림 불러오기",notifications:"알림",read:"읽음!",repeated_you:"당신의 게시물을 리핏"},post_status:{new_status:"새 게시물 게시",account_not_locked_warning:"당신의 계정은 {0} 상태가 아닙니다. 누구나 당신을 팔로우 하고 팔로워 전용 게시물을 볼 수 있습니다.",account_not_locked_warning_link:"잠김",attachments_sensitive:"첨부물을 민감함으로 설정",content_type:{plain_text:"평문"},content_warning:"주제 (필수 아님)",default:"LA에 도착!",direct_warning:"이 게시물을 멘션 된 사용자들에게만 보여집니다",posting:"게시",scope:{direct:"다이렉트 - 멘션 된 사용자들에게만",private:"팔로워 전용 - 팔로워들에게만",public:"공개 - 공개 타임라인으로",unlisted:"비공개 - 공개 타임라인에 게시 안 함"}},registration:{bio:"소개",email:"이메일",fullname:"표시 되는 이름",password_confirm:"암호 확인",registration:"가입하기",token:"초대 토큰",captcha:"캡차",new_captcha:"이미지를 클릭해서 새로운 캡차",validations:{username_required:"공백으로 둘 수 없습니다",fullname_required:"공백으로 둘 수 없습니다",email_required:"공백으로 둘 수 없습니다",password_required:"공백으로 둘 수 없습니다",password_confirmation_required:"공백으로 둘 수 없습니다",password_confirmation_match:"패스워드와 일치해야 합니다"}},settings:{attachmentRadius:"첨부물",attachments:"첨부물",autoload:"최하단에 도착하면 자동으로 로드 활성화",avatar:"아바타",avatarAltRadius:"아바타 (알림)",avatarRadius:"아바타",background:"배경",bio:"소개",btnRadius:"버튼",cBlue:"파랑 (답글, 팔로우)",cGreen:"초록 (리트윗)",cOrange:"주황 (즐겨찾기)",cRed:"빨강 (취소)",change_password:"암호 바꾸기",change_password_error:"암호를 바꾸는 데 몇 가지 문제가 있습니다.",changed_password:"암호를 바꾸었습니다!",collapse_subject:"주제를 가진 게시물 접기",composing:"작성",confirm_new_password:"새 패스워드 확인",current_avatar:"현재 아바타",current_password:"현재 패스워드",current_profile_banner:"현재 프로필 배너",data_import_export_tab:"데이터 불러오기 / 내보내기",default_vis:"기본 공개 범위",delete_account:"계정 삭제",delete_account_description:"계정과 메시지를 영구히 삭제.",delete_account_error:"계정을 삭제하는데 문제가 있습니다. 계속 발생한다면 인스턴스 관리자에게 문의하세요.",delete_account_instructions:"계정 삭제를 확인하기 위해 아래에 패스워드 입력.",export_theme:"프리셋 저장",filtering:"필터링",filtering_explanation:"아래의 단어를 가진 게시물들은 뮤트 됩니다, 한 줄에 하나씩 적으세요",follow_export:"팔로우 내보내기",follow_export_button:"팔로우 목록을 csv로 내보내기",follow_export_processing:"진행 중입니다, 곧 다운로드 가능해 질 것입니다",follow_import:"팔로우 불러오기",follow_import_error:"팔로우 불러오기 실패",follows_imported:"팔로우 목록을 불러왔습니다! 처리에는 시간이 걸립니다.",foreground:"전경",general:"일반",hide_attachments_in_convo:"대화의 첨부물 숨기기",hide_attachments_in_tl:"타임라인의 첨부물 숨기기",hide_isp:"인스턴스 전용 패널 숨기기",preload_images:"이미지 미리 불러오기",hide_post_stats:"게시물 통계 숨기기 (즐겨찾기 수 등)",hide_user_stats:"사용자 통계 숨기기 (팔로워 수 등)",import_followers_from_a_csv_file:"csv 파일에서 팔로우 목록 불러오기",import_theme:"프리셋 불러오기",inputRadius:"입력 칸",checkboxRadius:"체크박스",instance_default:"(기본: {value})",instance_default_simple:"(기본)",interface:"인터페이스",interfaceLanguage:"인터페이스 언어",invalid_theme_imported:"선택한 파일은 지원하는 플레로마 테마가 아닙니다. 아무런 변경도 일어나지 않았습니다.",limited_availability:"이 브라우저에서 사용 불가",links:"링크",lock_account_description:"계정을 승인 된 팔로워들로 제한",loop_video:"비디오 반복재생",loop_video_silent_only:'소리가 없는 비디오만 반복 재생 (마스토돈의 "gifs" 같은 것들)',name:"이름",name_bio:"이름 & 소개",new_password:"새 암호",notification_visibility:"보여 줄 알림 종류",notification_visibility_follows:"팔로우",notification_visibility_likes:"좋아함",notification_visibility_mentions:"멘션",notification_visibility_repeats:"반복",no_rich_text_description:"모든 게시물의 서식을 지우기",hide_follows_description:"내가 팔로우하는 사람을 표시하지 않음",hide_followers_description:"나를 따르는 사람을 보여주지 마라.",nsfw_clickthrough:'NSFW 이미지 "클릭해서 보이기"를 활성화',oauth_tokens:"OAuth 토큰",token:"토큰",refresh_token:"토큰 새로 고침",valid_until:"까지 유효하다",revoke_token:"취소",panelRadius:"패널",pause_on_unfocused:"탭이 활성 상태가 아닐 때 스트리밍 멈추기",presets:"프리셋",profile_background:"프로필 배경",profile_banner:"프로필 배너",profile_tab:"프로필",radii_help:"인터페이스 모서리 둥글기 (픽셀 단위)",replies_in_timeline:"답글을 타임라인에",reply_link_preview:"마우스를 올려서 답글 링크 미리보기 활성화",reply_visibility_all:"모든 답글 보기",reply_visibility_following:"나에게 직접 오는 답글이나 내가 팔로우 중인 사람에게서 오는 답글만 표시",reply_visibility_self:"나에게 직접 전송 된 답글만 보이기",saving_err:"설정 저장 실패",saving_ok:"설정 저장 됨",security_tab:"보안",scope_copy:"답글을 달 때 공개 범위 따라가리 (다이렉트 메시지는 언제나 따라감)",set_new_avatar:"새 아바타 설정",set_new_profile_background:"새 프로필 배경 설정",set_new_profile_banner:"새 프로필 배너 설정",settings:"설정",subject_input_always_show:"항상 주제 칸 보이기",subject_line_behavior:"답글을 달 때 주제 복사하기",subject_line_email:'이메일처럼: "re: 주제"',subject_line_mastodon:"마스토돈처럼: 그대로 복사",subject_line_noop:"복사 안 함",stop_gifs:"GIF파일에 마우스를 올려서 재생",streaming:"최상단에 도달하면 자동으로 새 게시물 스트리밍",text:"텍스트",theme:"테마",theme_help:"16진수 색상코드(#rrggbb)를 사용해 색상 테마를 커스터마이즈.",theme_help_v2_1:'체크박스를 통해 몇몇 컴포넌트의 색상과 불투명도를 조절 가능, "모두 지우기" 버튼으로 덮어 씌운 것을 모두 취소.',theme_help_v2_2:"몇몇 입력칸 밑의 아이콘은 전경/배경 대비 관련 표시등입니다, 마우스를 올려 자세한 정보를 볼 수 있습니다. 투명도 대비 표시등이 가장 최악의 경우를 나타낸다는 것을 유의하세요.",tooltipRadius:"툴팁/경고",user_settings:"사용자 설정",values:{false:"아니오",true:"네"},notifications:"알림",enable_web_push_notifications:"웹 푸시 알림 활성화",style:{switcher:{keep_color:"색상 유지",keep_shadows:"그림자 유지",keep_opacity:"불투명도 유지",keep_roundness:"둥글기 유지",keep_fonts:"글자체 유지",save_load_hint:'"유지" 옵션들은 다른 테마를 고르거나 불러 올 때 현재 설정 된 옵션들을 건드리지 않게 합니다, 테마를 내보내기 할 때도 이 옵션에 따라 저장합니다. 아무 것도 체크 되지 않았다면 모든 설정을 내보냅니다.',reset:"초기화",clear_all:"모두 지우기",clear_opacity:"불투명도 지우기"},common:{color:"색상",opacity:"불투명도",contrast:{hint:"대비율이 {ratio}입니다, 이것은 {context} {level}",level:{aa:"AA등급 가이드라인에 부합합니다 (최소한도)",aaa:"AAA등급 가이드라인에 부합합니다 (권장)",bad:"아무런 가이드라인 등급에도 미치지 못합니다"},context:{"18pt":"큰 (18pt 이상) 텍스트에 대해",text:"텍스트에 대해"}}},common_colors:{_tab_label:"일반",main:"일반 색상",foreground_hint:'"고급" 탭에서 더 자세한 설정이 가능합니다',rgbo:"아이콘, 강조, 배지"},advanced_colors:{_tab_label:"고급",alert:"주의 배경",alert_error:"에러",badge:"배지 배경",badge_notification:"알림",panel_header:"패널 헤더",top_bar:"상단 바",borders:"테두리",buttons:"버튼",inputs:"입력칸",faint_text:"흐려진 텍스트"},radii:{_tab_label:"둥글기"},shadows:{_tab_label:"그림자와 빛",component:"컴포넌트",override:"덮어쓰기",shadow_id:"그림자 #{value}",blur:"흐리기",spread:"퍼지기",inset:"안쪽으로",hint:"그림자에는 CSS3 변수를 --variable을 통해 색상 값으로 사용할 수 있습니다. 불투명도에는 적용 되지 않습니다.",filter_hint:{always_drop_shadow:"경고, 이 그림자는 브라우저가 지원하는 경우 항상 {0}을 사용합니다.",drop_shadow_syntax:"{0}는 {1} 파라미터와 {2} 키워드를 지원하지 않습니다.",avatar_inset:"안쪽과 안쪽이 아닌 그림자를 모두 설정하는 경우 투명 아바타에서 예상치 못 한 결과가 나올 수 있다는 것에 주의해 주세요.",spread_zero:"퍼지기가 0보다 큰 그림자는 0으로 설정한 것과 동일하게 보여집니다",inset_classic:"안쪽 그림자는 {0}를 사용합니다"},components:{panel:"패널",panelHeader:"패널 헤더",topBar:"상단 바",avatar:"사용자 아바타 (프로필 뷰에서)",avatarStatus:"사용자 아바타 (게시물에서)",popup:"팝업과 툴팁",button:"버튼",buttonHover:"버튼 (마우스 올렸을 때)",buttonPressed:"버튼 (눌렸을 때)",buttonPressedHover:"Button (마우스 올림 + 눌림)",input:"입력칸"}},fonts:{_tab_label:"글자체",help:'인터페이스의 요소에 사용 될 글자체를 고르세요. "커스텀"은 시스템에 있는 폰트 이름을 정확히 입력해야 합니다.',components:{interface:"인터페이스",input:"입력칸",post:"게시물 텍스트",postCode:"게시물의 고정폭 텍스트 (서식 있는 텍스트)"},family:"글자체 이름",size:"크기 (px 단위)",weight:"굵기",custom:"커스텀"},preview:{header:"미리보기",content:"내용",error:"에러 예시",button:"버튼",text:"더 많은 {0} 그리고 {1}",mono:"내용",input:"LA에 막 도착!",faint_link:"도움 되는 설명서",fine_print:"우리의 {0} 를 읽고 도움 되지 않는 것들을 배우자!",header_faint:"이건 괜찮아",checkbox:"나는 약관을 대충 훑어보았습니다",link:"작고 귀여운 링크"}}},timeline:{collapse:"접기",conversation:"대화",error_fetching:"업데이트 불러오기 실패",load_older:"더 오래 된 게시물 불러오기",no_retweet_hint:"팔로워 전용, 다이렉트 메시지는 반복할 수 없습니다",repeated:"반복 됨",show_new:"새로운 것 보기",up_to_date:"최신 상태"},user_card:{approve:"승인",block:"차단",blocked:"차단 됨!",deny:"거부",follow:"팔로우",follow_sent:"요청 보내짐!",follow_progress:"요청 중…",follow_again:"요청을 다시 보낼까요?",follow_unfollow:"팔로우 중지",followees:"팔로우 중",followers:"팔로워",following:"팔로우 중!",follows_you:"당신을 팔로우 합니다!",its_you:"당신입니다!",mute:"침묵",muted:"침묵 됨",per_day:" / 하루",remote_follow:"원격 팔로우",statuses:"게시물"},user_profile:{timeline_title:"사용자 타임라인"},who_to_follow:{more:"더 보기",who_to_follow:"팔로우 추천"},tool_tip:{media_upload:"미디어 업로드",repeat:"반복",reply:"답글",favorite:"즐겨찾기",user_settings:"사용자 설정" +},upload:{error:{base:"업로드 실패.",file_too_big:"파일이 너무 커요 [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]",default:"잠시 후에 다시 시도해 보세요"},file_size_units:{B:"바이트",KiB:"키비바이트",MiB:"메비바이트",GiB:"기비바이트",TiB:"테비바이트"}}}},function(e,t){e.exports={chat:{title:"Nettprat"},features_panel:{chat:"Nettprat",gopher:"Gopher",media_proxy:"Media proxy",scope_options:"Velg mottakere",text_limit:"Tekst-grense",title:"Egenskaper",who_to_follow:"Hvem å følge"},finder:{error_fetching_user:"Feil ved henting av bruker",find_user:"Finn bruker"},general:{apply:"Bruk",submit:"Send"},login:{login:"Logg inn",logout:"Logg ut",password:"Passord",placeholder:"f. eks lain",register:"Registrer",username:"Brukernavn"},nav:{chat:"Lokal nettprat",friend_requests:"Følgeforespørsler",mentions:"Nevnt",public_tl:"Offentlig Tidslinje",timeline:"Tidslinje",twkn:"Det hele kjente nettverket"},notifications:{broken_favorite:"Ukjent status, leter etter den...",favorited_you:"likte din status",followed_you:"fulgte deg",load_older:"Last eldre varsler",notifications:"Varslinger",read:"Les!",repeated_you:"Gjentok din status"},post_status:{account_not_locked_warning:"Kontoen din er ikke {0}. Hvem som helst kan følge deg for å se dine statuser til følgere",account_not_locked_warning_link:"låst",attachments_sensitive:"Merk vedlegg som sensitive",content_type:{plain_text:"Klar tekst"},content_warning:"Tema (valgfritt)",default:"Landet akkurat i L.A.",direct_warning:"Denne statusen vil kun bli sett av nevnte brukere",posting:"Publiserer",scope:{direct:"Direkte, publiser bare til nevnte brukere",private:"Bare følgere, publiser bare til brukere som følger deg",public:"Offentlig, publiser til offentlige tidslinjer",unlisted:"Uoppført, ikke publiser til offentlige tidslinjer"}},registration:{bio:"Biografi",email:"Epost-adresse",fullname:"Visningsnavn",password_confirm:"Bekreft passord",registration:"Registrering",token:"Invitasjons-bevis"},settings:{attachmentRadius:"Vedlegg",attachments:"Vedlegg",autoload:"Automatisk lasting når du blar ned til bunnen",avatar:"Profilbilde",avatarAltRadius:"Profilbilde (Varslinger)",avatarRadius:"Profilbilde",background:"Bakgrunn",bio:"Biografi",btnRadius:"Knapper",cBlue:"Blå (Svar, følg)",cGreen:"Grønn (Gjenta)",cOrange:"Oransje (Lik)",cRed:"Rød (Avbryt)",change_password:"Endre passord",change_password_error:"Feil ved endring av passord",changed_password:"Passord endret",collapse_subject:"Sammenfold statuser med tema",confirm_new_password:"Bekreft nytt passord",current_avatar:"Ditt nåværende profilbilde",current_password:"Nåværende passord",current_profile_banner:"Din nåværende profil-banner",data_import_export_tab:"Data import / eksport",default_vis:"Standard visnings-omfang",delete_account:"Slett konto",delete_account_description:"Slett din konto og alle dine statuser",delete_account_error:"Det oppsto et problem ved sletting av kontoen din, hvis dette problemet forblir kontakt din administrator",delete_account_instructions:"Skriv inn ditt passord i feltet nedenfor for å bekrefte sletting av konto",export_theme:"Lagre tema",filtering:"Filtrering",filtering_explanation:"Alle statuser som inneholder disse ordene vil bli dempet, en kombinasjon av tegn per linje",follow_export:"Eksporter følginger",follow_export_button:"Eksporter følgingene dine til en .csv fil",follow_export_processing:"Jobber, du vil snart bli spurt om å laste ned filen din.",follow_import:"Importer følginger",follow_import_error:"Feil ved importering av følginger.",follows_imported:"Følginger importert! Behandling vil ta litt tid.",foreground:"Forgrunn",general:"Generell",hide_attachments_in_convo:"Gjem vedlegg i samtaler",hide_attachments_in_tl:"Gjem vedlegg på tidslinje",import_followers_from_a_csv_file:"Importer følginger fra en csv fil",import_theme:"Last tema",inputRadius:"Input felt",instance_default:"(standard: {value})",interfaceLanguage:"Grensesnitt-språk",invalid_theme_imported:"Den valgte filen er ikke ett støttet Pleroma-tema, ingen endringer til ditt tema ble gjort",limited_availability:"Ikke tilgjengelig i din nettleser",links:"Linker",lock_account_description:"Begrens din konto til bare godkjente følgere",loop_video:"Gjenta videoer",loop_video_silent_only:'Gjenta bare videoer uten lyd, (for eksempel Mastodon sine "gifs")',name:"Navn",name_bio:"Navn & Biografi",new_password:"Nytt passord",notification_visibility:"Typer varsler som skal vises",notification_visibility_follows:"Følginger",notification_visibility_likes:"Likes",notification_visibility_mentions:"Nevnt",notification_visibility_repeats:"Gjentakelser",no_rich_text_description:"Fjern all formatering fra statuser",nsfw_clickthrough:"Krev trykk for å vise statuser som kan være upassende",oauth_tokens:"OAuth Tokens",token:"Pollett",refresh_token:"Refresh Token",valid_until:"Gyldig til",revoke_token:"Tilbakekall",panelRadius:"Panel",pause_on_unfocused:"Stopp henting av poster når vinduet ikke er i fokus",presets:"Forhåndsdefinerte tema",profile_background:"Profil-bakgrunn",profile_banner:"Profil-banner",profile_tab:"Profil",radii_help:"Bestem hvor runde hjørnene i brukergrensesnittet skal være (i piksler)",replies_in_timeline:"Svar på tidslinje",reply_link_preview:"Vis en forhåndsvisning når du holder musen over svar til en status",reply_visibility_all:"Vis alle svar",reply_visibility_following:"Vis bare svar som er til meg eller folk jeg følger",reply_visibility_self:"Vis bare svar som er til meg",saving_err:"Feil ved lagring av innstillinger",saving_ok:"Innstillinger lagret",security_tab:"Sikkerhet",set_new_avatar:"Rediger profilbilde",set_new_profile_background:"Rediger profil-bakgrunn",set_new_profile_banner:"Sett ny profil-banner",settings:"Innstillinger",stop_gifs:"Spill av GIFs når du holder over dem",streaming:"Automatisk strømming av nye statuser når du har bladd til toppen",text:"Tekst",theme:"Tema",theme_help:"Bruk heksadesimale fargekoder (#rrggbb) til å endre farge-temaet ditt.",tooltipRadius:"Verktøytips/advarsler",user_settings:"Brukerinstillinger",values:{false:"nei",true:"ja"}},timeline:{collapse:"Sammenfold",conversation:"Samtale",error_fetching:"Feil ved henting av oppdateringer",load_older:"Last eldre statuser",no_retweet_hint:"Status er markert som bare til følgere eller direkte og kan ikke gjentas",repeated:"gjentok",show_new:"Vis nye",up_to_date:"Oppdatert"},user_card:{approve:"Godkjenn",block:"Blokker",blocked:"Blokkert!",deny:"Avslå",follow:"Følg",followees:"Følger",followers:"Følgere",following:"Følger!",follows_you:"Følger deg!",mute:"Demp",muted:"Dempet",per_day:"per dag",remote_follow:"Følg eksternt",statuses:"Statuser"},user_profile:{timeline_title:"Bruker-tidslinje"},who_to_follow:{more:"Mer",who_to_follow:"Hvem å følge"}}},function(e,t){e.exports={chat:{title:"Chat"},features_panel:{chat:"Chat",gopher:"Gopher",media_proxy:"Media proxy",scope_options:"Zichtbaarheidsopties",text_limit:"Tekst limiet",title:"Features",who_to_follow:"Wie te volgen"},finder:{error_fetching_user:"Fout tijdens ophalen gebruiker",find_user:"Gebruiker zoeken"},general:{apply:"toepassen",submit:"Verzend"},login:{login:"Log in",description:"Log in met OAuth",logout:"Log uit",password:"Wachtwoord",placeholder:"bv. lain",register:"Registreer",username:"Gebruikersnaam"},nav:{about:"Over",back:"Terug",chat:"Locale Chat",friend_requests:"Volgverzoek",mentions:"Vermeldingen",dms:"Directe Berichten",public_tl:"Publieke Tijdlijn",timeline:"Tijdlijn",twkn:"Het Geheel Gekende Netwerk",user_search:"Zoek Gebruiker",who_to_follow:"Wie te volgen",preferences:"Voorkeuren"},notifications:{broken_favorite:"Onbekende status, aan het zoeken...",favorited_you:"vond je status leuk",followed_you:"volgt jou",load_older:"Laad oudere meldingen",notifications:"Meldingen",read:"Gelezen!",repeated_you:"Herhaalde je status"},post_status:{new_status:"Post nieuwe status",account_not_locked_warning:"Je account is niet {0}. Iedereen die je volgt kan enkel-volgers posts lezen.",account_not_locked_warning_link:"gesloten",attachments_sensitive:"Markeer bijlage als gevoelig",content_type:{plain_text:"Gewone tekst"},content_warning:"Onderwerp (optioneel)",default:"Tijd voor een pauze!",direct_warning:"Deze post zal enkel zichtbaar zijn voor de personen die genoemd zijn.",posting:"Plaatsen",scope:{direct:"Direct - Post enkel naar genoemde gebruikers",private:"Enkel volgers - Post enkel naar volgers",public:"Publiek - Post op publieke tijdlijnen",unlisted:"Unlisted - Toon niet op publieke tijdlijnen"}},registration:{bio:"Bio",email:"Email",fullname:"Weergave naam",password_confirm:"Wachtwoord bevestiging",registration:"Registratie",token:"Uitnodigingstoken",captcha:"CAPTCHA",new_captcha:"Klik op de afbeelding voor een nieuwe captcha",validations:{username_required:"moet ingevuld zijn",fullname_required:"moet ingevuld zijn",email_required:"moet ingevuld zijn",password_required:"moet ingevuld zijn",password_confirmation_required:"moet ingevuld zijn",password_confirmation_match:"komt niet overeen met het wachtwoord"}},settings:{attachmentRadius:"Bijlages",attachments:"Bijlages",autoload:"Automatisch laden wanneer tot de bodem gescrold inschakelen",avatar:"Avatar",avatarAltRadius:"Avatars (Meldingen)",avatarRadius:"Avatars",background:"Achtergrond",bio:"Bio",btnRadius:"Knoppen",cBlue:"Blauw (Antwoord, volgen)",cGreen:"Groen (Herhaal)",cOrange:"Oranje (Vind ik leuk)",cRed:"Rood (Annuleer)",change_password:"Verander Wachtwoord",change_password_error:"Er was een probleem bij het aanpassen van je wachtwoord.",changed_password:"Wachtwoord succesvol aangepast!",collapse_subject:"Klap posts met onderwerp in",composing:"Samenstellen",confirm_new_password:"Bevestig nieuw wachtwoord",current_avatar:"Je huidige avatar",current_password:"Huidig wachtwoord",current_profile_banner:"Je huidige profiel banner",data_import_export_tab:"Data Import / Export",default_vis:"Standaard zichtbaarheidsscope",delete_account:"Verwijder Account",delete_account_description:"Verwijder je account en berichten permanent.",delete_account_error:"Er was een probleem bij het verwijderen van je account. Indien dit probleem blijft, gelieve de administratie van deze instantie te verwittigen.",delete_account_instructions:"Typ je wachtwoord in de input hieronder om het verwijderen van je account te bevestigen.",export_theme:"Sla preset op",filtering:"Filtering",filtering_explanation:"Alle statussen die deze woorden bevatten worden genegeerd, één filter per lijn.",follow_export:"Volgers export",follow_export_button:"Exporteer je volgers naar een csv file",follow_export_processing:"Aan het verwerken, binnen enkele ogenblikken wordt je gevraagd je bestand te downloaden",follow_import:"Volgers import",follow_import_error:"Fout bij importeren volgers",follows_imported:"Volgers geïmporteerd! Het kan even duren om ze allemaal te verwerken.",foreground:"Voorgrond",general:"Algemeen",hide_attachments_in_convo:"Verberg bijlages in conversaties",hide_attachments_in_tl:"Verberg bijlages in de tijdlijn",hide_isp:"Verberg instantie-specifiek paneel",preload_images:"Afbeeldingen voorladen",hide_post_stats:"Verberg post statistieken (bv. het aantal vind-ik-leuks)",hide_user_stats:"Verberg post statistieken (bv. het aantal volgers)",import_followers_from_a_csv_file:"Importeer volgers uit een csv file",import_theme:"Laad preset",inputRadius:"Invoer velden",checkboxRadius:"Checkboxen",instance_default:"(standaard: {value})",instance_default_simple:"(standaard)",interface:"Interface",interfaceLanguage:"Interface taal",invalid_theme_imported:"Het geselecteerde thema is geen door Pleroma ondersteund thema. Er zijn geen aanpassingen gedaan.",limited_availability:"Onbeschikbaar in je browser",links:"Links",lock_account_description:"Laat volgers enkel toe na expliciete toestemming",loop_video:"Speel videos af in een lus",loop_video_silent_only:'Speel enkel videos zonder geluid af in een lus (bv. Mastodon\'s "gifs")',name:"Naam",name_bio:"Naam & Bio",new_password:"Nieuw wachtwoord",notification_visibility:"Type meldingen die getoond worden",notification_visibility_follows:"Volgers",notification_visibility_likes:"Vind-ik-leuks",notification_visibility_mentions:"Vermeldingen",notification_visibility_repeats:"Herhalingen",no_rich_text_description:"Strip rich text formattering van alle posts",hide_network_description:"Toon niet wie mij volgt en wie ik volg.",nsfw_clickthrough:"Schakel doorklikbaar verbergen van NSFW bijlages in",oauth_tokens:"OAuth-tokens",token:"Token",refresh_token:"Token vernieuwen",valid_until:"Geldig tot",revoke_token:"Intrekken",panelRadius:"Panelen",pause_on_unfocused:"Pauzeer streamen wanneer de tab niet gefocused is",presets:"Presets",profile_background:"Profiel Achtergrond",profile_banner:"Profiel Banner",profile_tab:"Profiel",radii_help:"Stel afronding van hoeken in de interface in (in pixels)",replies_in_timeline:"Antwoorden in tijdlijn",reply_link_preview:"Schakel antwoordlink preview in bij over zweven met muisaanwijzer",reply_visibility_all:"Toon alle antwoorden",reply_visibility_following:"Toon enkel antwoorden naar mij of andere gebruikers gericht",reply_visibility_self:"Toon enkel antwoorden naar mij gericht",saving_err:"Fout tijdens opslaan van instellingen",saving_ok:"Instellingen opgeslagen",security_tab:"Veiligheid",scope_copy:"Neem scope over bij antwoorden (Directe Berichten blijven altijd Direct)",set_new_avatar:"Zet nieuwe avatar",set_new_profile_background:"Zet nieuwe profiel achtergrond",set_new_profile_banner:"Zet nieuwe profiel banner",settings:"Instellingen",subject_input_always_show:"Maak onderwerpveld altijd zichtbaar",subject_line_behavior:"Kopieer onderwerp bij antwoorden",subject_line_email:'Zoals email: "re: onderwerp"',subject_line_mastodon:"Zoals Mastodon: kopieer zoals het is",subject_line_noop:"Kopieer niet",stop_gifs:"Speel GIFs af bij zweven",streaming:"Schakel automatisch streamen van posts in wanneer tot boven gescrold.",text:"Tekst",theme:"Thema",theme_help:"Gebruik hex color codes (#rrggbb) om je kleurschema te wijzigen.",theme_help_v2_1:'Je kan ook de kleur en transparantie van bepaalde componenten overschrijven door de checkbox aan te vinken, gebruik de "Wis alles" knop om alle overschrijvingen te annuleren.',theme_help_v2_2:"Iconen onder sommige items zijn achtergrond/tekst contrast indicators, zweef er over voor gedetailleerde info. Hou er rekening mee dat bij doorzichtigheid de ergst mogelijke situatie wordt weer gegeven.",tooltipRadius:"Gereedschapstips/alarmen",user_settings:"Gebruikers Instellingen",values:{false:"nee",true:"ja"},notifications:"Meldingen",enable_web_push_notifications:"Schakel web push meldingen in",style:{switcher:{keep_color:"Behoud kleuren",keep_shadows:"Behoud schaduwen",keep_opacity:"Behoud transparantie",keep_roundness:"Behoud afrondingen",keep_fonts:"Behoud lettertypes",save_load_hint:"\"Behoud\" opties behouden de momenteel ingestelde opties bij het selecteren of laden van thema's, maar slaan ook de genoemde opties op bij het exporteren van een thema. Wanneer alle selectievakjes zijn uitgeschakeld, zal het exporteren van thema's alles opslaan.",reset:"Reset",clear_all:"Wis alles",clear_opacity:"Wis transparantie"},common:{color:"Kleur",opacity:"Transparantie",contrast:{hint:"Contrast ratio is {ratio}, {level} {context}",level:{aa:"voldoet aan de richtlijn van niveau AA (minimum)",aaa:"voldoet aan de richtlijn van niveau AAA (aangeraden)",bad:"voldoet aan geen enkele toegankelijkheidsrichtlijn"},context:{"18pt":"voor grote (18pt+) tekst",text:"voor tekst"}}},common_colors:{_tab_label:"Gemeenschappelijk",main:"Gemeenschappelijke kleuren",foreground_hint:'Zie "Geavanceerd" tab voor meer gedetailleerde controle',rgbo:"Iconen, accenten, badges"},advanced_colors:{_tab_label:"Geavanceerd",alert:"Alarm achtergrond",alert_error:"Fout",badge:"Badge achtergrond",badge_notification:"Meldingen",panel_header:"Paneel hoofding",top_bar:"Top bar",borders:"Randen",buttons:"Knoppen",inputs:"Invoervelden",faint_text:"Vervaagde tekst"},radii:{_tab_label:"Rondheid"},shadows:{_tab_label:"Schaduw en belichting",component:"Component",override:"Overschrijven",shadow_id:"Schaduw #{value}",blur:"Vervagen",spread:"Spreid",inset:"Inzet",hint:"Voor schaduw kan je ook --variable gebruiken als een kleur waarde om CSS3 variabelen te gebruiken. Houd er rekening mee dat het instellen van opaciteit in dit geval niet werkt.",filter_hint:{always_drop_shadow:"Waarschuwing, deze schaduw gebruikt altijd {0} als de browser dit ondersteund.",drop_shadow_syntax:"{0} ondersteund niet de {1} parameter en {2} sleutelwoord.",avatar_inset:"Houd er rekening mee dat het combineren van zowel inzet and niet-inzet schaduwen op transparante avatars onverwachte resultaten kan opleveren.",spread_zero:"Schaduw met spreiding > 0 worden weergegeven alsof ze op nul staan",inset_classic:"Inzet schaduw zal {0} gebruiken"},components:{panel:"Paneel",panelHeader:"Paneel hoofding",topBar:"Top bar",avatar:"Gebruiker avatar (in profiel weergave)",avatarStatus:"Gebruiker avatar (in post weergave)",popup:"Popups en gereedschapstips",button:"Knop",buttonHover:"Knop (zweven)",buttonPressed:"Knop (ingedrukt)",buttonPressedHover:"Knop (ingedrukt+zweven)",input:"Invoerveld"}},fonts:{_tab_label:"Lettertypes",help:'Selecteer het lettertype om te gebruiken voor elementen van de UI.Voor "aangepast" moet je de exacte naam van het lettertype invoeren zoals die in het systeem wordt weergegeven.',components:{interface:"Interface",input:"Invoervelden",post:"Post tekst",postCode:"Monospaced tekst in een post (rich text)"},family:"Naam lettertype",size:"Grootte (in px)",weight:"Gewicht (vetheid)",custom:"Aangepast"},preview:{header:"Voorvertoning",content:"Inhoud",error:"Voorbeeld fout",button:"Knop",text:"Nog een boel andere {0} en {1}",mono:"inhoud",input:"Tijd voor een pauze!",faint_link:"handige gebruikershandleiding",fine_print:"Lees onze {0} om niets nuttig te leren!",header_faint:"Alles komt goed",checkbox:"Ik heb de gebruikersvoorwaarden eens van ver bekeken",link:"een link"}}},timeline:{collapse:"Inklappen",conversation:"Conversatie",error_fetching:"Fout bij ophalen van updates",load_older:"Laad oudere Statussen",no_retweet_hint:"Post is gemarkeerd als enkel volgers of direct en kan niet worden herhaald",repeated:"herhaalde",show_new:"Toon nieuwe",up_to_date:"Up-to-date"},user_card:{approve:"Goedkeuren",block:"Blokkeren",blocked:"Geblokkeerd!",deny:"Ontzeggen",favorites:"Vind-ik-leuks",follow:"Volgen",follow_sent:"Aanvraag verzonden!",follow_progress:"Aanvragen…",follow_again:"Aanvraag opnieuw zenden?",follow_unfollow:"Stop volgen",followees:"Aan het volgen",followers:"Volgers",following:"Aan het volgen!",follows_you:"Volgt jou!",its_you:"'t is jij!",mute:"Dempen",muted:"Gedempt",per_day:"per dag",remote_follow:"Volg vanop afstand",statuses:"Statussen"},user_profile:{timeline_title:"Gebruikers Tijdlijn"},who_to_follow:{more:"Meer",who_to_follow:"Wie te volgen"},tool_tip:{media_upload:"Upload Media",repeat:"Herhaal",reply:"Antwoord",favorite:"Vind-ik-leuk",user_settings:"Gebruikers Instellingen"},upload:{error:{base:"Upload gefaald.",file_too_big:"Bestand is te groot [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]",default:"Probeer later opnieuw"},file_size_units:{B:"B",KiB:"KiB",MiB:"MiB",GiB:"GiB",TiB:"TiB"}}}},function(e,t){e.exports={chat:{title:"Messatjariá"},features_panel:{chat:"Chat",gopher:"Gopher",media_proxy:"Servidor mandatari mèdia",scope_options:"Nivèls de confidencialitat",text_limit:"Limita de tèxte",title:"Foncionalitats",who_to_follow:"Qual seguir"},finder:{error_fetching_user:"Error pendent la cèrca d’un utilizaire",find_user:"Cercar un utilizaire"},general:{apply:"Aplicar",submit:"Mandar",more:"Mai",generic_error:"Una error s’es producha",optional:"opcional"},image_cropper:{crop_picture:"Talhar l’imatge",save:"Salvar",cancel:"Anullar"},login:{login:"Connexion",description:"Connexion via OAuth",logout:"Desconnexion",password:"Senhal",placeholder:"e.g. lain",register:"Se marcar",username:"Nom d’utilizaire",hint:"Connectatz-vos per participar a la discutida"},media_modal:{previous:"Precedent",next:"Seguent"},nav:{about:"A prepaus",back:"Tornar",chat:"Chat local",friend_requests:"Demandas de seguiment",mentions:"Notificacions",dms:"Messatges privats",public_tl:"Estatuts locals",timeline:"Flux d’actualitat",twkn:"Lo malhum conegut",user_search:"Cèrca d’utilizaires",who_to_follow:"Qual seguir",preferences:"Preferéncias"},notifications:{broken_favorite:"Estatut desconegut, sèm a lo cercar...",favorited_you:"a aimat vòstre estatut",followed_you:"vos a seguit",load_older:"Cargar las notificaciones mai ancianas",notifications:"Notficacions",read:"Legit !",repeated_you:"a repetit vòstre estatut",no_more_notifications:"Pas mai de notificacions"},post_status:{new_status:"Publicar d’estatuts novèls",account_not_locked_warning:"Vòstre compte es pas {0}. Qual que siá pòt vos seguir per veire vòstras publicacions destinadas pas qu'a vòstres seguidors.",account_not_locked_warning_link:"clavat",attachments_sensitive:"Marcar las pèças juntas coma sensiblas",content_type:{plain_text:"Tèxte brut"},content_warning:"Avís de contengut (opcional)",default:"Escrivètz aquí vòstre estatut.",direct_warning:"Aquesta publicacion serà pas que visibla pels utilizaires mencionats.",posting:"Mandadís",scope:{direct:"Dirècte - Publicar pels utilizaires mencionats solament",private:"Seguidors solament - Publicar pels sols seguidors",public:"Public - Publicar pel flux d’actualitat public",unlisted:"Pas listat - Publicar pas pel flux public"}},registration:{bio:"Biografia",email:"Adreça de corrièl",fullname:"Nom complèt",password_confirm:"Confirmar lo senhal",registration:"Inscripcion",token:"Geton de convidat",captcha:"CAPTCHA",new_captcha:"Clicatz l’imatge per obténer una nòva captcha",username_placeholder:"e.g. lain",fullname_placeholder:"e.g. Lain Iwakura",bio_placeholder:"e.g.\nHi, Soi lo Lain\nSoi afocada d’animes e vivi al Japan. Benlèu que me coneissètz de the Wired.",validations:{username_required:"pòt pas èsser void",fullname_required:"pòt pas èsser void",email_required:"pòt pas èsser void",password_required:"pòt pas èsser void",password_confirmation_required:"pòt pas èsser void",password_confirmation_match:"deu èsser lo meteis senhal"}},settings:{app_name:"Nom de l’aplicacion",attachmentRadius:"Pèças juntas",attachments:"Pèças juntas",autoload:"Activar lo cargament automatic un còp arribat al cap de la pagina",avatar:"Avatar",avatarAltRadius:"Avatars (Notificacions)",avatarRadius:"Avatars",background:"Rèire plan",bio:"Biografia",blocks_tab:"Blocatges",btnRadius:"Botons",cBlue:"Blau (Respondre, seguir)",cGreen:"Verd (Repartajar)",cOrange:"Irange (Aimar)",cRed:"Roge (Anullar)",change_password:"Cambiar lo senhal",change_password_error:"Una error s’es producha en cambiant lo senhal.",changed_password:"Senhal corrèctament cambiat !",collapse_subject:"Replegar las publicacions amb de subjèctes",composing:"Escritura",confirm_new_password:"Confirmatz lo nòu senhal",current_avatar:"Vòstre avatar actual",current_password:"Senhal actual",current_profile_banner:"Bandièra actuala del perfil",data_import_export_tab:"Importar / Exportar las donadas",default_vis:"Nivèl de visibilitat per defaut",delete_account:"Suprimir lo compte",delete_account_description:"Suprimir vòstre compte e los messatges per sempre.",delete_account_error:"Una error s’es producha en suprimir lo compte. S’aquò ten d’arribar mercés de contactar vòstre administrador d’instància.",delete_account_instructions:"Picatz vòstre senhal dins lo camp tèxte çai-jos per confirmar la supression del compte.",avatar_size_instruction:"La talha minimum recomandada pels imatges d’avatar es 150x150 pixèls.",export_theme:"Enregistrar la preconfiguracion",filtering:"Filtratge",filtering_explanation:"Totes los estatuts amb aqueles mots seràn en silenci, un mot per linha",follow_export:"Exportar los abonaments",follow_export_button:"Exportar vòstres abonaments dins un fichièr csv",follow_export_processing:"Tractament, vos demandarem lèu de telecargar lo fichièr",follow_import:"Importar los abonaments",follow_import_error:"Error en important los seguidors",follows_imported:"Seguidors importats. Lo tractament pòt trigar una estona.",foreground:"Endavant",general:"General",hide_attachments_in_convo:"Rescondre las pèças juntas dins las conversacions",hide_attachments_in_tl:"Rescondre las pèças juntas",max_thumbnails:"Nombre maximum de vinhetas per publicacion",hide_isp:"Amagar lo panèl especial instància",preload_images:"Precargar los imatges",use_one_click_nsfw:"Dobrir las pèças juntas NSFW amb un clic",hide_post_stats:"Amagar los estatistics de publicacion (ex. lo ombre de favorits)",hide_user_stats:"Amagar las estatisticas de l’utilizaire (ex. lo nombre de seguidors)",hide_filtered_statuses:"Amagar los estatuts filtrats",import_followers_from_a_csv_file:"Importar los seguidors d’un fichièr csv",import_theme:"Cargar un tèma",inputRadius:"Camps tèxte",checkboxRadius:"Casas de marcar",instance_default:"(defaut : {value})",instance_default_simple:"(defaut)",interface:"Interfàcia",interfaceLanguage:"Lenga de l’interfàcia",invalid_theme_imported:"Lo fichièr seleccionat es pas un tèma Pleroma valid. Cap de cambiament es estat fach a vòstre tèma.",limited_availability:"Pas disponible per vòstre navigador",links:"Ligams",lock_account_description:"Limitar vòstre compte als seguidors acceptats solament",loop_video:"Bocla vidèo",loop_video_silent_only:"Legir en bocla solament las vidèos sens son (coma los « Gifs » de Mastodon)",mutes_tab:"Agamats",play_videos_in_modal:"Legir las vidèoas dirèctament dins la visualizaira mèdia",use_contain_fit:"Talhar pas las pèças juntas per las vinhetas",name:"Nom",name_bio:"Nom & Bio",new_password:"Nòu senhal",notification_visibility_follows:"Abonaments",notification_visibility_likes:"Aimar",notification_visibility_mentions:"Mencions",notification_visibility_repeats:"Repeticions",notification_visibility:"Tipes de notificacion de mostrar",no_rich_text_description:"Netejar lo format tèxte de totas las publicacions",no_blocks:"Cap de blocatge",no_mutes:"Cap d’amagat",hide_follows_description:"Mostrar pas qual seguissi",hide_followers_description:"Mostrar pas qual me seguisson",show_admin_badge:"Mostrar lo badge Admin badge al perfil meu",show_moderator_badge:"Mostrar lo badge Moderator al perfil meu",nsfw_clickthrough:"Activar lo clic per mostrar los imatges marcats coma pels adults o sensibles",oauth_tokens:"Listats OAuth",token:"Geton",refresh_token:"Actualizar lo geton",valid_until:"Valid fins a",revoke_token:"Revocar",panelRadius:"Panèls",pause_on_unfocused:"Pausar la difusion quand l’onglet es pas seleccionat",presets:"Pre-enregistrats",profile_background:"Imatge de fons",profile_banner:"Bandièra del perfil",profile_tab:"Perfil",radii_help:"Configurar los caires arredondits de l’interfàcia (en pixèls)",replies_in_timeline:"Responsas del flux",reply_link_preview:"Activar l’apercebut en passar la mirga",reply_visibility_all:"Mostrar totas las responsas",reply_visibility_following:"Mostrar pas que las responsas que me son destinada a ieu o un utilizaire que seguissi",reply_visibility_self:"Mostrar pas que las responsas que me son destinadas",saving_err:"Error en enregistrant los paramètres",saving_ok:"Paramètres enregistrats",scope_copy:"Copiar lo nivèl de confidencialitat per las responsas (Totjorn aissí pels Messatges Dirèctes)",security_tab:"Seguretat",set_new_avatar:"Definir un nòu avatar",set_new_profile_background:"Definir un nòu fons de perfil",set_new_profile_banner:"Definir una nòva bandièra de perfil",settings:"Paramètres",subject_input_always_show:"Totjorn mostrar lo camp de subjècte",subject_line_behavior:"Copiar lo subjècte per las responsas",subject_line_email:'Coma los corrièls : "re: subjècte"',subject_line_mastodon:"Coma mastodon : copiar tal coma es",subject_line_noop:"Copiar pas",post_status_content_type:"Publicar lo tipe de contengut dels estatuts",stop_gifs:"Lançar los GIFs al subrevòl",streaming:"Activar lo cargament automatic dels novèls estatus en anar amont",text:"Tèxt",theme:"Tèma",theme_help_v2_1:'You can also override certain component\'s colors and opacity by toggling the checkbox, use "Clear all" button to clear all overrides.',theme_help_v2_2:"Icons underneath some entries are background/text contrast indicators, hover over for detailed info. Please keep in mind that when using transparency contrast indicators show the worst possible case.",theme_help:"Emplegatz los còdis de color hex (#rrggbb) per personalizar vòstre tèma de color.",tooltipRadius:"Astúcias/alèrtas",upload_a_photo:"Enviar una fotografia",user_settings:"Paramètres utilizaire",values:{false:"non",true:"òc"}},timeline:{collapse:"Tampar",conversation:"Conversacion",error_fetching:"Error en cercant de mesas a jorn",load_older:"Ne veire mai",repeated:"repetit",show_new:"Ne veire mai",up_to_date:"A jorn",no_retweet_hint:"La publicacion marcada coma pels seguidors solament o dirècte pòt pas èsser repetida"},status:{reply_to:"Respondre à",replies_list:"Responsas :"},user_card:{approve:"Validar",block:"Blocar",blocked:"Blocat !",deny:"Refusar",favorites:"Favorits",follow:"Seguir",follow_sent:"Demanda enviada !",follow_progress:"Demanda…",follow_again:"Tornar enviar la demanda ?",follow_unfollow:"Quitar de seguir",followees:"Abonaments",followers:"Seguidors",following:"Seguit !",follows_you:"Vos sèc !",its_you:"Sètz vos !",media:"Mèdia",mute:"Amagar",muted:"Amagat",per_day:"per jorn",remote_follow:"Seguir a distància",statuses:"Estatuts",unblock:"Desblocar",unblock_progress:"Desblocatge...",block_progress:"Blocatge...",unmute:"Tornar mostrar",unmute_progress:"Afichatge...",mute_progress:"A amagar..."},user_profile:{timeline_title:"Flux utilizaire",profile_does_not_exist:"Aqueste perfil existís pas.",profile_loading_error:"Una error s’es producha en cargant aqueste perfil."},who_to_follow:{more:"Mai",who_to_follow:"Qual seguir"},tool_tip:{media_upload:"Enviar un mèdia",repeat:"Repetir",reply:"Respondre",favorite:"aimar",user_settings:"Paramètres utilizaire"},upload:{error:{base:"Mandadís fracassat.",file_too_big:"Fichièr tròp grand [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]",default:"Tornatz ensajar mai tard"},file_size_units:{B:"o",KiB:"Kio",MiB:"Mio",GiB:"Gio",TiB:"Tio"}}}},function(e,t){e.exports={chat:{title:"Czat"},finder:{error_fetching_user:"Błąd przy pobieraniu profilu",find_user:"Znajdź użytkownika"},general:{apply:"Zastosuj",submit:"Wyślij"},login:{login:"Zaloguj",logout:"Wyloguj",password:"Hasło",placeholder:"n.p. lain",register:"Zarejestruj",username:"Użytkownik"},nav:{chat:"Lokalny czat",mentions:"Wzmianki",public_tl:"Publiczna oś czasu",timeline:"Oś czasu",twkn:"Cała znana sieć"},notifications:{favorited_you:"dodał twój status do ulubionych",followed_you:"obserwuje cię",notifications:"Powiadomienia",read:"Przeczytane!",repeated_you:"powtórzył twój status"},post_status:{default:"Właśnie wróciłem z kościoła",posting:"Wysyłanie"},registration:{bio:"Bio",email:"Email",fullname:"Wyświetlana nazwa profilu",password_confirm:"Potwierdzenie hasła",registration:"Rejestracja"},settings:{attachmentRadius:"Załączniki",attachments:"Załączniki",autoload:"Włącz automatyczne ładowanie po przewinięciu do końca strony",avatar:"Awatar",avatarAltRadius:"Awatary (powiadomienia)",avatarRadius:"Awatary",background:"Tło",bio:"Bio",btnRadius:"Przyciski",cBlue:"Niebieski (odpowiedz, obserwuj)",cGreen:"Zielony (powtórzenia)",cOrange:"Pomarańczowy (ulubione)",cRed:"Czerwony (anuluj)",change_password:"Zmień hasło",change_password_error:"Podczas zmiany hasła wystąpił problem.",changed_password:"Hasło zmienione poprawnie!",confirm_new_password:"Potwierdź nowe hasło",current_avatar:"Twój obecny awatar",current_password:"Obecne hasło",current_profile_banner:"Twój obecny banner profilu",delete_account:"Usuń konto",delete_account_description:"Trwale usuń konto i wszystkie posty.",delete_account_error:"Wystąpił problem z usuwaniem twojego konta. Jeżeli problem powtarza się, poinformuj administratora swojej instancji.", +delete_account_instructions:"Wprowadź swoje hasło w poniższe pole aby potwierdzić usunięcie konta.",filtering:"Filtrowanie",filtering_explanation:"Wszystkie statusy zawierające te słowa będą wyciszone. Jedno słowo na linijkę.",follow_export:"Eksport obserwowanych",follow_export_button:"Eksportuj swoją listę obserwowanych do pliku CSV",follow_export_processing:"Przetwarzanie, wkrótce twój plik zacznie się ściągać.",follow_import:"Import obserwowanych",follow_import_error:"Błąd przy importowaniu obserwowanych",follows_imported:"Obserwowani zaimportowani! Przetwarzanie może trochę potrwać.",foreground:"Pierwszy plan",hide_attachments_in_convo:"Ukryj załączniki w rozmowach",hide_attachments_in_tl:"Ukryj załączniki w osi czasu",import_followers_from_a_csv_file:"Importuj obserwowanych z pliku CSV",inputRadius:"Pola tekstowe",links:"Łącza",name:"Imię",name_bio:"Imię i bio",new_password:"Nowe hasło",nsfw_clickthrough:"Włącz domyślne ukrywanie załączników o treści nieprzyzwoitej (NSFW)",oauth_tokens:"Tokeny OAuth",token:"Token",refresh_token:"Odśwież token",valid_until:"Ważne do",revoke_token:"Odwołać",panelRadius:"Panele",presets:"Gotowe motywy",profile_background:"Tło profilu",profile_banner:"Banner profilu",radii_help:"Ustaw zaokrąglenie krawędzi interfejsu (w pikselach)",reply_link_preview:"Włącz dymek z podglądem postu po najechaniu na znak odpowiedzi",set_new_avatar:"Ustaw nowy awatar",set_new_profile_background:"Ustaw nowe tło profilu",set_new_profile_banner:"Ustaw nowy banner profilu",settings:"Ustawienia",stop_gifs:"Odtwarzaj GIFy po najechaniu kursorem",streaming:"Włącz automatycznie strumieniowanie nowych postów gdy na początku strony",text:"Tekst",theme:"Motyw",theme_help:"Użyj kolorów w notacji szesnastkowej (#rrggbb), by stworzyć swój motyw.",tooltipRadius:"Etykiety/alerty",user_settings:"Ustawienia użytkownika"},timeline:{collapse:"Zwiń",conversation:"Rozmowa",error_fetching:"Błąd pobierania",load_older:"Załaduj starsze statusy",repeated:"powtórzono",show_new:"Pokaż nowe",up_to_date:"Na bieżąco"},user_card:{block:"Zablokuj",blocked:"Zablokowany!",follow:"Obserwuj",followees:"Obserwowani",followers:"Obserwujący",following:"Obserwowany!",follows_you:"Obserwuje cię!",mute:"Wycisz",muted:"Wyciszony",per_day:"dziennie",remote_follow:"Zdalna obserwacja",statuses:"Statusy"},user_profile:{timeline_title:"Oś czasu użytkownika"}}},function(e,t){e.exports={chat:{title:"Chat"},features_panel:{chat:"Chat",gopher:"Gopher",media_proxy:"Proxy de mídia",scope_options:"Opções de privacidade",text_limit:"Limite de caracteres",title:"Funções",who_to_follow:"Quem seguir"},finder:{error_fetching_user:"Erro ao procurar usuário",find_user:"Buscar usuário"},general:{apply:"Aplicar",submit:"Enviar",more:"Mais",generic_error:"Houve um erro",optional:"opcional"},image_cropper:{crop_picture:"Cortar imagem",save:"Salvar",cancel:"Cancelar"},login:{login:"Entrar",description:"Entrar com OAuth",logout:"Sair",password:"Senha",placeholder:"p.e. lain",register:"Registrar",username:"Usuário",hint:"Entre para participar da discussão"},media_modal:{previous:"Anterior",next:"Próximo"},nav:{about:"Sobre",back:"Voltar",chat:"Chat local",friend_requests:"Solicitações de seguidores",mentions:"Menções",dms:"Mensagens diretas",public_tl:"Linha do tempo pública",timeline:"Linha do tempo",twkn:"Toda a rede conhecida",user_search:"Busca de usuário",who_to_follow:"Quem seguir",preferences:"Preferências"},notifications:{broken_favorite:"Status desconhecido, buscando...",favorited_you:"favoritou sua postagem",followed_you:"seguiu você",load_older:"Carregar notificações antigas",notifications:"Notificações",read:"Lido!",repeated_you:"repetiu sua postagem",no_more_notifications:"Mais nenhuma notificação"},post_status:{new_status:"Postar novo status",account_not_locked_warning:"Sua conta não está {0}. Qualquer pessoa pode te seguir para ver seus posts restritos.",account_not_locked_warning_link:"fechada",attachments_sensitive:"Marcar anexos como sensíveis",content_type:{plain_text:"Texto puro"},content_warning:"Assunto (opcional)",default:"Acabei de chegar no Rio!",direct_warning:"Este post será visível apenas para os usuários mencionados.",posting:"Publicando",scope:{direct:"Direto - Enviar somente aos usuários mencionados",private:"Apenas para seguidores - Enviar apenas para seguidores",public:"Público - Enviar a linhas do tempo públicas",unlisted:"Não listado - Não enviar a linhas do tempo públicas"}},registration:{bio:"Biografia",email:"Correio eletrônico",fullname:"Nome para exibição",password_confirm:"Confirmação de senha",registration:"Registro",token:"Código do convite",captcha:"CAPTCHA",new_captcha:"Clique na imagem para carregar um novo captcha",username_placeholder:"p. ex. lain",fullname_placeholder:"p. ex. Lain Iwakura",bio_placeholder:"e.g.\nOi, sou Lain\nSou uma garota que vive no subúrbio do Japão. Você deve me conhecer da Rede.",validations:{username_required:"não pode ser deixado em branco",fullname_required:"não pode ser deixado em branco",email_required:"não pode ser deixado em branco",password_required:"não pode ser deixado em branco",password_confirmation_required:"não pode ser deixado em branco",password_confirmation_match:"deve ser idêntica à senha"}},settings:{app_name:"Nome do aplicativo",attachmentRadius:"Anexos",attachments:"Anexos",autoload:"Habilitar carregamento automático quando a rolagem chegar ao fim.",avatar:"Avatar",avatarAltRadius:"Avatares (Notificações)",avatarRadius:"Avatares",background:"Pano de Fundo",bio:"Biografia",blocks_tab:"Blocos",btnRadius:"Botões",cBlue:"Azul (Responder, seguir)",cGreen:"Verde (Repetir)",cOrange:"Laranja (Favoritar)",cRed:"Vermelho (Cancelar)",change_password:"Mudar senha",change_password_error:"Houve um erro ao modificar sua senha.",changed_password:"Senha modificada com sucesso!",collapse_subject:"Esconder posts com assunto",composing:"Escrevendo",confirm_new_password:"Confirmar nova senha",current_avatar:"Seu avatar atual",current_password:"Sua senha atual",current_profile_banner:"Sua capa de perfil atual",data_import_export_tab:"Importação/exportação de dados",default_vis:"Opção de privacidade padrão",delete_account:"Deletar conta",delete_account_description:"Deletar sua conta e mensagens permanentemente.",delete_account_error:"Houve um problema ao deletar sua conta. Se ele persistir, por favor entre em contato com o/a administrador/a da instância.",delete_account_instructions:"Digite sua senha no campo abaixo para confirmar a exclusão da conta.",avatar_size_instruction:"O tamanho mínimo recomendado para imagens de avatar é 150x150 pixels.",export_theme:"Salvar predefinições",filtering:"Filtragem",filtering_explanation:"Todas as postagens contendo estas palavras serão silenciadas, uma por linha.",follow_export:"Exportar quem você segue",follow_export_button:"Exportar quem você segue para um arquivo CSV",follow_export_processing:"Processando. Em breve você receberá a solicitação de download do arquivo",follow_import:"Importar quem você segue",follow_import_error:"Erro ao importar seguidores",follows_imported:"Seguidores importados! O processamento pode demorar um pouco.",foreground:"Primeiro Plano",general:"Geral",hide_attachments_in_convo:"Ocultar anexos em conversas",hide_attachments_in_tl:"Ocultar anexos na linha do tempo.",max_thumbnails:"Número máximo de miniaturas por post",hide_isp:"Esconder painel específico da instância",preload_images:"Pré-carregar imagens",use_one_click_nsfw:"Abrir anexos sensíveis com um clique",hide_post_stats:"Esconder estatísticas de posts (p. ex. número de favoritos)",hide_user_stats:"Esconder estatísticas do usuário (p. ex. número de seguidores)",hide_filtered_statuses:"Esconder posts filtrados",import_followers_from_a_csv_file:"Importe seguidores a partir de um arquivo CSV",import_theme:"Carregar pré-definição",inputRadius:"Campos de entrada",checkboxRadius:"Checkboxes",instance_default:"(padrão: {value})",instance_default_simple:"(padrão)",interface:"Interface",interfaceLanguage:"Idioma da interface",invalid_theme_imported:"O arquivo selecionado não é um tema compatível com o Pleroma. Nenhuma mudança no tema foi feita.",limited_availability:"Indisponível para seu navegador",links:"Links",lock_account_description:"Restringir sua conta a seguidores aprovados",loop_video:"Repetir vídeos",loop_video_silent_only:'Repetir apenas vídeos sem som (como os "gifs" do Mastodon)',mutes_tab:"Silenciados",play_videos_in_modal:"Tocar vídeos diretamente no visualizador de mídia",use_contain_fit:"Não cortar o anexo na miniatura",name:"Nome",name_bio:"Nome & Biografia",new_password:"Nova senha",notification_visibility:"Tipos de notificação para mostrar",notification_visibility_follows:"Seguidos",notification_visibility_likes:"Favoritos",notification_visibility_mentions:"Menções",notification_visibility_repeats:"Repetições",no_rich_text_description:"Remover formatação de todos os posts",no_blocks:"Sem bloqueios",no_mutes:"Sem silenciados",hide_follows_description:"Não mostrar quem estou seguindo",hide_followers_description:"Não mostrar quem me segue",show_admin_badge:"Mostrar distintivo de Administrador em meu perfil",show_moderator_badge:"Mostrar título de Moderador em meu perfil",nsfw_clickthrough:"Habilitar clique para ocultar anexos sensíveis",oauth_tokens:"Token OAuth",token:"Token",refresh_token:"Atualizar Token",valid_until:"Válido até",revoke_token:"Revogar",panelRadius:"Paineis",pause_on_unfocused:"Parar transmissão quando a aba não estiver em primeiro plano",presets:"Predefinições",profile_background:"Pano de fundo de perfil",profile_banner:"Capa de perfil",profile_tab:"Perfil",radii_help:"Arredondar arestas da interface (em píxeis)",replies_in_timeline:"Respostas na linha do tempo",reply_link_preview:"Habilitar a pré-visualização de link de respostas ao passar o mouse.",reply_visibility_all:"Mostrar todas as respostas",reply_visibility_following:"Só mostrar respostas direcionadas a mim ou a usuários que sigo",reply_visibility_self:"Só mostrar respostas direcionadas a mim",saving_err:"Erro ao salvar configurações",saving_ok:"Configurações salvas",security_tab:"Segurança",scope_copy:"Copiar opções de privacidade ao responder (Mensagens diretas sempre copiam)",set_new_avatar:"Alterar avatar",set_new_profile_background:"Alterar o plano de fundo de perfil",set_new_profile_banner:"Alterar capa de perfil",settings:"Configurações",subject_input_always_show:"Sempre mostrar campo de assunto",subject_line_behavior:"Copiar assunto ao responder",subject_line_email:'Como em email: "re: assunto"',subject_line_mastodon:"Como o Mastodon: copiar como está",subject_line_noop:"Não copiar",post_status_content_type:"Postar tipo de conteúdo do status",stop_gifs:"Reproduzir GIFs ao passar o cursor em cima",streaming:"Habilitar o fluxo automático de postagens quando ao topo da página",text:"Texto",theme:"Tema",theme_help:"Use cores em código hexadecimal (#rrggbb) para personalizar seu esquema de cores.",theme_help_v2_1:'Você também pode sobrescrever as cores e opacidade de alguns componentes ao modificar o checkbox, use "Limpar todos" para limpar todas as modificações.',theme_help_v2_2:"Alguns ícones sob registros são indicadores de fundo/contraste de textos, passe por cima para informações detalhadas. Tenha ciência de que os indicadores de contraste não funcionam muito bem com transparência.",tooltipRadius:"Dicas/alertas",upload_a_photo:"Enviar uma foto",user_settings:"Configurações de Usuário",values:{false:"não",true:"sim"},notifications:"Notifications",enable_web_push_notifications:"Habilitar notificações web push",style:{switcher:{keep_color:"Manter cores",keep_shadows:"Manter sombras",keep_opacity:"Manter opacidade",keep_roundness:"Manter arredondado",keep_fonts:"Manter fontes",save_load_hint:"Manter as opções preserva as opções atuais ao selecionar ou carregar temas; também salva as opções ao exportar um tempo. Quanto todos os campos estiverem desmarcados, tudo será salvo ao exportar o tema.",reset:"Voltar ao padrão",clear_all:"Limpar tudo",clear_opacity:"Limpar opacidade"},common:{color:"Cor",opacity:"Opacidade",contrast:{hint:"A taxa de contraste é {ratio}, {level} {context}",level:{aa:"padrão Nível AA (mínimo)",aaa:"padrão Nível AAA (recomendado)",bad:"nenhum padrão de acessibilidade"},context:{"18pt":"para textos longos (18pt+)",text:"para texto"}}},common_colors:{_tab_label:"Comum",main:"Cores Comuns",foreground_hint:'Configurações mais detalhadas na aba"Avançado"',rgbo:"Ícones, acentuação, distintivos"},advanced_colors:{_tab_label:"Avançado",alert:"Fundo de alerta",alert_error:"Erro",badge:"Fundo do distintivo",badge_notification:"Notificação",panel_header:"Topo do painel",top_bar:"Barra do topo",borders:"Bordas",buttons:"Botões",inputs:"Caixas de entrada",faint_text:"Texto esmaecido"},radii:{_tab_label:"Arredondado"},shadows:{_tab_label:"Luz e sombra",component:"Componente",override:"Sobrescrever",shadow_id:"Sombra #{value}",blur:"Borrado",spread:"Difusão",inset:"Inserção",hint:"Para as sombras você também pode usar --variável como valor de cor para utilizar variáveis do CSS3. Tenha em mente que configurar a opacidade não será possível neste caso.",filter_hint:{always_drop_shadow:"Atenção, esta sombra sempre utiliza {0} quando compatível com o navegador.",drop_shadow_syntax:"{0} não é compatível com o parâmetro {1} e a palavra-chave {2}.",avatar_inset:"Tenha em mente que combinar as sombras de inserção e a não-inserção em avatares pode causar resultados inesperados em avatares transparentes.",spread_zero:"Sombras com uma difusão > 0 aparecerão como se fossem definidas como 0.",inset_classic:"Sombras de inserção utilizarão {0}"},components:{panel:"Painel",panelHeader:"Topo do painel",topBar:"Barra do topo",avatar:"Avatar do usuário (na visualização do perfil)",avatarStatus:"Avatar do usuário (na exibição de posts)",popup:"Dicas e notificações",button:"Botão",buttonHover:"Botão (em cima)",buttonPressed:"Botão (pressionado)",buttonPressedHover:"Botão (pressionado+em cima)",input:"Campo de entrada"}},fonts:{_tab_label:"Fontes",help:'Selecionar fonte dos elementos da interface. Para fonte "personalizada" você deve entrar exatamente o nome da fonte no sistema.',components:{interface:"Interface",input:"Campo de entrada",post:"Postar texto",postCode:"Texto monoespaçado em post (formatação rica)"},family:"Nome da fonte",size:"Tamanho (em px)",weight:"Peso",custom:"Personalizada"},preview:{header:"Pré-visualizar",content:"Conteúdo",error:"Erro de exemplo",button:"Botão",text:"Vários {0} e {1}",mono:"conteúdo",input:"Acabei de chegar no Rio!",faint_link:"manual útil",fine_print:"Leia nosso {0} para não aprender nada!",header_faint:"Está ok!",checkbox:"Li os termos e condições",link:"um belo link"}}},timeline:{collapse:"Esconder",conversation:"Conversa",error_fetching:"Erro ao buscar atualizações",load_older:"Carregar postagens antigas",no_retweet_hint:"Posts apenas para seguidores ou diretos não podem ser repetidos",repeated:"Repetido",show_new:"Mostrar novas",up_to_date:"Atualizado",no_more_statuses:"Sem mais posts",no_statuses:"Sem posts"},status:{reply_to:"Responder a",replies_list:"Respostas:"},user_card:{approve:"Aprovar",block:"Bloquear",blocked:"Bloqueado!",deny:"Negar",favorites:"Favoritos",follow:"Seguir",follow_sent:"Pedido enviado!",follow_progress:"Enviando…",follow_again:"Enviar solicitação novamente?",follow_unfollow:"Deixar de seguir",followees:"Seguindo",followers:"Seguidores",following:"Seguindo!",follows_you:"Segue você!",its_you:"É você!",media:"Mídia",mute:"Silenciar",muted:"Silenciado",per_day:"por dia",remote_follow:"Seguidor Remoto",statuses:"Postagens",unblock:"Desbloquear",unblock_progress:"Desbloqueando...",block_progress:"Bloqueando...",unmute:"Retirar silêncio",unmute_progress:"Retirando silêncio...",mute_progress:"Silenciando..."},user_profile:{timeline_title:"Linha do tempo do usuário",profile_does_not_exist:"Desculpe, este perfil não existe.",profile_loading_error:"Desculpe, houve um erro ao carregar este perfil."},who_to_follow:{more:"Mais",who_to_follow:"Quem seguir"},tool_tip:{media_upload:"Envio de mídia",repeat:"Repetir",reply:"Responder",favorite:"Favoritar",user_settings:"Configurações do usuário"},upload:{error:{base:"Falha no envio.",file_too_big:"Arquivo grande demais [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]",default:"Tente novamente mais tarde"},file_size_units:{B:"B",KiB:"KiB",MiB:"MiB",GiB:"GiB",TiB:"TiB"}}}},function(e,t){e.exports={finder:{error_fetching_user:"Eroare la preluarea utilizatorului",find_user:"Găsește utilizator"},general:{submit:"trimite"},login:{login:"Loghează",logout:"Deloghează",password:"Parolă",placeholder:"d.e. lain",register:"Înregistrare",username:"Nume utilizator"},nav:{mentions:"Menționări",public_tl:"Cronologie Publică",timeline:"Cronologie",twkn:"Toată Reșeaua Cunoscută"},notifications:{followed_you:"te-a urmărit",notifications:"Notificări",read:"Citit!"},post_status:{default:"Nu de mult am aterizat în L.A.",posting:"Postează"},registration:{bio:"Bio",email:"Email",fullname:"Numele întreg",password_confirm:"Cofirmă parola",registration:"Îregistrare"},settings:{attachments:"Atașamente",autoload:"Permite încărcarea automată când scrolat la capăt",avatar:"Avatar",bio:"Bio",current_avatar:"Avatarul curent",current_profile_banner:"Bannerul curent al profilului",filtering:"Filtru",filtering_explanation:"Toate stările care conțin aceste cuvinte vor fi puse pe mut, una pe linie",hide_attachments_in_convo:"Ascunde atașamentele în conversații",hide_attachments_in_tl:"Ascunde atașamentele în cronologie",name:"Nume",name_bio:"Nume și Bio",nsfw_clickthrough:"Permite ascunderea al atașamentelor NSFW",profile_background:"Fundalul de profil",profile_banner:"Banner de profil",reply_link_preview:"Permite previzualizarea linkului de răspuns la planarea de mouse",set_new_avatar:"Setează avatar nou",set_new_profile_background:"Setează fundal nou",set_new_profile_banner:"Setează banner nou la profil",settings:"Setări",theme:"Temă",user_settings:"Setările utilizatorului"},timeline:{conversation:"Conversație",error_fetching:"Erare la preluarea actualizărilor",load_older:"Încarcă stări mai vechi",show_new:"Arată cele noi",up_to_date:"La zi"},user_card:{block:"Blochează",blocked:"Blocat!",follow:"Urmărește",followees:"Urmărește",followers:"Următori",following:"Urmărit!",follows_you:"Te urmărește!",mute:"Pune pe mut",muted:"Pus pe mut",per_day:"pe zi",statuses:"Stări"}}},function(e,t){e.exports={chat:{title:"Чат"},finder:{error_fetching_user:"Пользователь не найден",find_user:"Найти пользователя"},general:{apply:"Применить",submit:"Отправить"},login:{login:"Войти",logout:"Выйти",password:"Пароль",placeholder:"e.c. lain",register:"Зарегистрироваться",username:"Имя пользователя"},nav:{back:"Назад",chat:"Локальный чат",mentions:"Упоминания",public_tl:"Публичная лента",timeline:"Лента",twkn:"Федеративная лента"},notifications:{broken_favorite:"Неизвестный статус, ищем...",favorited_you:"нравится ваш статус",followed_you:"начал(а) читать вас",load_older:"Загрузить старые уведомления",notifications:"Уведомления",read:"Прочесть",repeated_you:"повторил(а) ваш статус"},post_status:{account_not_locked_warning:"Ваш аккаунт не {0}. Кто угодно может зафоловить вас чтобы прочитать посты только для подписчиков",account_not_locked_warning_link:"залочен",attachments_sensitive:"Вложения содержат чувствительный контент",content_warning:"Тема (не обязательно)",default:"Что нового?",direct_warning:"Этот пост будет видет только упомянутым пользователям",posting:"Отправляется",scope:{direct:"Личное - этот пост видят только те кто в нём упомянут",private:"Для подписчиков - этот пост видят только подписчики",public:"Публичный - этот пост виден всем",unlisted:"Непубличный - этот пост не виден на публичных лентах"}},registration:{bio:"Описание",email:"Email",fullname:"Отображаемое имя",password_confirm:"Подтверждение пароля",registration:"Регистрация",token:"Код приглашения",validations:{username_required:"не должно быть пустым",fullname_required:"не должно быть пустым",email_required:"не должен быть пустым",password_required:"не должен быть пустым",password_confirmation_required:"не должно быть пустым",password_confirmation_match:"должно совпадать с паролем"}},settings:{attachmentRadius:"Прикреплённые файлы",attachments:"Вложения",autoload:"Включить автоматическую загрузку при прокрутке вниз",avatar:"Аватар",avatarAltRadius:"Аватары в уведомлениях",avatarRadius:"Аватары",background:"Фон",bio:"Описание",btnRadius:"Кнопки",cBlue:"Ответить, читать",cGreen:"Повторить",cOrange:"Нравится",cRed:"Отменить",change_password:"Сменить пароль",change_password_error:"Произошла ошибка при попытке изменить пароль.",changed_password:"Пароль изменён успешно.",collapse_subject:"Сворачивать посты с темой",confirm_new_password:"Подтверждение нового пароля",current_avatar:"Текущий аватар",current_password:"Текущий пароль",current_profile_banner:"Текущий баннер профиля",data_import_export_tab:"Импорт / Экспорт данных",delete_account:"Удалить аккаунт",delete_account_description:"Удалить ваш аккаунт и все ваши сообщения.",delete_account_error:"Возникла ошибка в процессе удаления вашего аккаунта. Если это повторяется, свяжитесь с администратором вашего сервера.",delete_account_instructions:"Введите ваш пароль в поле ниже для подтверждения удаления.",export_theme:"Сохранить Тему",filtering:"Фильтрация",filtering_explanation:"Все статусы, содержащие данные слова, будут игнорироваться, по одному в строке",follow_export:"Экспортировать читаемых",follow_export_button:"Экспортировать читаемых в файл .csv",follow_export_processing:"Ведётся обработка, скоро вам будет предложено загрузить файл",follow_import:"Импортировать читаемых",follow_import_error:"Ошибка при импортировании читаемых.",follows_imported:"Список читаемых импортирован. Обработка займёт некоторое время..",foreground:"Передний план",general:"Общие",hide_attachments_in_convo:"Прятать вложения в разговорах",hide_attachments_in_tl:"Прятать вложения в ленте",hide_isp:"Скрыть серверную панель",import_followers_from_a_csv_file:"Импортировать читаемых из файла .csv",import_theme:"Загрузить Тему",inputRadius:"Поля ввода",checkboxRadius:"Чекбоксы",interface:"Интерфейс",interfaceLanguage:"Язык интерфейса",limited_availability:"Не доступно в вашем браузере",links:"Ссылки",lock_account_description:"Аккаунт доступен только подтверждённым подписчикам",loop_video:"Зациливать видео",loop_video_silent_only:'Зацикливать только беззвучные видео (т.е. "гифки" с Mastodon)',name:"Имя",name_bio:"Имя и описание",new_password:"Новый пароль",notification_visibility:"Показывать уведомления",notification_visibility_follows:"Подписки",notification_visibility_likes:"Лайки",notification_visibility_mentions:"Упоминания",notification_visibility_repeats:"Повторы",no_rich_text_description:"Убрать форматирование из всех постов",hide_follows_description:"Не показывать кого я читаю",hide_followers_description:"Не показывать кто читает меня",show_admin_badge:"Показывать значок администратора в моем профиле",show_moderator_badge:"Показывать значок модератора в моем профиле",nsfw_clickthrough:"Включить скрытие NSFW вложений",oauth_tokens:"OAuth токены",token:"Токен",refresh_token:"Рефреш токен",valid_until:"Годен до",revoke_token:"Удалить",panelRadius:"Панели",pause_on_unfocused:"Приостановить загрузку когда вкладка не в фокусе",presets:"Пресеты",profile_background:"Фон профиля",profile_banner:"Баннер профиля",profile_tab:"Профиль",radii_help:"Скругление углов элементов интерфейса (в пикселях)",replies_in_timeline:"Ответы в ленте",reply_link_preview:"Включить предварительный просмотр ответа при наведении мыши",reply_visibility_all:"Показывать все ответы",reply_visibility_following:"Показывать только ответы мне и тех на кого я подписан",reply_visibility_self:"Показывать только ответы мне",security_tab:"Безопасность",set_new_avatar:"Загрузить новый аватар",set_new_profile_background:"Загрузить новый фон профиля",set_new_profile_banner:"Загрузить новый баннер профиля",settings:"Настройки",subject_input_always_show:"Всегда показывать поле ввода темы",stop_gifs:"Проигрывать GIF анимации только при наведении",streaming:"Включить автоматическую загрузку новых сообщений при прокрутке вверх",text:"Текст",theme:"Тема",theme_help:"Используйте шестнадцатеричные коды цветов (#rrggbb) для настройки темы.",theme_help_v2_1:'Вы так же можете перепоределить цвета определенных компонентов нажав соотв. галочку. Используйте кнопку "Очистить всё" чтобы снять все переопределения',theme_help_v2_2:"Под некоторыми полями ввода это идикаторы контрастности, наведите на них мышью чтобы узнать больше. Приспользовании прозрачности контраст расчитывается для наихудшего варианта.",tooltipRadius:"Всплывающие подсказки/уведомления",user_settings:"Настройки пользователя",style:{switcher:{keep_color:"Оставить цвета",keep_shadows:"Оставить тени",keep_opacity:"Оставить прозрачность",keep_roundness:"Оставить скругление",keep_fonts:"Оставить шрифты",save_load_hint:'Опции "оставить..." позволяют сохранить текущие настройки при выборе другой темы или импорта её из файла. Так же они влияют на то какие компоненты будут сохранены при экспорте темы. Когда все галочки сняты все компоненты будут экспортированы.',reset:"Сбросить",clear_all:"Очистить всё",clear_opacity:"Очистить прозрачность"},common:{color:"Цвет",opacity:"Прозрачность",contrast:{hint:"Уровень контраста: {ratio}, что {level} {context}",level:{aa:"соответствует гайдлайну Level AA (минимальный)",aaa:"соответствует гайдлайну Level AAA (рекомендуемый)",bad:"не соответствует каким либо гайдлайнам"},context:{"18pt":"для крупного (18pt+) текста",text:"для текста"}}},common_colors:{_tab_label:"Общие",main:"Общие цвета",foreground_hint:'См. вкладку "Дополнительно" для более детального контроля',rgbo:"Иконки, акценты, ярылки"},advanced_colors:{_tab_label:"Дополнительно",alert:"Фон уведомлений",alert_error:"Ошибки",badge:"Фон значков",badge_notification:"Уведомления",panel_header:"Заголовок панели",top_bar:"Верняя полоска",borders:"Границы",buttons:"Кнопки",inputs:"Поля ввода",faint_text:"Маловажный текст"},radii:{_tab_label:"Скругление"},shadows:{_tab_label:"Светотень",component:"Компонент",override:"Переопределить",shadow_id:"Тень №{value}",blur:"Размытие",spread:"Разброс",inset:"Внутренняя",hint:"Для теней вы так же можете использовать --variable в качестве цвета чтобы использовать CSS3-переменные. В таком случае прозрачность работать не будет.",filter_hint:{always_drop_shadow:"Внимание, эта тень всегда использует {0} когда браузер поддерживает это",drop_shadow_syntax:"{0} не поддерживает параметр {1} и ключевое слово {2}",avatar_inset:"Одновременное использование внутренних и внешних теней на (прозрачных) аватарках может дать не те результаты что вы ожидаете",spread_zero:"Тени с разбросом > 0 будут выглядеть как если бы разброс установлен в 0",inset_classic:"Внутренние тени будут использовать {0}"},components:{panel:"Панель",panelHeader:"Заголовок панели",topBar:"Верхняя полоска",avatar:"Аватарка (профиль)",avatarStatus:"Аватарка (в ленте)",popup:"Всплывающие подсказки",button:"Кнопки",buttonHover:"Кнопки (наведен курсор)",buttonPressed:"Кнопки (нажата)",buttonPressedHover:"Кнопки (нажата+наведен курсор)",input:"Поля ввода"}},fonts:{_tab_label:"Шрифты",help:'Выберите тип шрифта для использования в интерфейсе. При выборе варианта "другой" надо ввести название шрифта в точности как он называется в системе.',components:{interface:"Интерфейс",input:"Поля ввода",post:"Текст постов",postCode:"Моноширинный текст в посте (форматирование)"},family:"Шрифт",size:"Размер (в пикселях)",weight:"Ширина",custom:"Другой"},preview:{header:"Пример",content:"Контент",error:"Ошибка стоп 000",button:"Кнопка",text:"Еще немного {0} и масенькая {1}",mono:"контента",input:"Что нового?",faint_link:"Его придется убрать",fine_print:"Если проблемы остались — ваш гуртовщик мыши плохо стоит. {0}.",header_faint:"Все идет по плану",checkbox:"Я подтверждаю что не было ни единого разрыва",link:"ссылка"}}},timeline:{collapse:"Свернуть",conversation:"Разговор",error_fetching:"Ошибка при обновлении",load_older:"Загрузить старые статусы",no_retweet_hint:'Пост помечен как "только для подписчиков" или "личное" и поэтому не может быть повторён',repeated:"повторил(а)",show_new:"Показать новые",up_to_date:"Обновлено"},user_card:{block:"Заблокировать",blocked:"Заблокирован",favorites:"Понравившиеся",follow:"Читать",follow_sent:"Запрос отправлен!",follow_progress:"Запрашиваем…",follow_again:"Запросить еще заново?",follow_unfollow:"Перестать читать",followees:"Читаемые",followers:"Читатели",following:"Читаю",follows_you:"Читает вас",mute:"Игнорировать",muted:"Игнорирую",per_day:"в день",remote_follow:"Читать удалённо",statuses:"Статусы"},user_profile:{timeline_title:"Лента пользователя"}}},function(e,t){e.exports={chat:{title:"聊天"},features_panel:{chat:"聊天",gopher:"Gopher",media_proxy:"媒体代理",scope_options:"可见范围设置",text_limit:"文本长度限制",title:"功能",who_to_follow:"推荐关注"},finder:{error_fetching_user:"获取用户时发生错误",find_user:"寻找用户"},general:{apply:"应用",submit:"提交"},login:{login:"登录",logout:"登出",password:"密码",placeholder:"例如:lain",register:"注册",username:"用户名"},nav:{chat:"本地聊天",friend_requests:"关注请求",mentions:"提及",public_tl:"公共时间线",timeline:"时间线",twkn:"所有已知网络"},notifications:{broken_favorite:"未知的状态,正在搜索中...",favorited_you:"收藏了你的状态",followed_you:"关注了你",load_older:"加载更早的通知",notifications:"通知",read:"阅读!",repeated_you:"转发了你的状态"},post_status:{account_not_locked_warning:"你的帐号没有 {0}。任何人都可以关注你并浏览你的上锁内容。",account_not_locked_warning_link:"上锁",attachments_sensitive:"标记附件为敏感内容",content_type:{plain_text:"纯文本"},content_warning:"主题(可选)",default:"刚刚抵达上海",direct_warning:"本条内容只有被提及的用户能够看到。",posting:"发送",scope:{direct:"私信 - 只发送给被提及的用户",private:"仅关注者 - 只有关注了你的人能看到",public:"公共 - 发送到公共时间轴",unlisted:"不公开 - 所有人可见,但不会发送到公共时间轴"}},registration:{bio:"简介",email:"电子邮箱",fullname:"全名",password_confirm:"确认密码",registration:"注册",token:"邀请码"},settings:{attachmentRadius:"附件",attachments:"附件",autoload:"启用滚动到底部时的自动加载",avatar:"头像",avatarAltRadius:"头像(通知)",avatarRadius:"头像",background:"背景",bio:"简介",btnRadius:"按钮",cBlue:"蓝色(回复,关注)",cGreen:"绿色(转发)",cOrange:"橙色(收藏)",cRed:"红色(取消)",change_password:"修改密码",change_password_error:"修改密码的时候出了点问题。",changed_password:"成功修改了密码!",collapse_subject:"折叠带主题的内容",confirm_new_password:"确认新密码",current_avatar:"当前头像",current_password:"当前密码",current_profile_banner:"您当前的横幅图片",data_import_export_tab:"数据导入/导出",default_vis:"默认可见范围",delete_account:"删除账户",delete_account_description:"永久删除你的帐号和所有消息。",delete_account_error:"删除账户时发生错误,如果一直删除不了,请联系实例管理员。",delete_account_instructions:"在下面输入你的密码来确认删除账户",export_theme:"导出预置主题",filtering:"过滤器",filtering_explanation:"所有包含以下词汇的内容都会被隐藏,一行一个",follow_export:"导出关注",follow_export_button:"将关注导出成 csv 文件",follow_export_processing:"正在处理,过一会儿就可以下载你的文件了",follow_import:"导入关注",follow_import_error:"导入关注时错误",follows_imported:"关注已导入!尚需要一些时间来处理。",foreground:"前景",general:"通用",hide_attachments_in_convo:"在对话中隐藏附件",hide_attachments_in_tl:"在时间线上隐藏附件",hide_post_stats:"隐藏推文相关的统计数据(例如:收藏的次数)",hide_user_stats:"隐藏用户的统计数据(例如:关注者的数量)",import_followers_from_a_csv_file:"从 csv 文件中导入关注",import_theme:"导入预置主题",inputRadius:"输入框",instance_default:"(默认:{value})",interfaceLanguage:"界面语言",invalid_theme_imported:"您所选择的主题文件不被 Pleroma 支持,因此主题未被修改。",limited_availability:"在您的浏览器中无法使用",links:"链接",lock_account_description:"你需要手动审核关注请求",loop_video:"循环视频",loop_video_silent_only:"只循环没有声音的视频(例如:Mastodon 里的“GIF”)",name:"名字",name_bio:"名字及简介",new_password:"新密码",notification_visibility:"要显示的通知类型",notification_visibility_follows:"关注",notification_visibility_likes:"点赞",notification_visibility_mentions:"提及",notification_visibility_repeats:"转发",no_rich_text_description:"不显示富文本格式",nsfw_clickthrough:"将不和谐附件隐藏,点击才能打开",oauth_tokens:"OAuth令牌",token:"代币",refresh_token:"刷新令牌",valid_until:"有效期至",revoke_token:"撤消",panelRadius:"面板",pause_on_unfocused:"在离开页面时暂停时间线推送",presets:"预置",profile_background:"个人资料背景图",profile_banner:"横幅图片",profile_tab:"个人资料",radii_help:"设置界面边缘的圆角 (单位:像素)",replies_in_timeline:"时间线中的回复",reply_link_preview:"启用鼠标悬停时预览回复链接", +reply_visibility_all:"显示所有回复",reply_visibility_following:"只显示发送给我的回复/发送给我关注的用户的回复",reply_visibility_self:"只显示发送给我的回复",saving_err:"保存设置时发生错误",saving_ok:"设置已保存",security_tab:"安全",set_new_avatar:"设置新头像",set_new_profile_background:"设置新的个人资料背景",set_new_profile_banner:"设置新的横幅图片",settings:"设置",stop_gifs:"鼠标悬停时播放GIF",streaming:"开启滚动到顶部时的自动推送",text:"文本",theme:"主题",theme_help:"使用十六进制代码(#rrggbb)来设置主题颜色。",tooltipRadius:"提醒",user_settings:"用户设置",values:{false:"否",true:"是"}},timeline:{collapse:"折叠",conversation:"对话",error_fetching:"获取更新时发生错误",load_older:"加载更早的状态",no_retweet_hint:"这条内容仅关注者可见,或者是私信,因此不能转发。",repeated:"已转发",show_new:"显示新内容",up_to_date:"已是最新"},user_card:{approve:"允许",block:"屏蔽",blocked:"已屏蔽!",deny:"拒绝",follow:"关注",followees:"正在关注",followers:"关注者",following:"正在关注!",follows_you:"关注了你!",mute:"隐藏",muted:"已隐藏",per_day:"每天",remote_follow:"跨站关注",statuses:"状态"},user_profile:{timeline_title:"用户时间线"},who_to_follow:{more:"更多",who_to_follow:"推荐关注"}}},function(e,t){e.exports=["teď",["%s s","%s s"],["%s min","%s min"],["%s h","%s h"],["%s d","%s d"],["%s týd","%s týd"],["%s měs","%s měs"],["%s r","%s l"]]},function(e,t){e.exports=["now",["%ss","%ss"],["%smin","%smin"],["%sh","%sh"],["%sd","%sd"],["%sw","%sw"],["%smo","%smo"],["%sy","%sy"]]},function(e,t){e.exports=["たった今","%s 秒前","%s 分前","%s 時間前","%s 日前","%s 週間前","%s ヶ月前","%s 年前"]},,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,function(e,t,a){e.exports=a.p+"static/img/nsfw.74818f9.png"},,,,function(e,t,a){a(407);var i=a(1)(a(252),a(705),null,null);e.exports=i.exports},function(e,t,a){a(408);var i=a(1)(a(253),a(707),null,null);e.exports=i.exports},function(e,t,a){a(409);var i=a(1)(a(256),a(709),null,null);e.exports=i.exports},function(e,t,a){a(395);var i=a(1)(a(247),a(688),null,null);e.exports=i.exports},function(e,t,a){var i=a(1)(a(258),a(720),null,null);e.exports=i.exports},function(e,t,a){a(423);var i=a(1)(a(260),a(729),null,null);e.exports=i.exports},function(e,t,a){var i=a(1)(a(261),a(712),null,null);e.exports=i.exports},function(e,t,a){a(430);var i=a(1)(a(248),a(737),null,null);e.exports=i.exports},function(e,t,a){a(425);var i=a(1)(a(262),a(732),null,null);e.exports=i.exports},function(e,t,a){a(398);var i=a(1)(a(265),a(694),null,null);e.exports=i.exports},function(e,t,a){var i=a(1)(a(266),a(680),null,null);e.exports=i.exports},function(e,t,a){a(406);var i=a(1)(a(267),a(704),null,null);e.exports=i.exports},function(e,t,a){var i=a(1)(a(268),a(727),null,null);e.exports=i.exports},function(e,t,a){a(428);var i=a(1)(a(269),a(735),null,null);e.exports=i.exports},function(e,t,a){a(421);var i=a(1)(a(270),a(726),null,null);e.exports=i.exports},function(e,t,a){var i=a(1)(a(249),a(695),null,null);e.exports=i.exports},function(e,t,a){a(417);var i=a(1)(a(272),a(722),null,null);e.exports=i.exports},function(e,t,a){a(411);var i=a(1)(a(274),a(711),null,null);e.exports=i.exports},function(e,t,a){a(410);var i=a(1)(a(275),a(710),null,null);e.exports=i.exports},function(e,t,a){var i=a(1)(a(276),a(691),null,null);e.exports=i.exports},function(e,t,a){a(388);var i=a(1)(a(277),a(678),null,null);e.exports=i.exports},function(e,t,a){var i=a(1)(a(278),a(690),null,null);e.exports=i.exports},function(e,t,a){a(427);var i=a(1)(a(279),a(734),null,null);e.exports=i.exports},function(e,t,a){var i=a(1)(a(280),a(717),null,null);e.exports=i.exports},function(e,t,a){var i=a(1)(a(282),a(697),null,null);e.exports=i.exports},function(e,t,a){var i=a(1)(a(284),a(692),null,null);e.exports=i.exports},function(e,t,a){var i=a(1)(a(285),a(714),null,null);e.exports=i.exports},function(e,t,a){var i=a(1)(a(251),a(715),null,null);e.exports=i.exports},function(e,t,a){a(402);var i=a(1)(a(286),a(700),null,null);e.exports=i.exports},function(e,t,a){a(393);var i=a(1)(a(287),a(686),null,null);e.exports=i.exports},function(e,t,a){a(426);var i=a(1)(a(288),a(733),null,null);e.exports=i.exports},function(e,t,a){a(415);var i=a(1)(a(289),a(719),null,null);e.exports=i.exports},function(e,t,a){a(414);var i=a(1)(a(290),a(718),null,null);e.exports=i.exports},function(e,t,a){a(400);var i=a(1)(a(292),a(698),null,null);e.exports=i.exports},function(e,t,a){var i=a(1)(null,a(731),null,null);e.exports=i.exports},function(e,t,a){var i=a(1)(a(295),a(684),null,null);e.exports=i.exports},function(e,t,a){a(394);var i=a(1)(a(296),a(687),null,null);e.exports=i.exports},function(e,t,a){a(399);var i=a(1)(a(300),a(696),null,null);e.exports=i.exports},function(e,t,a){var i=a(1)(a(301),a(738),null,null);e.exports=i.exports},function(e,t,a){a(404);var i=a(1)(a(302),a(702),null,null);e.exports=i.exports},function(e,t,a){a(412);var i=a(1)(a(303),a(713),null,null);e.exports=i.exports},function(e,t,a){a(422);var i=a(1)(a(304),a(728),null,null);e.exports=i.exports},function(e,t,a){a(392);var i=a(1)(a(306),a(685),null,null);e.exports=i.exports},function(e,t,a){a(429);var i=a(1)(a(307),a(736),null,null);e.exports=i.exports},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"notifications"},[a("div",{staticClass:"panel panel-default"},[a("div",{staticClass:"panel-heading"},[a("div",{staticClass:"title"},[e._v("\n "+e._s(e.$t("notifications.notifications"))+"\n "),e.unseenCount?a("span",{staticClass:"badge badge-notification unseen-count"},[e._v(e._s(e.unseenCount))]):e._e()]),e._v(" "),e.error?a("div",{staticClass:"loadmore-error alert error",on:{click:function(e){e.preventDefault()}}},[e._v("\n "+e._s(e.$t("timeline.error_fetching"))+"\n ")]):e._e(),e._v(" "),e.unseenCount?a("button",{staticClass:"read-button",on:{click:function(t){return t.preventDefault(),e.markAsSeen(t)}}},[e._v(e._s(e.$t("notifications.read")))]):e._e()]),e._v(" "),a("div",{staticClass:"panel-body"},e._l(e.visibleNotifications,function(t){return a("div",{key:t.action.id,staticClass:"notification",class:{unseen:!t.seen}},[a("div",{staticClass:"notification-overlay"}),e._v(" "),a("notification",{attrs:{notification:t}})],1)}),0),e._v(" "),a("div",{staticClass:"panel-footer"},[e.bottomedOut?a("div",{staticClass:"new-status-notification text-center panel-footer faint"},[e._v("\n "+e._s(e.$t("notifications.no_more_notifications"))+"\n ")]):e.loading?a("div",{staticClass:"new-status-notification text-center panel-footer"},[a("i",{staticClass:"icon-spin3 animate-spin"})]):a("a",{attrs:{href:"#"},on:{click:function(t){t.preventDefault(),e.fetchOlderNotifications()}}},[a("div",{staticClass:"new-status-notification text-center panel-footer"},[e._v(e._s(e.$t("notifications.load_older")))])])])])])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return e.currentUser?a("div",[a("div",{directives:[{name:"show",rawName:"v-show",value:e.postFormOpen,expression:"postFormOpen"}],staticClass:"post-form-modal-view modal-view",on:{click:e.closePostForm}},[a("div",{staticClass:"post-form-modal-panel panel",on:{click:function(e){e.stopPropagation()}}},[a("div",{staticClass:"panel-heading"},[e._v(e._s(e.$t("post_status.new_status")))]),e._v(" "),a("PostStatusForm",{staticClass:"panel-body",on:{posted:e.closePostForm}})],1)]),e._v(" "),a("button",{staticClass:"new-status-button",class:{hidden:e.isHidden},on:{click:e.openPostForm}},[a("i",{staticClass:"icon-edit"})])]):e._e()},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{class:e.classes.root},[a("div",{class:e.classes.header},[a("div",{staticClass:"title"},[e._v("\n "+e._s(e.title)+"\n ")]),e._v(" "),e.timelineError?a("div",{staticClass:"loadmore-error alert error",on:{click:function(e){e.preventDefault()}}},[e._v("\n "+e._s(e.$t("timeline.error_fetching"))+"\n ")]):e._e(),e._v(" "),e.timeline.newStatusCount>0&&!e.timelineError?a("button",{staticClass:"loadmore-button",on:{click:function(t){return t.preventDefault(),e.showNewStatuses(t)}}},[e._v("\n "+e._s(e.$t("timeline.show_new"))+e._s(e.newStatusCountStr)+"\n ")]):e._e(),e._v(" "),!e.timeline.newStatusCount>0&&!e.timelineError?a("div",{staticClass:"loadmore-text faint",on:{click:function(e){e.preventDefault()}}},[e._v("\n "+e._s(e.$t("timeline.up_to_date"))+"\n ")]):e._e()]),e._v(" "),a("div",{class:e.classes.body},[a("div",{staticClass:"timeline"},e._l(e.timeline.visibleStatuses,function(e){return a("status-or-conversation",{key:e.id,staticClass:"status-fadein",attrs:{statusoid:e}})}),1)]),e._v(" "),a("div",{class:e.classes.footer},[0===e.count?a("div",{staticClass:"new-status-notification text-center panel-footer faint"},[e._v("\n "+e._s(e.$t("timeline.no_statuses"))+"\n ")]):e.bottomedOut?a("div",{staticClass:"new-status-notification text-center panel-footer faint"},[e._v("\n "+e._s(e.$t("timeline.no_more_statuses"))+"\n ")]):e.timeline.loading?a("div",{staticClass:"new-status-notification text-center panel-footer"},[a("i",{staticClass:"icon-spin3 animate-spin"})]):a("a",{attrs:{href:"#"},on:{click:function(t){t.preventDefault(),e.fetchOlderStatuses()}}},[a("div",{staticClass:"new-status-notification text-center panel-footer"},[e._v(e._s(e.$t("timeline.load_older")))])])])])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"settings panel panel-default"},[a("div",{staticClass:"panel-heading"},[e._v("\n "+e._s(e.$t("nav.friend_requests"))+"\n ")]),e._v(" "),a("div",{staticClass:"panel-body"},e._l(e.requests,function(e){return a("FollowRequestCard",{key:e.id,attrs:{user:e}})}),1)])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("StillImage",{staticClass:"avatar",class:{"avatar-compact":e.compact,"better-shadow":e.betterShadow},attrs:{src:e.imgSrc,imageLoadError:e.imageLoadError}})},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"post-status-form"},[a("form",{on:{submit:function(t){t.preventDefault(),e.postStatus(e.newStatus)}}},[a("div",{staticClass:"form-group"},[this.$store.state.users.currentUser.locked||"private"!=this.newStatus.visibility?e._e():a("i18n",{staticClass:"visibility-notice",attrs:{path:"post_status.account_not_locked_warning",tag:"p"}},[a("router-link",{attrs:{to:{name:"user-settings"}}},[e._v(e._s(e.$t("post_status.account_not_locked_warning_link")))])],1),e._v(" "),"direct"==this.newStatus.visibility?a("p",{staticClass:"visibility-notice"},[e._v(e._s(e.$t("post_status.direct_warning")))]):e._e(),e._v(" "),e.newStatus.spoilerText||e.alwaysShowSubject?a("input",{directives:[{name:"model",rawName:"v-model",value:e.newStatus.spoilerText,expression:"newStatus.spoilerText"}],staticClass:"form-cw",attrs:{type:"text",placeholder:e.$t("post_status.content_warning")},domProps:{value:e.newStatus.spoilerText},on:{input:function(t){t.target.composing||e.$set(e.newStatus,"spoilerText",t.target.value)}}}):e._e(),e._v(" "),a("textarea",{directives:[{name:"model",rawName:"v-model",value:e.newStatus.status,expression:"newStatus.status"}],ref:"textarea",staticClass:"form-control",attrs:{placeholder:e.$t("post_status.default"),rows:"1",disabled:e.posting},domProps:{value:e.newStatus.status},on:{click:e.setCaret,keyup:[e.setCaret,function(t){return("button"in t||!e._k(t.keyCode,"enter",13,t.key,"Enter"))&&t.ctrlKey?void e.postStatus(e.newStatus):null}],keydown:[e.onKeydown,function(t){return"button"in t||!e._k(t.keyCode,"down",40,t.key,["Down","ArrowDown"])?e.cycleForward(t):null},function(t){return"button"in t||!e._k(t.keyCode,"up",38,t.key,["Up","ArrowUp"])?e.cycleBackward(t):null},function(t){return("button"in t||!e._k(t.keyCode,"tab",9,t.key,"Tab"))&&t.shiftKey?e.cycleBackward(t):null},function(t){return"button"in t||!e._k(t.keyCode,"tab",9,t.key,"Tab")?e.cycleForward(t):null},function(t){return"button"in t||!e._k(t.keyCode,"enter",13,t.key,"Enter")?e.replaceCandidate(t):null},function(t){return("button"in t||!e._k(t.keyCode,"enter",13,t.key,"Enter"))&&t.metaKey?void e.postStatus(e.newStatus):null}],drop:e.fileDrop,dragover:function(t){return t.preventDefault(),e.fileDrag(t)},input:[function(t){t.target.composing||e.$set(e.newStatus,"status",t.target.value)},e.resize],paste:e.paste}}),e._v(" "),a("div",{staticClass:"visibility-tray"},[e.formattingOptionsEnabled?a("span",{staticClass:"text-format"},[a("label",{staticClass:"select",attrs:{for:"post-content-type"}},[a("select",{directives:[{name:"model",rawName:"v-model",value:e.newStatus.contentType,expression:"newStatus.contentType"}],staticClass:"form-control",attrs:{id:"post-content-type"},on:{change:function(t){var a=Array.prototype.filter.call(t.target.options,function(e){return e.selected}).map(function(e){var t="_value"in e?e._value:e.value;return t});e.$set(e.newStatus,"contentType",t.target.multiple?a:a[0])}}},e._l(e.postFormats,function(t){return a("option",{key:t,domProps:{value:t}},[e._v("\n "+e._s(e.$t('post_status.content_type["'+t+'"]'))+"\n ")])}),0),e._v(" "),a("i",{staticClass:"icon-down-open"})])]):e._e(),e._v(" "),e.scopeOptionsEnabled?a("div",[a("i",{staticClass:"icon-mail-alt",class:e.vis.direct,attrs:{title:e.$t("post_status.scope.direct")},on:{click:function(t){e.changeVis("direct")}}}),e._v(" "),a("i",{staticClass:"icon-lock",class:e.vis.private,attrs:{title:e.$t("post_status.scope.private")},on:{click:function(t){e.changeVis("private")}}}),e._v(" "),a("i",{staticClass:"icon-lock-open-alt",class:e.vis.unlisted,attrs:{title:e.$t("post_status.scope.unlisted")},on:{click:function(t){e.changeVis("unlisted")}}}),e._v(" "),a("i",{staticClass:"icon-globe",class:e.vis.public,attrs:{title:e.$t("post_status.scope.public")},on:{click:function(t){e.changeVis("public")}}})]):e._e()])],1),e._v(" "),e.candidates?a("div",{staticStyle:{position:"relative"}},[a("div",{staticClass:"autocomplete-panel"},e._l(e.candidates,function(t){return a("div",{on:{click:function(a){e.replace(t.utf||t.screen_name+" ")}}},[a("div",{staticClass:"autocomplete",class:{highlighted:t.highlighted}},[t.img?a("span",[a("img",{attrs:{src:t.img}})]):a("span",[e._v(e._s(t.utf))]),e._v(" "),a("span",[e._v(e._s(t.screen_name)),a("small",[e._v(e._s(t.name))])])])])}),0)]):e._e(),e._v(" "),a("div",{staticClass:"form-bottom"},[a("media-upload",{ref:"mediaUpload",attrs:{"drop-files":e.dropFiles},on:{uploading:e.disableSubmit,uploaded:e.addMediaFile,"upload-failed":e.uploadFailed}}),e._v(" "),e.isOverLengthLimit?a("p",{staticClass:"error"},[e._v(e._s(e.charactersLeft))]):e.hasStatusLengthLimit?a("p",{staticClass:"faint"},[e._v(e._s(e.charactersLeft))]):e._e(),e._v(" "),e.posting?a("button",{staticClass:"btn btn-default",attrs:{disabled:""}},[e._v(e._s(e.$t("post_status.posting")))]):e.isOverLengthLimit?a("button",{staticClass:"btn btn-default",attrs:{disabled:""}},[e._v(e._s(e.$t("general.submit")))]):a("button",{staticClass:"btn btn-default",attrs:{disabled:e.submitDisabled,type:"submit"}},[e._v(e._s(e.$t("general.submit")))])],1),e._v(" "),e.error?a("div",{staticClass:"alert error"},[e._v("\n Error: "+e._s(e.error)+"\n "),a("i",{staticClass:"button-icon icon-cancel",on:{click:e.clearError}})]):e._e(),e._v(" "),a("div",{staticClass:"attachments"},e._l(e.newStatus.files,function(t){return a("div",{staticClass:"media-upload-wrapper"},[a("i",{staticClass:"fa button-icon icon-cancel",on:{click:function(a){e.removeMediaFile(t)}}}),e._v(" "),a("div",{staticClass:"media-upload-container attachment"},["image"===e.type(t)?a("img",{staticClass:"thumbnail media-upload",attrs:{src:t.image}}):e._e(),e._v(" "),"video"===e.type(t)?a("video",{attrs:{src:t.image,controls:""}}):e._e(),e._v(" "),"audio"===e.type(t)?a("audio",{attrs:{src:t.image,controls:""}}):e._e(),e._v(" "),"unknown"===e.type(t)?a("a",{attrs:{href:t.image}},[e._v(e._s(t.url))]):e._e()])])}),0),e._v(" "),e.newStatus.files.length>0?a("div",{staticClass:"upload_settings"},[a("input",{directives:[{name:"model",rawName:"v-model",value:e.newStatus.nsfw,expression:"newStatus.nsfw"}],attrs:{type:"checkbox",id:"filesSensitive"},domProps:{checked:Array.isArray(e.newStatus.nsfw)?e._i(e.newStatus.nsfw,null)>-1:e.newStatus.nsfw},on:{change:function(t){var a=e.newStatus.nsfw,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&e.$set(e.newStatus,"nsfw",a.concat([o])):s>-1&&e.$set(e.newStatus,"nsfw",a.slice(0,s).concat(a.slice(s+1)))}else e.$set(e.newStatus,"nsfw",n)}}}),e._v(" "),a("label",{attrs:{for:"filesSensitive"}},[e._v(e._s(e.$t("post_status.attachments_sensitive")))])]):e._e()])])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"timeline panel panel-default"},[a("div",{staticClass:"panel-heading conversation-heading"},[a("span",{staticClass:"title"},[e._v(" "+e._s(e.$t("timeline.conversation"))+" ")]),e._v(" "),e.collapsable?a("span",[a("a",{attrs:{href:"#"},on:{click:function(t){t.preventDefault(),e.$emit("toggleExpanded")}}},[e._v(e._s(e.$t("timeline.collapse")))])]):e._e()]),e._v(" "),a("div",{staticClass:"panel-body"},[a("div",{staticClass:"timeline"},e._l(e.conversation,function(t){return a("status",{key:t.id,staticClass:"status-fadein",attrs:{inlineExpanded:e.collapsable,statusoid:t,expandable:!1,focused:e.focused(t.id),inConversation:!0,highlight:e.highlight,replies:e.getReplies(t.id)},on:{goto:e.setHighlight}})}),1)])])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("Timeline",{attrs:{title:e.tag,timeline:e.timeline,"timeline-name":"tag",tag:e.tag}})},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"panel panel-default"},[a("div",{staticClass:"panel-heading"},[e._v("\n "+e._s(e.$t("who_to_follow.who_to_follow"))+"\n ")]),e._v(" "),a("div",{staticClass:"panel-body"},e._l(e.users,function(e){return a("FollowCard",{key:e.id,attrs:{user:e}})}),1)])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return e.loggedIn?a("div",["private"!==e.visibility&&"direct"!==e.visibility?[a("i",{staticClass:"button-icon retweet-button icon-retweet rt-active",class:e.classes,attrs:{title:e.$t("tool_tip.repeat")},on:{click:function(t){t.preventDefault(),e.retweet()}}}),e._v(" "),!e.hidePostStatsLocal&&e.status.repeat_num>0?a("span",[e._v(e._s(e.status.repeat_num))]):e._e()]:[a("i",{staticClass:"button-icon icon-lock",class:e.classes,attrs:{title:e.$t("timeline.no_retweet_hint")}})]],2):e.loggedIn?e._e():a("div",[a("i",{staticClass:"button-icon icon-retweet",class:e.classes,attrs:{title:e.$t("tool_tip.repeat")}}),e._v(" "),!e.hidePostStatsLocal&&e.status.repeat_num>0?a("span",[e._v(e._s(e.status.repeat_num))]):e._e()])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",[a("div",{staticClass:"panel panel-default"},[a("div",{staticClass:"panel-body"},[a("div",{staticClass:"tos-content",domProps:{innerHTML:e._s(e.content)}})])])])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return e.contrast?a("span",{staticClass:"contrast-ratio"},[a("span",{staticClass:"rating",attrs:{title:e.hint}},[e.contrast.aaa?a("span",[a("i",{staticClass:"icon-thumbs-up-alt"})]):e._e(),e._v(" "),!e.contrast.aaa&&e.contrast.aa?a("span",[a("i",{staticClass:"icon-adjust"})]):e._e(),e._v(" "),e.contrast.aaa||e.contrast.aa?e._e():a("span",[a("i",{staticClass:"icon-attention"})])]),e._v(" "),e.contrast&&e.large?a("span",{staticClass:"rating",attrs:{title:e.hint_18pt}},[e.contrast.laaa?a("span",[a("i",{staticClass:"icon-thumbs-up-alt"})]):e._e(),e._v(" "),!e.contrast.laaa&&e.contrast.laa?a("span",[a("i",{staticClass:"icon-adjust"})]):e._e(),e._v(" "),e.contrast.laaa||e.contrast.laa?e._e():a("span",[a("i",{staticClass:"icon-attention"})])]):e._e()]):e._e()},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("basic-user-card",{attrs:{user:e.user}},[a("div",{staticClass:"follow-card-content-container"},[!e.noFollowsYou&&e.user.follows_you?a("span",{staticClass:"faint"},[e._v("\n "+e._s(e.isMe?e.$t("user_card.its_you"):e.$t("user_card.follows_you"))+"\n ")]):e._e(),e._v(" "),e.showFollow?a("button",{staticClass:"btn btn-default",attrs:{disabled:e.inProgress,title:e.requestSent?e.$t("user_card.follow_again"):""},on:{click:e.followUser}},[e.inProgress?[e._v("\n "+e._s(e.$t("user_card.follow_progress"))+"\n ")]:e.requestSent?[e._v("\n "+e._s(e.$t("user_card.follow_sent"))+"\n ")]:[e._v("\n "+e._s(e.$t("user_card.follow"))+"\n ")]],2):e._e(),e._v(" "),e.following?a("button",{staticClass:"btn btn-default pressed",attrs:{disabled:e.inProgress},on:{click:e.unfollowUser}},[e.inProgress?[e._v("\n "+e._s(e.$t("user_card.follow_progress"))+"\n ")]:[e._v("\n "+e._s(e.$t("user_card.follow_unfollow"))+"\n ")]],2):e._e()])])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("basic-user-card",{attrs:{user:e.user}},[a("template",{slot:"secondary-area"},[e.muted?a("button",{staticClass:"btn btn-default",attrs:{disabled:e.progress},on:{click:e.unmuteUser}},[e.progress?[e._v("\n "+e._s(e.$t("user_card.unmute_progress"))+"\n ")]:[e._v("\n "+e._s(e.$t("user_card.unmute"))+"\n ")]],2):a("button",{staticClass:"btn btn-default",attrs:{disabled:e.progress},on:{click:e.muteUser}},[e.progress?[e._v("\n "+e._s(e.$t("user_card.mute_progress"))+"\n ")]:[e._v("\n "+e._s(e.$t("user_card.mute"))+"\n ")]],2)])],2)},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("Timeline",{attrs:{title:e.$t("nav.mentions"),timeline:e.timeline,"timeline-name":"mentions"}})},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("Timeline",{attrs:{title:e.$t("nav.twkn"),timeline:e.timeline,"timeline-name":"publicAndExternal"}})},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return this.collapsed&&this.floating?a("div",{staticClass:"chat-panel"},[a("div",{staticClass:"panel panel-default"},[a("div",{staticClass:"panel-heading stub timeline-heading chat-heading",on:{click:function(t){return t.stopPropagation(),t.preventDefault(),e.togglePanel(t)}}},[a("div",{staticClass:"title"},[a("i",{staticClass:"icon-comment-empty"}),e._v("\n "+e._s(e.$t("chat.title"))+"\n ")])])])]):a("div",{staticClass:"chat-panel"},[a("div",{staticClass:"panel panel-default"},[a("div",{staticClass:"panel-heading timeline-heading",class:{"chat-heading":e.floating},on:{click:function(t){return t.stopPropagation(),t.preventDefault(),e.togglePanel(t)}}},[a("div",{staticClass:"title"},[a("span",[e._v(e._s(e.$t("chat.title")))]),e._v(" "),e.floating?a("i",{staticClass:"icon-cancel"}):e._e()])]),e._v(" "),a("div",{directives:[{name:"chat-scroll",rawName:"v-chat-scroll"}],staticClass:"chat-window"},e._l(e.messages,function(t){return a("div",{key:t.id,staticClass:"chat-message"},[a("span",{staticClass:"chat-avatar"},[a("img",{attrs:{src:t.author.avatar}})]),e._v(" "),a("div",{staticClass:"chat-content"},[a("router-link",{staticClass:"chat-name",attrs:{to:e.userProfileLink(t.author)}},[e._v("\n "+e._s(t.author.username)+"\n ")]),e._v(" "),a("br"),e._v(" "),a("span",{staticClass:"chat-text"},[e._v("\n "+e._s(t.text)+"\n ")])],1)])}),0),e._v(" "),a("div",{staticClass:"chat-input"},[a("textarea",{directives:[{name:"model",rawName:"v-model",value:e.currentMessage,expression:"currentMessage"}],staticClass:"chat-input-textarea",attrs:{rows:"1"},domProps:{value:e.currentMessage},on:{keyup:function(t){return"button"in t||!e._k(t.keyCode,"enter",13,t.key,"Enter")?void e.submit(e.currentMessage):null},input:function(t){t.target.composing||(e.currentMessage=t.target.value)}}})])])])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("basic-user-card",{attrs:{user:e.user}},[a("div",{staticClass:"follow-request-card-content-container"},[a("button",{staticClass:"btn btn-default",on:{click:e.approveUser}},[e._v(e._s(e.$t("user_card.approve")))]),e._v(" "),a("button",{staticClass:"btn btn-default",on:{click:e.denyUser}},[e._v(e._s(e.$t("user_card.deny")))])])])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",[a("label",{attrs:{for:"interface-language-switcher"}},[e._v("\n "+e._s(e.$t("settings.interfaceLanguage"))+"\n ")]),e._v(" "),a("label",{staticClass:"select",attrs:{for:"interface-language-switcher"}},[a("select",{directives:[{name:"model",rawName:"v-model",value:e.language,expression:"language"}],attrs:{id:"interface-language-switcher"},on:{change:function(t){var a=Array.prototype.filter.call(t.target.options,function(e){return e.selected}).map(function(e){var t="_value"in e?e._value:e.value;return t});e.language=t.target.multiple?a:a[0]}}},e._l(e.languageCodes,function(t,i){return a("option",{domProps:{value:t}},[e._v("\n "+e._s(e.languageNames[i])+"\n ")])}),0),e._v(" "),a("i",{staticClass:"icon-down-open"})])])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",[a("div",{staticClass:"user-finder-container"},[e.loading?a("i",{staticClass:"icon-spin4 user-finder-icon animate-spin-slow"}):e._e(),e._v(" "),e.hidden?a("a",{attrs:{href:"#",title:e.$t("finder.find_user")}},[a("i",{staticClass:"icon-user-plus user-finder-icon",on:{click:function(t){return t.preventDefault(),t.stopPropagation(),e.toggleHidden(t)}}})]):[a("input",{directives:[{name:"model",rawName:"v-model",value:e.username,expression:"username"}],ref:"userSearchInput",staticClass:"user-finder-input",attrs:{placeholder:e.$t("finder.find_user"),id:"user-finder-input",type:"text"},domProps:{value:e.username},on:{keyup:function(t){return"button"in t||!e._k(t.keyCode,"enter",13,t.key,"Enter")?void e.findUser(e.username):null},input:function(t){t.target.composing||(e.username=t.target.value)}}}),e._v(" "),a("button",{staticClass:"btn search-button",on:{click:function(t){e.findUser(e.username)}}},[a("i",{staticClass:"icon-search"})]),e._v(" "),a("i",{staticClass:"button-icon icon-cancel user-finder-icon",on:{click:function(t){return t.preventDefault(),t.stopPropagation(),e.toggleHidden(t)}}})]],2)])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("h1",[e._v("...")])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",[e.expanded?a("conversation",{attrs:{collapsable:!0,statusoid:e.statusoid},on:{toggleExpanded:e.toggleExpanded}}):e._e(),e._v(" "),e.expanded?e._e():a("status",{attrs:{expandable:!0,inConversation:!1,focused:!1,statusoid:e.statusoid},on:{toggleExpanded:e.toggleExpanded}})],1)},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"login panel panel-default"},[a("div",{staticClass:"panel-heading"},[e._v("\n "+e._s(e.$t("login.login"))+"\n ")]),e._v(" "),a("div",{staticClass:"panel-body"},["password"==e.loginMethod?a("form",{staticClass:"login-form",on:{submit:function(t){t.preventDefault(),e.submit(e.user)}}},[a("div",{staticClass:"form-group"},[a("label",{attrs:{for:"username"}},[e._v(e._s(e.$t("login.username")))]),e._v(" "),a("input",{directives:[{name:"model",rawName:"v-model",value:e.user.username,expression:"user.username"}],staticClass:"form-control",attrs:{disabled:e.loggingIn,id:"username",placeholder:e.$t("login.placeholder")},domProps:{value:e.user.username},on:{input:function(t){t.target.composing||e.$set(e.user,"username",t.target.value)}}})]),e._v(" "),a("div",{staticClass:"form-group"},[a("label",{attrs:{for:"password"}},[e._v(e._s(e.$t("login.password")))]),e._v(" "),a("input",{directives:[{name:"model",rawName:"v-model",value:e.user.password,expression:"user.password"}],staticClass:"form-control",attrs:{disabled:e.loggingIn,id:"password",type:"password"},domProps:{value:e.user.password},on:{input:function(t){t.target.composing||e.$set(e.user,"password",t.target.value)}}})]),e._v(" "),a("div",{staticClass:"form-group"},[a("div",{staticClass:"login-bottom"},[a("div",[e.registrationOpen?a("router-link",{staticClass:"register",attrs:{to:{name:"registration"}}},[e._v(e._s(e.$t("login.register")))]):e._e()],1),e._v(" "),a("button",{staticClass:"btn btn-default",attrs:{disabled:e.loggingIn,type:"submit"}},[e._v(e._s(e.$t("login.login")))])])])]):e._e(),e._v(" "),"token"==e.loginMethod?a("form",{staticClass:"login-form",on:{submit:function(t){return t.preventDefault(),e.oAuthLogin(t)}}},[a("div",{staticClass:"form-group"},[a("p",[e._v(e._s(e.$t("login.description")))])]),e._v(" "),a("div",{staticClass:"form-group"},[a("div",{staticClass:"login-bottom"},[a("div",[e.registrationOpen?a("router-link",{staticClass:"register",attrs:{to:{name:"registration"}}},[e._v(e._s(e.$t("login.register")))]):e._e()],1),e._v(" "),a("button",{staticClass:"btn btn-default",attrs:{disabled:e.loggingIn,type:"submit"}},[e._v(e._s(e.$t("login.login")))])])])]):e._e(),e._v(" "),e.authError?a("div",{staticClass:"form-group"},[a("div",{staticClass:"alert error"},[e._v("\n "+e._s(e.authError)+"\n "),a("i",{staticClass:"button-icon icon-cancel",on:{click:e.clearError}})])]):e._e()])])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"settings panel panel-default"},[a("div",{staticClass:"panel-heading"},[e._v("\n "+e._s(e.$t("registration.registration"))+"\n ")]),e._v(" "),a("div",{staticClass:"panel-body"},[a("form",{staticClass:"registration-form",on:{submit:function(t){t.preventDefault(),e.submit(e.user)}}},[a("div",{staticClass:"container"},[a("div",{staticClass:"text-fields"},[a("div",{staticClass:"form-group",class:{"form-group--error":e.$v.user.username.$error}},[a("label",{staticClass:"form--label",attrs:{for:"sign-up-username"}},[e._v(e._s(e.$t("login.username")))]),e._v(" "),a("input",{directives:[{name:"model",rawName:"v-model.trim",value:e.$v.user.username.$model,expression:"$v.user.username.$model",modifiers:{trim:!0}}],staticClass:"form-control",attrs:{disabled:e.isPending,id:"sign-up-username",placeholder:e.$t("registration.username_placeholder")},domProps:{value:e.$v.user.username.$model},on:{input:function(t){t.target.composing||e.$set(e.$v.user.username,"$model",t.target.value.trim())},blur:function(t){e.$forceUpdate()}}})]),e._v(" "),e.$v.user.username.$dirty?a("div",{staticClass:"form-error"},[a("ul",[e.$v.user.username.required?e._e():a("li",[a("span",[e._v(e._s(e.$t("registration.validations.username_required")))])])])]):e._e(),e._v(" "),a("div",{staticClass:"form-group",class:{"form-group--error":e.$v.user.fullname.$error}},[a("label",{staticClass:"form--label",attrs:{for:"sign-up-fullname"}},[e._v(e._s(e.$t("registration.fullname")))]),e._v(" "),a("input",{directives:[{name:"model",rawName:"v-model.trim",value:e.$v.user.fullname.$model,expression:"$v.user.fullname.$model",modifiers:{trim:!0}}],staticClass:"form-control",attrs:{disabled:e.isPending,id:"sign-up-fullname",placeholder:e.$t("registration.fullname_placeholder")},domProps:{value:e.$v.user.fullname.$model},on:{input:function(t){t.target.composing||e.$set(e.$v.user.fullname,"$model",t.target.value.trim()); +},blur:function(t){e.$forceUpdate()}}})]),e._v(" "),e.$v.user.fullname.$dirty?a("div",{staticClass:"form-error"},[a("ul",[e.$v.user.fullname.required?e._e():a("li",[a("span",[e._v(e._s(e.$t("registration.validations.fullname_required")))])])])]):e._e(),e._v(" "),a("div",{staticClass:"form-group",class:{"form-group--error":e.$v.user.email.$error}},[a("label",{staticClass:"form--label",attrs:{for:"email"}},[e._v(e._s(e.$t("registration.email")))]),e._v(" "),a("input",{directives:[{name:"model",rawName:"v-model",value:e.$v.user.email.$model,expression:"$v.user.email.$model"}],staticClass:"form-control",attrs:{disabled:e.isPending,id:"email",type:"email"},domProps:{value:e.$v.user.email.$model},on:{input:function(t){t.target.composing||e.$set(e.$v.user.email,"$model",t.target.value)}}})]),e._v(" "),e.$v.user.email.$dirty?a("div",{staticClass:"form-error"},[a("ul",[e.$v.user.email.required?e._e():a("li",[a("span",[e._v(e._s(e.$t("registration.validations.email_required")))])])])]):e._e(),e._v(" "),a("div",{staticClass:"form-group"},[a("label",{staticClass:"form--label",attrs:{for:"bio"}},[e._v(e._s(e.$t("registration.bio"))+" ("+e._s(e.$t("general.optional"))+")")]),e._v(" "),a("textarea",{directives:[{name:"model",rawName:"v-model",value:e.user.bio,expression:"user.bio"}],staticClass:"form-control",attrs:{disabled:e.isPending,id:"bio",placeholder:e.$t("registration.bio_placeholder")},domProps:{value:e.user.bio},on:{input:function(t){t.target.composing||e.$set(e.user,"bio",t.target.value)}}})]),e._v(" "),a("div",{staticClass:"form-group",class:{"form-group--error":e.$v.user.password.$error}},[a("label",{staticClass:"form--label",attrs:{for:"sign-up-password"}},[e._v(e._s(e.$t("login.password")))]),e._v(" "),a("input",{directives:[{name:"model",rawName:"v-model",value:e.user.password,expression:"user.password"}],staticClass:"form-control",attrs:{disabled:e.isPending,id:"sign-up-password",type:"password"},domProps:{value:e.user.password},on:{input:function(t){t.target.composing||e.$set(e.user,"password",t.target.value)}}})]),e._v(" "),e.$v.user.password.$dirty?a("div",{staticClass:"form-error"},[a("ul",[e.$v.user.password.required?e._e():a("li",[a("span",[e._v(e._s(e.$t("registration.validations.password_required")))])])])]):e._e(),e._v(" "),a("div",{staticClass:"form-group",class:{"form-group--error":e.$v.user.confirm.$error}},[a("label",{staticClass:"form--label",attrs:{for:"sign-up-password-confirmation"}},[e._v(e._s(e.$t("registration.password_confirm")))]),e._v(" "),a("input",{directives:[{name:"model",rawName:"v-model",value:e.user.confirm,expression:"user.confirm"}],staticClass:"form-control",attrs:{disabled:e.isPending,id:"sign-up-password-confirmation",type:"password"},domProps:{value:e.user.confirm},on:{input:function(t){t.target.composing||e.$set(e.user,"confirm",t.target.value)}}})]),e._v(" "),e.$v.user.confirm.$dirty?a("div",{staticClass:"form-error"},[a("ul",[e.$v.user.confirm.required?e._e():a("li",[a("span",[e._v(e._s(e.$t("registration.validations.password_confirmation_required")))])]),e._v(" "),e.$v.user.confirm.sameAsPassword?e._e():a("li",[a("span",[e._v(e._s(e.$t("registration.validations.password_confirmation_match")))])])])]):e._e(),e._v(" "),"none"!=e.captcha.type?a("div",{staticClass:"form-group",attrs:{id:"captcha-group"}},[a("label",{staticClass:"form--label",attrs:{for:"captcha-label"}},[e._v(e._s(e.$t("captcha")))]),e._v(" "),"kocaptcha"==e.captcha.type?[a("img",{attrs:{src:e.captcha.url},on:{click:e.setCaptcha}}),e._v(" "),a("sub",[e._v(e._s(e.$t("registration.new_captcha")))]),e._v(" "),a("input",{directives:[{name:"model",rawName:"v-model",value:e.captcha.solution,expression:"captcha.solution"}],staticClass:"form-control",attrs:{disabled:e.isPending,id:"captcha-answer",type:"text",autocomplete:"off"},domProps:{value:e.captcha.solution},on:{input:function(t){t.target.composing||e.$set(e.captcha,"solution",t.target.value)}}})]:e._e()],2):e._e(),e._v(" "),e.token?a("div",{staticClass:"form-group"},[a("label",{attrs:{for:"token"}},[e._v(e._s(e.$t("registration.token")))]),e._v(" "),a("input",{directives:[{name:"model",rawName:"v-model",value:e.token,expression:"token"}],staticClass:"form-control",attrs:{disabled:"true",id:"token",type:"text"},domProps:{value:e.token},on:{input:function(t){t.target.composing||(e.token=t.target.value)}}})]):e._e(),e._v(" "),a("div",{staticClass:"form-group"},[a("button",{staticClass:"btn btn-default",attrs:{disabled:e.isPending,type:"submit"}},[e._v(e._s(e.$t("general.submit")))])])]),e._v(" "),a("div",{staticClass:"terms-of-service",domProps:{innerHTML:e._s(e.termsOfService)}})]),e._v(" "),e.serverValidationErrors.length?a("div",{staticClass:"form-group"},[a("div",{staticClass:"alert error"},e._l(e.serverValidationErrors,function(t){return a("span",[e._v(e._s(t))])}),0)]):e._e()])])])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"features-panel"},[a("div",{staticClass:"panel panel-default base01-background"},[a("div",{staticClass:"panel-heading timeline-heading base02-background base04"},[a("div",{staticClass:"title"},[e._v("\n "+e._s(e.$t("features_panel.title"))+"\n ")])]),e._v(" "),a("div",{staticClass:"panel-body features-panel"},[a("ul",[e.chat?a("li",[e._v(e._s(e.$t("features_panel.chat")))]):e._e(),e._v(" "),e.gopher?a("li",[e._v(e._s(e.$t("features_panel.gopher")))]):e._e(),e._v(" "),e.whoToFollow?a("li",[e._v(e._s(e.$t("features_panel.who_to_follow")))]):e._e(),e._v(" "),e.mediaProxy?a("li",[e._v(e._s(e.$t("features_panel.media_proxy")))]):e._e(),e._v(" "),e.scopeOptions?a("li",[e._v(e._s(e.$t("features_panel.scope_options")))]):e._e(),e._v(" "),a("li",[e._v(e._s(e.$t("features_panel.text_limit"))+" = "+e._s(e.textlimit))])])])])])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",[e.user.id?a("div",{staticClass:"user-profile panel panel-default"},[a("UserCard",{attrs:{user:e.user,switcher:!0,selected:e.timeline.viewing,rounded:"top"}}),e._v(" "),a("tab-switcher",{ref:"tabSwitcher",attrs:{renderOnlyFocused:!0}},[a("Timeline",{attrs:{label:e.$t("user_card.statuses"),disabled:!e.user.statuses_count,count:e.user.statuses_count,embedded:!0,title:e.$t("user_profile.timeline_title"),timeline:e.timeline,"timeline-name":"user","user-id":e.fetchBy}}),e._v(" "),e.followsTabVisible?a("div",{attrs:{label:e.$t("user_card.followees"),disabled:!e.user.friends_count}},[a("FriendList",{attrs:{userId:e.userId}})],1):e._e(),e._v(" "),e.followersTabVisible?a("div",{attrs:{label:e.$t("user_card.followers"),disabled:!e.user.followers_count}},[a("FollowerList",{attrs:{userId:e.userId,entryProps:{noFollowsYou:e.isUs}}})],1):e._e(),e._v(" "),a("Timeline",{attrs:{label:e.$t("user_card.media"),disabled:!e.media.visibleStatuses.length,embedded:!0,title:e.$t("user_card.media"),"timeline-name":"media",timeline:e.media,"user-id":e.fetchBy}}),e._v(" "),e.isUs?a("Timeline",{attrs:{label:e.$t("user_card.favorites"),disabled:!e.favorites.visibleStatuses.length,embedded:!0,title:e.$t("user_card.favorites"),"timeline-name":"favorites",timeline:e.favorites}}):e._e()],1)],1):a("div",{staticClass:"panel user-profile-placeholder"},[a("div",{staticClass:"panel-heading"},[a("div",{staticClass:"title"},[e._v("\n "+e._s(e.$t("settings.profile_tab"))+"\n ")])]),e._v(" "),a("div",{staticClass:"panel-body"},[e.error?a("span",[e._v(e._s(e.error))]):a("i",{staticClass:"icon-spin3 animate-spin"})])])])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return e.usePlaceHolder?a("div",{on:{click:e.openModal}},["html"!==e.type?a("a",{staticClass:"placeholder",attrs:{target:"_blank",href:e.attachment.url}},[e._v("\n ["+e._s(e.nsfw?"NSFW/":"")+e._s(e.type.toUpperCase())+"]\n ")]):e._e()]):a("div",{directives:[{name:"show",rawName:"v-show",value:!e.isEmpty,expression:"!isEmpty"}],staticClass:"attachment",class:(i={loading:e.loading,fullwidth:e.fullwidth,"nsfw-placeholder":e.hidden},i[e.type]=!0,i)},[e.hidden?a("a",{staticClass:"image-attachment",attrs:{href:e.attachment.url},on:{click:function(t){return t.preventDefault(),e.toggleHidden(t)}}},[a("img",{key:e.nsfwImage,staticClass:"nsfw",class:{small:e.isSmall},attrs:{src:e.nsfwImage}}),e._v(" "),"video"===e.type?a("i",{staticClass:"play-icon icon-play-circled"}):e._e()]):e._e(),e._v(" "),e.nsfw&&e.hideNsfwLocal&&!e.hidden?a("div",{staticClass:"hider"},[a("a",{attrs:{href:"#"},on:{click:function(t){return t.preventDefault(),e.toggleHidden(t)}}},[e._v("Hide")])]):e._e(),e._v(" "),"image"!==e.type||e.hidden&&!e.preloadImage?e._e():a("a",{staticClass:"image-attachment",class:{hidden:e.hidden&&e.preloadImage},attrs:{href:e.attachment.url,target:"_blank",title:e.attachment.description},on:{click:e.openModal}},[a("StillImage",{attrs:{referrerpolicy:e.referrerpolicy,mimetype:e.attachment.mimetype,src:e.attachment.large_thumb_url||e.attachment.url}})],1),e._v(" "),"video"!==e.type||e.hidden?e._e():a("a",{staticClass:"video-container",class:{small:e.isSmall},attrs:{href:e.allowPlay?void 0:e.attachment.url},on:{click:e.openModal}},[a("VideoAttachment",{staticClass:"video",attrs:{attachment:e.attachment,controls:e.allowPlay}}),e._v(" "),e.allowPlay?e._e():a("i",{staticClass:"play-icon icon-play-circled"})],1),e._v(" "),"audio"===e.type?a("audio",{attrs:{src:e.attachment.url,controls:""}}):e._e(),e._v(" "),"html"===e.type&&e.attachment.oembed?a("div",{staticClass:"oembed",on:{click:function(t){return t.preventDefault(),e.linkClicked(t)}}},[e.attachment.thumb_url?a("div",{staticClass:"image"},[a("img",{attrs:{src:e.attachment.thumb_url}})]):e._e(),e._v(" "),a("div",{staticClass:"text"},[a("h1",[a("a",{attrs:{href:e.attachment.url}},[e._v(e._s(e.attachment.oembed.title))])]),e._v(" "),a("div",{domProps:{innerHTML:e._s(e.attachment.oembed.oembedHTML)}})])]):e._e()]);var i},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"font-control style-control",class:{custom:e.isCustom}},[a("label",{staticClass:"label",attrs:{for:"custom"===e.preset?e.name:e.name+"-font-switcher"}},[e._v("\n "+e._s(e.label)+"\n ")]),e._v(" "),"undefined"!=typeof e.fallback?a("input",{staticClass:"opt exlcude-disabled",attrs:{type:"checkbox",id:e.name+"-o"},domProps:{checked:e.present},on:{input:function(t){e.$emit("input","undefined"==typeof e.value?e.fallback:void 0)}}}):e._e(),e._v(" "),"undefined"!=typeof e.fallback?a("label",{staticClass:"opt-l",attrs:{for:e.name+"-o"}}):e._e(),e._v(" "),a("label",{staticClass:"select",attrs:{for:e.name+"-font-switcher",disabled:!e.present}},[a("select",{directives:[{name:"model",rawName:"v-model",value:e.preset,expression:"preset"}],staticClass:"font-switcher",attrs:{disabled:!e.present,id:e.name+"-font-switcher"},on:{change:function(t){var a=Array.prototype.filter.call(t.target.options,function(e){return e.selected}).map(function(e){var t="_value"in e?e._value:e.value;return t});e.preset=t.target.multiple?a:a[0]}}},e._l(e.availableOptions,function(t){return a("option",{domProps:{value:t}},[e._v("\n "+e._s("custom"===t?e.$t("settings.style.fonts.custom"):t)+"\n ")])}),0),e._v(" "),a("i",{staticClass:"icon-down-open"})]),e._v(" "),e.isCustom?a("input",{directives:[{name:"model",rawName:"v-model",value:e.family,expression:"family"}],staticClass:"custom-font",attrs:{type:"text",id:e.name},domProps:{value:e.family},on:{input:function(t){t.target.composing||(e.family=t.target.value)}}}):e._e()])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{style:e.bgAppStyle,attrs:{id:"app"}},[a("div",{staticClass:"app-bg-wrapper",style:e.bgStyle}),e._v(" "),a("nav",{staticClass:"nav-bar container",attrs:{id:"nav"},on:{click:function(t){e.scrollToTop()}}},[a("div",{staticClass:"logo",style:e.logoBgStyle},[a("div",{staticClass:"mask",style:e.logoMaskStyle}),e._v(" "),a("img",{style:e.logoStyle,attrs:{src:e.logo}})]),e._v(" "),a("div",{staticClass:"inner-nav"},[a("div",{staticClass:"item"},[a("a",{staticClass:"menu-button",attrs:{href:"#"},on:{click:function(t){t.stopPropagation(),t.preventDefault(),e.toggleMobileSidebar()}}},[a("i",{staticClass:"button-icon icon-menu"}),e._v(" "),e.unseenNotificationsCount?a("div",{staticClass:"alert-dot"}):e._e()]),e._v(" "),a("router-link",{staticClass:"site-name",attrs:{to:{name:"root"},"active-class":"home"}},[e._v(e._s(e.sitename))])],1),e._v(" "),a("div",{staticClass:"item right"},[a("user-finder",{staticClass:"button-icon nav-icon mobile-hidden",on:{toggled:e.onFinderToggled}}),e._v(" "),a("router-link",{staticClass:"mobile-hidden",attrs:{to:{name:"settings"}}},[a("i",{staticClass:"button-icon icon-cog nav-icon",attrs:{title:e.$t("nav.preferences")}})]),e._v(" "),e.currentUser?a("a",{staticClass:"mobile-hidden",attrs:{href:"#"},on:{click:function(t){return t.preventDefault(),e.logout(t)}}},[a("i",{staticClass:"button-icon icon-logout nav-icon",attrs:{title:e.$t("login.logout")}})]):e._e()],1)])]),e._v(" "),a("div",{staticClass:"container",attrs:{id:"content"}},[a("side-drawer",{ref:"sideDrawer",attrs:{logout:e.logout}}),e._v(" "),a("div",{staticClass:"sidebar-flexer mobile-hidden"},[a("div",{staticClass:"sidebar-bounds"},[a("div",{staticClass:"sidebar-scroller"},[a("div",{staticClass:"sidebar"},[a("user-panel"),e._v(" "),a("nav-panel"),e._v(" "),e.showInstanceSpecificPanel?a("instance-specific-panel"):e._e(),e._v(" "),!e.currentUser&&e.showFeaturesPanel?a("features-panel"):e._e(),e._v(" "),e.currentUser&&e.suggestionsEnabled?a("who-to-follow-panel"):e._e(),e._v(" "),e.currentUser?a("notifications"):e._e()],1)])])]),e._v(" "),a("div",{staticClass:"main"},[e.currentUser?e._e():a("div",{staticClass:"login-hint panel panel-default"},[a("router-link",{staticClass:"panel-body",attrs:{to:{name:"login"}}},[e._v("\n "+e._s(e.$t("login.hint"))+"\n ")])],1),e._v(" "),a("transition",{attrs:{name:"fade"}},[a("router-view")],1)],1),e._v(" "),a("media-modal")],1),e._v(" "),e.currentUser&&e.chat?a("chat-panel",{staticClass:"floating-chat mobile-hidden",attrs:{floating:!0}}):e._e(),e._v(" "),a("MobilePostStatusModal")],1)},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"opacity-control style-control",class:{disabled:!e.present||e.disabled}},[a("label",{staticClass:"label",attrs:{for:e.name}},[e._v("\n "+e._s(e.$t("settings.style.common.opacity"))+"\n ")]),e._v(" "),"undefined"!=typeof e.fallback?a("input",{staticClass:"opt exclude-disabled",attrs:{id:e.name+"-o",type:"checkbox"},domProps:{checked:e.present},on:{input:function(t){e.$emit("input",e.present?void 0:e.fallback)}}}):e._e(),e._v(" "),"undefined"!=typeof e.fallback?a("label",{staticClass:"opt-l",attrs:{for:e.name+"-o"}}):e._e(),e._v(" "),a("input",{staticClass:"input-number",attrs:{id:e.name,type:"number",disabled:!e.present||e.disabled,max:"1",min:"0",step:".05"},domProps:{value:e.value||e.fallback},on:{input:function(t){e.$emit("input",t.target.value)}}})])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"sidebar"},[a("instance-specific-panel"),e._v(" "),e.showFeaturesPanel?a("features-panel"):e._e(),e._v(" "),a("terms-of-service-panel")],1)},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("video",{staticClass:"video",attrs:{src:e.attachment.url,loop:e.loopVideo,controls:e.controls,playsinline:""},on:{loadeddata:e.onVideoDataLoad}})},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("basic-user-card",{attrs:{user:e.user}},[a("div",{staticClass:"block-card-content-container"},[e.blocked?a("button",{staticClass:"btn btn-default",attrs:{disabled:e.progress},on:{click:e.unblockUser}},[e.progress?[e._v("\n "+e._s(e.$t("user_card.unblock_progress"))+"\n ")]:[e._v("\n "+e._s(e.$t("user_card.unblock"))+"\n ")]],2):a("button",{staticClass:"btn btn-default",attrs:{disabled:e.progress},on:{click:e.blockUser}},[e.progress?[e._v("\n "+e._s(e.$t("user_card.block_progress"))+"\n ")]:[e._v("\n "+e._s(e.$t("user_card.block"))+"\n ")]],2)])])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"media-upload",on:{drop:[function(e){e.preventDefault()},e.fileDrop],dragover:function(t){return t.preventDefault(),e.fileDrag(t)}}},[a("label",{staticClass:"btn btn-default",attrs:{title:e.$t("tool_tip.media_upload")}},[e.uploading?a("i",{staticClass:"icon-spin4 animate-spin"}):e._e(),e._v(" "),e.uploading?e._e():a("i",{staticClass:"icon-upload"}),e._v(" "),e.uploadReady?a("input",{staticStyle:{position:"fixed",top:"-100em"},attrs:{type:"file",multiple:"true"},on:{change:e.change}}):e._e()])])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return e.showing?a("div",{staticClass:"modal-view media-modal-view",on:{click:function(t){return t.preventDefault(),e.hide(t)}}},["image"===e.type?a("img",{staticClass:"modal-image",attrs:{src:e.currentMedia.url}}):e._e(),e._v(" "),"video"===e.type?a("VideoAttachment",{staticClass:"modal-image",attrs:{attachment:e.currentMedia,controls:!0},nativeOn:{click:function(e){e.stopPropagation()}}}):e._e(),e._v(" "),e.canNavigate?a("button",{staticClass:"modal-view-button-arrow modal-view-button-arrow--prev",attrs:{title:e.$t("media_modal.previous")},on:{click:function(t){return t.stopPropagation(),t.preventDefault(),e.goPrev(t)}}},[a("i",{staticClass:"icon-left-open arrow-icon"})]):e._e(),e._v(" "),e.canNavigate?a("button",{staticClass:"modal-view-button-arrow modal-view-button-arrow--next",attrs:{title:e.$t("media_modal.next")},on:{click:function(t){return t.stopPropagation(),t.preventDefault(),e.goNext(t)}}},[a("i",{staticClass:"icon-right-open arrow-icon"})]):e._e()],1):e._e()},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("Timeline",{attrs:{title:e.$t("nav.dms"),timeline:e.timeline,"timeline-name":"dms"}})},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"user-search panel panel-default"},[a("div",{staticClass:"panel-heading"},[e._v("\n "+e._s(e.$t("nav.user_search"))+"\n ")]),e._v(" "),a("div",{staticClass:"user-search-input-container"},[a("input",{directives:[{name:"model",rawName:"v-model",value:e.username,expression:"username"}],ref:"userSearchInput",staticClass:"user-finder-input",attrs:{placeholder:e.$t("finder.find_user")},domProps:{value:e.username},on:{keyup:function(t){return"button"in t||!e._k(t.keyCode,"enter",13,t.key,"Enter")?void e.newQuery(e.username):null},input:function(t){t.target.composing||(e.username=t.target.value)}}}),e._v(" "),a("button",{staticClass:"btn search-button",on:{click:function(t){e.newQuery(e.username)}}},[a("i",{staticClass:"icon-search"})])]),e._v(" "),e.loading?a("div",{staticClass:"text-center loading-icon"},[a("i",{staticClass:"icon-spin3 animate-spin"})]):a("div",{staticClass:"panel-body"},e._l(e.users,function(e){return a("FollowCard",{key:e.id,attrs:{user:e}})}),1)])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("Timeline",{attrs:{title:e.$t("nav.public_tl"),timeline:e.timeline,"timeline-name":"public"}})},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"range-control style-control",class:{disabled:!e.present||e.disabled}},[a("label",{staticClass:"label",attrs:{for:e.name}},[e._v("\n "+e._s(e.label)+"\n ")]),e._v(" "),"undefined"!=typeof e.fallback?a("input",{staticClass:"opt exclude-disabled",attrs:{id:e.name+"-o",type:"checkbox"},domProps:{checked:e.present},on:{input:function(t){e.$emit("input",e.present?void 0:e.fallback)}}}):e._e(),e._v(" "),"undefined"!=typeof e.fallback?a("label",{staticClass:"opt-l",attrs:{for:e.name+"-o"}}):e._e(),e._v(" "),a("input",{staticClass:"input-number",attrs:{id:e.name,type:"range",disabled:!e.present||e.disabled,max:e.max||e.hardMax||100,min:e.min||e.hardMin||0,step:e.step||1},domProps:{value:e.value||e.fallback},on:{input:function(t){e.$emit("input",t.target.value)}}}),e._v(" "),a("input",{staticClass:"input-number",attrs:{id:e.name,type:"number",disabled:!e.present||e.disabled,max:e.hardMax,min:e.hardMin,step:e.step||1},domProps:{value:e.value||e.fallback},on:{input:function(t){e.$emit("input",t.target.value)}}})])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"basic-user-card"},[a("router-link",{attrs:{to:e.userProfileLink(e.user)}},[a("UserAvatar",{staticClass:"avatar",attrs:{src:e.user.profile_image_url},nativeOn:{click:function(t){return t.preventDefault(),e.toggleUserExpanded(t)}}})],1),e._v(" "),e.userExpanded?a("div",{staticClass:"basic-user-card-expanded-content"},[a("UserCard",{attrs:{user:e.user,rounded:!0,bordered:!0}})],1):a("div",{staticClass:"basic-user-card-collapsed-content"},[a("div",{staticClass:"basic-user-card-user-name",attrs:{title:e.user.name}},[e.user.name_html?a("span",{domProps:{innerHTML:e._s(e.user.name_html)}}):a("span",[e._v(e._s(e.user.name))])]),e._v(" "),a("div",[a("router-link",{staticClass:"basic-user-card-screen-name",attrs:{to:e.userProfileLink(e.user)}},[e._v("\n @"+e._s(e.user.screen_name)+"\n ")])],1),e._v(" "),e._t("default")],2)],1)},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return"mention"===e.notification.type?a("status",{attrs:{compact:!0,statusoid:e.notification.status}}):a("div",{staticClass:"non-mention",class:[e.userClass,{highlighted:e.userStyle}],style:[e.userStyle]},[a("a",{staticClass:"avatar-container",attrs:{href:e.notification.action.user.statusnet_profile_url},on:{"!click":function(t){return t.stopPropagation(),t.preventDefault(),e.toggleUserExpanded(t)}}},[a("UserAvatar",{attrs:{compact:!0,betterShadow:e.betterShadow,src:e.notification.action.user.profile_image_url_original}})],1),e._v(" "),a("div",{staticClass:"notification-right"},[e.userExpanded?a("UserCard",{attrs:{user:e.notification.action.user,rounded:!0,bordered:!0}}):e._e(),e._v(" "),a("span",{staticClass:"notification-details"},[a("div",{staticClass:"name-and-action"},[e.notification.action.user.name_html?a("span",{staticClass:"username",attrs:{title:"@"+e.notification.action.user.screen_name},domProps:{innerHTML:e._s(e.notification.action.user.name_html)}}):a("span",{staticClass:"username",attrs:{title:"@"+e.notification.action.user.screen_name}},[e._v(e._s(e.notification.action.user.name))]),e._v(" "),"like"===e.notification.type?a("span",[a("i",{staticClass:"fa icon-star lit"}),e._v(" "),a("small",[e._v(e._s(e.$t("notifications.favorited_you")))])]):e._e(),e._v(" "),"repeat"===e.notification.type?a("span",[a("i",{staticClass:"fa icon-retweet lit",attrs:{title:e.$t("tool_tip.repeat")}}),e._v(" "),a("small",[e._v(e._s(e.$t("notifications.repeated_you")))])]):e._e(),e._v(" "),"follow"===e.notification.type?a("span",[a("i",{staticClass:"fa icon-user-plus lit"}),e._v(" "),a("small",[e._v(e._s(e.$t("notifications.followed_you")))])]):e._e()]),e._v(" "),a("div",{staticClass:"timeago"},[e.notification.status?a("router-link",{staticClass:"faint-link",attrs:{to:{name:"conversation",params:{id:e.notification.status.id}}}},[a("timeago",{attrs:{since:e.notification.action.created_at,"auto-update":240}})],1):e._e()],1)]),e._v(" "),"follow"===e.notification.type?a("div",{staticClass:"follow-text"},[a("router-link",{attrs:{to:e.userProfileLink(e.notification.action.user)}},[e._v("\n @"+e._s(e.notification.action.user.screen_name)+"\n ")])],1):[a("status",{staticClass:"faint",attrs:{compact:!0,statusoid:e.notification.status,noHeading:!0}})]],2)])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"side-drawer-container",class:{"side-drawer-container-closed":e.closed,"side-drawer-container-open":!e.closed}},[a("div",{staticClass:"side-drawer",class:{"side-drawer-closed":e.closed},on:{touchstart:e.touchStart,touchmove:e.touchMove}},[a("div",{staticClass:"side-drawer-heading",on:{click:e.toggleDrawer}},[e.currentUser?a("UserCard",{attrs:{user:e.currentUser,hideBio:!0}}):a("div",{staticClass:"side-drawer-logo-wrapper"},[a("img",{attrs:{src:e.logo}}),e._v(" "),a("span",[e._v(e._s(e.sitename))])])],1),e._v(" "),a("ul",[e.currentUser?e._e():a("li",{on:{click:e.toggleDrawer}},[a("router-link",{attrs:{to:{name:"login"}}},[e._v("\n "+e._s(e.$t("login.login"))+"\n ")])],1),e._v(" "),e.currentUser?a("li",{on:{click:e.toggleDrawer}},[a("router-link",{attrs:{to:{name:"notifications",params:{username:e.currentUser.screen_name}}}},[e._v("\n "+e._s(e.$t("notifications.notifications"))+" "+e._s(e.unseenNotificationsCount>0?"("+e.unseenNotificationsCount+")":"")+"\n ")])],1):e._e(),e._v(" "),e.currentUser?a("li",{on:{click:e.toggleDrawer}},[a("router-link",{attrs:{to:{name:"dms",params:{username:e.currentUser.screen_name}}}},[e._v("\n "+e._s(e.$t("nav.dms"))+"\n ")])],1):e._e()]),e._v(" "),a("ul",[e.currentUser?a("li",{on:{click:e.toggleDrawer}},[a("router-link",{attrs:{to:{name:"friends"}}},[e._v("\n "+e._s(e.$t("nav.timeline"))+"\n ")])],1):e._e(),e._v(" "),e.currentUser&&e.currentUser.locked?a("li",{on:{click:e.toggleDrawer}},[a("router-link",{attrs:{to:"/friend-requests"}},[e._v("\n "+e._s(e.$t("nav.friend_requests"))+"\n "),e.followRequestCount>0?a("span",{staticClass:"badge follow-request-count"},[e._v("\n "+e._s(e.followRequestCount)+"\n ")]):e._e()])],1):e._e(),e._v(" "),a("li",{on:{click:e.toggleDrawer}},[a("router-link",{attrs:{to:"/main/public"}},[e._v("\n "+e._s(e.$t("nav.public_tl"))+"\n ")])],1),e._v(" "),a("li",{on:{click:e.toggleDrawer}},[a("router-link",{attrs:{to:"/main/all"}},[e._v("\n "+e._s(e.$t("nav.twkn"))+"\n ")])],1),e._v(" "),e.currentUser&&e.chat?a("li",{on:{click:e.toggleDrawer}},[a("router-link",{attrs:{to:{name:"chat"}}},[e._v("\n "+e._s(e.$t("nav.chat"))+"\n ")])],1):e._e()]),e._v(" "),a("ul",[a("li",{on:{click:e.toggleDrawer}},[a("router-link",{attrs:{to:{name:"user-search"}}},[e._v("\n "+e._s(e.$t("nav.user_search"))+"\n ")])],1),e._v(" "),e.currentUser&&e.suggestionsEnabled?a("li",{on:{click:e.toggleDrawer}},[a("router-link",{attrs:{to:{name:"who-to-follow"}}},[e._v("\n "+e._s(e.$t("nav.who_to_follow"))+"\n ")])],1):e._e(),e._v(" "),a("li",{on:{click:e.toggleDrawer}},[a("router-link",{attrs:{to:{name:"settings"}}},[e._v("\n "+e._s(e.$t("settings.settings"))+"\n ")])],1),e._v(" "),a("li",{on:{click:e.toggleDrawer}},[a("router-link",{attrs:{to:{name:"about"}}},[e._v("\n "+e._s(e.$t("nav.about"))+"\n ")])],1),e._v(" "),e.currentUser?a("li",{on:{click:e.toggleDrawer}},[a("a",{attrs:{href:"#"},on:{click:e.doLogout}},[e._v("\n "+e._s(e.$t("login.logout"))+"\n ")])]):e._e()])]),e._v(" "),a("div",{staticClass:"side-drawer-click-outside",class:{"side-drawer-click-outside-closed":e.closed},on:{click:function(t){return t.stopPropagation(),t.preventDefault(),e.toggleDrawer(t)}}})])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"shadow-control",class:{disabled:!e.present}},[a("div",{staticClass:"shadow-preview-container"},[a("div",{staticClass:"y-shift-control",attrs:{disabled:!e.present}},[a("input",{directives:[{name:"model",rawName:"v-model",value:e.selected.y,expression:"selected.y"}],staticClass:"input-number",attrs:{disabled:!e.present,type:"number"},domProps:{value:e.selected.y},on:{input:function(t){t.target.composing||e.$set(e.selected,"y",t.target.value)}}}),e._v(" "),a("div",{staticClass:"wrap"},[a("input",{directives:[{name:"model",rawName:"v-model",value:e.selected.y,expression:"selected.y"}],staticClass:"input-range",attrs:{disabled:!e.present,type:"range",max:"20",min:"-20"},domProps:{value:e.selected.y},on:{__r:function(t){e.$set(e.selected,"y",t.target.value)}}})])]),e._v(" "),a("div",{staticClass:"preview-window"},[a("div",{staticClass:"preview-block",style:e.style})]),e._v(" "),a("div",{staticClass:"x-shift-control",attrs:{disabled:!e.present}},[a("input",{directives:[{name:"model",rawName:"v-model",value:e.selected.x,expression:"selected.x"}],staticClass:"input-number",attrs:{disabled:!e.present,type:"number"},domProps:{value:e.selected.x},on:{input:function(t){t.target.composing||e.$set(e.selected,"x",t.target.value)}}}),e._v(" "),a("div",{staticClass:"wrap"},[a("input",{directives:[{name:"model",rawName:"v-model",value:e.selected.x,expression:"selected.x"}],staticClass:"input-range",attrs:{disabled:!e.present,type:"range",max:"20",min:"-20"},domProps:{value:e.selected.x},on:{__r:function(t){e.$set(e.selected,"x",t.target.value)}}})])])]),e._v(" "),a("div",{staticClass:"shadow-tweak"},[a("div",{staticClass:"id-control style-control",attrs:{disabled:e.usingFallback}},[a("label",{staticClass:"select",attrs:{for:"shadow-switcher",disabled:!e.ready||e.usingFallback}},[a("select",{directives:[{name:"model",rawName:"v-model",value:e.selectedId,expression:"selectedId"}],staticClass:"shadow-switcher",attrs:{disabled:!e.ready||e.usingFallback,id:"shadow-switcher"},on:{change:function(t){var a=Array.prototype.filter.call(t.target.options,function(e){return e.selected}).map(function(e){var t="_value"in e?e._value:e.value;return t});e.selectedId=t.target.multiple?a:a[0]}}},e._l(e.cValue,function(t,i){return a("option",{domProps:{value:i}},[e._v("\n "+e._s(e.$t("settings.style.shadows.shadow_id",{value:i}))+"\n ")])}),0),e._v(" "),a("i",{staticClass:"icon-down-open"})]),e._v(" "),a("button",{staticClass:"btn btn-default",attrs:{disabled:!e.ready||!e.present},on:{click:e.del}},[a("i",{staticClass:"icon-cancel"})]),e._v(" "),a("button",{staticClass:"btn btn-default",attrs:{disabled:!e.moveUpValid},on:{click:e.moveUp}},[a("i",{staticClass:"icon-up-open"})]),e._v(" "),a("button",{staticClass:"btn btn-default",attrs:{disabled:!e.moveDnValid},on:{click:e.moveDn}},[a("i",{staticClass:"icon-down-open"})]),e._v(" "),a("button",{staticClass:"btn btn-default",attrs:{disabled:e.usingFallback},on:{click:e.add}},[a("i",{staticClass:"icon-plus"})])]),e._v(" "),a("div",{staticClass:"inset-control style-control",attrs:{disabled:!e.present}},[a("label",{staticClass:"label",attrs:{for:"inset"}},[e._v("\n "+e._s(e.$t("settings.style.shadows.inset"))+"\n ")]),e._v(" "),a("input",{directives:[{name:"model",rawName:"v-model",value:e.selected.inset,expression:"selected.inset"}],staticClass:"input-inset",attrs:{disabled:!e.present,name:"inset",id:"inset",type:"checkbox"},domProps:{checked:Array.isArray(e.selected.inset)?e._i(e.selected.inset,null)>-1:e.selected.inset},on:{change:function(t){var a=e.selected.inset,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&e.$set(e.selected,"inset",a.concat([o])):s>-1&&e.$set(e.selected,"inset",a.slice(0,s).concat(a.slice(s+1)))}else e.$set(e.selected,"inset",n)}}}),e._v(" "),a("label",{staticClass:"checkbox-label",attrs:{for:"inset"}})]),e._v(" "),a("div",{staticClass:"blur-control style-control",attrs:{disabled:!e.present}},[a("label",{staticClass:"label",attrs:{for:"spread"}},[e._v("\n "+e._s(e.$t("settings.style.shadows.blur"))+"\n ")]),e._v(" "),a("input",{ +directives:[{name:"model",rawName:"v-model",value:e.selected.blur,expression:"selected.blur"}],staticClass:"input-range",attrs:{disabled:!e.present,name:"blur",id:"blur",type:"range",max:"20",min:"0"},domProps:{value:e.selected.blur},on:{__r:function(t){e.$set(e.selected,"blur",t.target.value)}}}),e._v(" "),a("input",{directives:[{name:"model",rawName:"v-model",value:e.selected.blur,expression:"selected.blur"}],staticClass:"input-number",attrs:{disabled:!e.present,type:"number",min:"0"},domProps:{value:e.selected.blur},on:{input:function(t){t.target.composing||e.$set(e.selected,"blur",t.target.value)}}})]),e._v(" "),a("div",{staticClass:"spread-control style-control",attrs:{disabled:!e.present}},[a("label",{staticClass:"label",attrs:{for:"spread"}},[e._v("\n "+e._s(e.$t("settings.style.shadows.spread"))+"\n ")]),e._v(" "),a("input",{directives:[{name:"model",rawName:"v-model",value:e.selected.spread,expression:"selected.spread"}],staticClass:"input-range",attrs:{disabled:!e.present,name:"spread",id:"spread",type:"range",max:"20",min:"-20"},domProps:{value:e.selected.spread},on:{__r:function(t){e.$set(e.selected,"spread",t.target.value)}}}),e._v(" "),a("input",{directives:[{name:"model",rawName:"v-model",value:e.selected.spread,expression:"selected.spread"}],staticClass:"input-number",attrs:{disabled:!e.present,type:"number"},domProps:{value:e.selected.spread},on:{input:function(t){t.target.composing||e.$set(e.selected,"spread",t.target.value)}}})]),e._v(" "),a("ColorInput",{attrs:{disabled:!e.present,label:e.$t("settings.style.common.color"),name:"shadow"},model:{value:e.selected.color,callback:function(t){e.$set(e.selected,"color",t)},expression:"selected.color"}}),e._v(" "),a("OpacityInput",{attrs:{disabled:!e.present},model:{value:e.selected.alpha,callback:function(t){e.$set(e.selected,"alpha",t)},expression:"selected.alpha"}}),e._v(" "),a("p",[e._v("\n "+e._s(e.$t("settings.style.shadows.hint"))+"\n ")])],1)])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("conversation",{attrs:{collapsable:!1,statusoid:e.statusoid}})},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"still-image",class:{animated:e.animated}},[e.animated?a("canvas",{ref:"canvas"}):e._e(),e._v(" "),a("img",{ref:"src",attrs:{src:e.src,referrerpolicy:e.referrerpolicy},on:{load:e.onLoad,error:e.onError}})])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",[a("a",{staticClass:"link-preview-card",attrs:{href:e.card.url,target:"_blank",rel:"noopener"}},[e.useImage?a("div",{staticClass:"card-image",class:{"small-image":"small"===e.size}},[a("img",{attrs:{src:e.card.image}})]):e._e(),e._v(" "),a("div",{staticClass:"card-content"},[a("span",{staticClass:"card-host faint"},[e._v(e._s(e.card.provider_name))]),e._v(" "),a("h4",{staticClass:"card-title"},[e._v(e._s(e.card.title))]),e._v(" "),e.useDescription?a("p",{staticClass:"card-description"},[e._v(e._s(e.card.description))]):e._e()])])])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"color-control style-control",class:{disabled:!e.present||e.disabled}},[a("label",{staticClass:"label",attrs:{for:e.name}},[e._v("\n "+e._s(e.label)+"\n ")]),e._v(" "),"undefined"!=typeof e.fallback?a("input",{staticClass:"opt exlcude-disabled",attrs:{id:e.name+"-o",type:"checkbox"},domProps:{checked:e.present},on:{input:function(t){e.$emit("input","undefined"==typeof e.value?e.fallback:void 0)}}}):e._e(),e._v(" "),"undefined"!=typeof e.fallback?a("label",{staticClass:"opt-l",attrs:{for:e.name+"-o"}}):e._e(),e._v(" "),a("input",{staticClass:"color-input",attrs:{id:e.name,type:"color",disabled:!e.present||e.disabled},domProps:{value:e.value||e.fallback},on:{input:function(t){e.$emit("input",t.target.value)}}}),e._v(" "),a("input",{staticClass:"text-input",attrs:{id:e.name+"-t",type:"text",disabled:!e.present||e.disabled},domProps:{value:e.value||e.fallback},on:{input:function(t){e.$emit("input",t.target.value)}}})])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return e.hideStatus?e._e():a("div",{staticClass:"status-el",class:[{"status-el_focused":e.isFocused},{"status-conversation":e.inlineExpanded}]},[e.muted&&!e.isPreview?[a("div",{staticClass:"media status container muted"},[a("small",[a("router-link",{attrs:{to:e.userProfileLink}},[e._v("\n "+e._s(e.status.user.screen_name)+"\n ")])],1),e._v(" "),a("small",{staticClass:"muteWords"},[e._v(e._s(e.muteWordHits.join(", ")))]),e._v(" "),a("a",{staticClass:"unmute",attrs:{href:"#"},on:{click:function(t){return t.preventDefault(),e.toggleMute(t)}}},[a("i",{staticClass:"button-icon icon-eye-off"})])])]:[e.retweet&&!e.noHeading?a("div",{staticClass:"media container retweet-info",class:[e.repeaterClass,{highlighted:e.repeaterStyle}],style:[e.repeaterStyle]},[e.retweet?a("UserAvatar",{staticClass:"media-left",attrs:{betterShadow:e.betterShadow,src:e.statusoid.user.profile_image_url_original}}):e._e(),e._v(" "),a("div",{staticClass:"media-body faint"},[a("span",{staticClass:"user-name"},[e.retweeterHtml?a("router-link",{attrs:{to:e.retweeterProfileLink},domProps:{innerHTML:e._s(e.retweeterHtml)}}):a("router-link",{attrs:{to:e.retweeterProfileLink}},[e._v(e._s(e.retweeter))])],1),e._v(" "),a("i",{staticClass:"fa icon-retweet retweeted",attrs:{title:e.$t("tool_tip.repeat")}}),e._v("\n "+e._s(e.$t("timeline.repeated"))+"\n ")])],1):e._e(),e._v(" "),a("div",{staticClass:"media status",class:[e.userClass,{highlighted:e.userStyle,"is-retweet":e.retweet}],style:[e.userStyle]},[e.noHeading?e._e():a("div",{staticClass:"media-left"},[a("router-link",{attrs:{to:e.userProfileLink},nativeOn:{"!click":function(t){return t.stopPropagation(),t.preventDefault(),e.toggleUserExpanded(t)}}},[a("UserAvatar",{attrs:{compact:e.compact,betterShadow:e.betterShadow,src:e.status.user.profile_image_url_original}})],1)],1),e._v(" "),a("div",{staticClass:"status-body"},[e.userExpanded?a("UserCard",{staticClass:"status-usercard",attrs:{user:e.status.user,rounded:!0,bordered:!0}}):e._e(),e._v(" "),e.noHeading?e._e():a("div",{staticClass:"media-heading"},[a("div",{staticClass:"heading-name-row"},[a("div",{staticClass:"name-and-account-name"},[e.status.user.name_html?a("h4",{staticClass:"user-name",domProps:{innerHTML:e._s(e.status.user.name_html)}}):a("h4",{staticClass:"user-name"},[e._v(e._s(e.status.user.name))]),e._v(" "),a("router-link",{staticClass:"account-name",attrs:{to:e.userProfileLink}},[e._v("\n "+e._s(e.status.user.screen_name)+"\n ")])],1),e._v(" "),a("span",{staticClass:"heading-right"},[a("router-link",{staticClass:"timeago faint-link",attrs:{to:{name:"conversation",params:{id:e.status.id}}}},[a("timeago",{attrs:{since:e.status.created_at,"auto-update":60}})],1),e._v(" "),e.status.visibility?a("div",{staticClass:"button-icon visibility-icon"},[a("i",{class:e.visibilityIcon(e.status.visibility),attrs:{title:e._f("capitalize")(e.status.visibility)}})]):e._e(),e._v(" "),e.status.is_local||e.isPreview?e._e():a("a",{staticClass:"source_url",attrs:{href:e.status.external_url,target:"_blank",title:"Source"}},[a("i",{staticClass:"button-icon icon-link-ext-alt"})]),e._v(" "),e.expandable&&!e.isPreview?[a("a",{attrs:{href:"#",title:"Expand"},on:{click:function(t){return t.preventDefault(),e.toggleExpanded(t)}}},[a("i",{staticClass:"button-icon icon-plus-squared"})])]:e._e(),e._v(" "),e.unmuted?a("a",{attrs:{href:"#"},on:{click:function(t){return t.preventDefault(),e.toggleMute(t)}}},[a("i",{staticClass:"button-icon icon-eye-off"})]):e._e()],2)]),e._v(" "),a("div",{staticClass:"heading-reply-row"},[e.isReply?a("div",{staticClass:"reply-to-and-accountname"},[a("a",{staticClass:"reply-to",attrs:{href:"#","aria-label":e.$t("tool_tip.reply")},on:{click:function(t){t.preventDefault(),e.gotoOriginal(e.status.in_reply_to_status_id)},mouseenter:function(t){t.preventDefault(),t.stopPropagation(),e.replyEnter(e.status.in_reply_to_status_id,t)},mouseleave:function(t){t.preventDefault(),t.stopPropagation(),e.replyLeave()}}},[e.isPreview?e._e():a("i",{staticClass:"button-icon icon-reply"}),e._v(" "),a("span",{staticClass:"faint-link reply-to-text"},[e._v(e._s(e.$t("status.reply_to")))])]),e._v(" "),a("router-link",{attrs:{to:e.replyProfileLink}},[e._v("\n "+e._s(e.replyToName)+"\n ")]),e._v(" "),e.replies&&e.replies.length?a("span",{staticClass:"faint replies-separator"},[e._v("\n -\n ")]):e._e()],1):e._e(),e._v(" "),e.inConversation&&!e.isPreview?a("div",{staticClass:"replies"},[e.replies&&e.replies.length?a("span",{staticClass:"faint"},[e._v(e._s(e.$t("status.replies_list")))]):e._e(),e._v(" "),e._l(e.replies,function(t){return e.replies?a("span",{staticClass:"reply-link faint"},[a("a",{attrs:{href:"#"},on:{click:function(a){a.preventDefault(),e.gotoOriginal(t.id)},mouseenter:function(a){e.replyEnter(t.id,a)},mouseout:function(t){e.replyLeave()}}},[e._v(e._s(t.name))])]):e._e()})],2):e._e()])]),e._v(" "),e.showPreview?a("div",{staticClass:"status-preview-container"},[e.preview?a("status",{staticClass:"status-preview",attrs:{isPreview:!0,statusoid:e.preview,compact:!0}}):a("div",{staticClass:"status-preview status-preview-loading"},[a("i",{staticClass:"icon-spin4 animate-spin"})])],1):e._e(),e._v(" "),e.longSubject?a("div",{staticClass:"status-content-wrapper",class:{"tall-status":!e.showingLongSubject}},[e.showingLongSubject?e._e():a("a",{staticClass:"tall-status-hider",class:{"tall-status-hider_focused":e.isFocused},attrs:{href:"#"},on:{click:function(t){t.preventDefault(),e.showingLongSubject=!0}}},[e._v("Show more")]),e._v(" "),a("div",{staticClass:"status-content media-body",domProps:{innerHTML:e._s(e.status.statusnet_html)},on:{click:function(t){return t.preventDefault(),e.linkClicked(t)}}}),e._v(" "),e.showingLongSubject?a("a",{staticClass:"status-unhider",attrs:{href:"#"},on:{click:function(t){t.preventDefault(),e.showingLongSubject=!1}}},[e._v("Show less")]):e._e()]):a("div",{staticClass:"status-content-wrapper",class:{"tall-status":e.hideTallStatus}},[e.hideTallStatus?a("a",{staticClass:"tall-status-hider",class:{"tall-status-hider_focused":e.isFocused},attrs:{href:"#"},on:{click:function(t){return t.preventDefault(),e.toggleShowMore(t)}}},[e._v("Show more")]):e._e(),e._v(" "),e.hideSubjectStatus?a("div",{staticClass:"status-content media-body",domProps:{innerHTML:e._s(e.status.summary_html)},on:{click:function(t){return t.preventDefault(),e.linkClicked(t)}}}):a("div",{staticClass:"status-content media-body",domProps:{innerHTML:e._s(e.status.statusnet_html)},on:{click:function(t){return t.preventDefault(),e.linkClicked(t)}}}),e._v(" "),e.hideSubjectStatus?a("a",{staticClass:"cw-status-hider",attrs:{href:"#"},on:{click:function(t){return t.preventDefault(),e.toggleShowMore(t)}}},[e._v("Show more")]):e._e(),e._v(" "),e.showingMore?a("a",{staticClass:"status-unhider",attrs:{href:"#"},on:{click:function(t){return t.preventDefault(),e.toggleShowMore(t)}}},[e._v("Show less")]):e._e()]),e._v(" "),!e.status.attachments||e.hideSubjectStatus&&!e.showingLongSubject?e._e():a("div",{staticClass:"attachments media-body"},[e._l(e.nonGalleryAttachments,function(t){return a("attachment",{key:t.id,staticClass:"non-gallery",attrs:{size:e.attachmentSize,nsfw:e.nsfwClickthrough,attachment:t,allowPlay:!0,setMedia:e.setMedia()}})}),e._v(" "),e.galleryAttachments.length>0?a("gallery",{attrs:{nsfw:e.nsfwClickthrough,attachments:e.galleryAttachments,setMedia:e.setMedia()}}):e._e()],2),e._v(" "),!e.status.card||e.hideSubjectStatus||e.noHeading?e._e():a("div",{staticClass:"link-preview media-body"},[a("link-preview",{attrs:{card:e.status.card,size:e.attachmentSize,nsfw:e.nsfwClickthrough}})],1),e._v(" "),e.noHeading||e.isPreview?e._e():a("div",{staticClass:"status-actions media-body"},[e.loggedIn?a("div",[a("a",{attrs:{href:"#",title:e.$t("tool_tip.reply")},on:{click:function(t){return t.preventDefault(),e.toggleReplying(t)}}},[a("i",{staticClass:"button-icon icon-reply",class:{"icon-reply-active":e.replying}})])]):e._e(),e._v(" "),a("retweet-button",{attrs:{visibility:e.status.visibility,loggedIn:e.loggedIn,status:e.status}}),e._v(" "),a("favorite-button",{attrs:{loggedIn:e.loggedIn,status:e.status}}),e._v(" "),a("delete-button",{attrs:{status:e.status}})],1)],1)]),e._v(" "),e.replying?a("div",{staticClass:"container"},[a("div",{staticClass:"reply-left"}),e._v(" "),a("post-status-form",{staticClass:"reply-body",attrs:{"reply-to":e.status.id,attentions:e.status.attentions,repliedUser:e.status.user,"copy-message-scope":e.status.visibility,subject:e.replySubject},on:{posted:e.toggleReplying}})],1):e._e()]],2)},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return e.show?a("div",{staticClass:"instance-specific-panel"},[a("div",{staticClass:"panel panel-default"},[a("div",{staticClass:"panel-body"},[a("div",{domProps:{innerHTML:e._s(e.instanceSpecificPanelContent)}})])])]):e._e()},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"image-cropper"},[e.dataUrl?a("div",[a("div",{staticClass:"image-cropper-image-container"},[a("img",{ref:"img",attrs:{src:e.dataUrl,alt:""},on:{load:function(t){return t.stopPropagation(),e.createCropper(t)}}})]),e._v(" "),a("div",{staticClass:"image-cropper-buttons-wrapper"},[a("button",{staticClass:"btn",attrs:{type:"button",disabled:e.submitting},domProps:{textContent:e._s(e.saveText)},on:{click:e.submit}}),e._v(" "),a("button",{staticClass:"btn",attrs:{type:"button",disabled:e.submitting},domProps:{textContent:e._s(e.cancelText)},on:{click:e.destroy}}),e._v(" "),e.submitting?a("i",{staticClass:"icon-spin4 animate-spin"}):e._e()]),e._v(" "),e.submitError?a("div",{staticClass:"alert error"},[e._v("\n "+e._s(e.submitErrorMsg)+"\n "),a("i",{staticClass:"button-icon icon-cancel",on:{click:e.clearError}})]):e._e()]):e._e(),e._v(" "),a("input",{ref:"input",staticClass:"image-cropper-img-input",attrs:{type:"file",accept:e.mimes}})])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("Timeline",{attrs:{title:e.$t("nav.timeline"),timeline:e.timeline,"timeline-name":"friends"}})},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"settings panel panel-default"},[a("div",{staticClass:"panel-heading"},[a("div",{staticClass:"title"},[e._v("\n "+e._s(e.$t("settings.user_settings"))+"\n ")]),e._v(" "),a("transition",{attrs:{name:"fade"}},[e.currentSaveStateNotice?[e.currentSaveStateNotice.error?a("div",{staticClass:"alert error",on:{click:function(e){e.preventDefault()}}},[e._v("\n "+e._s(e.$t("settings.saving_err"))+"\n ")]):e._e(),e._v(" "),e.currentSaveStateNotice.error?e._e():a("div",{staticClass:"alert transparent",on:{click:function(e){e.preventDefault()}}},[e._v("\n "+e._s(e.$t("settings.saving_ok"))+"\n ")])]:e._e()],2)],1),e._v(" "),a("div",{staticClass:"panel-body profile-edit"},[a("tab-switcher",[a("div",{attrs:{label:e.$t("settings.profile_tab")}},[a("div",{staticClass:"setting-item"},[a("h2",[e._v(e._s(e.$t("settings.name_bio")))]),e._v(" "),a("p",[e._v(e._s(e.$t("settings.name")))]),e._v(" "),a("input",{directives:[{name:"model",rawName:"v-model",value:e.newName,expression:"newName"}],staticClass:"name-changer",attrs:{id:"username"},domProps:{value:e.newName},on:{input:function(t){t.target.composing||(e.newName=t.target.value)}}}),e._v(" "),a("p",[e._v(e._s(e.$t("settings.bio")))]),e._v(" "),a("textarea",{directives:[{name:"model",rawName:"v-model",value:e.newBio,expression:"newBio"}],staticClass:"bio",domProps:{value:e.newBio},on:{input:function(t){t.target.composing||(e.newBio=t.target.value)}}}),e._v(" "),a("p",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.newLocked,expression:"newLocked"}],attrs:{type:"checkbox",id:"account-locked"},domProps:{checked:Array.isArray(e.newLocked)?e._i(e.newLocked,null)>-1:e.newLocked},on:{change:function(t){var a=e.newLocked,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.newLocked=a.concat([o])):s>-1&&(e.newLocked=a.slice(0,s).concat(a.slice(s+1)))}else e.newLocked=n}}}),e._v(" "),a("label",{attrs:{for:"account-locked"}},[e._v(e._s(e.$t("settings.lock_account_description")))])]),e._v(" "),e.scopeOptionsEnabled?a("div",[a("label",{attrs:{for:"default-vis"}},[e._v(e._s(e.$t("settings.default_vis")))]),e._v(" "),a("div",{staticClass:"visibility-tray",attrs:{id:"default-vis"}},[a("i",{staticClass:"icon-mail-alt",class:e.vis.direct,attrs:{title:e.$t("post_status.scope.direct")},on:{click:function(t){e.changeVis("direct")}}}),e._v(" "),a("i",{staticClass:"icon-lock",class:e.vis.private,attrs:{title:e.$t("post_status.scope.private")},on:{click:function(t){e.changeVis("private")}}}),e._v(" "),a("i",{staticClass:"icon-lock-open-alt",class:e.vis.unlisted,attrs:{title:e.$t("post_status.scope.unlisted")},on:{click:function(t){e.changeVis("unlisted")}}}),e._v(" "),a("i",{staticClass:"icon-globe",class:e.vis.public,attrs:{title:e.$t("post_status.scope.public")},on:{click:function(t){e.changeVis("public")}}})])]):e._e(),e._v(" "),a("p",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.newNoRichText,expression:"newNoRichText"}],attrs:{type:"checkbox",id:"account-no-rich-text"},domProps:{checked:Array.isArray(e.newNoRichText)?e._i(e.newNoRichText,null)>-1:e.newNoRichText},on:{change:function(t){var a=e.newNoRichText,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.newNoRichText=a.concat([o])):s>-1&&(e.newNoRichText=a.slice(0,s).concat(a.slice(s+1)))}else e.newNoRichText=n}}}),e._v(" "),a("label",{attrs:{for:"account-no-rich-text"}},[e._v(e._s(e.$t("settings.no_rich_text_description")))])]),e._v(" "),a("p",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.hideFollows,expression:"hideFollows"}],attrs:{type:"checkbox",id:"account-hide-follows"},domProps:{checked:Array.isArray(e.hideFollows)?e._i(e.hideFollows,null)>-1:e.hideFollows},on:{change:function(t){var a=e.hideFollows,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.hideFollows=a.concat([o])):s>-1&&(e.hideFollows=a.slice(0,s).concat(a.slice(s+1)))}else e.hideFollows=n}}}),e._v(" "),a("label",{attrs:{for:"account-hide-follows"}},[e._v(e._s(e.$t("settings.hide_follows_description")))])]),e._v(" "),a("p",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.hideFollowers,expression:"hideFollowers"}],attrs:{type:"checkbox",id:"account-hide-followers"},domProps:{checked:Array.isArray(e.hideFollowers)?e._i(e.hideFollowers,null)>-1:e.hideFollowers},on:{change:function(t){var a=e.hideFollowers,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.hideFollowers=a.concat([o])):s>-1&&(e.hideFollowers=a.slice(0,s).concat(a.slice(s+1)))}else e.hideFollowers=n}}}),e._v(" "),a("label",{attrs:{for:"account-hide-followers"}},[e._v(e._s(e.$t("settings.hide_followers_description")))])]),e._v(" "),a("p",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.showRole,expression:"showRole"}],attrs:{type:"checkbox",id:"account-show-role"},domProps:{checked:Array.isArray(e.showRole)?e._i(e.showRole,null)>-1:e.showRole},on:{change:function(t){var a=e.showRole,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.showRole=a.concat([o])):s>-1&&(e.showRole=a.slice(0,s).concat(a.slice(s+1)))}else e.showRole=n}}}),e._v(" "),"admin"===e.role?a("label",{attrs:{for:"account-show-role"}},[e._v(e._s(e.$t("settings.show_admin_badge")))]):e._e(),e._v(" "),"moderator"===e.role?a("label",{attrs:{for:"account-show-role"}},[e._v(e._s(e.$t("settings.show_moderator_badge")))]):e._e()]),e._v(" "),a("button",{staticClass:"btn btn-default",attrs:{disabled:e.newName&&0===e.newName.length},on:{click:e.updateProfile}},[e._v(e._s(e.$t("general.submit")))])]),e._v(" "),a("div",{staticClass:"setting-item"},[a("h2",[e._v(e._s(e.$t("settings.avatar")))]),e._v(" "),a("p",{staticClass:"visibility-notice"},[e._v(e._s(e.$t("settings.avatar_size_instruction")))]),e._v(" "),a("p",[e._v(e._s(e.$t("settings.current_avatar")))]),e._v(" "),a("img",{staticClass:"current-avatar",attrs:{src:e.user.profile_image_url_original}}),e._v(" "),a("p",[e._v(e._s(e.$t("settings.set_new_avatar")))]),e._v(" "),a("button",{directives:[{name:"show",rawName:"v-show",value:e.pickAvatarBtnVisible,expression:"pickAvatarBtnVisible"}],staticClass:"btn",attrs:{type:"button",id:"pick-avatar"}},[e._v(e._s(e.$t("settings.upload_a_photo")))]),e._v(" "),a("image-cropper",{attrs:{trigger:"#pick-avatar",submitHandler:e.submitAvatar},on:{open:function(t){e.pickAvatarBtnVisible=!1},close:function(t){e.pickAvatarBtnVisible=!0}}})],1),e._v(" "),a("div",{staticClass:"setting-item"},[a("h2",[e._v(e._s(e.$t("settings.profile_banner")))]),e._v(" "),a("p",[e._v(e._s(e.$t("settings.current_profile_banner")))]),e._v(" "),a("img",{staticClass:"banner",attrs:{src:e.user.cover_photo}}),e._v(" "),a("p",[e._v(e._s(e.$t("settings.set_new_profile_banner")))]),e._v(" "),e.bannerPreview?a("img",{staticClass:"banner",attrs:{src:e.bannerPreview}}):e._e(),e._v(" "),a("div",[a("input",{attrs:{type:"file"},on:{change:function(t){e.uploadFile("banner",t)}}})]),e._v(" "),e.bannerUploading?a("i",{staticClass:" icon-spin4 animate-spin uploading"}):e.bannerPreview?a("button",{staticClass:"btn btn-default",on:{click:e.submitBanner}},[e._v(e._s(e.$t("general.submit")))]):e._e(),e._v(" "),e.bannerUploadError?a("div",{staticClass:"alert error"},[e._v("\n Error: "+e._s(e.bannerUploadError)+"\n "),a("i",{staticClass:"button-icon icon-cancel",on:{click:function(t){e.clearUploadError("banner")}}})]):e._e()]),e._v(" "),a("div",{staticClass:"setting-item"},[a("h2",[e._v(e._s(e.$t("settings.profile_background")))]),e._v(" "),a("p",[e._v(e._s(e.$t("settings.set_new_profile_background")))]),e._v(" "),e.backgroundPreview?a("img",{staticClass:"bg",attrs:{src:e.backgroundPreview}}):e._e(),e._v(" "),a("div",[a("input",{attrs:{type:"file"},on:{change:function(t){e.uploadFile("background",t)}}})]),e._v(" "),e.backgroundUploading?a("i",{staticClass:" icon-spin4 animate-spin uploading"}):e.backgroundPreview?a("button",{staticClass:"btn btn-default",on:{click:e.submitBg}},[e._v(e._s(e.$t("general.submit")))]):e._e(),e._v(" "),e.backgroundUploadError?a("div",{staticClass:"alert error"},[e._v("\n Error: "+e._s(e.backgroundUploadError)+"\n "),a("i",{staticClass:"button-icon icon-cancel",on:{click:function(t){e.clearUploadError("background")}}})]):e._e()])]),e._v(" "),a("div",{attrs:{label:e.$t("settings.security_tab")}},[a("div",{staticClass:"setting-item"},[a("h2",[e._v(e._s(e.$t("settings.change_password")))]),e._v(" "),a("div",[a("p",[e._v(e._s(e.$t("settings.current_password")))]),e._v(" "),a("input",{directives:[{name:"model",rawName:"v-model",value:e.changePasswordInputs[0],expression:"changePasswordInputs[0]"}],attrs:{type:"password"},domProps:{value:e.changePasswordInputs[0]},on:{input:function(t){t.target.composing||e.$set(e.changePasswordInputs,0,t.target.value)}}})]),e._v(" "),a("div",[a("p",[e._v(e._s(e.$t("settings.new_password")))]),e._v(" "),a("input",{directives:[{name:"model",rawName:"v-model",value:e.changePasswordInputs[1],expression:"changePasswordInputs[1]"}],attrs:{type:"password"},domProps:{value:e.changePasswordInputs[1]},on:{input:function(t){t.target.composing||e.$set(e.changePasswordInputs,1,t.target.value)}}})]),e._v(" "),a("div",[a("p",[e._v(e._s(e.$t("settings.confirm_new_password")))]),e._v(" "),a("input",{directives:[{name:"model",rawName:"v-model",value:e.changePasswordInputs[2],expression:"changePasswordInputs[2]"}],attrs:{type:"password"},domProps:{value:e.changePasswordInputs[2]},on:{input:function(t){t.target.composing||e.$set(e.changePasswordInputs,2,t.target.value)}}})]),e._v(" "),a("button",{staticClass:"btn btn-default",on:{click:e.changePassword}},[e._v(e._s(e.$t("general.submit")))]),e._v(" "),e.changedPassword?a("p",[e._v(e._s(e.$t("settings.changed_password")))]):e.changePasswordError!==!1?a("p",[e._v(e._s(e.$t("settings.change_password_error")))]):e._e(),e._v(" "),e.changePasswordError?a("p",[e._v(e._s(e.changePasswordError))]):e._e()]),e._v(" "),a("div",{staticClass:"setting-item"},[a("h2",[e._v(e._s(e.$t("settings.oauth_tokens")))]),e._v(" "),a("table",{staticClass:"oauth-tokens"},[a("thead",[a("tr",[a("th",[e._v(e._s(e.$t("settings.app_name")))]),e._v(" "),a("th",[e._v(e._s(e.$t("settings.valid_until")))]),e._v(" "),a("th")])]),e._v(" "),a("tbody",e._l(e.oauthTokens,function(t){return a("tr",{key:t.id},[a("td",[e._v(e._s(t.appName))]),e._v(" "),a("td",[e._v(e._s(t.validUntil))]),e._v(" "),a("td",{staticClass:"actions"},[a("button",{staticClass:"btn btn-default",on:{click:function(a){e.revokeToken(t.id)}}},[e._v("\n "+e._s(e.$t("settings.revoke_token"))+"\n ")])])])}),0)])]),e._v(" "),a("div",{staticClass:"setting-item"},[a("h2",[e._v(e._s(e.$t("settings.delete_account")))]),e._v(" "),e.deletingAccount?e._e():a("p",[e._v(e._s(e.$t("settings.delete_account_description")))]),e._v(" "),e.deletingAccount?a("div",[a("p",[e._v(e._s(e.$t("settings.delete_account_instructions")))]),e._v(" "),a("p",[e._v(e._s(e.$t("login.password")))]),e._v(" "),a("input",{directives:[{name:"model",rawName:"v-model",value:e.deleteAccountConfirmPasswordInput,expression:"deleteAccountConfirmPasswordInput"}],attrs:{type:"password"},domProps:{value:e.deleteAccountConfirmPasswordInput},on:{input:function(t){t.target.composing||(e.deleteAccountConfirmPasswordInput=t.target.value)}}}),e._v(" "),a("button",{staticClass:"btn btn-default",on:{click:e.deleteAccount}},[e._v(e._s(e.$t("settings.delete_account")))])]):e._e(),e._v(" "),e.deleteAccountError!==!1?a("p",[e._v(e._s(e.$t("settings.delete_account_error")))]):e._e(),e._v(" "),e.deleteAccountError?a("p",[e._v(e._s(e.deleteAccountError))]):e._e(),e._v(" "),e.deletingAccount?e._e():a("button",{staticClass:"btn btn-default",on:{click:e.confirmDelete}},[e._v(e._s(e.$t("general.submit")))])])]),e._v(" "),e.pleromaBackend?a("div",{attrs:{label:e.$t("settings.data_import_export_tab")}},[a("div",{staticClass:"setting-item"},[a("h2",[e._v(e._s(e.$t("settings.follow_import")))]),e._v(" "),a("p",[e._v(e._s(e.$t("settings.import_followers_from_a_csv_file")))]),e._v(" "),a("form",[a("input",{ref:"followlist",attrs:{type:"file"},on:{change:e.followListChange}})]),e._v(" "),e.followListUploading?a("i",{staticClass:" icon-spin4 animate-spin uploading"}):a("button",{staticClass:"btn btn-default",on:{click:e.importFollows}},[e._v(e._s(e.$t("general.submit")))]),e._v(" "),e.followsImported?a("div",[a("i",{staticClass:"icon-cross",on:{click:e.dismissImported}}),e._v(" "),a("p",[e._v(e._s(e.$t("settings.follows_imported")))])]):e.followImportError?a("div",[a("i",{staticClass:"icon-cross",on:{click:e.dismissImported}}),e._v(" "),a("p",[e._v(e._s(e.$t("settings.follow_import_error")))])]):e._e()]),e._v(" "),e.enableFollowsExport?a("div",{staticClass:"setting-item"},[a("h2",[e._v(e._s(e.$t("settings.follow_export")))]),e._v(" "),a("button",{staticClass:"btn btn-default",on:{click:e.exportFollows}},[e._v(e._s(e.$t("settings.follow_export_button")))])]):a("div",{staticClass:"setting-item"},[a("h2",[e._v(e._s(e.$t("settings.follow_export_processing")))])])]):e._e(),e._v(" "),a("div",{attrs:{label:e.$t("settings.blocks_tab")}},[a("block-list",{attrs:{refresh:!0}},[a("template",{slot:"empty"},[e._v(e._s(e.$t("settings.no_blocks")))])],2)],1)])],1)])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return e.canDelete?a("div",[a("a",{attrs:{href:"#"},on:{click:function(t){t.preventDefault(),e.deleteStatus()}}},[a("i",{staticClass:"button-icon icon-cancel delete-status"})])]):e._e()},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"style-switcher"},[a("div",{staticClass:"presets-container"},[a("div",{staticClass:"save-load"},[a("export-import",{attrs:{exportObject:e.exportedTheme,exportLabel:e.$t("settings.export_theme"),importLabel:e.$t("settings.import_theme"),importFailedText:e.$t("settings.invalid_theme_imported"),onImport:e.onImport,validator:e.importValidator}},[a("template",{slot:"before"},[a("div",{staticClass:"presets"},[e._v("\n "+e._s(e.$t("settings.presets"))+"\n "),a("label",{staticClass:"select",attrs:{for:"preset-switcher"}},[a("select",{directives:[{name:"model",rawName:"v-model",value:e.selected,expression:"selected"}],staticClass:"preset-switcher",attrs:{id:"preset-switcher"},on:{change:function(t){var a=Array.prototype.filter.call(t.target.options,function(e){return e.selected}).map(function(e){var t="_value"in e?e._value:e.value;return t});e.selected=t.target.multiple?a:a[0]}}},e._l(e.availableStyles,function(t){return a("option",{style:{backgroundColor:t[1]||t.theme.colors.bg,color:t[3]||t.theme.colors.text},domProps:{value:t}},[e._v("\n "+e._s(t[0]||t.name)+"\n ")])}),0),e._v(" "),a("i",{staticClass:"icon-down-open"})])])])],2)],1),e._v(" "),a("div",{staticClass:"save-load-options"},[a("span",{staticClass:"keep-option"},[a("input",{directives:[{name:"model",rawName:"v-model",value:e.keepColor,expression:"keepColor"}],attrs:{id:"keep-color",type:"checkbox"},domProps:{checked:Array.isArray(e.keepColor)?e._i(e.keepColor,null)>-1:e.keepColor},on:{change:function(t){var a=e.keepColor,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.keepColor=a.concat([o])):s>-1&&(e.keepColor=a.slice(0,s).concat(a.slice(s+1)))}else e.keepColor=n}}}),e._v(" "),a("label",{attrs:{for:"keep-color"}},[e._v(e._s(e.$t("settings.style.switcher.keep_color")))])]),e._v(" "),a("span",{staticClass:"keep-option"},[a("input",{directives:[{name:"model",rawName:"v-model",value:e.keepShadows,expression:"keepShadows"}],attrs:{id:"keep-shadows",type:"checkbox"},domProps:{checked:Array.isArray(e.keepShadows)?e._i(e.keepShadows,null)>-1:e.keepShadows},on:{change:function(t){var a=e.keepShadows,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.keepShadows=a.concat([o])):s>-1&&(e.keepShadows=a.slice(0,s).concat(a.slice(s+1)))}else e.keepShadows=n}}}),e._v(" "),a("label",{attrs:{for:"keep-shadows"}},[e._v(e._s(e.$t("settings.style.switcher.keep_shadows")))])]),e._v(" "),a("span",{staticClass:"keep-option"},[a("input",{directives:[{name:"model",rawName:"v-model",value:e.keepOpacity,expression:"keepOpacity"}],attrs:{id:"keep-opacity",type:"checkbox"},domProps:{checked:Array.isArray(e.keepOpacity)?e._i(e.keepOpacity,null)>-1:e.keepOpacity},on:{change:function(t){var a=e.keepOpacity,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.keepOpacity=a.concat([o])):s>-1&&(e.keepOpacity=a.slice(0,s).concat(a.slice(s+1)))}else e.keepOpacity=n}}}),e._v(" "),a("label",{attrs:{for:"keep-opacity"}},[e._v(e._s(e.$t("settings.style.switcher.keep_opacity")))])]),e._v(" "),a("span",{staticClass:"keep-option"},[a("input",{directives:[{name:"model",rawName:"v-model",value:e.keepRoundness,expression:"keepRoundness"}],attrs:{id:"keep-roundness",type:"checkbox"},domProps:{checked:Array.isArray(e.keepRoundness)?e._i(e.keepRoundness,null)>-1:e.keepRoundness},on:{change:function(t){var a=e.keepRoundness,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o); +i.checked?s<0&&(e.keepRoundness=a.concat([o])):s>-1&&(e.keepRoundness=a.slice(0,s).concat(a.slice(s+1)))}else e.keepRoundness=n}}}),e._v(" "),a("label",{attrs:{for:"keep-roundness"}},[e._v(e._s(e.$t("settings.style.switcher.keep_roundness")))])]),e._v(" "),a("span",{staticClass:"keep-option"},[a("input",{directives:[{name:"model",rawName:"v-model",value:e.keepFonts,expression:"keepFonts"}],attrs:{id:"keep-fonts",type:"checkbox"},domProps:{checked:Array.isArray(e.keepFonts)?e._i(e.keepFonts,null)>-1:e.keepFonts},on:{change:function(t){var a=e.keepFonts,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.keepFonts=a.concat([o])):s>-1&&(e.keepFonts=a.slice(0,s).concat(a.slice(s+1)))}else e.keepFonts=n}}}),e._v(" "),a("label",{attrs:{for:"keep-fonts"}},[e._v(e._s(e.$t("settings.style.switcher.keep_fonts")))])]),e._v(" "),a("p",[e._v(e._s(e.$t("settings.style.switcher.save_load_hint")))])])]),e._v(" "),a("div",{staticClass:"preview-container"},[a("preview",{style:e.previewRules})],1),e._v(" "),a("keep-alive",[a("tab-switcher",{key:"style-tweak"},[a("div",{staticClass:"color-container",attrs:{label:e.$t("settings.style.common_colors._tab_label")}},[a("div",{staticClass:"tab-header"},[a("p",[e._v(e._s(e.$t("settings.theme_help")))]),e._v(" "),a("button",{staticClass:"btn",on:{click:e.clearOpacity}},[e._v(e._s(e.$t("settings.style.switcher.clear_opacity")))]),e._v(" "),a("button",{staticClass:"btn",on:{click:e.clearV1}},[e._v(e._s(e.$t("settings.style.switcher.clear_all")))])]),e._v(" "),a("p",[e._v(e._s(e.$t("settings.theme_help_v2_1")))]),e._v(" "),a("h4",[e._v(e._s(e.$t("settings.style.common_colors.main")))]),e._v(" "),a("div",{staticClass:"color-item"},[a("ColorInput",{attrs:{name:"bgColor",label:e.$t("settings.background")},model:{value:e.bgColorLocal,callback:function(t){e.bgColorLocal=t},expression:"bgColorLocal"}}),e._v(" "),a("OpacityInput",{attrs:{name:"bgOpacity",fallback:e.previewTheme.opacity.bg||1},model:{value:e.bgOpacityLocal,callback:function(t){e.bgOpacityLocal=t},expression:"bgOpacityLocal"}}),e._v(" "),a("ColorInput",{attrs:{name:"textColor",label:e.$t("settings.text")},model:{value:e.textColorLocal,callback:function(t){e.textColorLocal=t},expression:"textColorLocal"}}),e._v(" "),a("ContrastRatio",{attrs:{contrast:e.previewContrast.bgText}}),e._v(" "),a("ColorInput",{attrs:{name:"linkColor",label:e.$t("settings.links")},model:{value:e.linkColorLocal,callback:function(t){e.linkColorLocal=t},expression:"linkColorLocal"}}),e._v(" "),a("ContrastRatio",{attrs:{contrast:e.previewContrast.bgLink}})],1),e._v(" "),a("div",{staticClass:"color-item"},[a("ColorInput",{attrs:{name:"fgColor",label:e.$t("settings.foreground")},model:{value:e.fgColorLocal,callback:function(t){e.fgColorLocal=t},expression:"fgColorLocal"}}),e._v(" "),a("ColorInput",{attrs:{name:"fgTextColor",label:e.$t("settings.text"),fallback:e.previewTheme.colors.fgText},model:{value:e.fgTextColorLocal,callback:function(t){e.fgTextColorLocal=t},expression:"fgTextColorLocal"}}),e._v(" "),a("ColorInput",{attrs:{name:"fgLinkColor",label:e.$t("settings.links"),fallback:e.previewTheme.colors.fgLink},model:{value:e.fgLinkColorLocal,callback:function(t){e.fgLinkColorLocal=t},expression:"fgLinkColorLocal"}}),e._v(" "),a("p",[e._v(e._s(e.$t("settings.style.common_colors.foreground_hint")))])],1),e._v(" "),a("h4",[e._v(e._s(e.$t("settings.style.common_colors.rgbo")))]),e._v(" "),a("div",{staticClass:"color-item"},[a("ColorInput",{attrs:{name:"cRedColor",label:e.$t("settings.cRed")},model:{value:e.cRedColorLocal,callback:function(t){e.cRedColorLocal=t},expression:"cRedColorLocal"}}),e._v(" "),a("ContrastRatio",{attrs:{contrast:e.previewContrast.bgRed}}),e._v(" "),a("ColorInput",{attrs:{name:"cBlueColor",label:e.$t("settings.cBlue")},model:{value:e.cBlueColorLocal,callback:function(t){e.cBlueColorLocal=t},expression:"cBlueColorLocal"}}),e._v(" "),a("ContrastRatio",{attrs:{contrast:e.previewContrast.bgBlue}})],1),e._v(" "),a("div",{staticClass:"color-item"},[a("ColorInput",{attrs:{name:"cGreenColor",label:e.$t("settings.cGreen")},model:{value:e.cGreenColorLocal,callback:function(t){e.cGreenColorLocal=t},expression:"cGreenColorLocal"}}),e._v(" "),a("ContrastRatio",{attrs:{contrast:e.previewContrast.bgGreen}}),e._v(" "),a("ColorInput",{attrs:{name:"cOrangeColor",label:e.$t("settings.cOrange")},model:{value:e.cOrangeColorLocal,callback:function(t){e.cOrangeColorLocal=t},expression:"cOrangeColorLocal"}}),e._v(" "),a("ContrastRatio",{attrs:{contrast:e.previewContrast.bgOrange}})],1),e._v(" "),a("p",[e._v(e._s(e.$t("settings.theme_help_v2_2")))])]),e._v(" "),a("div",{staticClass:"color-container",attrs:{label:e.$t("settings.style.advanced_colors._tab_label")}},[a("div",{staticClass:"tab-header"},[a("p",[e._v(e._s(e.$t("settings.theme_help")))]),e._v(" "),a("button",{staticClass:"btn",on:{click:e.clearOpacity}},[e._v(e._s(e.$t("settings.style.switcher.clear_opacity")))]),e._v(" "),a("button",{staticClass:"btn",on:{click:e.clearV1}},[e._v(e._s(e.$t("settings.style.switcher.clear_all")))])]),e._v(" "),a("div",{staticClass:"color-item"},[a("h4",[e._v(e._s(e.$t("settings.style.advanced_colors.alert")))]),e._v(" "),a("ColorInput",{attrs:{name:"alertError",label:e.$t("settings.style.advanced_colors.alert_error"),fallback:e.previewTheme.colors.alertError},model:{value:e.alertErrorColorLocal,callback:function(t){e.alertErrorColorLocal=t},expression:"alertErrorColorLocal"}}),e._v(" "),a("ContrastRatio",{attrs:{contrast:e.previewContrast.alertError}})],1),e._v(" "),a("div",{staticClass:"color-item"},[a("h4",[e._v(e._s(e.$t("settings.style.advanced_colors.badge")))]),e._v(" "),a("ColorInput",{attrs:{name:"badgeNotification",label:e.$t("settings.style.advanced_colors.badge_notification"),fallback:e.previewTheme.colors.badgeNotification},model:{value:e.badgeNotificationColorLocal,callback:function(t){e.badgeNotificationColorLocal=t},expression:"badgeNotificationColorLocal"}})],1),e._v(" "),a("div",{staticClass:"color-item"},[a("h4",[e._v(e._s(e.$t("settings.style.advanced_colors.panel_header")))]),e._v(" "),a("ColorInput",{attrs:{name:"panelColor",fallback:e.fgColorLocal,label:e.$t("settings.background")},model:{value:e.panelColorLocal,callback:function(t){e.panelColorLocal=t},expression:"panelColorLocal"}}),e._v(" "),a("OpacityInput",{attrs:{name:"panelOpacity",fallback:e.previewTheme.opacity.panel||1},model:{value:e.panelOpacityLocal,callback:function(t){e.panelOpacityLocal=t},expression:"panelOpacityLocal"}}),e._v(" "),a("ColorInput",{attrs:{name:"panelTextColor",fallback:e.previewTheme.colors.panelText,label:e.$t("settings.text")},model:{value:e.panelTextColorLocal,callback:function(t){e.panelTextColorLocal=t},expression:"panelTextColorLocal"}}),e._v(" "),a("ContrastRatio",{attrs:{contrast:e.previewContrast.panelText,large:"1"}}),e._v(" "),a("ColorInput",{attrs:{name:"panelLinkColor",fallback:e.previewTheme.colors.panelLink,label:e.$t("settings.links")},model:{value:e.panelLinkColorLocal,callback:function(t){e.panelLinkColorLocal=t},expression:"panelLinkColorLocal"}}),e._v(" "),a("ContrastRatio",{attrs:{contrast:e.previewContrast.panelLink,large:"1"}})],1),e._v(" "),a("div",{staticClass:"color-item"},[a("h4",[e._v(e._s(e.$t("settings.style.advanced_colors.top_bar")))]),e._v(" "),a("ColorInput",{attrs:{name:"topBarColor",fallback:e.fgColorLocal,label:e.$t("settings.background")},model:{value:e.topBarColorLocal,callback:function(t){e.topBarColorLocal=t},expression:"topBarColorLocal"}}),e._v(" "),a("ColorInput",{attrs:{name:"topBarTextColor",fallback:e.previewTheme.colors.topBarText,label:e.$t("settings.text")},model:{value:e.topBarTextColorLocal,callback:function(t){e.topBarTextColorLocal=t},expression:"topBarTextColorLocal"}}),e._v(" "),a("ContrastRatio",{attrs:{contrast:e.previewContrast.topBarText}}),e._v(" "),a("ColorInput",{attrs:{name:"topBarLinkColor",fallback:e.previewTheme.colors.topBarLink,label:e.$t("settings.links")},model:{value:e.topBarLinkColorLocal,callback:function(t){e.topBarLinkColorLocal=t},expression:"topBarLinkColorLocal"}}),e._v(" "),a("ContrastRatio",{attrs:{contrast:e.previewContrast.topBarLink}})],1),e._v(" "),a("div",{staticClass:"color-item"},[a("h4",[e._v(e._s(e.$t("settings.style.advanced_colors.inputs")))]),e._v(" "),a("ColorInput",{attrs:{name:"inputColor",fallback:e.fgColorLocal,label:e.$t("settings.background")},model:{value:e.inputColorLocal,callback:function(t){e.inputColorLocal=t},expression:"inputColorLocal"}}),e._v(" "),a("OpacityInput",{attrs:{name:"inputOpacity",fallback:e.previewTheme.opacity.input||1},model:{value:e.inputOpacityLocal,callback:function(t){e.inputOpacityLocal=t},expression:"inputOpacityLocal"}}),e._v(" "),a("ColorInput",{attrs:{name:"inputTextColor",fallback:e.previewTheme.colors.inputText,label:e.$t("settings.text")},model:{value:e.inputTextColorLocal,callback:function(t){e.inputTextColorLocal=t},expression:"inputTextColorLocal"}}),e._v(" "),a("ContrastRatio",{attrs:{contrast:e.previewContrast.inputText}})],1),e._v(" "),a("div",{staticClass:"color-item"},[a("h4",[e._v(e._s(e.$t("settings.style.advanced_colors.buttons")))]),e._v(" "),a("ColorInput",{attrs:{name:"btnColor",fallback:e.fgColorLocal,label:e.$t("settings.background")},model:{value:e.btnColorLocal,callback:function(t){e.btnColorLocal=t},expression:"btnColorLocal"}}),e._v(" "),a("OpacityInput",{attrs:{name:"btnOpacity",fallback:e.previewTheme.opacity.btn||1},model:{value:e.btnOpacityLocal,callback:function(t){e.btnOpacityLocal=t},expression:"btnOpacityLocal"}}),e._v(" "),a("ColorInput",{attrs:{name:"btnTextColor",fallback:e.previewTheme.colors.btnText,label:e.$t("settings.text")},model:{value:e.btnTextColorLocal,callback:function(t){e.btnTextColorLocal=t},expression:"btnTextColorLocal"}}),e._v(" "),a("ContrastRatio",{attrs:{contrast:e.previewContrast.btnText}})],1),e._v(" "),a("div",{staticClass:"color-item"},[a("h4",[e._v(e._s(e.$t("settings.style.advanced_colors.borders")))]),e._v(" "),a("ColorInput",{attrs:{name:"borderColor",fallback:e.previewTheme.colors.border,label:e.$t("settings.style.common.color")},model:{value:e.borderColorLocal,callback:function(t){e.borderColorLocal=t},expression:"borderColorLocal"}}),e._v(" "),a("OpacityInput",{attrs:{name:"borderOpacity",fallback:e.previewTheme.opacity.border||1},model:{value:e.borderOpacityLocal,callback:function(t){e.borderOpacityLocal=t},expression:"borderOpacityLocal"}})],1),e._v(" "),a("div",{staticClass:"color-item"},[a("h4",[e._v(e._s(e.$t("settings.style.advanced_colors.faint_text")))]),e._v(" "),a("ColorInput",{attrs:{name:"faintColor",fallback:e.previewTheme.colors.faint||1,label:e.$t("settings.text")},model:{value:e.faintColorLocal,callback:function(t){e.faintColorLocal=t},expression:"faintColorLocal"}}),e._v(" "),a("ColorInput",{attrs:{name:"faintLinkColor",fallback:e.previewTheme.colors.faintLink,label:e.$t("settings.links")},model:{value:e.faintLinkColorLocal,callback:function(t){e.faintLinkColorLocal=t},expression:"faintLinkColorLocal"}}),e._v(" "),a("ColorInput",{attrs:{name:"panelFaintColor",fallback:e.previewTheme.colors.panelFaint,label:e.$t("settings.style.advanced_colors.panel_header")},model:{value:e.panelFaintColorLocal,callback:function(t){e.panelFaintColorLocal=t},expression:"panelFaintColorLocal"}}),e._v(" "),a("OpacityInput",{attrs:{name:"faintOpacity",fallback:e.previewTheme.opacity.faint||.5},model:{value:e.faintOpacityLocal,callback:function(t){e.faintOpacityLocal=t},expression:"faintOpacityLocal"}})],1)]),e._v(" "),a("div",{staticClass:"radius-container",attrs:{label:e.$t("settings.style.radii._tab_label")}},[a("div",{staticClass:"tab-header"},[a("p",[e._v(e._s(e.$t("settings.radii_help")))]),e._v(" "),a("button",{staticClass:"btn",on:{click:e.clearRoundness}},[e._v(e._s(e.$t("settings.style.switcher.clear_all")))])]),e._v(" "),a("RangeInput",{attrs:{name:"btnRadius",label:e.$t("settings.btnRadius"),fallback:e.previewTheme.radii.btn,max:"16",hardMin:"0"},model:{value:e.btnRadiusLocal,callback:function(t){e.btnRadiusLocal=t},expression:"btnRadiusLocal"}}),e._v(" "),a("RangeInput",{attrs:{name:"inputRadius",label:e.$t("settings.inputRadius"),fallback:e.previewTheme.radii.input,max:"9",hardMin:"0"},model:{value:e.inputRadiusLocal,callback:function(t){e.inputRadiusLocal=t},expression:"inputRadiusLocal"}}),e._v(" "),a("RangeInput",{attrs:{name:"checkboxRadius",label:e.$t("settings.checkboxRadius"),fallback:e.previewTheme.radii.checkbox,max:"16",hardMin:"0"},model:{value:e.checkboxRadiusLocal,callback:function(t){e.checkboxRadiusLocal=t},expression:"checkboxRadiusLocal"}}),e._v(" "),a("RangeInput",{attrs:{name:"panelRadius",label:e.$t("settings.panelRadius"),fallback:e.previewTheme.radii.panel,max:"50",hardMin:"0"},model:{value:e.panelRadiusLocal,callback:function(t){e.panelRadiusLocal=t},expression:"panelRadiusLocal"}}),e._v(" "),a("RangeInput",{attrs:{name:"avatarRadius",label:e.$t("settings.avatarRadius"),fallback:e.previewTheme.radii.avatar,max:"28",hardMin:"0"},model:{value:e.avatarRadiusLocal,callback:function(t){e.avatarRadiusLocal=t},expression:"avatarRadiusLocal"}}),e._v(" "),a("RangeInput",{attrs:{name:"avatarAltRadius",label:e.$t("settings.avatarAltRadius"),fallback:e.previewTheme.radii.avatarAlt,max:"28",hardMin:"0"},model:{value:e.avatarAltRadiusLocal,callback:function(t){e.avatarAltRadiusLocal=t},expression:"avatarAltRadiusLocal"}}),e._v(" "),a("RangeInput",{attrs:{name:"attachmentRadius",label:e.$t("settings.attachmentRadius"),fallback:e.previewTheme.radii.attachment,max:"50",hardMin:"0"},model:{value:e.attachmentRadiusLocal,callback:function(t){e.attachmentRadiusLocal=t},expression:"attachmentRadiusLocal"}}),e._v(" "),a("RangeInput",{attrs:{name:"tooltipRadius",label:e.$t("settings.tooltipRadius"),fallback:e.previewTheme.radii.tooltip,max:"50",hardMin:"0"},model:{value:e.tooltipRadiusLocal,callback:function(t){e.tooltipRadiusLocal=t},expression:"tooltipRadiusLocal"}})],1),e._v(" "),a("div",{staticClass:"shadow-container",attrs:{label:e.$t("settings.style.shadows._tab_label")}},[a("div",{staticClass:"tab-header shadow-selector"},[a("div",{staticClass:"select-container"},[e._v("\n "+e._s(e.$t("settings.style.shadows.component"))+"\n "),a("label",{staticClass:"select",attrs:{for:"shadow-switcher"}},[a("select",{directives:[{name:"model",rawName:"v-model",value:e.shadowSelected,expression:"shadowSelected"}],staticClass:"shadow-switcher",attrs:{id:"shadow-switcher"},on:{change:function(t){var a=Array.prototype.filter.call(t.target.options,function(e){return e.selected}).map(function(e){var t="_value"in e?e._value:e.value;return t});e.shadowSelected=t.target.multiple?a:a[0]}}},e._l(e.shadowsAvailable,function(t){return a("option",{domProps:{value:t}},[e._v("\n "+e._s(e.$t("settings.style.shadows.components."+t))+"\n ")])}),0),e._v(" "),a("i",{staticClass:"icon-down-open"})])]),e._v(" "),a("div",{staticClass:"override"},[a("label",{staticClass:"label",attrs:{for:"override"}},[e._v("\n "+e._s(e.$t("settings.style.shadows.override"))+"\n ")]),e._v(" "),a("input",{directives:[{name:"model",rawName:"v-model",value:e.currentShadowOverriden,expression:"currentShadowOverriden"}],staticClass:"input-override",attrs:{name:"override",id:"override",type:"checkbox"},domProps:{checked:Array.isArray(e.currentShadowOverriden)?e._i(e.currentShadowOverriden,null)>-1:e.currentShadowOverriden},on:{change:function(t){var a=e.currentShadowOverriden,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.currentShadowOverriden=a.concat([o])):s>-1&&(e.currentShadowOverriden=a.slice(0,s).concat(a.slice(s+1)))}else e.currentShadowOverriden=n}}}),e._v(" "),a("label",{staticClass:"checkbox-label",attrs:{for:"override"}})]),e._v(" "),a("button",{staticClass:"btn",on:{click:e.clearShadows}},[e._v(e._s(e.$t("settings.style.switcher.clear_all")))])]),e._v(" "),a("shadow-control",{attrs:{ready:!!e.currentShadowFallback,fallback:e.currentShadowFallback},model:{value:e.currentShadow,callback:function(t){e.currentShadow=t},expression:"currentShadow"}}),e._v(" "),"avatar"===e.shadowSelected||"avatarStatus"===e.shadowSelected?a("div",[a("i18n",{attrs:{path:"settings.style.shadows.filter_hint.always_drop_shadow",tag:"p"}},[a("code",[e._v("filter: drop-shadow()")])]),e._v(" "),a("p",[e._v(e._s(e.$t("settings.style.shadows.filter_hint.avatar_inset")))]),e._v(" "),a("i18n",{attrs:{path:"settings.style.shadows.filter_hint.drop_shadow_syntax",tag:"p"}},[a("code",[e._v("drop-shadow")]),e._v(" "),a("code",[e._v("spread-radius")]),e._v(" "),a("code",[e._v("inset")])]),e._v(" "),a("i18n",{attrs:{path:"settings.style.shadows.filter_hint.inset_classic",tag:"p"}},[a("code",[e._v("box-shadow")])]),e._v(" "),a("p",[e._v(e._s(e.$t("settings.style.shadows.filter_hint.spread_zero")))])],1):e._e()],1),e._v(" "),a("div",{staticClass:"fonts-container",attrs:{label:e.$t("settings.style.fonts._tab_label")}},[a("div",{staticClass:"tab-header"},[a("p",[e._v(e._s(e.$t("settings.style.fonts.help")))]),e._v(" "),a("button",{staticClass:"btn",on:{click:e.clearFonts}},[e._v(e._s(e.$t("settings.style.switcher.clear_all")))])]),e._v(" "),a("FontControl",{attrs:{name:"ui",label:e.$t("settings.style.fonts.components.interface"),fallback:e.previewTheme.fonts.interface,"no-inherit":"1"},model:{value:e.fontsLocal.interface,callback:function(t){e.$set(e.fontsLocal,"interface",t)},expression:"fontsLocal.interface"}}),e._v(" "),a("FontControl",{attrs:{name:"input",label:e.$t("settings.style.fonts.components.input"),fallback:e.previewTheme.fonts.input},model:{value:e.fontsLocal.input,callback:function(t){e.$set(e.fontsLocal,"input",t)},expression:"fontsLocal.input"}}),e._v(" "),a("FontControl",{attrs:{name:"post",label:e.$t("settings.style.fonts.components.post"),fallback:e.previewTheme.fonts.post},model:{value:e.fontsLocal.post,callback:function(t){e.$set(e.fontsLocal,"post",t)},expression:"fontsLocal.post"}}),e._v(" "),a("FontControl",{attrs:{name:"postCode",label:e.$t("settings.style.fonts.components.postCode"),fallback:e.previewTheme.fonts.postCode},model:{value:e.fontsLocal.postCode,callback:function(t){e.$set(e.fontsLocal,"postCode",t)},expression:"fontsLocal.postCode"}})],1)])],1),e._v(" "),a("div",{staticClass:"apply-container"},[a("button",{staticClass:"btn submit",attrs:{disabled:!e.themeValid},on:{click:e.setCustomTheme}},[e._v(e._s(e.$t("general.apply")))]),e._v(" "),a("button",{staticClass:"btn",on:{click:e.clearAll}},[e._v(e._s(e.$t("settings.style.switcher.reset")))])])],1)},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"panel dummy"},[a("div",{staticClass:"panel-heading"},[a("div",{staticClass:"title"},[e._v("\n "+e._s(e.$t("settings.style.preview.header"))+"\n "),a("span",{staticClass:"badge badge-notification"},[e._v("\n 99\n ")])]),e._v(" "),a("span",{staticClass:"faint"},[e._v("\n "+e._s(e.$t("settings.style.preview.header_faint"))+"\n ")]),e._v(" "),a("span",{staticClass:"alert error"},[e._v("\n "+e._s(e.$t("settings.style.preview.error"))+"\n ")]),e._v(" "),a("button",{staticClass:"btn"},[e._v("\n "+e._s(e.$t("settings.style.preview.button"))+"\n ")])]),e._v(" "),a("div",{staticClass:"panel-body theme-preview-content"},[a("div",{staticClass:"post"},[a("div",{staticClass:"avatar"},[e._v("\n ( ͡° ͜ʖ ͡°)\n ")]),e._v(" "),a("div",{staticClass:"content"},[a("h4",[e._v("\n "+e._s(e.$t("settings.style.preview.content"))+"\n ")]),e._v(" "),a("i18n",{attrs:{path:"settings.style.preview.text"}},[a("code",{staticStyle:{"font-family":"var(--postCodeFont)"}},[e._v("\n "+e._s(e.$t("settings.style.preview.mono"))+"\n ")]),e._v(" "),a("a",{staticStyle:{color:"var(--link)"}},[e._v("\n "+e._s(e.$t("settings.style.preview.link"))+"\n ")])]),e._v(" "),e._m(0)],1)]),e._v(" "),a("div",{staticClass:"after-post"},[a("div",{staticClass:"avatar-alt"},[e._v("\n :^)\n ")]),e._v(" "),a("div",{staticClass:"content"},[a("i18n",{staticClass:"faint",attrs:{path:"settings.style.preview.fine_print",tag:"span"}},[a("a",{staticStyle:{color:"var(--faintLink)"}},[e._v("\n "+e._s(e.$t("settings.style.preview.faint_link"))+"\n ")])])],1)]),e._v(" "),a("div",{staticClass:"separator"}),e._v(" "),a("span",{staticClass:"alert error"},[e._v("\n "+e._s(e.$t("settings.style.preview.error"))+"\n ")]),e._v(" "),a("input",{attrs:{type:"text"},domProps:{value:e.$t("settings.style.preview.input")}}),e._v(" "),a("div",{staticClass:"actions"},[a("span",{staticClass:"checkbox"},[a("input",{attrs:{checked:"very yes",type:"checkbox",id:"preview_checkbox"}}),e._v(" "),a("label",{attrs:{for:"preview_checkbox"}},[e._v(e._s(e.$t("settings.style.preview.checkbox")))])]),e._v(" "),a("button",{staticClass:"btn"},[e._v("\n "+e._s(e.$t("settings.style.preview.button"))+"\n ")])])])])},staticRenderFns:[function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"icons"},[a("i",{staticClass:"button-icon icon-reply",staticStyle:{color:"var(--cBlue)"}}),e._v(" "),a("i",{staticClass:"button-icon icon-retweet",staticStyle:{color:"var(--cGreen)"}}),e._v(" "),a("i",{staticClass:"button-icon icon-star",staticStyle:{color:"var(--cOrange)"}}),e._v(" "),a("i",{staticClass:"button-icon icon-cancel",staticStyle:{color:"var(--cRed)"}})])}]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return e.loggedIn?a("div",[a("i",{staticClass:"button-icon favorite-button fav-active",class:e.classes,attrs:{title:e.$t("tool_tip.favorite")},on:{click:function(t){t.preventDefault(),e.favorite()}}}),e._v(" "),!e.hidePostStatsLocal&&e.status.fave_num>0?a("span",[e._v(e._s(e.status.fave_num))]):e._e()]):a("div",[a("i",{staticClass:"button-icon favorite-button",class:e.classes,attrs:{title:e.$t("tool_tip.favorite")}}),e._v(" "),!e.hidePostStatsLocal&&e.status.fave_num>0?a("span",[e._v(e._s(e.status.fave_num))]):e._e()])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"settings panel panel-default"},[a("div",{staticClass:"panel-heading"},[a("div",{staticClass:"title"},[e._v("\n "+e._s(e.$t("settings.settings"))+"\n ")]),e._v(" "),a("transition",{attrs:{name:"fade"}},[e.currentSaveStateNotice?[e.currentSaveStateNotice.error?a("div",{staticClass:"alert error",on:{click:function(e){e.preventDefault()}}},[e._v("\n "+e._s(e.$t("settings.saving_err"))+"\n ")]):e._e(),e._v(" "),e.currentSaveStateNotice.error?e._e():a("div",{staticClass:"alert transparent",on:{click:function(e){e.preventDefault()}}},[e._v("\n "+e._s(e.$t("settings.saving_ok"))+"\n ")])]:e._e()],2)],1),e._v(" "),a("div",{staticClass:"panel-body"},[a("keep-alive",[a("tab-switcher",[a("div",{attrs:{label:e.$t("settings.general")}},[a("div",{staticClass:"setting-item"},[a("h2",[e._v(e._s(e.$t("settings.interface")))]),e._v(" "),a("ul",{staticClass:"setting-list"},[a("li",[a("interface-language-switcher")],1),e._v(" "),e.instanceSpecificPanelPresent?a("li",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.hideISPLocal,expression:"hideISPLocal"}],attrs:{type:"checkbox",id:"hideISP"},domProps:{checked:Array.isArray(e.hideISPLocal)?e._i(e.hideISPLocal,null)>-1:e.hideISPLocal},on:{change:function(t){var a=e.hideISPLocal,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.hideISPLocal=a.concat([o])):s>-1&&(e.hideISPLocal=a.slice(0,s).concat(a.slice(s+1)))}else e.hideISPLocal=n}}}),e._v(" "),a("label",{attrs:{for:"hideISP"}},[e._v(e._s(e.$t("settings.hide_isp")))])]):e._e()])]),e._v(" "),a("div",{staticClass:"setting-item"},[a("h2",[e._v(e._s(e.$t("nav.timeline")))]),e._v(" "),a("ul",{staticClass:"setting-list"},[a("li",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.collapseMessageWithSubjectLocal,expression:"collapseMessageWithSubjectLocal"}],attrs:{type:"checkbox",id:"collapseMessageWithSubject"},domProps:{checked:Array.isArray(e.collapseMessageWithSubjectLocal)?e._i(e.collapseMessageWithSubjectLocal,null)>-1:e.collapseMessageWithSubjectLocal},on:{change:function(t){var a=e.collapseMessageWithSubjectLocal,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.collapseMessageWithSubjectLocal=a.concat([o])):s>-1&&(e.collapseMessageWithSubjectLocal=a.slice(0,s).concat(a.slice(s+1)))}else e.collapseMessageWithSubjectLocal=n}}}),e._v(" "),a("label",{attrs:{for:"collapseMessageWithSubject"}},[e._v("\n "+e._s(e.$t("settings.collapse_subject"))+" "+e._s(e.$t("settings.instance_default",{value:e.collapseMessageWithSubjectDefault}))+"\n ")])]),e._v(" "),a("li",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.streamingLocal,expression:"streamingLocal"}],attrs:{type:"checkbox",id:"streaming"},domProps:{checked:Array.isArray(e.streamingLocal)?e._i(e.streamingLocal,null)>-1:e.streamingLocal},on:{change:function(t){var a=e.streamingLocal,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.streamingLocal=a.concat([o])):s>-1&&(e.streamingLocal=a.slice(0,s).concat(a.slice(s+1)))}else e.streamingLocal=n}}}),e._v(" "),a("label",{attrs:{for:"streaming"}},[e._v(e._s(e.$t("settings.streaming")))]),e._v(" "),a("ul",{staticClass:"setting-list suboptions",class:[{disabled:!e.streamingLocal}]},[a("li",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.pauseOnUnfocusedLocal,expression:"pauseOnUnfocusedLocal"}],attrs:{disabled:!e.streamingLocal,type:"checkbox",id:"pauseOnUnfocused"},domProps:{checked:Array.isArray(e.pauseOnUnfocusedLocal)?e._i(e.pauseOnUnfocusedLocal,null)>-1:e.pauseOnUnfocusedLocal},on:{change:function(t){var a=e.pauseOnUnfocusedLocal,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.pauseOnUnfocusedLocal=a.concat([o])):s>-1&&(e.pauseOnUnfocusedLocal=a.slice(0,s).concat(a.slice(s+1)))}else e.pauseOnUnfocusedLocal=n}}}),e._v(" "),a("label",{attrs:{for:"pauseOnUnfocused"}},[e._v(e._s(e.$t("settings.pause_on_unfocused")))])])])]),e._v(" "),a("li",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.autoLoadLocal,expression:"autoLoadLocal"}],attrs:{type:"checkbox",id:"autoload"},domProps:{checked:Array.isArray(e.autoLoadLocal)?e._i(e.autoLoadLocal,null)>-1:e.autoLoadLocal},on:{change:function(t){var a=e.autoLoadLocal,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.autoLoadLocal=a.concat([o])):s>-1&&(e.autoLoadLocal=a.slice(0,s).concat(a.slice(s+1)))}else e.autoLoadLocal=n}}}),e._v(" "),a("label",{attrs:{for:"autoload"}},[e._v(e._s(e.$t("settings.autoload")))])]),e._v(" "),a("li",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.hoverPreviewLocal,expression:"hoverPreviewLocal"}],attrs:{type:"checkbox",id:"hoverPreview"},domProps:{checked:Array.isArray(e.hoverPreviewLocal)?e._i(e.hoverPreviewLocal,null)>-1:e.hoverPreviewLocal},on:{change:function(t){var a=e.hoverPreviewLocal,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.hoverPreviewLocal=a.concat([o])):s>-1&&(e.hoverPreviewLocal=a.slice(0,s).concat(a.slice(s+1)))}else e.hoverPreviewLocal=n}}}),e._v(" "),a("label",{attrs:{for:"hoverPreview"}},[e._v(e._s(e.$t("settings.reply_link_preview")))])])])]),e._v(" "),a("div",{staticClass:"setting-item"},[a("h2",[e._v(e._s(e.$t("settings.composing")))]),e._v(" "),a("ul",{staticClass:"setting-list"},[a("li",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.scopeCopyLocal,expression:"scopeCopyLocal"}],attrs:{type:"checkbox",id:"scopeCopy"},domProps:{checked:Array.isArray(e.scopeCopyLocal)?e._i(e.scopeCopyLocal,null)>-1:e.scopeCopyLocal},on:{change:function(t){var a=e.scopeCopyLocal,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.scopeCopyLocal=a.concat([o])):s>-1&&(e.scopeCopyLocal=a.slice(0,s).concat(a.slice(s+1)))}else e.scopeCopyLocal=n}}}),e._v(" "),a("label",{attrs:{for:"scopeCopy"}},[e._v("\n "+e._s(e.$t("settings.scope_copy"))+" "+e._s(e.$t("settings.instance_default",{value:e.scopeCopyDefault}))+"\n ")])]),e._v(" "),a("li",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.alwaysShowSubjectInputLocal,expression:"alwaysShowSubjectInputLocal"}],attrs:{type:"checkbox",id:"subjectHide"},domProps:{checked:Array.isArray(e.alwaysShowSubjectInputLocal)?e._i(e.alwaysShowSubjectInputLocal,null)>-1:e.alwaysShowSubjectInputLocal},on:{change:function(t){var a=e.alwaysShowSubjectInputLocal,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.alwaysShowSubjectInputLocal=a.concat([o])):s>-1&&(e.alwaysShowSubjectInputLocal=a.slice(0,s).concat(a.slice(s+1)))}else e.alwaysShowSubjectInputLocal=n}}}),e._v(" "),a("label",{attrs:{for:"subjectHide"}},[e._v("\n "+e._s(e.$t("settings.subject_input_always_show"))+" "+e._s(e.$t("settings.instance_default",{value:e.alwaysShowSubjectInputDefault}))+"\n ")])]),e._v(" "),a("li",[a("div",[e._v("\n "+e._s(e.$t("settings.subject_line_behavior"))+"\n "),a("label",{staticClass:"select",attrs:{for:"subjectLineBehavior"}},[a("select",{directives:[{name:"model",rawName:"v-model",value:e.subjectLineBehaviorLocal,expression:"subjectLineBehaviorLocal"}],attrs:{id:"subjectLineBehavior"},on:{change:function(t){var a=Array.prototype.filter.call(t.target.options,function(e){return e.selected}).map(function(e){var t="_value"in e?e._value:e.value;return t});e.subjectLineBehaviorLocal=t.target.multiple?a:a[0]}}},[a("option",{attrs:{value:"email"}},[e._v("\n "+e._s(e.$t("settings.subject_line_email"))+"\n "+e._s("email"==e.subjectLineBehaviorDefault?e.$t("settings.instance_default_simple"):"")+"\n ")]),e._v(" "),a("option",{attrs:{value:"masto"}},[e._v("\n "+e._s(e.$t("settings.subject_line_mastodon"))+"\n "+e._s("mastodon"==e.subjectLineBehaviorDefault?e.$t("settings.instance_default_simple"):"")+"\n ")]),e._v(" "),a("option",{attrs:{value:"noop"}},[e._v("\n "+e._s(e.$t("settings.subject_line_noop"))+"\n "+e._s("noop"==e.subjectLineBehaviorDefault?e.$t("settings.instance_default_simple"):"")+"\n ")])]),e._v(" "),a("i",{staticClass:"icon-down-open"})])])]),e._v(" "),a("li",[a("div",[e._v("\n "+e._s(e.$t("settings.post_status_content_type"))+"\n "),a("label",{staticClass:"select",attrs:{for:"postContentType"}},[a("select",{directives:[{name:"model",rawName:"v-model",value:e.postContentTypeLocal,expression:"postContentTypeLocal"}],attrs:{id:"postContentType"},on:{change:function(t){var a=Array.prototype.filter.call(t.target.options,function(e){return e.selected}).map(function(e){var t="_value"in e?e._value:e.value;return t});e.postContentTypeLocal=t.target.multiple?a:a[0]}}},e._l(e.postFormats,function(t){return a("option",{key:t,domProps:{value:t}},[e._v("\n "+e._s(e.$t('post_status.content_type["'+t+'"]'))+"\n "+e._s(e.postContentTypeDefault===t?e.$t("settings.instance_default_simple"):"")+"\n ")])}),0),e._v(" "),a("i",{staticClass:"icon-down-open"})])])])])]),e._v(" "),a("div",{staticClass:"setting-item"},[a("h2",[e._v(e._s(e.$t("settings.attachments")))]),e._v(" "),a("ul",{staticClass:"setting-list"},[a("li",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.hideAttachmentsLocal,expression:"hideAttachmentsLocal"}],attrs:{type:"checkbox",id:"hideAttachments"},domProps:{checked:Array.isArray(e.hideAttachmentsLocal)?e._i(e.hideAttachmentsLocal,null)>-1:e.hideAttachmentsLocal},on:{change:function(t){ +var a=e.hideAttachmentsLocal,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.hideAttachmentsLocal=a.concat([o])):s>-1&&(e.hideAttachmentsLocal=a.slice(0,s).concat(a.slice(s+1)))}else e.hideAttachmentsLocal=n}}}),e._v(" "),a("label",{attrs:{for:"hideAttachments"}},[e._v(e._s(e.$t("settings.hide_attachments_in_tl")))])]),e._v(" "),a("li",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.hideAttachmentsInConvLocal,expression:"hideAttachmentsInConvLocal"}],attrs:{type:"checkbox",id:"hideAttachmentsInConv"},domProps:{checked:Array.isArray(e.hideAttachmentsInConvLocal)?e._i(e.hideAttachmentsInConvLocal,null)>-1:e.hideAttachmentsInConvLocal},on:{change:function(t){var a=e.hideAttachmentsInConvLocal,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.hideAttachmentsInConvLocal=a.concat([o])):s>-1&&(e.hideAttachmentsInConvLocal=a.slice(0,s).concat(a.slice(s+1)))}else e.hideAttachmentsInConvLocal=n}}}),e._v(" "),a("label",{attrs:{for:"hideAttachmentsInConv"}},[e._v(e._s(e.$t("settings.hide_attachments_in_convo")))])]),e._v(" "),a("li",[a("label",{attrs:{for:"maxThumbnails"}},[e._v(e._s(e.$t("settings.max_thumbnails")))]),e._v(" "),a("input",{directives:[{name:"model",rawName:"v-model.number",value:e.maxThumbnails,expression:"maxThumbnails",modifiers:{number:!0}}],staticClass:"number-input",attrs:{type:"number",id:"maxThumbnails",min:"0",step:"1"},domProps:{value:e.maxThumbnails},on:{input:function(t){t.target.composing||(e.maxThumbnails=e._n(t.target.value))},blur:function(t){e.$forceUpdate()}}})]),e._v(" "),a("li",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.hideNsfwLocal,expression:"hideNsfwLocal"}],attrs:{type:"checkbox",id:"hideNsfw"},domProps:{checked:Array.isArray(e.hideNsfwLocal)?e._i(e.hideNsfwLocal,null)>-1:e.hideNsfwLocal},on:{change:function(t){var a=e.hideNsfwLocal,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.hideNsfwLocal=a.concat([o])):s>-1&&(e.hideNsfwLocal=a.slice(0,s).concat(a.slice(s+1)))}else e.hideNsfwLocal=n}}}),e._v(" "),a("label",{attrs:{for:"hideNsfw"}},[e._v(e._s(e.$t("settings.nsfw_clickthrough")))])]),e._v(" "),a("ul",{staticClass:"setting-list suboptions"},[a("li",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.preloadImage,expression:"preloadImage"}],attrs:{disabled:!e.hideNsfwLocal,type:"checkbox",id:"preloadImage"},domProps:{checked:Array.isArray(e.preloadImage)?e._i(e.preloadImage,null)>-1:e.preloadImage},on:{change:function(t){var a=e.preloadImage,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.preloadImage=a.concat([o])):s>-1&&(e.preloadImage=a.slice(0,s).concat(a.slice(s+1)))}else e.preloadImage=n}}}),e._v(" "),a("label",{attrs:{for:"preloadImage"}},[e._v(e._s(e.$t("settings.preload_images")))])]),e._v(" "),a("li",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.useOneClickNsfw,expression:"useOneClickNsfw"}],attrs:{disabled:!e.hideNsfwLocal,type:"checkbox",id:"useOneClickNsfw"},domProps:{checked:Array.isArray(e.useOneClickNsfw)?e._i(e.useOneClickNsfw,null)>-1:e.useOneClickNsfw},on:{change:function(t){var a=e.useOneClickNsfw,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.useOneClickNsfw=a.concat([o])):s>-1&&(e.useOneClickNsfw=a.slice(0,s).concat(a.slice(s+1)))}else e.useOneClickNsfw=n}}}),e._v(" "),a("label",{attrs:{for:"useOneClickNsfw"}},[e._v(e._s(e.$t("settings.use_one_click_nsfw")))])])]),e._v(" "),a("li",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.stopGifs,expression:"stopGifs"}],attrs:{type:"checkbox",id:"stopGifs"},domProps:{checked:Array.isArray(e.stopGifs)?e._i(e.stopGifs,null)>-1:e.stopGifs},on:{change:function(t){var a=e.stopGifs,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.stopGifs=a.concat([o])):s>-1&&(e.stopGifs=a.slice(0,s).concat(a.slice(s+1)))}else e.stopGifs=n}}}),e._v(" "),a("label",{attrs:{for:"stopGifs"}},[e._v(e._s(e.$t("settings.stop_gifs")))])]),e._v(" "),a("li",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.loopVideoLocal,expression:"loopVideoLocal"}],attrs:{type:"checkbox",id:"loopVideo"},domProps:{checked:Array.isArray(e.loopVideoLocal)?e._i(e.loopVideoLocal,null)>-1:e.loopVideoLocal},on:{change:function(t){var a=e.loopVideoLocal,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.loopVideoLocal=a.concat([o])):s>-1&&(e.loopVideoLocal=a.slice(0,s).concat(a.slice(s+1)))}else e.loopVideoLocal=n}}}),e._v(" "),a("label",{attrs:{for:"loopVideo"}},[e._v(e._s(e.$t("settings.loop_video")))]),e._v(" "),a("ul",{staticClass:"setting-list suboptions",class:[{disabled:!e.streamingLocal}]},[a("li",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.loopVideoSilentOnlyLocal,expression:"loopVideoSilentOnlyLocal"}],attrs:{disabled:!e.loopVideoLocal||!e.loopSilentAvailable,type:"checkbox",id:"loopVideoSilentOnly"},domProps:{checked:Array.isArray(e.loopVideoSilentOnlyLocal)?e._i(e.loopVideoSilentOnlyLocal,null)>-1:e.loopVideoSilentOnlyLocal},on:{change:function(t){var a=e.loopVideoSilentOnlyLocal,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.loopVideoSilentOnlyLocal=a.concat([o])):s>-1&&(e.loopVideoSilentOnlyLocal=a.slice(0,s).concat(a.slice(s+1)))}else e.loopVideoSilentOnlyLocal=n}}}),e._v(" "),a("label",{attrs:{for:"loopVideoSilentOnly"}},[e._v(e._s(e.$t("settings.loop_video_silent_only")))]),e._v(" "),e.loopSilentAvailable?e._e():a("div",{staticClass:"unavailable"},[a("i",{staticClass:"icon-globe"}),e._v("! "+e._s(e.$t("settings.limited_availability"))+"\n ")])])])]),e._v(" "),a("li",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.playVideosInModal,expression:"playVideosInModal"}],attrs:{type:"checkbox",id:"playVideosInModal"},domProps:{checked:Array.isArray(e.playVideosInModal)?e._i(e.playVideosInModal,null)>-1:e.playVideosInModal},on:{change:function(t){var a=e.playVideosInModal,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.playVideosInModal=a.concat([o])):s>-1&&(e.playVideosInModal=a.slice(0,s).concat(a.slice(s+1)))}else e.playVideosInModal=n}}}),e._v(" "),a("label",{attrs:{for:"playVideosInModal"}},[e._v(e._s(e.$t("settings.play_videos_in_modal")))])]),e._v(" "),a("li",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.useContainFit,expression:"useContainFit"}],attrs:{type:"checkbox",id:"useContainFit"},domProps:{checked:Array.isArray(e.useContainFit)?e._i(e.useContainFit,null)>-1:e.useContainFit},on:{change:function(t){var a=e.useContainFit,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.useContainFit=a.concat([o])):s>-1&&(e.useContainFit=a.slice(0,s).concat(a.slice(s+1)))}else e.useContainFit=n}}}),e._v(" "),a("label",{attrs:{for:"useContainFit"}},[e._v(e._s(e.$t("settings.use_contain_fit")))])])])]),e._v(" "),a("div",{staticClass:"setting-item"},[a("h2",[e._v(e._s(e.$t("settings.notifications")))]),e._v(" "),a("ul",{staticClass:"setting-list"},[a("li",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.webPushNotificationsLocal,expression:"webPushNotificationsLocal"}],attrs:{type:"checkbox",id:"webPushNotifications"},domProps:{checked:Array.isArray(e.webPushNotificationsLocal)?e._i(e.webPushNotificationsLocal,null)>-1:e.webPushNotificationsLocal},on:{change:function(t){var a=e.webPushNotificationsLocal,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.webPushNotificationsLocal=a.concat([o])):s>-1&&(e.webPushNotificationsLocal=a.slice(0,s).concat(a.slice(s+1)))}else e.webPushNotificationsLocal=n}}}),e._v(" "),a("label",{attrs:{for:"webPushNotifications"}},[e._v("\n "+e._s(e.$t("settings.enable_web_push_notifications"))+"\n ")])])])])]),e._v(" "),a("div",{attrs:{label:e.$t("settings.theme")}},[a("div",{staticClass:"setting-item"},[a("style-switcher")],1)]),e._v(" "),a("div",{attrs:{label:e.$t("settings.filtering")}},[a("div",{staticClass:"setting-item"},[a("div",{staticClass:"select-multiple"},[a("span",{staticClass:"label"},[e._v(e._s(e.$t("settings.notification_visibility")))]),e._v(" "),a("ul",{staticClass:"option-list"},[a("li",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.notificationVisibilityLocal.likes,expression:"notificationVisibilityLocal.likes"}],attrs:{type:"checkbox",id:"notification-visibility-likes"},domProps:{checked:Array.isArray(e.notificationVisibilityLocal.likes)?e._i(e.notificationVisibilityLocal.likes,null)>-1:e.notificationVisibilityLocal.likes},on:{change:function(t){var a=e.notificationVisibilityLocal.likes,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&e.$set(e.notificationVisibilityLocal,"likes",a.concat([o])):s>-1&&e.$set(e.notificationVisibilityLocal,"likes",a.slice(0,s).concat(a.slice(s+1)))}else e.$set(e.notificationVisibilityLocal,"likes",n)}}}),e._v(" "),a("label",{attrs:{for:"notification-visibility-likes"}},[e._v("\n "+e._s(e.$t("settings.notification_visibility_likes"))+"\n ")])]),e._v(" "),a("li",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.notificationVisibilityLocal.repeats,expression:"notificationVisibilityLocal.repeats"}],attrs:{type:"checkbox",id:"notification-visibility-repeats"},domProps:{checked:Array.isArray(e.notificationVisibilityLocal.repeats)?e._i(e.notificationVisibilityLocal.repeats,null)>-1:e.notificationVisibilityLocal.repeats},on:{change:function(t){var a=e.notificationVisibilityLocal.repeats,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&e.$set(e.notificationVisibilityLocal,"repeats",a.concat([o])):s>-1&&e.$set(e.notificationVisibilityLocal,"repeats",a.slice(0,s).concat(a.slice(s+1)))}else e.$set(e.notificationVisibilityLocal,"repeats",n)}}}),e._v(" "),a("label",{attrs:{for:"notification-visibility-repeats"}},[e._v("\n "+e._s(e.$t("settings.notification_visibility_repeats"))+"\n ")])]),e._v(" "),a("li",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.notificationVisibilityLocal.follows,expression:"notificationVisibilityLocal.follows"}],attrs:{type:"checkbox",id:"notification-visibility-follows"},domProps:{checked:Array.isArray(e.notificationVisibilityLocal.follows)?e._i(e.notificationVisibilityLocal.follows,null)>-1:e.notificationVisibilityLocal.follows},on:{change:function(t){var a=e.notificationVisibilityLocal.follows,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&e.$set(e.notificationVisibilityLocal,"follows",a.concat([o])):s>-1&&e.$set(e.notificationVisibilityLocal,"follows",a.slice(0,s).concat(a.slice(s+1)))}else e.$set(e.notificationVisibilityLocal,"follows",n)}}}),e._v(" "),a("label",{attrs:{for:"notification-visibility-follows"}},[e._v("\n "+e._s(e.$t("settings.notification_visibility_follows"))+"\n ")])]),e._v(" "),a("li",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.notificationVisibilityLocal.mentions,expression:"notificationVisibilityLocal.mentions"}],attrs:{type:"checkbox",id:"notification-visibility-mentions"},domProps:{checked:Array.isArray(e.notificationVisibilityLocal.mentions)?e._i(e.notificationVisibilityLocal.mentions,null)>-1:e.notificationVisibilityLocal.mentions},on:{change:function(t){var a=e.notificationVisibilityLocal.mentions,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&e.$set(e.notificationVisibilityLocal,"mentions",a.concat([o])):s>-1&&e.$set(e.notificationVisibilityLocal,"mentions",a.slice(0,s).concat(a.slice(s+1)))}else e.$set(e.notificationVisibilityLocal,"mentions",n)}}}),e._v(" "),a("label",{attrs:{for:"notification-visibility-mentions"}},[e._v("\n "+e._s(e.$t("settings.notification_visibility_mentions"))+"\n ")])])])]),e._v(" "),a("div",[e._v("\n "+e._s(e.$t("settings.replies_in_timeline"))+"\n "),a("label",{staticClass:"select",attrs:{for:"replyVisibility"}},[a("select",{directives:[{name:"model",rawName:"v-model",value:e.replyVisibilityLocal,expression:"replyVisibilityLocal"}],attrs:{id:"replyVisibility"},on:{change:function(t){var a=Array.prototype.filter.call(t.target.options,function(e){return e.selected}).map(function(e){var t="_value"in e?e._value:e.value;return t});e.replyVisibilityLocal=t.target.multiple?a:a[0]}}},[a("option",{attrs:{value:"all",selected:""}},[e._v(e._s(e.$t("settings.reply_visibility_all")))]),e._v(" "),a("option",{attrs:{value:"following"}},[e._v(e._s(e.$t("settings.reply_visibility_following")))]),e._v(" "),a("option",{attrs:{value:"self"}},[e._v(e._s(e.$t("settings.reply_visibility_self")))])]),e._v(" "),a("i",{staticClass:"icon-down-open"})])]),e._v(" "),a("div",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.hidePostStatsLocal,expression:"hidePostStatsLocal"}],attrs:{type:"checkbox",id:"hidePostStats"},domProps:{checked:Array.isArray(e.hidePostStatsLocal)?e._i(e.hidePostStatsLocal,null)>-1:e.hidePostStatsLocal},on:{change:function(t){var a=e.hidePostStatsLocal,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.hidePostStatsLocal=a.concat([o])):s>-1&&(e.hidePostStatsLocal=a.slice(0,s).concat(a.slice(s+1)))}else e.hidePostStatsLocal=n}}}),e._v(" "),a("label",{attrs:{for:"hidePostStats"}},[e._v("\n "+e._s(e.$t("settings.hide_post_stats"))+" "+e._s(e.$t("settings.instance_default",{value:e.hidePostStatsDefault}))+"\n ")])]),e._v(" "),a("div",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.hideUserStatsLocal,expression:"hideUserStatsLocal"}],attrs:{type:"checkbox",id:"hideUserStats"},domProps:{checked:Array.isArray(e.hideUserStatsLocal)?e._i(e.hideUserStatsLocal,null)>-1:e.hideUserStatsLocal},on:{change:function(t){var a=e.hideUserStatsLocal,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.hideUserStatsLocal=a.concat([o])):s>-1&&(e.hideUserStatsLocal=a.slice(0,s).concat(a.slice(s+1)))}else e.hideUserStatsLocal=n}}}),e._v(" "),a("label",{attrs:{for:"hideUserStats"}},[e._v("\n "+e._s(e.$t("settings.hide_user_stats"))+" "+e._s(e.$t("settings.instance_default",{value:e.hideUserStatsDefault}))+"\n ")])])]),e._v(" "),a("div",{staticClass:"setting-item"},[a("div",[a("p",[e._v(e._s(e.$t("settings.filtering_explanation")))]),e._v(" "),a("textarea",{directives:[{name:"model",rawName:"v-model",value:e.muteWordsString,expression:"muteWordsString"}],attrs:{id:"muteWords"},domProps:{value:e.muteWordsString},on:{input:function(t){t.target.composing||(e.muteWordsString=t.target.value)}}})]),e._v(" "),a("div",[a("input",{directives:[{name:"model",rawName:"v-model",value:e.hideFilteredStatusesLocal,expression:"hideFilteredStatusesLocal"}],attrs:{type:"checkbox",id:"hideFilteredStatuses"},domProps:{checked:Array.isArray(e.hideFilteredStatusesLocal)?e._i(e.hideFilteredStatusesLocal,null)>-1:e.hideFilteredStatusesLocal},on:{change:function(t){var a=e.hideFilteredStatusesLocal,i=t.target,n=!!i.checked;if(Array.isArray(a)){var o=null,s=e._i(a,o);i.checked?s<0&&(e.hideFilteredStatusesLocal=a.concat([o])):s>-1&&(e.hideFilteredStatusesLocal=a.slice(0,s).concat(a.slice(s+1)))}else e.hideFilteredStatusesLocal=n}}}),e._v(" "),a("label",{attrs:{for:"hideFilteredStatuses"}},[e._v("\n "+e._s(e.$t("settings.hide_filtered_statuses"))+" "+e._s(e.$t("settings.instance_default",{value:e.hideFilteredStatusesDefault}))+"\n ")])])])])])],1)],1)])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"nav-panel"},[a("div",{staticClass:"panel panel-default"},[a("ul",[e.currentUser?a("li",[a("router-link",{attrs:{to:{name:"friends"}}},[e._v("\n "+e._s(e.$t("nav.timeline"))+"\n ")])],1):e._e(),e._v(" "),e.currentUser?a("li",[a("router-link",{attrs:{to:{name:"mentions",params:{username:e.currentUser.screen_name}}}},[e._v("\n "+e._s(e.$t("nav.mentions"))+"\n ")])],1):e._e(),e._v(" "),e.currentUser?a("li",[a("router-link",{attrs:{to:{name:"dms",params:{username:e.currentUser.screen_name}}}},[e._v("\n "+e._s(e.$t("nav.dms"))+"\n ")])],1):e._e(),e._v(" "),e.currentUser&&e.currentUser.locked?a("li",[a("router-link",{attrs:{to:{name:"friend-requests"}}},[e._v("\n "+e._s(e.$t("nav.friend_requests"))+"\n "),e.followRequestCount>0?a("span",{staticClass:"badge follow-request-count"},[e._v("\n "+e._s(e.followRequestCount)+"\n ")]):e._e()])],1):e._e(),e._v(" "),a("li",[a("router-link",{attrs:{to:{name:"public-timeline"}}},[e._v("\n "+e._s(e.$t("nav.public_tl"))+"\n ")])],1),e._v(" "),a("li",[a("router-link",{attrs:{to:{name:"public-external-timeline"}}},[e._v("\n "+e._s(e.$t("nav.twkn"))+"\n ")])],1)])])])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{ref:"galleryContainer",staticStyle:{width:"100%"}},e._l(e.rows,function(t){return a("div",{staticClass:"gallery-row",class:{"contain-fit":e.useContainFit,"cover-fit":!e.useContainFit},style:e.rowHeight(t.length)},e._l(t,function(t){return a("attachment",{key:t.id,attrs:{setMedia:e.setMedia,nsfw:e.nsfw,attachment:t,allowPlay:!1}})}),1)}),0)},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"who-to-follow-panel"},[a("div",{staticClass:"panel panel-default base01-background"},[a("div",{staticClass:"panel-heading timeline-heading base02-background base04"},[a("div",{staticClass:"title"},[e._v("\n "+e._s(e.$t("who_to_follow.who_to_follow"))+"\n ")])]),e._v(" "),a("div",{staticClass:"panel-body who-to-follow"},[e._l(e.usersToFollow,function(t){return a("span",[a("img",{attrs:{src:t.img}}),e._v(" "),a("router-link",{attrs:{to:e.userProfileLink(t.id,t.name)}},[e._v("\n "+e._s(t.name)+"\n ")]),a("br")],1)}),e._v(" "),a("img",{attrs:{src:e.$store.state.instance.logo}}),e._v(" "),a("router-link",{attrs:{to:{name:"who-to-follow"}}},[e._v(e._s(e.$t("who_to_follow.more")))])],2)])])},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"import-export-container"},[e._t("before"),e._v(" "),a("button",{staticClass:"btn",on:{click:e.exportData}},[e._v(e._s(e.exportLabel))]),e._v(" "),a("button",{staticClass:"btn",on:{click:e.importData}},[e._v(e._s(e.importLabel))]),e._v(" "),e._t("afterButtons"),e._v(" "),e.importFailed?a("p",{staticClass:"alert error"},[e._v(e._s(e.importFailedText))]):e._e(),e._v(" "),e._t("afterError")],2)},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"user-panel"},[e.user?a("div",{staticClass:"panel panel-default",staticStyle:{overflow:"visible"}},[a("UserCard",{attrs:{user:e.user,hideBio:!0,rounded:"top"}}),e._v(" "),a("div",{staticClass:"panel-footer"},[e.user?a("post-status-form"):e._e()],1)],1):e._e(),e._v(" "),e.user?e._e():a("login-form")],1)},staticRenderFns:[]}},function(e,t){e.exports={render:function(){var e=this,t=e.$createElement,a=e._self._c||t;return a("div",{staticClass:"user-card",class:e.classes,style:e.style},[a("div",{staticClass:"panel-heading"},[a("div",{staticClass:"user-info"},[a("div",{staticClass:"container"},[a("router-link",{attrs:{to:e.userProfileLink(e.user)}},[a("UserAvatar",{attrs:{betterShadow:e.betterShadow,src:e.user.profile_image_url_original}})],1),e._v(" "),a("div",{staticClass:"name-and-screen-name"},[a("div",{staticClass:"top-line"},[e.user.name_html?a("div",{staticClass:"user-name",attrs:{title:e.user.name},domProps:{innerHTML:e._s(e.user.name_html)}}):a("div",{staticClass:"user-name",attrs:{title:e.user.name}},[e._v(e._s(e.user.name))]),e._v(" "),e.isOtherUser?e._e():a("router-link",{attrs:{to:{name:"user-settings"}}},[a("i",{staticClass:"button-icon icon-pencil usersettings",attrs:{title:e.$t("tool_tip.user_settings")}})]),e._v(" "),e.isOtherUser&&!e.user.is_local?a("a",{attrs:{href:e.user.statusnet_profile_url,target:"_blank"}},[a("i",{staticClass:"icon-link-ext usersettings"})]):e._e()],1),e._v(" "),a("router-link",{staticClass:"user-screen-name",attrs:{to:e.userProfileLink(e.user)}},[a("span",{staticClass:"handle"},[e._v("@"+e._s(e.user.screen_name)+"\n "),!e.hideBio&&e.visibleRole?a("span",{staticClass:"alert staff"},[e._v(e._s(e.visibleRole))]):e._e()]),e.user.locked?a("span",[a("i",{staticClass:"icon icon-lock"})]):e._e(),e._v(" "),e.hideUserStatsLocal||e.hideBio?e._e():a("span",{staticClass:"dailyAvg"},[e._v(e._s(e.dailyAvg)+" "+e._s(e.$t("user_card.per_day")))])])],1)],1),e._v(" "),a("div",{staticClass:"user-meta"},[e.user.follows_you&&e.loggedIn&&e.isOtherUser?a("div",{staticClass:"following"},[e._v("\n "+e._s(e.$t("user_card.follows_you"))+"\n ")]):e._e(),e._v(" "),!e.isOtherUser||!e.loggedIn&&e.switcher?e._e():a("div",{staticClass:"highlighter"},["disabled"!==e.userHighlightType?a("input",{directives:[{name:"model",rawName:"v-model",value:e.userHighlightColor,expression:"userHighlightColor"}],staticClass:"userHighlightText",attrs:{type:"text",id:"userHighlightColorTx"+e.user.id},domProps:{value:e.userHighlightColor},on:{input:function(t){t.target.composing||(e.userHighlightColor=t.target.value)}}}):e._e(),e._v(" "),"disabled"!==e.userHighlightType?a("input",{directives:[{name:"model",rawName:"v-model",value:e.userHighlightColor,expression:"userHighlightColor"}],staticClass:"userHighlightCl",attrs:{type:"color",id:"userHighlightColor"+e.user.id},domProps:{value:e.userHighlightColor},on:{input:function(t){t.target.composing||(e.userHighlightColor=t.target.value)}}}):e._e(),e._v(" "),a("label",{staticClass:"userHighlightSel select",attrs:{for:"style-switcher"}},[a("select",{directives:[{name:"model",rawName:"v-model",value:e.userHighlightType,expression:"userHighlightType"}],staticClass:"userHighlightSel",attrs:{id:"userHighlightSel"+e.user.id},on:{change:function(t){var a=Array.prototype.filter.call(t.target.options,function(e){return e.selected}).map(function(e){var t="_value"in e?e._value:e.value;return t});e.userHighlightType=t.target.multiple?a:a[0]}}},[a("option",{attrs:{value:"disabled"}},[e._v("No highlight")]),e._v(" "),a("option",{attrs:{value:"solid"}},[e._v("Solid bg")]),e._v(" "),a("option",{attrs:{value:"striped"}},[e._v("Striped bg")]),e._v(" "),a("option",{attrs:{value:"side"}},[e._v("Side stripe")])]),e._v(" "),a("i",{staticClass:"icon-down-open"})])])]),e._v(" "),e.isOtherUser?a("div",{staticClass:"user-interactions"},[e.loggedIn?a("div",{staticClass:"follow"},[e.user.following?a("span",[a("button",{staticClass:"pressed",attrs:{disabled:e.followRequestInProgress,title:e.$t("user_card.follow_unfollow")},on:{click:e.unfollowUser}},[e.followRequestInProgress?[e._v("\n "+e._s(e.$t("user_card.follow_progress"))+"\n ")]:[e._v("\n "+e._s(e.$t("user_card.following"))+"\n ")]],2)]):e._e(),e._v(" "),e.user.following?e._e():a("span",[a("button",{attrs:{disabled:e.followRequestInProgress,title:e.followRequestSent?e.$t("user_card.follow_again"):""},on:{click:e.followUser}},[e.followRequestInProgress?[e._v("\n "+e._s(e.$t("user_card.follow_progress"))+"\n ")]:e.followRequestSent?[e._v("\n "+e._s(e.$t("user_card.follow_sent"))+"\n ")]:[e._v("\n "+e._s(e.$t("user_card.follow"))+"\n ")]],2)])]):e._e(),e._v(" "),e.isOtherUser&&e.loggedIn?a("div",{staticClass:"mute"},[e.user.muted?a("span",[a("button",{staticClass:"pressed",on:{click:e.toggleMute}},[e._v("\n "+e._s(e.$t("user_card.muted"))+"\n ")])]):e._e(),e._v(" "),e.user.muted?e._e():a("span",[a("button",{on:{click:e.toggleMute}},[e._v("\n "+e._s(e.$t("user_card.mute"))+"\n ")])])]):e._e(),e._v(" "),!e.loggedIn&&e.user.is_local?a("div",{staticClass:"remote-follow"},[a("form",{attrs:{method:"POST",action:e.subscribeUrl}},[a("input",{attrs:{type:"hidden",name:"nickname"},domProps:{value:e.user.screen_name}}),e._v(" "),a("input",{attrs:{type:"hidden",name:"profile",value:""}}),e._v(" "),a("button",{staticClass:"remote-button",attrs:{click:"submit"}},[e._v("\n "+e._s(e.$t("user_card.remote_follow"))+"\n ")])])]):e._e(),e._v(" "),e.isOtherUser&&e.loggedIn?a("div",{staticClass:"block"},[e.user.statusnet_blocking?a("span",[a("button",{staticClass:"pressed",on:{click:e.unblockUser}},[e._v("\n "+e._s(e.$t("user_card.blocked"))+"\n ")])]):e._e(),e._v(" "),e.user.statusnet_blocking?e._e():a("span",[a("button",{on:{click:e.blockUser}},[e._v("\n "+e._s(e.$t("user_card.block"))+"\n ")])])]):e._e()]):e._e()])]),e._v(" "),e.hideBio?e._e():a("div",{staticClass:"panel-body"},[!e.hideUserStatsLocal&&e.switcher?a("div",{staticClass:"user-counts"},[a("div",{staticClass:"user-count",on:{click:function(t){t.preventDefault(),e.setProfileView("statuses")}}},[a("h5",[e._v(e._s(e.$t("user_card.statuses")))]),e._v(" "),a("span",[e._v(e._s(e.user.statuses_count)+" "),a("br")])]),e._v(" "),a("div",{staticClass:"user-count",on:{click:function(t){t.preventDefault(),e.setProfileView("friends")}}},[a("h5",[e._v(e._s(e.$t("user_card.followees")))]),e._v(" "),a("span",[e._v(e._s(e.user.friends_count))])]),e._v(" "),a("div",{staticClass:"user-count",on:{click:function(t){t.preventDefault(),e.setProfileView("followers")}}},[a("h5",[e._v(e._s(e.$t("user_card.followers")))]),e._v(" "),a("span",[e._v(e._s(e.user.followers_count))])])]):e._e(),e._v(" "),!e.hideBio&&e.user.description_html?a("p",{staticClass:"user-card-bio",domProps:{innerHTML:e._s(e.user.description_html)},on:{click:function(t){return t.preventDefault(),e.linkClicked(t)}}}):e.hideBio?e._e():a("p",{staticClass:"user-card-bio"},[e._v(e._s(e.user.description))])])])},staticRenderFns:[]}}]); +//# sourceMappingURL=app.77434de4e756a5d79672.js.map \ No newline at end of file diff --git a/priv/static/static/js/app.77434de4e756a5d79672.js.map b/priv/static/static/js/app.77434de4e756a5d79672.js.map new file mode 100644 index 000000000..5f68977a7 --- /dev/null +++ b/priv/static/static/js/app.77434de4e756a5d79672.js.map @@ -0,0 +1 @@ +{"version":3,"sources":["webpack:///static/js/app.77434de4e756a5d79672.js","webpack:///./src/main.js","webpack:///./src/services/api/api.service.js","webpack:///./src/components/timeline/timeline.vue","webpack:///./src/services/user_profile_link_generator/user_profile_link_generator.js","webpack:///./src/components/user_card/user_card.vue","webpack:///./src/services/color_convert/color_convert.js","webpack:///./src/services/file_type/file_type.service.js","webpack:///./src/services/style_setter/style_setter.js","webpack:///./src/components/basic_user_card/basic_user_card.vue","webpack:///./src/components/status/status.vue","webpack:///./src/components/user_avatar/user_avatar.vue","webpack:///./src/components/tab_switcher/tab_switcher.js","webpack:///./src/services/new_api/oauth.js","webpack:///./src/services/notification_utils/notification_utils.js","webpack:///./src/components/follow_card/follow_card.vue","webpack:///./src/components/post_status_form/post_status_form.vue","webpack:///./src/components/still-image/still-image.vue","webpack:///./src/hocs/with_list/with_list.js","webpack:///./src/i18n/messages.js","webpack:///./src/services/backend_interactor_service/backend_interactor_service.js","webpack:///./src/services/component_utils/component_utils.js","webpack:///./src/services/file_size_format/file_size_format.js","webpack:///./src/services/follow_manipulate/follow_manipulate.js","webpack:///./src/services/status_poster/status_poster.service.js","webpack:///./src/services/timeline_fetcher/timeline_fetcher.service.js","webpack:///./src/services/user_highlighter/user_highlighter.js","webpack:///./src/components/attachment/attachment.vue","webpack:///./src/components/chat_panel/chat_panel.vue","webpack:///./src/components/color_input/color_input.vue","webpack:///./src/components/conversation/conversation.vue","webpack:///./src/components/features_panel/features_panel.vue","webpack:///./src/components/instance_specific_panel/instance_specific_panel.vue","webpack:///./src/components/login_form/login_form.vue","webpack:///./src/components/notifications/notifications.vue","webpack:///./src/components/opacity_input/opacity_input.vue","webpack:///./src/components/style_switcher/style_switcher.vue","webpack:///./src/components/video_attachment/video_attachment.vue","webpack:///./src/boot/after_store.js","webpack:///./src/boot/routes.js","webpack:///./src/hocs/with_load_more/with_load_more.js","webpack:///./src/hocs/with_subscription/with_subscription.js","webpack:///./src/lib/persisted_state.js","webpack:///./src/lib/push_notifications_plugin.js","webpack:///./src/modules/api.js","webpack:///./src/modules/chat.js","webpack:///./src/modules/config.js","webpack:///./src/modules/errors.js","webpack:///./src/modules/instance.js","webpack:///./src/modules/interface.js","webpack:///./src/modules/media_viewer.js","webpack:///./src/modules/oauth.js","webpack:///./src/modules/oauth_tokens.js","webpack:///./src/modules/statuses.js","webpack:///./src/modules/users.js","webpack:///./src/services/completion/completion.js","webpack:///./src/services/entity_normalizer/entity_normalizer.service.js","webpack:///./src/services/errors/errors.js","webpack:///./src/services/follow_request_fetcher/follow_request_fetcher.service.js","webpack:///./src/services/matcher/matcher.service.js","webpack:///./src/services/new_api/user_search.js","webpack:///./src/services/new_api/utils.js","webpack:///./src/services/notifications_fetcher/notifications_fetcher.service.js","webpack:///./src/services/push/push.js","webpack:///color_input.vue","webpack:///contrast_ratio.vue","webpack:///export_import.vue","webpack:///interface_language_switcher.vue","webpack:///opacity_input.vue","webpack:///range_input.vue","webpack:///./src/App.js","webpack:///./src/components/about/about.js","webpack:///./src/components/attachment/attachment.js","webpack:///./src/components/basic_user_card/basic_user_card.js","webpack:///./src/components/block_card/block_card.js","webpack:///./src/components/chat_panel/chat_panel.js","webpack:///./src/components/conversation-page/conversation-page.js","webpack:///./src/components/conversation/conversation.js","webpack:///./src/components/delete_button/delete_button.js","webpack:///./src/components/dm_timeline/dm_timeline.js","webpack:///./src/components/favorite_button/favorite_button.js","webpack:///./src/components/features_panel/features_panel.js","webpack:///./src/components/follow_card/follow_card.js","webpack:///./src/components/follow_request_card/follow_request_card.js","webpack:///./src/components/follow_requests/follow_requests.js","webpack:///./src/components/font_control/font_control.js","webpack:///./src/components/friends_timeline/friends_timeline.js","webpack:///./src/components/gallery/gallery.js","webpack:///./src/components/image_cropper/image_cropper.js","webpack:///./src/components/instance_specific_panel/instance_specific_panel.js","webpack:///./src/components/link-preview/link-preview.js","webpack:///./src/components/login_form/login_form.js","webpack:///./src/components/media_modal/media_modal.js","webpack:///./src/components/media_upload/media_upload.js","webpack:///./src/components/mentions/mentions.js","webpack:///./src/components/mobile_post_status_modal/mobile_post_status_modal.js","webpack:///./src/components/mute_card/mute_card.js","webpack:///./src/components/nav_panel/nav_panel.js","webpack:///./src/components/notification/notification.js","webpack:///./src/components/notifications/notifications.js","webpack:///./src/components/oauth_callback/oauth_callback.js","webpack:///./src/components/post_status_form/post_status_form.js","webpack:///./src/components/public_and_external_timeline/public_and_external_timeline.js","webpack:///./src/components/public_timeline/public_timeline.js","webpack:///./src/components/registration/registration.js","webpack:///./src/components/retweet_button/retweet_button.js","webpack:///./src/components/settings/settings.js","webpack:///./src/components/shadow_control/shadow_control.js","webpack:///./src/components/side_drawer/side_drawer.js","webpack:///./src/components/status/status.js","webpack:///./src/components/status_or_conversation/status_or_conversation.js","webpack:///./src/components/still-image/still-image.js","webpack:///./src/components/style_switcher/style_switcher.js","webpack:///./src/components/tag_timeline/tag_timeline.js","webpack:///./src/components/terms_of_service_panel/terms_of_service_panel.js","webpack:///./src/components/timeline/timeline.js","webpack:///./src/components/user_avatar/user_avatar.js","webpack:///./src/components/user_card/user_card.js","webpack:///./src/components/user_finder/user_finder.js","webpack:///./src/components/user_panel/user_panel.js","webpack:///./src/components/user_profile/user_profile.js","webpack:///./src/components/user_search/user_search.js","webpack:///./src/components/user_settings/user_settings.js","webpack:///./src/components/video_attachment/video_attachment.js","webpack:///./src/components/who_to_follow/who_to_follow.js","webpack:///./src/components/who_to_follow_panel/who_to_follow_panel.js","webpack:///./src/i18n/ar.json","webpack:///./src/i18n/ca.json","webpack:///./src/i18n/cs.json","webpack:///./src/i18n/de.json","webpack:///./src/i18n/en.json","webpack:///./src/i18n/eo.json","webpack:///./src/i18n/es.json","webpack:///./src/i18n/et.json","webpack:///./src/i18n/fi.json","webpack:///./src/i18n/fr.json","webpack:///./src/i18n/ga.json","webpack:///./src/i18n/he.json","webpack:///./src/i18n/hu.json","webpack:///./src/i18n/it.json","webpack:///./src/i18n/ja.json","webpack:///./src/i18n/ko.json","webpack:///./src/i18n/nb.json","webpack:///./src/i18n/nl.json","webpack:///./src/i18n/oc.json","webpack:///./src/i18n/pl.json","webpack:///./src/i18n/pt.json","webpack:///./src/i18n/ro.json","webpack:///./src/i18n/ru.json","webpack:///./src/i18n/zh.json","webpack:///./static/timeago-cs.json","webpack:///./static/timeago-en.json","webpack:///./static/timeago-ja.json","webpack:///./src/assets/nsfw.png","webpack:///./src/App.vue","webpack:///./src/components/about/about.vue","webpack:///./src/components/block_card/block_card.vue","webpack:///./src/components/contrast_ratio/contrast_ratio.vue","webpack:///./src/components/conversation-page/conversation-page.vue","webpack:///./src/components/delete_button/delete_button.vue","webpack:///./src/components/dm_timeline/dm_timeline.vue","webpack:///./src/components/export_import/export_import.vue","webpack:///./src/components/favorite_button/favorite_button.vue","webpack:///./src/components/follow_request_card/follow_request_card.vue","webpack:///./src/components/follow_requests/follow_requests.vue","webpack:///./src/components/font_control/font_control.vue","webpack:///./src/components/friends_timeline/friends_timeline.vue","webpack:///./src/components/gallery/gallery.vue","webpack:///./src/components/image_cropper/image_cropper.vue","webpack:///./src/components/interface_language_switcher/interface_language_switcher.vue","webpack:///./src/components/link-preview/link-preview.vue","webpack:///./src/components/media_modal/media_modal.vue","webpack:///./src/components/media_upload/media_upload.vue","webpack:///./src/components/mentions/mentions.vue","webpack:///./src/components/mobile_post_status_modal/mobile_post_status_modal.vue","webpack:///./src/components/mute_card/mute_card.vue","webpack:///./src/components/nav_panel/nav_panel.vue","webpack:///./src/components/notification/notification.vue","webpack:///./src/components/oauth_callback/oauth_callback.vue","webpack:///./src/components/public_and_external_timeline/public_and_external_timeline.vue","webpack:///./src/components/public_timeline/public_timeline.vue","webpack:///./src/components/range_input/range_input.vue","webpack:///./src/components/registration/registration.vue","webpack:///./src/components/retweet_button/retweet_button.vue","webpack:///./src/components/settings/settings.vue","webpack:///./src/components/shadow_control/shadow_control.vue","webpack:///./src/components/side_drawer/side_drawer.vue","webpack:///./src/components/status_or_conversation/status_or_conversation.vue","webpack:///./src/components/style_switcher/preview.vue","webpack:///./src/components/tag_timeline/tag_timeline.vue","webpack:///./src/components/terms_of_service_panel/terms_of_service_panel.vue","webpack:///./src/components/user_finder/user_finder.vue","webpack:///./src/components/user_panel/user_panel.vue","webpack:///./src/components/user_profile/user_profile.vue","webpack:///./src/components/user_search/user_search.vue","webpack:///./src/components/user_settings/user_settings.vue","webpack:///./src/components/who_to_follow/who_to_follow.vue","webpack:///./src/components/who_to_follow_panel/who_to_follow_panel.vue","webpack:///./src/components/notifications/notifications.vue?110d","webpack:///./src/components/mobile_post_status_modal/mobile_post_status_modal.vue?9ce8","webpack:///./src/components/timeline/timeline.vue?553c","webpack:///./src/components/follow_requests/follow_requests.vue?81fe","webpack:///./src/components/user_avatar/user_avatar.vue?085f","webpack:///./src/components/post_status_form/post_status_form.vue?6c54","webpack:///./src/components/conversation/conversation.vue?d3cb","webpack:///./src/components/tag_timeline/tag_timeline.vue?ba5d","webpack:///./src/components/who_to_follow/who_to_follow.vue?e568","webpack:///./src/components/retweet_button/retweet_button.vue?f246","webpack:///./src/components/terms_of_service_panel/terms_of_service_panel.vue?c990","webpack:///./src/components/contrast_ratio/contrast_ratio.vue?ff01","webpack:///./src/components/follow_card/follow_card.vue?43f5","webpack:///./src/components/mute_card/mute_card.vue?de60","webpack:///./src/components/mentions/mentions.vue?4c17","webpack:///./src/components/public_and_external_timeline/public_and_external_timeline.vue?f3ad","webpack:///./src/components/chat_panel/chat_panel.vue?b29f","webpack:///./src/components/follow_request_card/follow_request_card.vue?f245","webpack:///./src/components/interface_language_switcher/interface_language_switcher.vue?8c7d","webpack:///./src/components/user_finder/user_finder.vue?fdda","webpack:///./src/components/oauth_callback/oauth_callback.vue?cb4c","webpack:///./src/components/status_or_conversation/status_or_conversation.vue?6082","webpack:///./src/components/login_form/login_form.vue?bf4a","webpack:///./src/components/registration/registration.vue?0694","webpack:///./src/components/features_panel/features_panel.vue?9cbe","webpack:///./src/components/user_profile/user_profile.vue?0a18","webpack:///./src/components/attachment/attachment.vue?0a61","webpack:///./src/components/font_control/font_control.vue?23c1","webpack:///./src/App.vue?ed72","webpack:///./src/components/opacity_input/opacity_input.vue?60ce","webpack:///./src/components/about/about.vue?4e84","webpack:///./src/components/video_attachment/video_attachment.vue?87e2","webpack:///./src/components/block_card/block_card.vue?279e","webpack:///./src/components/media_upload/media_upload.vue?6fd6","webpack:///./src/components/media_modal/media_modal.vue?e269","webpack:///./src/components/dm_timeline/dm_timeline.vue?c8f5","webpack:///./src/components/user_search/user_search.vue?817e","webpack:///./src/components/public_timeline/public_timeline.vue?a42e","webpack:///./src/components/range_input/range_input.vue?b975","webpack:///./src/components/basic_user_card/basic_user_card.vue?3aaf","webpack:///./src/components/notification/notification.vue?a4a9","webpack:///./src/components/side_drawer/side_drawer.vue?c7de","webpack:///./src/components/shadow_control/shadow_control.vue?090f","webpack:///./src/components/conversation-page/conversation-page.vue?e263","webpack:///./src/components/still-image/still-image.vue?29e1","webpack:///./src/components/link-preview/link-preview.vue?8bca","webpack:///./src/components/color_input/color_input.vue?40b2","webpack:///./src/components/status/status.vue?9dd7","webpack:///./src/components/instance_specific_panel/instance_specific_panel.vue?6986","webpack:///./src/components/image_cropper/image_cropper.vue?5629","webpack:///./src/components/friends_timeline/friends_timeline.vue?e2be","webpack:///./src/components/user_settings/user_settings.vue?b71a","webpack:///./src/components/delete_button/delete_button.vue?a06e","webpack:///./src/components/style_switcher/style_switcher.vue?7da7","webpack:///./src/components/style_switcher/preview.vue?ecf9","webpack:///./src/components/favorite_button/favorite_button.vue?95b5","webpack:///./src/components/settings/settings.vue?8fb0","webpack:///./src/components/nav_panel/nav_panel.vue?2994","webpack:///./src/components/gallery/gallery.vue?5160","webpack:///./src/components/who_to_follow_panel/who_to_follow_panel.vue?b7e9","webpack:///./src/components/export_import/export_import.vue?6650","webpack:///./src/components/user_panel/user_panel.vue?cc0b","webpack:///./src/components/user_card/user_card.vue?91fc"],"names":["webpackJsonp","module","exports","__webpack_require__","_interopRequireDefault","obj","__esModule","default","_vue","_vue2","_vueRouter","_vueRouter2","_vuex","_vuex2","_interface","_interface2","_instance","_instance2","_statuses","_statuses2","_users","_users2","_api","_api2","_config","_config2","_chat","_chat2","_oauth","_oauth2","_media_viewer","_media_viewer2","_oauth_tokens","_oauth_tokens2","_vueTimeago","_vueTimeago2","_vueI18n","_vueI18n2","_persisted_state","_persisted_state2","_push_notifications_plugin","_push_notifications_plugin2","_messages","_messages2","_vueChatScroll","_vueChatScroll2","_after_store","_after_store2","currentLocale","window","navigator","language","split","Vue","use","Vuex","VueRouter","VueTimeago","locale","locales","cs","en","ja","VueI18n","VueChatScroll","i18n","fallbackLocale","messages","persistedStateOptions","paths","then","persistedState","store","Store","modules","interface","interfaceModule","instance","instanceModule","statuses","statusesModule","users","usersModule","api","apiModule","config","configModule","chat","chatModule","oauth","oauthModule","mediaViewer","mediaViewerModule","oauthTokens","oauthTokensModule","plugins","pushNotifications","strict","___pleromafe_mode","NODE_ENV","___pleromafe_commit_hash","___pleromafe_dev_overrides","Object","defineProperty","value","_promise","_promise2","_map2","_map3","_each2","_each3","_entity_normalizerService","_errors","LOGIN_URL","FRIENDS_TIMELINE_URL","ALL_FOLLOWING_URL","PUBLIC_TIMELINE_URL","PUBLIC_AND_EXTERNAL_TIMELINE_URL","TAG_TIMELINE_URL","FAVORITE_URL","UNFAVORITE_URL","RETWEET_URL","UNRETWEET_URL","STATUS_UPDATE_URL","STATUS_DELETE_URL","STATUS_URL","MEDIA_UPLOAD_URL","CONVERSATION_URL","MENTIONS_URL","DM_TIMELINE_URL","FOLLOWERS_URL","FRIENDS_URL","BLOCKS_URL","FOLLOWING_URL","UNFOLLOWING_URL","QVITTER_USER_PREF_URL","REGISTRATION_URL","AVATAR_UPDATE_URL","BG_UPDATE_URL","BANNER_UPDATE_URL","PROFILE_UPDATE_URL","EXTERNAL_PROFILE_URL","QVITTER_USER_TIMELINE_URL","QVITTER_USER_NOTIFICATIONS_URL","QVITTER_USER_NOTIFICATIONS_READ_URL","BLOCKING_URL","UNBLOCKING_URL","USER_URL","FOLLOW_IMPORT_URL","DELETE_ACCOUNT_URL","CHANGE_PASSWORD_URL","FOLLOW_REQUESTS_URL","APPROVE_USER_URL","DENY_USER_URL","SUGGESTIONS_URL","MASTODON_USER_FAVORITES_TIMELINE_URL","oldfetch","fetch","url","options","baseUrl","fullUrl","credentials","updateAvatar","_ref","params","form","FormData","key","append","headers","authHeaders","method","body","data","json","updateBg","_ref2","updateBanner","_ref3","updateProfile","_ref4","fields","includes","register","getCaptcha","resp","accessToken","Authorization","externalProfile","_ref5","profileUrl","followUser","_ref6","id","unfollowUser","_ref7","blockUser","_ref8","unblockUser","_ref9","approveUser","_ref10","denyUser","_ref11","fetchUser","_ref12","response","resolve","reject","ok","StatusCodeError","status","parseUser","fetchFriends","_ref13","page","map","exportFriends","_ref14","fetchFollowers","_ref15","fetchAllFollowing","_ref16","username","fetchFollowRequests","_ref17","fetchConversation","_ref18","Error","parseStatus","fetchStatus","_ref19","setUserMute","_ref20","_ref20$muted","muted","undefined","muteInteger","fetchTimeline","_ref21","timeline","_ref21$since","since","_ref21$until","until","_ref21$userId","userId","_ref21$tag","tag","timelineUrls","public","friends","mentions","dms","notifications","publicAndExternal","user","media","favorites","isNotifications","push","queryString","param","join","parseNotification","verifyCredentials","error","favorite","_ref22","unfavorite","_ref23","retweet","_ref24","unretweet","_ref25","postStatus","_ref26","spoilerText","visibility","sensitive","mediaIds","inReplyToStatusId","contentType","noAttachmentLinks","idsText","deleteStatus","_ref27","uploadMedia","_ref28","formData","text","DOMParser","parseFromString","followImport","_ref29","deleteAccount","_ref30","password","changePassword","_ref31","newPassword","newPasswordConfirmation","fetchMutes","_ref32","fetchBlocks","_ref33","fetchOAuthTokens","_ref34","revokeOAuthToken","_ref35","suggestions","_ref36","markNotificationsAsSeen","_ref37","apiService","Component","_includes2","_includes3","generateProfileLink","screenName","restrictedNicknames","complicated","isExternal","name","alphaBlend","getContrastRatio","invert","mixrgb","hex2rgb","rgb2hex","_keys","_keys2","_slicedToArray2","_slicedToArray3","_typeof2","_typeof3","_map4","_map5","r","g","b","_r","val","Math","ceil","toString","slice","c2linear","bit","c","pow","srgbToLinear","srgb","reduce","acc","relativeLuminance","_srgbToLinear","a","la","lb","l1","l2","fg","fga","bg","rgb","hex","result","exec","parseInt","k","fileType","mimetype","match","fileMatchesSomeType","types","file","some","type","fileTypeService","getCssShadowFilter","getCssShadow","composePreset","getThemes","generatePreset","generateFonts","generateShadows","generateRadii","generateColors","getTextColor","applyTheme","setPreset","setStyle","_entries","_entries2","_extends2","_extends3","_assign","_assign2","_times2","_times3","_chromatism","_color_convert","href","commit","head","document","style","display","cssEl","createElement","setAttribute","appendChild","setDynamic","baseEl","colors","n","toUpperCase","color","getComputedStyle","getPropertyValue","removeChild","styleEl","addEventListener","rgb2rgba","rgba","preserve","bgIsLight","convert","hsl","l","textIsLight","base","invertLightness","contrastRatio","input","_generatePreset","rules","theme","styleSheet","sheet","insertRule","radii","shadows","fonts","usesDropShadow","length","filter","_","inset","shad","x","y","blur","spread","concat","getCssColor","alpha","Number","startsWith","opacity","alert","faint","v","col","isLightOnDark","mod","lightText","brightness","link","lightBg","fgText","fgLink","border","btn","btnText","inputText","panel","panelText","panelLink","panelFaint","topBar","topBarText","topBarLink","faintLink","icon","cBlue","cRed","cGreen","cOrange","alertError","alertErrorText","alertErrorPanelText","badgeNotification","badgeNotificationText","forEach","console","htmlColors","solid","complete","inputRadii","btnRadius","endsWith","e","checkbox","avatar","avatarAlt","tooltip","attachment","family","post","postCode","top","shadow","buttonInsetFakeBorders","inputInsetFakeBorders","hoverGlow","popup","avatarStatus","panelHeader","button","buttonHover","buttonPressed","themes","all","_ref38","catch","promises","_ref39","_ref40","_ref41","_ref42","isV1","Array","isArray","bgRgb","fgRgb","textRgb","linkRgb","cRedRgb","cGreenRgb","cBlueRgb","cOrangeRgb","themeLoaded","component","props","active","this","$slots","findIndex","methods","activateTab","index","_this","beforeUpdate","currentSlot","render","h","_this2","tabs","slot","classesTab","classesWrapper","class","attrs","disabled","on","click","label","contents","renderOnlyFocused","_reduce2","_reduce3","getOrCreateApp","random","location","origin","login","args","app","response_type","client_id","redirect_uri","scope","dataString","encoded","encodeURIComponent","getTokenWithCredentials","client_secret","getToken","code","unseenNotificationsFromStore","visibleNotificationsFromStore","visibleTypes","notificationsFromStore","_isNan","_isNan2","_sortBy2","_sortBy3","_filter2","_filter3","state","notificationVisibility","likes","repeats","follows","sortById","seqA","action","seqB","isSeqA","isSeqB","sortedNotifications","sort","notification","seen","_map","_isEmpty","_isEmpty2","defaultEntryPropsGetter","entry","defaultKeyGetter","withList","_ref$getEntryProps","getEntryProps","_ref$getKey","getKey","ItemComponent","arguments","entries","$props","entryProps","entryListeners","empty","ar","ca","de","eo","es","et","fi","fr","ga","he","hu","it","ko","nb","nl","oc","pl","pt","ro","ru","zh","_apiService","_apiService2","_timeline_fetcherService","_timeline_fetcherService2","backendInteractorService","startFetching","_ref8$userId","timelineFetcherService","_ref9$muted","backendInteractorServiceInstance","getComponentProps","getComponentOptions","_isFunction","_isFunction2","fileSizeFormat","num","exponent","unit","units","min","floor","log","toFixed","fileSizeFormatService","requestUnfollow","requestFollow","attempt","setTimeout","backendInteractor","following","updated","locked","sent","_ref$media","_ref$inReplyToStatusI","_ref$contentType","currentUser","dispatch","showImmediately","noIdUpdate","err","message","xml","getElementsByTagName","mediaData","textContent","image","getAttribute","statusPosterService","_camelCase2","_camelCase3","update","ccTimeline","fetchAndUpdate","_ref2$timeline","_ref2$older","older","_ref2$showImmediately","_ref2$userId","_ref2$tag","rootState","timelineData","timelines","minId","maxId","numStatusesBeforeFetch","loading","_ref3$timeline","_ref3$userId","_ref3$tag","visibleStatuses","boundFetchAndUpdate","setInterval","timelineFetcher","highlightStyle","highlightClass","prefs","solidColor","tintColor","tintColor2","backgroundImage","backgroundPosition","backgroundColor","screen_name","replace","_routes","_routes2","_App","_App2","afterStoreSetup","res","_data$site","site","registrationClosed","closed","textlimit","uploadlimit","server","vapidPublicKey","avatarlimit","backgroundlimit","bannerlimit","apiConfig","pleromafe","warn","staticConfig","overrides","env","staticConfigPreference","copyInstanceOption","logoMask","logoMargin","chatDisabled","router","mode","routes","scrollBehavior","to","_from","savedPosition","matched","m","meta","dontScroll","el","App","html","values","emoji","shortcode","image_url","failure","utf","metadata","features","postFormats","enabled","web","_public_timeline","_public_timeline2","_public_and_external_timeline","_public_and_external_timeline2","_friends_timeline","_friends_timeline2","_tag_timeline","_tag_timeline2","_conversationPage","_conversationPage2","_mentions","_mentions2","_dm_timeline","_dm_timeline2","_user_profile","_user_profile2","_settings","_settings2","_registration","_registration2","_user_settings","_user_settings2","_follow_requests","_follow_requests2","_oauth_callback","_oauth_callback2","_user_search","_user_search2","_notifications","_notifications2","_login_form","_login_form2","_chat_panel","_chat_panel2","_who_to_follow","_who_to_follow2","_about","_about2","path","redirect","_to","redirectRootLogin","redirectRootNoLogin","PublicAndExternalTimeline","PublicTimeline","FriendsTimeline","TagTimeline","ConversationPage","UserProfile","Mentions","DMs","Settings","Registration","FollowRequests","UserSettings","Notifications","LoginForm","ChatPanel","floating","OAuthCallback","route","query","UserSearch","WhoToFollow","About","_defineProperty2","_defineProperty3","_extends4","_component_utils","withLoadMore","select","destroy","_ref$childPropName","childPropName","_ref$additionalPropNa","additionalPropNames","WrappedComponent","originalProps","$listeners","scopedSlots","$scopedSlots","children","fetchEntries","$t","bottomedOut","computed","$store","created","scrollLoad","destroyed","removeEventListener","newEntries","bodyBRect","getBoundingClientRect","height","max","$el","offsetHeight","innerHeight","pageYOffset","_toConsumableArray2","_toConsumableArray3","withSubscription","fetchData","fetchedData","refresh","createPersistedState","_ref$key","_ref$paths","_ref$getState","getState","storage","getItem","_ref$setState","setState","loaded","setItem","_ref$reducer","reducer","defaultReducer","_ref$storage","defaultStorage","_ref$subscriber","subscriber","handler","subscribe","savedState","usersState","usersObject","replaceState","_lodash2","customTheme","token","mutation","saveImmedeatelyActions","success","_lodash","_objectPath","_objectPath2","_localforage","_localforage2","substate","objectPath","set","get","localforage","webPushNotification","webPushNotifications","permission","notificationPermission","isUserMutation","isVapidMutation","payload","isPermMutation","isUserConfigMutation","isVisibilityMutation","_backend_interactor_service","_backend_interactor_service2","_phoenix","fetchers","socket","followRequests","mutations","setBackendInteractor","addFetcher","fetcher","removeFetcher","setWsToken","wsToken","setSocket","setChatDisabled","setFollowRequests","actions","stopFetching","clearInterval","initializeSocket","Socket","connect","disableChat","removeFollowRequest","request","requests","channel","setChannel","addMessage","setMessages","disconnectFromChat","disconnect","initializeChat","msg","_style_setter","browserLocale","defaultState","collapseMessageWithSubject","hideAttachments","hideAttachmentsInConv","maxThumbnails","hideNsfw","preloadImage","loopVideo","loopVideoSilentOnly","autoLoad","streaming","hoverPreview","pauseOnUnfocused","stopGifs","replyVisibility","muteWords","highlight","interfaceLanguage","scopeCopy","subjectLineBehavior","alwaysShowSubjectInput","postContentType","setOption","setHighlight","delete","humanizeErrors","errors","errs","_capitalize3","_capitalize2","registrationOpen","background","logo","showInstanceSpecificPanel","scopeOptionsEnabled","formattingOptionsEnabled","hidePostStats","hideUserStats","hideFilteredStatuses","loginMethod","nsfwCensorImage","showFeaturesPanel","pleromaBackend","customEmoji","mediaProxyAvailable","chatAvailable","gopherAvailable","suggestionsEnabled","suggestionsWeb","instanceSpecificPanelContent","tos","setInstanceOption","setTheme","themeName","settings","currentSaveStateNotice","noticeClearTimeout","browserSupport","cssFilter","CSS","supports","interfaceMod","settingsSaved","clearTimeout","errorData","setNotificationPermission","setPageTitle","option","title","_file_typeService","_file_typeService2","currentIndex","activated","setMedia","setCurrent","close","attachments","current","indexOf","closeMediaViewer","setClientData","setToken","tokens","fetchTokens","revokeToken","swapTokens","prepareStatus","_set","_set2","_isArray2","_isArray3","_last2","_last3","_first2","_first3","_merge2","_merge3","_minBy2","_minBy3","_maxBy2","_maxBy3","_find2","_find3","_slice2","_slice3","_remove2","_remove3","emptyTl","statusesObject","faves","visibleStatusesObject","newStatusCount","minVisibleId","followers","flushMarker","allStatuses","allStatusesObject","desktopNotificationSilence","POSITIVE_INFINITY","idStore","fetcherId","deleted","visibleNotificationTypes","mergeOrAdd","arr","item","oldItem","splice","new","sortTimeline","addNewStatuses","_ref$showImmediately","_ref$user","_ref$noIdUpdate","timelineObject","maxNew","minNew","newer","addStatus","addToTimeline","attentions","resultForCurrentTimeline","favoriteStatus","counter","in_reply_to_status_id","favorited","fave_num","processors","retweetedStatus","retweeted_status","s","has","add","deletion","uri","follow","unknown","processor","addNewNotifications","hasOwnProperty","Notification","notifObj","profile_image_url","nsfw","bind","removeStatus","showNewStatuses","oldTimeline","setNotificationFetcher","resetStatuses","emptyState","clearTimeline","setFavorited","newStatus","setFavoritedConfirm","setRetweeted","repeated","setDeleted","setLoading","setNsfw","setError","setNotificationsLoading","setNotificationsError","setNotificationsSilence","queueFlush","_ref22$showImmediatel","_ref22$timeline","_ref22$noIdUpdate","stopFetchingNotifications","getters","_regenerator","_regenerator2","_asyncToGenerator2","_asyncToGenerator3","_compact2","_compact3","_push","getNotificationPermission","requestPermission","setMuted","setCurrentUser","lastLoginName","clearCurrentUser","beginLogin","loggingIn","endLogin","addFriends","friend","friendsPage","addFollowers","follower","followersPage","clearFriends","clearFollowers","addNewUsers","saveBlocks","blockIds","saveMutes","muteIds","setUserForStatus","setUserForNotification","from_profile","setColor","highlighted","signUpPending","signUpErrors","signUpSuccess","signUpFailure","userById","find","userByName","toLowerCase","blocks","mutedUsers","muteUser","unmuteUser","fetchBy","registerPushNotifications","isEnabled","unregisterPushNotifications","retweetedUsers","notificationIds","notificationsObject","relevantNotifications","signUp","_x","_x2","apply","mark","_callee","userInfo","_data","wrap","_context","prev","next","oauthApi","access_token","JSON","parse","ap_id","stop","_x3","_callee2","_context2","abrupt","logout","loginUser","splitIntoWords","addPositionToWords","wordAtPosition","replaceWord","str","toReplace","replacement","start","end","pos","words","wordsWithPosition","word","previous","pop","regex","triggers","matches","completion","qvitterStatusType","is_post_verb","qvitter_delete_notice","activity_type","output","masto","mastoShort","String","acct","name_html","display_name","description","description_html","note","profile_image_url_original","cover_photo","header","friends_count","following_count","bot","statusnet_profile_url","pleroma","follows_you","statusnet_blocking","is_local","role","show_role","rights","no_rich_text","default_scope","hide_follows","hide_followers","background_image","created_at","Date","followers_count","statuses_count","follow_request_count","parseAttachment","favourited","favourites_count","reblogged","repeat_num","reblogs_count","reblog","statusnet_html","content","in_reply_to_id","in_reply_to_user_id","in_reply_to_account_id","in_reply_to_screen_name","statusnet_conversation_id","summary","spoiler_text","summary_html","external_url","isNsfw","card","account","media_attachments","mastoDict","favourite","parsedNotice","notice","ntype","Boolean","is_seen","favorited_status","nsfwRegex","tags","statusCode","_stringify2","captureStackTrace","_create","_create2","_stringify","prototype","constructor","followRequestFetcher","extractTagFromUrl","mentionMatchesUrl","attention","_attention$screen_nam","_attention$screen_nam2","namepart","instancepart","matchstring","RegExp","_utils","_utils2","search","utils","queryParams","_ref$method","unread","notificationsFetcher","urlBase64ToUint8Array","base64String","padding","repeat","base64","rawData","atob","Uint8Array","from","char","charCodeAt","isPushSupported","getOrCreateServiceWorker","runtime","subscribePush","registration","subscribeOptions","userVisibleOnly","applicationServerKey","pushManager","unsubscribePush","getSubscription","subscribtion","unsubscribe","deleteSubscriptionFromBackEnd","Content-Type","sendSubscriptionToBackEnd","subscription","alerts","mention","responseData","unsubResult","unregister","_runtime","_runtime2","present","hint","levelVal","contrast","aaa","aa","level","context","ratio","hint_18pt","laaa","laa","importFailed","exportData","stringified","exportObject","btoa","importData","filePicker","event","target","files","reader","FileReader","onload","parsed","valid","validator","onImport","readAsText","_iso","_iso2","languageCodes","languageNames","getName","$i18n","_user_panel","_user_panel2","_nav_panel","_nav_panel2","_user_finder","_user_finder2","_instance_specific_panel","_instance_specific_panel2","_features_panel","_features_panel2","_who_to_follow_panel","_who_to_follow_panel2","_media_modal","_media_modal2","_side_drawer","_side_drawer2","_mobile_post_status_modal","_mobile_post_status_modal2","_notification_utils","components","UserPanel","NavPanel","UserFinder","InstanceSpecificPanel","FeaturesPanel","WhoToFollowPanel","MediaModal","SideDrawer","MobilePostStatusModal","mobileActivePanel","finderHidden","supportsMask","enableMask","logoStyle","logoMaskStyle","mask-image","background-color","logoBgStyle","margin","bgStyle","background-image","bgAppStyle","--body-background-image","sitename","unseenNotifications","unseenNotificationsCount","scrollToTop","scrollTo","$router","onFinderToggled","hidden","toggleMobileSidebar","$refs","sideDrawer","toggleDrawer","_terms_of_service_panel","_terms_of_service_panel2","TermsOfServicePanel","_stillImage","_stillImage2","_video_attachment","_video_attachment2","_nsfw","_nsfw2","Attachment","nsfwImage","hideNsfwLocal","img","modalOpen","showHidden","StillImage","VideoAttachment","usePlaceHolder","size","referrerpolicy","isEmpty","oembed","isSmall","fullwidth","linkClicked","tagName","open","openModal","modalTypes","playVideosInModal","stopPropagation","preventDefault","toggleHidden","useOneClickNsfw","src","_user_card","_user_card2","_user_avatar","_user_avatar2","_user_profile_link_generator","_user_profile_link_generator2","BasicUserCard","userExpanded","UserCard","UserAvatar","toggleUserExpanded","userProfileLink","_basic_user_card","_basic_user_card2","BlockCard","progress","blocked","chatPanel","currentMessage","collapsed","submit","togglePanel","_conversation","_conversation2","conversationPage","Conversation","statusoid","$route","_status","_status2","sortAndFilterConversation","conversation","statusId","conversationId","replies","i","irid","Status","watch","getReplies","focused","DeleteButton","confirmed","confirm","canDelete","delete_others_notice","_timeline","_timeline2","Timeline","FavoriteButton","hidePostStatsLocal","animated","classes","icon-star-empty","icon-star","animate-spin","gopher","whoToFollow","mediaProxy","scopeOptions","_follow_manipulate","FollowCard","inProgress","requestSent","isMe","showFollow","FollowRequestCard","_follow_request_card","_follow_request_card2","lValue","availableOptions","noInherit","dValue","fallback","$emit","isCustom","preset","_dropRight2","_dropRight3","_chunk2","_chunk3","_attachment","_attachment2","Gallery","width","mounted","resize","rows","lastAttachment","allButLastRow","rowHeight","itemsPerRow","useContainFit","_cropperjs","_cropperjs2","ImageCropper","trigger","Element","required","submitHandler","Function","cropperOptions","aspectRatio","autoCropArea","viewMode","movable","zoomable","guides","mimes","saveButtonLabel","cancelButtonLabel","cropper","dataUrl","filename","submitting","submitError","saveText","cancelText","submitErrorMsg","avatarUploadError","finally","pickImage","createCropper","Cropper","getTriggerDOM","querySelector","readFile","fileInput","readAsDataURL","clearError","beforeDestroy","show","hideISP","LinkPreview","useImage","useDescription","test","authError","oAuthLogin","showing","currentMedia","canNavigate","hide","goPrev","prevIndex","goNext","nextIndex","handleKeyupEvent","keyCode","handleKeydownEvent","_status_posterService","_status_posterService2","_file_size_format","_file_size_format2","mediaUpload","uploading","uploadReady","uploadFile","self","filesize","allowedsize","filesizeunit","allowedsizeunit","fileData","fileDrop","dataTransfer","fileDrag","contains","dropEffect","clearFile","$nextTick","change","dropFiles","fileInfos","_throttle2","_throttle3","_post_status_form","_post_status_form2","PostStatusForm","postFormOpen","scrollingDown","inputActive","oldScrollPos","amountScrolled","handleScroll","handleOSK","isHidden","openPostForm","focus","closePostForm","smallPhone","innerWidth","smallPhoneKbOpen","biggerPhone","biggerPhoneKbOpen","scrollAmount","scrollY","MuteCard","_follow_request_fetcher","_follow_request_fetcher2","followRequestCount","_user_highlighter","betterShadow","userClass","userStyle","_notification","_notification2","_notifications_fetcherService","_notifications_fetcherService2","visibleNotifications","unseenCount","count","markAsSeen","fetchOlderNotifications","notifs","oac","_uniqBy2","_uniqBy3","_reject2","_reject3","_take2","_take3","_media_upload","_media_upload2","_completion","_completion2","buildMentionsString","allAttentions","unshift","MediaUpload","textarea","textLength","setSelectionRange","replyTo","statusText","repliedUser","copyMessageScope","submitDisabled","posting","subject","caret","vis","selected","unlisted","private","direct","candidates","firstchar","textAtCaret","charAt","matchedUsers","matchedEmoji","wordAtCaret","Completion","statusLength","spoilerTextLength","statusLengthLimit","hasStatusLengthLimit","charactersLeft","isOverLengthLimit","alwaysShowSubject","replaceCandidate","len","ctrlKey","candidate","cycleBackward","cycleForward","shiftKey","onKeydown","setCaret","selectionStart","statusPoster","addMediaFile","fileInfo","enableSubmit","removeMediaFile","uploadFailed","errString","templateArgs","disableSubmit","paste","clipboardData","vertPadding","substr","scrollHeight","changeVis","_vuelidate","_validators","mixins","validationMixin","email","fullname","captcha","validations","sameAsPassword","sameAs","signedIn","setCaptcha","mapState","isPending","serverValidationErrors","termsOfService","mapActions","nickname","captcha_solution","solution","captcha_token","captcha_answer_data","answer_data","$v","$touch","$invalid","t0","cpt","RetweetButton","retweeted","retweeted-empty","_getOwnPropertyDescriptor","_getOwnPropertyDescriptor2","_trim2","_trim3","_tab_switcher","_tab_switcher2","_style_switcher","_style_switcher2","_interface_language_switcher","_interface_language_switcher2","hideAttachmentsLocal","hideAttachmentsInConvLocal","hideISPLocal","hidePostStatsDefault","hideUserStatsLocal","hideUserStatsDefault","hideFilteredStatusesLocal","hideFilteredStatusesDefault","notificationVisibilityLocal","replyVisibilityLocal","loopVideoLocal","muteWordsString","autoLoadLocal","streamingLocal","pauseOnUnfocusedLocal","hoverPreviewLocal","collapseMessageWithSubjectLocal","collapseMessageWithSubjectDefault","subjectLineBehaviorLocal","subjectLineBehaviorDefault","postContentTypeLocal","postContentTypeDefault","alwaysShowSubjectInputLocal","alwaysShowSubjectInputDefault","scopeCopyLocal","scopeCopyDefault","webPushNotificationsLocal","loopVideoSilentOnlyLocal","loopVideosSilentOnly","loopSilentAvailable","HTMLVideoElement","HTMLMediaElement","TabSwitcher","StyleSwitcher","InterfaceLanguageSwitcher","instanceSpecificPanelPresent","notificationVisibilityLocal.likes","notificationVisibilityLocal.follows","notificationVisibilityLocal.repeats","notificationVisibilityLocal.mentions","_color_input","_color_input2","_opacity_input","_opacity_input2","selectedId","cValue","ColorInput","OpacityInput","del","moveUp","moveDn","ready","moveUpValid","moveDnValid","usingFallback","boxShadow","deltaCoord","oldCoord","newCoord","touchEventCoord","touches","screenX","screenY","touchCoord","doLogout","touchStart","touchMove","delta","abs","_unescape2","_unescape3","_favorite_button","_favorite_button2","_retweet_button","_retweet_button2","_delete_button","_delete_button2","_gallery","_gallery2","_linkPreview","_linkPreview2","_file_type","_file_type2","_matcherService","replying","expanded","unmuted","preview","showPreview","showingTall","inConversation","showingLongSubject","expandingSubject","localCollapseSubjectDefault","repeaterClass","repeaterStyle","noHeading","generateUserProfileLink","replyProfileLink","isReply","replyToName","retweeter","retweeterHtml","retweeterProfileLink","loggedIn","muteWordHits","hits","muteWord","hideStatus","hideReply","isFocused","tallStatus","lengthScore","longSubject","inlineExpanded","checkFollowing","hideSubjectStatus","hideTallStatus","showingMore","nsfwClickthrough","replySubject","decodedSummary","behavior","startsWithRe","attachmentSize","compact","galleryTypes","galleryAttachments","nonGalleryAttachments","visibilityIcon","parentNode","className","attn","generateTagLink","toggleReplying","gotoOriginal","toggleExpanded","toggleMute","toggleShowMore","replyEnter","_this3","targetId","replyLeave","_this4","rect","scrollBy","bottom","filters","capitalize","statusOrConversation","onLoad","canvas","naturalWidth","naturalHeight","getContext","drawImage","onError","imageLoadError","_set3","_values","_values2","_range_input","_range_input2","_shadow_control","_shadow_control2","_font_control","_font_control2","_contrast_ratio","_contrast_ratio2","_preview","_preview2","_export_import","_export_import2","v1OnlyNames","availableStyles","previewShadows","previewColors","previewRadii","previewFonts","shadowsInvalid","colorsInvalid","radiiInvalid","keepColor","keepShadows","keepOpacity","keepRoundness","keepFonts","textColorLocal","linkColorLocal","bgColorLocal","bgOpacityLocal","fgColorLocal","fgTextColorLocal","fgLinkColorLocal","btnColorLocal","btnTextColorLocal","btnOpacityLocal","inputColorLocal","inputTextColorLocal","inputOpacityLocal","panelColorLocal","panelTextColorLocal","panelLinkColorLocal","panelFaintColorLocal","panelOpacityLocal","topBarColorLocal","topBarTextColorLocal","topBarLinkColorLocal","alertErrorColorLocal","badgeOpacityLocal","badgeNotificationColorLocal","borderColorLocal","borderOpacityLocal","faintColorLocal","faintOpacityLocal","faintLinkColorLocal","cRedColorLocal","cBlueColorLocal","cGreenColorLocal","cOrangeColorLocal","shadowSelected","shadowsLocal","fontsLocal","btnRadiusLocal","inputRadiusLocal","checkboxRadiusLocal","panelRadiusLocal","avatarRadiusLocal","avatarAltRadiusLocal","attachmentRadiusLocal","tooltipRadiusLocal","themesComplete","normalizeLocalState","shadowsAvailable","selectedVersion","currentColors","currentOpacity","topBarOpacityLocal","currentRadii","previewTheme","previewContrast","hints","toPrecision","fgs","red","green","blue","orange","bgs","ratios","bgText","bgLink","bgRed","bgGreen","bgBlue","bgOrange","tintText","previewRules","currentShadowOverriden","currentShadow","currentShadowFallback","themeValid","exportedTheme","saveEverything","_pleroma_theme_version","RangeInput","ContrastRatio","ShadowControl","FontControl","Preview","ExportImport","setCustomTheme","importValidator","version","clearAll","clearV1","$data","clearRoundness","clearOpacity","clearShadows","clearFonts","keys","deep","fontsInvalid","_status_or_conversation","_status_or_conversation2","paused","unfocused","timelineError","newStatusCountStr","root","embedded","footer","StatusOrConversation","timelineName","handleVisibilityChange","handleShortKey","fetchOlderStatuses","doc","documentElement","scrollTop","clientTop","showPlaceholder","imgSrc","followRequestInProgress","followRequestSent","user-card-rounded-t","rounded","user-card-rounded","user-card-bordered","bordered","gradient","hideBio","isOtherUser","subscribeUrl","serverUrl","URL","protocol","host","dailyAvg","days","round","userHighlightType","userHighlightColor","visibleRole","validRole","showRole","blockedUser","unblockedUser","setProfileView","switcher","findUser","userSearchInput","_vueCompose","_get","_get2","_follow_card","_follow_card2","_with_load_more","_with_load_more2","_with_list","_with_list2","FollowerList","compose","destory","FriendList","startFetchFavorites","reason","errorMessage","cleanUp","userName","isUs","userInStore","followsTabVisible","followersTabVisible","startUp","tabSwitcher","userSearch","newV","newQuery","userSearchApi","_unescape","_image_cropper","_image_cropper2","_block_card","_block_card2","_mute_card","_mute_card2","_with_subscription","_with_subscription2","BlockList","MuteList","newName","newBio","newLocked","newNoRichText","newDefaultScope","hideFollows","hideFollowers","followList","followImportError","followsImported","enableFollowsExport","pickAvatarBtnVisible","bannerUploading","backgroundUploading","followListUploading","bannerPreview","backgroundPreview","bannerUploadError","backgroundUploadError","deletingAccount","deleteAccountConfirmPasswordInput","deleteAccountError","changePasswordInputs","changedPassword","changePasswordError","activeTab","oauthToken","appName","app_name","validUntil","valid_until","toLocaleDateString","submitAvatar","getCroppedCanvas","toDataURL","clearUploadError","submitBanner","banner","imginfo","Image","offset_top","offset_left","clone","submitBg","_this5","cropX","cropY","cropW","cropH","importFollows","_this6","exportPeople","UserAddresses","hostname","fileToDownload","exportFollows","_this7","friendList","followListChange","followlist","dismissImported","confirmDelete","_this8","_this9","tabName","t","onVideoDataLoad","srcElement","webkitAudioDecodedByteCount","mozHasAudio","audioTracks","getWhoToFollow","showWhoToFollow","reply","externalUser","shuffled","_shuffle3","usersToFollow","toFollow","_shuffle2","fill","oldUser","features_panel","media_proxy","scope_options","text_limit","who_to_follow","finder","error_fetching_user","find_user","general","placeholder","nav","friend_requests","public_tl","twkn","broken_favorite","favorited_you","followed_you","load_older","read","repeated_you","post_status","account_not_locked_warning","account_not_locked_warning_link","attachments_sensitive","content_type","plain_text","content_warning","direct_warning","bio","password_confirm","attachmentRadius","autoload","avatarAltRadius","avatarRadius","change_password","change_password_error","changed_password","collapse_subject","confirm_new_password","current_avatar","current_password","current_profile_banner","data_import_export_tab","default_vis","delete_account","delete_account_description","delete_account_error","delete_account_instructions","export_theme","filtering","filtering_explanation","follow_export","follow_export_button","follow_export_processing","follow_import","follow_import_error","follows_imported","foreground","hide_attachments_in_convo","hide_attachments_in_tl","hide_post_stats","hide_user_stats","import_followers_from_a_csv_file","import_theme","inputRadius","instance_default","invalid_theme_imported","limited_availability","links","lock_account_description","loop_video","loop_video_silent_only","name_bio","new_password","no_rich_text_description","notification_visibility","notification_visibility_follows","notification_visibility_likes","notification_visibility_mentions","notification_visibility_repeats","nsfw_clickthrough","oauth_tokens","refresh_token","revoke_token","panelRadius","pause_on_unfocused","presets","profile_background","profile_banner","profile_tab","radii_help","replies_in_timeline","reply_link_preview","reply_visibility_all","reply_visibility_following","reply_visibility_self","saving_err","saving_ok","security_tab","set_new_avatar","set_new_profile_background","set_new_profile_banner","stop_gifs","theme_help","tooltipRadius","user_settings","false","true","collapse","error_fetching","no_retweet_hint","show_new","up_to_date","user_card","approve","block","deny","followees","mute","per_day","remote_follow","user_profile","timeline_title","more","generic_error","optional","image_cropper","crop_picture","save","cancel","media_modal","about","back","user_search","preferences","no_more_notifications","new_status","text/html","text/markdown","new_captcha","username_placeholder","fullname_placeholder","bio_placeholder","username_required","fullname_required","email_required","password_required","password_confirmation_required","password_confirmation_match","blocks_tab","composing","avatar_size_instruction","max_thumbnails","hide_isp","preload_images","use_one_click_nsfw","hide_filtered_statuses","checkboxRadius","instance_default_simple","mutes_tab","play_videos_in_modal","use_contain_fit","no_blocks","no_mutes","hide_follows_description","hide_followers_description","show_admin_badge","show_moderator_badge","scope_copy","subject_input_always_show","subject_line_behavior","subject_line_email","subject_line_mastodon","subject_line_noop","post_status_content_type","theme_help_v2_1","theme_help_v2_2","upload_a_photo","enable_web_push_notifications","keep_color","keep_shadows","keep_opacity","keep_roundness","keep_fonts","save_load_hint","reset","clear_all","clear_opacity","common","bad","18pt","common_colors","_tab_label","main","foreground_hint","rgbo","advanced_colors","alert_error","badge","badge_notification","panel_header","top_bar","borders","buttons","inputs","faint_text","override","shadow_id","filter_hint","always_drop_shadow","drop_shadow_syntax","avatar_inset","spread_zero","inset_classic","buttonPressedHover","help","weight","custom","mono","faint_link","fine_print","header_faint","no_more_statuses","no_statuses","reply_to","replies_list","follow_sent","follow_progress","follow_again","follow_unfollow","its_you","unblock","unblock_progress","block_progress","unmute","unmute_progress","mute_progress","profile_does_not_exist","profile_loading_error","tool_tip","media_upload","upload","file_too_big","file_size_units","B","KiB","MiB","GiB","TiB","text/plain","hide_network_description","p","_vm","_h","$createElement","_c","_self","staticClass","_v","_s","_e","$event","_l","unseen","staticRenderFns","directives","rawName","expression","posted","avatar-compact","better-shadow","domProps","$set","ref","keyup","_k","keydown","metaKey","drop","dragover","for","$$selectedVal","call","o","_value","multiple","postFormat","staticStyle","position","drop-files","uploaded","upload-failed","controls","checked","_i","$$a","$$el","$$c","$$v","$$i","collapsable","expandable","goto","timeline-name","innerHTML","large","noFollowsYou","chat-heading","author","langCode","form-group--error","$error","modifiers","trim","$forceUpdate","autocomplete","viewing","user-id","_obj","nsfw-placeholder","small","large_thumb_url","allowPlay","thumb_url","oembedHTML","active-class","toggled","step","loop","playsinline","loadeddata","nativeOn","hardMax","hardMin","_t","!click","auto-update","side-drawer-container-closed","side-drawer-container-open","side-drawer-closed","touchstart","touchmove","side-drawer-click-outside-closed","__r","model","callback","load","rel","small-image","provider_name","status-el_focused","status-conversation","isPreview","is-retweet","_f","aria-label","mouseenter","mouseleave","mouseout","tall-status","tall-status-hider_focused","icon-reply-active","reply-to","copy-message-scope","alt","accept","exportLabel","importLabel","importFailedText","no-inherit","font-family","_m","number","_n","row","contain-fit","cover-fit","overflow"],"mappings":"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ACPmvC,EAAextD,O7HmrYtBliB,GAAQK,Q6H9qYMk7C,G7HirYN,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CAEH,SAAUx7C,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SAAUD,EAAQC,KAMlB,SA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3uC,SAAA,MAAA4uC,SAAA,QAAAC,WAAA,QAA6LC,WAAcC,QAAA,KAAAC,MAAA,KAAAh3B,QAAA,OAAAi3B,KAAA,KAAAtwC,OAAA,KAAAuwC,UAAA,OAAAjzC,UAAA,MAAA9Z,UAAA,QAAAkmB,YAAA,QAAA8mC,KAAA,KAAAjpE,MAAA,MAAAkpE,QAAA,KAAAC,cAAA,OAAAhzE,SAAA,MAAsOizE,cAAiBC,eAAA,SAAyBtH,eAAkBuH,KAAA,KAAAvH,cAAA,UrJqwZ76I,SAAU1wE,EAAQC,GsJrwZxBD,EAAAC,SAAA,oItJ2wZM,SAAUD,EAAQC,GuJ3wZxBD,EAAAC,SAAA,gHvJixZM,SAAUD,EAAQC,GwJjxZxBD,EAAAC,SAAA,oExJsxZS,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CACA,CAC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","file":"static/js/app.77434de4e756a5d79672.js","sourcesContent":["webpackJsonp([2,0],[\n/* 0 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tvar _vue = __webpack_require__(8);\n\t\n\tvar _vue2 = _interopRequireDefault(_vue);\n\t\n\tvar _vueRouter = __webpack_require__(217);\n\t\n\tvar _vueRouter2 = _interopRequireDefault(_vueRouter);\n\t\n\tvar _vuex = __webpack_require__(219);\n\t\n\tvar _vuex2 = _interopRequireDefault(_vuex);\n\t\n\tvar _interface = __webpack_require__(231);\n\t\n\tvar _interface2 = _interopRequireDefault(_interface);\n\t\n\tvar _instance = __webpack_require__(230);\n\t\n\tvar _instance2 = _interopRequireDefault(_instance);\n\t\n\tvar _statuses = __webpack_require__(235);\n\t\n\tvar _statuses2 = _interopRequireDefault(_statuses);\n\t\n\tvar _users = __webpack_require__(236);\n\t\n\tvar _users2 = _interopRequireDefault(_users);\n\t\n\tvar _api = __webpack_require__(226);\n\t\n\tvar _api2 = _interopRequireDefault(_api);\n\t\n\tvar _config = __webpack_require__(228);\n\t\n\tvar _config2 = _interopRequireDefault(_config);\n\t\n\tvar _chat = __webpack_require__(227);\n\t\n\tvar _chat2 = _interopRequireDefault(_chat);\n\t\n\tvar _oauth = __webpack_require__(233);\n\t\n\tvar _oauth2 = _interopRequireDefault(_oauth);\n\t\n\tvar _media_viewer = __webpack_require__(232);\n\t\n\tvar _media_viewer2 = _interopRequireDefault(_media_viewer);\n\t\n\tvar _oauth_tokens = __webpack_require__(234);\n\t\n\tvar _oauth_tokens2 = _interopRequireDefault(_oauth_tokens);\n\t\n\tvar _vueTimeago = __webpack_require__(741);\n\t\n\tvar _vueTimeago2 = _interopRequireDefault(_vueTimeago);\n\t\n\tvar _vueI18n = __webpack_require__(632);\n\t\n\tvar _vueI18n2 = _interopRequireDefault(_vueI18n);\n\t\n\tvar _persisted_state = __webpack_require__(224);\n\t\n\tvar _persisted_state2 = _interopRequireDefault(_persisted_state);\n\t\n\tvar _push_notifications_plugin = __webpack_require__(225);\n\t\n\tvar _push_notifications_plugin2 = _interopRequireDefault(_push_notifications_plugin);\n\t\n\tvar _messages = __webpack_require__(130);\n\t\n\tvar _messages2 = _interopRequireDefault(_messages);\n\t\n\tvar _vueChatScroll = __webpack_require__(630);\n\t\n\tvar _vueChatScroll2 = _interopRequireDefault(_vueChatScroll);\n\t\n\tvar _after_store = __webpack_require__(220);\n\t\n\tvar _after_store2 = _interopRequireDefault(_after_store);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar currentLocale = (window.navigator.language || 'en').split('-')[0];\n\t\n\t_vue2.default.use(_vuex2.default);\n\t_vue2.default.use(_vueRouter2.default);\n\t_vue2.default.use(_vueTimeago2.default, {\n\t locale: currentLocale === 'cs' ? 'cs' : currentLocale === 'ja' ? 'ja' : 'en',\n\t locales: {\n\t 'cs': __webpack_require__(457),\n\t 'en': __webpack_require__(458),\n\t 'ja': __webpack_require__(459)\n\t }\n\t});\n\t_vue2.default.use(_vueI18n2.default);\n\t_vue2.default.use(_vueChatScroll2.default);\n\t\n\tvar i18n = new _vueI18n2.default({\n\t locale: currentLocale,\n\t fallbackLocale: 'en',\n\t messages: _messages2.default\n\t});\n\t\n\tvar persistedStateOptions = {\n\t paths: ['config', 'users.lastLoginName', 'oauth']\n\t};\n\t\n\t(0, _persisted_state2.default)(persistedStateOptions).then(function (persistedState) {\n\t var store = new _vuex2.default.Store({\n\t modules: {\n\t interface: _interface2.default,\n\t instance: _instance2.default,\n\t statuses: _statuses2.default,\n\t users: _users2.default,\n\t api: _api2.default,\n\t config: _config2.default,\n\t chat: _chat2.default,\n\t oauth: _oauth2.default,\n\t mediaViewer: _media_viewer2.default,\n\t oauthTokens: _oauth_tokens2.default\n\t },\n\t plugins: [persistedState, _push_notifications_plugin2.default],\n\t strict: false });\n\t\n\t (0, _after_store2.default)({ store: store, i18n: i18n });\n\t});\n\t\n\twindow.___pleromafe_mode = ({\"NODE_ENV\":\"production\"});\n\twindow.___pleromafe_commit_hash = (\"7c26435e\\n\");\n\twindow.___pleromafe_dev_overrides = (undefined);\n\n/***/ }),\n/* 1 */,\n/* 2 */,\n/* 3 */,\n/* 4 */,\n/* 5 */,\n/* 6 */,\n/* 7 */,\n/* 8 */,\n/* 9 */,\n/* 10 */,\n/* 11 */,\n/* 12 */,\n/* 13 */,\n/* 14 */,\n/* 15 */,\n/* 16 */,\n/* 17 */,\n/* 18 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _promise = __webpack_require__(25);\n\t\n\tvar _promise2 = _interopRequireDefault(_promise);\n\t\n\tvar _map2 = __webpack_require__(31);\n\t\n\tvar _map3 = _interopRequireDefault(_map2);\n\t\n\tvar _each2 = __webpack_require__(82);\n\t\n\tvar _each3 = _interopRequireDefault(_each2);\n\t\n\tvar _entity_normalizerService = __webpack_require__(238);\n\t\n\t__webpack_require__(768);\n\t\n\tvar _errors = __webpack_require__(239);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar LOGIN_URL = '/api/account/verify_credentials.json';\n\tvar FRIENDS_TIMELINE_URL = '/api/statuses/friends_timeline.json';\n\tvar ALL_FOLLOWING_URL = '/api/qvitter/allfollowing';\n\tvar PUBLIC_TIMELINE_URL = '/api/statuses/public_timeline.json';\n\tvar PUBLIC_AND_EXTERNAL_TIMELINE_URL = '/api/statuses/public_and_external_timeline.json';\n\tvar TAG_TIMELINE_URL = '/api/statusnet/tags/timeline';\n\tvar FAVORITE_URL = '/api/favorites/create';\n\tvar UNFAVORITE_URL = '/api/favorites/destroy';\n\tvar RETWEET_URL = '/api/statuses/retweet';\n\tvar UNRETWEET_URL = '/api/statuses/unretweet';\n\tvar STATUS_UPDATE_URL = '/api/statuses/update.json';\n\tvar STATUS_DELETE_URL = '/api/statuses/destroy';\n\tvar STATUS_URL = '/api/statuses/show';\n\tvar MEDIA_UPLOAD_URL = '/api/statusnet/media/upload';\n\tvar CONVERSATION_URL = '/api/statusnet/conversation';\n\tvar MENTIONS_URL = '/api/statuses/mentions.json';\n\tvar DM_TIMELINE_URL = '/api/statuses/dm_timeline.json';\n\tvar FOLLOWERS_URL = '/api/statuses/followers.json';\n\tvar FRIENDS_URL = '/api/statuses/friends.json';\n\tvar BLOCKS_URL = '/api/statuses/blocks.json';\n\tvar FOLLOWING_URL = '/api/friendships/create.json';\n\tvar UNFOLLOWING_URL = '/api/friendships/destroy.json';\n\tvar QVITTER_USER_PREF_URL = '/api/qvitter/set_profile_pref.json';\n\tvar REGISTRATION_URL = '/api/account/register.json';\n\tvar AVATAR_UPDATE_URL = '/api/qvitter/update_avatar.json';\n\tvar BG_UPDATE_URL = '/api/qvitter/update_background_image.json';\n\tvar BANNER_UPDATE_URL = '/api/account/update_profile_banner.json';\n\tvar PROFILE_UPDATE_URL = '/api/account/update_profile.json';\n\tvar EXTERNAL_PROFILE_URL = '/api/externalprofile/show.json';\n\tvar QVITTER_USER_TIMELINE_URL = '/api/qvitter/statuses/user_timeline.json';\n\tvar QVITTER_USER_NOTIFICATIONS_URL = '/api/qvitter/statuses/notifications.json';\n\tvar QVITTER_USER_NOTIFICATIONS_READ_URL = '/api/qvitter/statuses/notifications/read.json';\n\tvar BLOCKING_URL = '/api/blocks/create.json';\n\tvar UNBLOCKING_URL = '/api/blocks/destroy.json';\n\tvar USER_URL = '/api/users/show.json';\n\tvar FOLLOW_IMPORT_URL = '/api/pleroma/follow_import';\n\tvar DELETE_ACCOUNT_URL = '/api/pleroma/delete_account';\n\tvar CHANGE_PASSWORD_URL = '/api/pleroma/change_password';\n\tvar FOLLOW_REQUESTS_URL = '/api/pleroma/friend_requests';\n\tvar APPROVE_USER_URL = '/api/pleroma/friendships/approve';\n\tvar DENY_USER_URL = '/api/pleroma/friendships/deny';\n\tvar SUGGESTIONS_URL = '/api/v1/suggestions';\n\t\n\tvar MASTODON_USER_FAVORITES_TIMELINE_URL = '/api/v1/favourites';\n\t\n\tvar oldfetch = window.fetch;\n\t\n\tvar fetch = function fetch(url, options) {\n\t options = options || {};\n\t var baseUrl = '';\n\t var fullUrl = baseUrl + url;\n\t options.credentials = 'same-origin';\n\t return oldfetch(fullUrl, options);\n\t};\n\t\n\tvar updateAvatar = function updateAvatar(_ref) {\n\t var credentials = _ref.credentials,\n\t params = _ref.params;\n\t\n\t var url = AVATAR_UPDATE_URL;\n\t\n\t var form = new FormData();\n\t\n\t (0, _each3.default)(params, function (value, key) {\n\t if (value) {\n\t form.append(key, value);\n\t }\n\t });\n\t\n\t return fetch(url, {\n\t headers: authHeaders(credentials),\n\t method: 'POST',\n\t body: form\n\t }).then(function (data) {\n\t return data.json();\n\t });\n\t};\n\t\n\tvar updateBg = function updateBg(_ref2) {\n\t var credentials = _ref2.credentials,\n\t params = _ref2.params;\n\t\n\t var url = BG_UPDATE_URL;\n\t\n\t var form = new FormData();\n\t\n\t (0, _each3.default)(params, function (value, key) {\n\t if (value) {\n\t form.append(key, value);\n\t }\n\t });\n\t\n\t return fetch(url, {\n\t headers: authHeaders(credentials),\n\t method: 'POST',\n\t body: form\n\t }).then(function (data) {\n\t return data.json();\n\t });\n\t};\n\t\n\tvar updateBanner = function updateBanner(_ref3) {\n\t var credentials = _ref3.credentials,\n\t params = _ref3.params;\n\t\n\t var url = BANNER_UPDATE_URL;\n\t\n\t var form = new FormData();\n\t\n\t (0, _each3.default)(params, function (value, key) {\n\t if (value) {\n\t form.append(key, value);\n\t }\n\t });\n\t\n\t return fetch(url, {\n\t headers: authHeaders(credentials),\n\t method: 'POST',\n\t body: form\n\t }).then(function (data) {\n\t return data.json();\n\t });\n\t};\n\t\n\tvar updateProfile = function updateProfile(_ref4) {\n\t var credentials = _ref4.credentials,\n\t params = _ref4.params;\n\t\n\t var fields = ['description', 'locked', 'no_rich_text', 'hide_follows', 'hide_followers', 'show_role'];\n\t var url = PROFILE_UPDATE_URL;\n\t\n\t var form = new FormData();\n\t\n\t (0, _each3.default)(params, function (value, key) {\n\t if (fields.includes(key) || value) {\n\t form.append(key, value);\n\t }\n\t });\n\t return fetch(url, {\n\t headers: authHeaders(credentials),\n\t method: 'POST',\n\t body: form\n\t }).then(function (data) {\n\t return data.json();\n\t });\n\t};\n\t\n\tvar register = function register(params) {\n\t var form = new FormData();\n\t\n\t (0, _each3.default)(params, function (value, key) {\n\t if (value) {\n\t form.append(key, value);\n\t }\n\t });\n\t\n\t return fetch(REGISTRATION_URL, {\n\t method: 'POST',\n\t body: form\n\t });\n\t};\n\t\n\tvar getCaptcha = function getCaptcha() {\n\t return fetch('/api/pleroma/captcha').then(function (resp) {\n\t return resp.json();\n\t });\n\t};\n\t\n\tvar authHeaders = function authHeaders(accessToken) {\n\t if (accessToken) {\n\t return { 'Authorization': 'Bearer ' + accessToken };\n\t } else {\n\t return {};\n\t }\n\t};\n\t\n\tvar externalProfile = function externalProfile(_ref5) {\n\t var profileUrl = _ref5.profileUrl,\n\t credentials = _ref5.credentials;\n\t\n\t var url = EXTERNAL_PROFILE_URL + '?profileurl=' + profileUrl;\n\t return fetch(url, {\n\t headers: authHeaders(credentials),\n\t method: 'GET'\n\t }).then(function (data) {\n\t return data.json();\n\t });\n\t};\n\t\n\tvar followUser = function followUser(_ref6) {\n\t var id = _ref6.id,\n\t credentials = _ref6.credentials;\n\t\n\t var url = FOLLOWING_URL + '?user_id=' + id;\n\t return fetch(url, {\n\t headers: authHeaders(credentials),\n\t method: 'POST'\n\t }).then(function (data) {\n\t return data.json();\n\t });\n\t};\n\t\n\tvar unfollowUser = function unfollowUser(_ref7) {\n\t var id = _ref7.id,\n\t credentials = _ref7.credentials;\n\t\n\t var url = UNFOLLOWING_URL + '?user_id=' + id;\n\t return fetch(url, {\n\t headers: authHeaders(credentials),\n\t method: 'POST'\n\t }).then(function (data) {\n\t return data.json();\n\t });\n\t};\n\t\n\tvar blockUser = function blockUser(_ref8) {\n\t var id = _ref8.id,\n\t credentials = _ref8.credentials;\n\t\n\t var url = BLOCKING_URL + '?user_id=' + id;\n\t return fetch(url, {\n\t headers: authHeaders(credentials),\n\t method: 'POST'\n\t }).then(function (data) {\n\t return data.json();\n\t });\n\t};\n\t\n\tvar unblockUser = function unblockUser(_ref9) {\n\t var id = _ref9.id,\n\t credentials = _ref9.credentials;\n\t\n\t var url = UNBLOCKING_URL + '?user_id=' + id;\n\t return fetch(url, {\n\t headers: authHeaders(credentials),\n\t method: 'POST'\n\t }).then(function (data) {\n\t return data.json();\n\t });\n\t};\n\t\n\tvar approveUser = function approveUser(_ref10) {\n\t var id = _ref10.id,\n\t credentials = _ref10.credentials;\n\t\n\t var url = APPROVE_USER_URL + '?user_id=' + id;\n\t return fetch(url, {\n\t headers: authHeaders(credentials),\n\t method: 'POST'\n\t }).then(function (data) {\n\t return data.json();\n\t });\n\t};\n\t\n\tvar denyUser = function denyUser(_ref11) {\n\t var id = _ref11.id,\n\t credentials = _ref11.credentials;\n\t\n\t var url = DENY_USER_URL + '?user_id=' + id;\n\t return fetch(url, {\n\t headers: authHeaders(credentials),\n\t method: 'POST'\n\t }).then(function (data) {\n\t return data.json();\n\t });\n\t};\n\t\n\tvar fetchUser = function fetchUser(_ref12) {\n\t var id = _ref12.id,\n\t credentials = _ref12.credentials;\n\t\n\t var url = USER_URL + '?user_id=' + id;\n\t return fetch(url, { headers: authHeaders(credentials) }).then(function (response) {\n\t return new _promise2.default(function (resolve, reject) {\n\t return response.json().then(function (json) {\n\t if (!response.ok) {\n\t return reject(new _errors.StatusCodeError(response.status, json, { url: url }, response));\n\t }\n\t return resolve(json);\n\t });\n\t });\n\t }).then(function (data) {\n\t return (0, _entity_normalizerService.parseUser)(data);\n\t });\n\t};\n\t\n\tvar fetchFriends = function fetchFriends(_ref13) {\n\t var id = _ref13.id,\n\t page = _ref13.page,\n\t credentials = _ref13.credentials;\n\t\n\t var url = FRIENDS_URL + '?user_id=' + id;\n\t if (page) {\n\t url = url + ('&page=' + page);\n\t }\n\t return fetch(url, { headers: authHeaders(credentials) }).then(function (data) {\n\t return data.json();\n\t }).then(function (data) {\n\t return data.map(_entity_normalizerService.parseUser);\n\t });\n\t};\n\t\n\tvar exportFriends = function exportFriends(_ref14) {\n\t var id = _ref14.id,\n\t credentials = _ref14.credentials;\n\t\n\t var url = FRIENDS_URL + '?user_id=' + id + '&all=true';\n\t return fetch(url, { headers: authHeaders(credentials) }).then(function (data) {\n\t return data.json();\n\t }).then(function (data) {\n\t return data.map(_entity_normalizerService.parseUser);\n\t });\n\t};\n\t\n\tvar fetchFollowers = function fetchFollowers(_ref15) {\n\t var id = _ref15.id,\n\t page = _ref15.page,\n\t credentials = _ref15.credentials;\n\t\n\t var url = FOLLOWERS_URL + '?user_id=' + id;\n\t if (page) {\n\t url = url + ('&page=' + page);\n\t }\n\t return fetch(url, { headers: authHeaders(credentials) }).then(function (data) {\n\t return data.json();\n\t }).then(function (data) {\n\t return data.map(_entity_normalizerService.parseUser);\n\t });\n\t};\n\t\n\tvar fetchAllFollowing = function fetchAllFollowing(_ref16) {\n\t var username = _ref16.username,\n\t credentials = _ref16.credentials;\n\t\n\t var url = ALL_FOLLOWING_URL + '/' + username + '.json';\n\t return fetch(url, { headers: authHeaders(credentials) }).then(function (data) {\n\t return data.json();\n\t }).then(function (data) {\n\t return data.map(_entity_normalizerService.parseUser);\n\t });\n\t};\n\t\n\tvar fetchFollowRequests = function fetchFollowRequests(_ref17) {\n\t var credentials = _ref17.credentials;\n\t\n\t var url = FOLLOW_REQUESTS_URL;\n\t return fetch(url, { headers: authHeaders(credentials) }).then(function (data) {\n\t return data.json();\n\t });\n\t};\n\t\n\tvar fetchConversation = function fetchConversation(_ref18) {\n\t var id = _ref18.id,\n\t credentials = _ref18.credentials;\n\t\n\t var url = CONVERSATION_URL + '/' + id + '.json?count=100';\n\t return fetch(url, { headers: authHeaders(credentials) }).then(function (data) {\n\t if (data.ok) {\n\t return data;\n\t }\n\t throw new Error('Error fetching timeline', data);\n\t }).then(function (data) {\n\t return data.json();\n\t }).then(function (data) {\n\t return data.map(_entity_normalizerService.parseStatus);\n\t });\n\t};\n\t\n\tvar fetchStatus = function fetchStatus(_ref19) {\n\t var id = _ref19.id,\n\t credentials = _ref19.credentials;\n\t\n\t var url = STATUS_URL + '/' + id + '.json';\n\t return fetch(url, { headers: authHeaders(credentials) }).then(function (data) {\n\t if (data.ok) {\n\t return data;\n\t }\n\t throw new Error('Error fetching timeline', data);\n\t }).then(function (data) {\n\t return data.json();\n\t }).then(function (data) {\n\t return (0, _entity_normalizerService.parseStatus)(data);\n\t });\n\t};\n\t\n\tvar setUserMute = function setUserMute(_ref20) {\n\t var id = _ref20.id,\n\t credentials = _ref20.credentials,\n\t _ref20$muted = _ref20.muted,\n\t muted = _ref20$muted === undefined ? true : _ref20$muted;\n\t\n\t var form = new FormData();\n\t\n\t var muteInteger = muted ? 1 : 0;\n\t\n\t form.append('namespace', 'qvitter');\n\t form.append('data', muteInteger);\n\t form.append('topic', 'mute:' + id);\n\t\n\t return fetch(QVITTER_USER_PREF_URL, {\n\t method: 'POST',\n\t headers: authHeaders(credentials),\n\t body: form\n\t });\n\t};\n\t\n\tvar fetchTimeline = function fetchTimeline(_ref21) {\n\t var timeline = _ref21.timeline,\n\t credentials = _ref21.credentials,\n\t _ref21$since = _ref21.since,\n\t since = _ref21$since === undefined ? false : _ref21$since,\n\t _ref21$until = _ref21.until,\n\t until = _ref21$until === undefined ? false : _ref21$until,\n\t _ref21$userId = _ref21.userId,\n\t userId = _ref21$userId === undefined ? false : _ref21$userId,\n\t _ref21$tag = _ref21.tag,\n\t tag = _ref21$tag === undefined ? false : _ref21$tag;\n\t\n\t var timelineUrls = {\n\t public: PUBLIC_TIMELINE_URL,\n\t friends: FRIENDS_TIMELINE_URL,\n\t mentions: MENTIONS_URL,\n\t dms: DM_TIMELINE_URL,\n\t notifications: QVITTER_USER_NOTIFICATIONS_URL,\n\t 'publicAndExternal': PUBLIC_AND_EXTERNAL_TIMELINE_URL,\n\t user: QVITTER_USER_TIMELINE_URL,\n\t media: QVITTER_USER_TIMELINE_URL,\n\t favorites: MASTODON_USER_FAVORITES_TIMELINE_URL,\n\t tag: TAG_TIMELINE_URL\n\t };\n\t var isNotifications = timeline === 'notifications';\n\t var params = [];\n\t\n\t var url = timelineUrls[timeline];\n\t\n\t if (since) {\n\t params.push(['since_id', since]);\n\t }\n\t if (until) {\n\t params.push(['max_id', until]);\n\t }\n\t if (userId) {\n\t params.push(['user_id', userId]);\n\t }\n\t if (tag) {\n\t url += '/' + tag + '.json';\n\t }\n\t if (timeline === 'media') {\n\t params.push(['only_media', 1]);\n\t }\n\t\n\t params.push(['count', 20]);\n\t\n\t var queryString = (0, _map3.default)(params, function (param) {\n\t return param[0] + '=' + param[1];\n\t }).join('&');\n\t url += '?' + queryString;\n\t\n\t return fetch(url, { headers: authHeaders(credentials) }).then(function (data) {\n\t if (data.ok) {\n\t return data;\n\t }\n\t throw new Error('Error fetching timeline', data);\n\t }).then(function (data) {\n\t return data.json();\n\t }).then(function (data) {\n\t return data.map(isNotifications ? _entity_normalizerService.parseNotification : _entity_normalizerService.parseStatus);\n\t });\n\t};\n\t\n\tvar verifyCredentials = function verifyCredentials(user) {\n\t return fetch(LOGIN_URL, {\n\t method: 'POST',\n\t headers: authHeaders(user)\n\t }).then(function (response) {\n\t if (response.ok) {\n\t return response.json();\n\t } else {\n\t return {\n\t error: response\n\t };\n\t }\n\t }).then(function (data) {\n\t return data.error ? data : (0, _entity_normalizerService.parseUser)(data);\n\t });\n\t};\n\t\n\tvar favorite = function favorite(_ref22) {\n\t var id = _ref22.id,\n\t credentials = _ref22.credentials;\n\t\n\t return fetch(FAVORITE_URL + '/' + id + '.json', {\n\t headers: authHeaders(credentials),\n\t method: 'POST'\n\t });\n\t};\n\t\n\tvar unfavorite = function unfavorite(_ref23) {\n\t var id = _ref23.id,\n\t credentials = _ref23.credentials;\n\t\n\t return fetch(UNFAVORITE_URL + '/' + id + '.json', {\n\t headers: authHeaders(credentials),\n\t method: 'POST'\n\t });\n\t};\n\t\n\tvar retweet = function retweet(_ref24) {\n\t var id = _ref24.id,\n\t credentials = _ref24.credentials;\n\t\n\t return fetch(RETWEET_URL + '/' + id + '.json', {\n\t headers: authHeaders(credentials),\n\t method: 'POST'\n\t });\n\t};\n\t\n\tvar unretweet = function unretweet(_ref25) {\n\t var id = _ref25.id,\n\t credentials = _ref25.credentials;\n\t\n\t return fetch(UNRETWEET_URL + '/' + id + '.json', {\n\t headers: authHeaders(credentials),\n\t method: 'POST'\n\t });\n\t};\n\t\n\tvar postStatus = function postStatus(_ref26) {\n\t var credentials = _ref26.credentials,\n\t status = _ref26.status,\n\t spoilerText = _ref26.spoilerText,\n\t visibility = _ref26.visibility,\n\t sensitive = _ref26.sensitive,\n\t mediaIds = _ref26.mediaIds,\n\t inReplyToStatusId = _ref26.inReplyToStatusId,\n\t contentType = _ref26.contentType,\n\t noAttachmentLinks = _ref26.noAttachmentLinks;\n\t\n\t var idsText = mediaIds.join(',');\n\t var form = new FormData();\n\t\n\t form.append('status', status);\n\t form.append('source', 'Pleroma FE');\n\t if (noAttachmentLinks) form.append('no_attachment_links', noAttachmentLinks);\n\t if (spoilerText) form.append('spoiler_text', spoilerText);\n\t if (visibility) form.append('visibility', visibility);\n\t if (sensitive) form.append('sensitive', sensitive);\n\t if (contentType) form.append('content_type', contentType);\n\t form.append('media_ids', idsText);\n\t if (inReplyToStatusId) {\n\t form.append('in_reply_to_status_id', inReplyToStatusId);\n\t }\n\t\n\t return fetch(STATUS_UPDATE_URL, {\n\t body: form,\n\t method: 'POST',\n\t headers: authHeaders(credentials)\n\t }).then(function (response) {\n\t if (response.ok) {\n\t return response.json();\n\t } else {\n\t return {\n\t error: response\n\t };\n\t }\n\t }).then(function (data) {\n\t return data.error ? data : (0, _entity_normalizerService.parseStatus)(data);\n\t });\n\t};\n\t\n\tvar deleteStatus = function deleteStatus(_ref27) {\n\t var id = _ref27.id,\n\t credentials = _ref27.credentials;\n\t\n\t return fetch(STATUS_DELETE_URL + '/' + id + '.json', {\n\t headers: authHeaders(credentials),\n\t method: 'POST'\n\t });\n\t};\n\t\n\tvar uploadMedia = function uploadMedia(_ref28) {\n\t var formData = _ref28.formData,\n\t credentials = _ref28.credentials;\n\t\n\t return fetch(MEDIA_UPLOAD_URL, {\n\t body: formData,\n\t method: 'POST',\n\t headers: authHeaders(credentials)\n\t }).then(function (response) {\n\t return response.text();\n\t }).then(function (text) {\n\t return new DOMParser().parseFromString(text, 'application/xml');\n\t });\n\t};\n\t\n\tvar followImport = function followImport(_ref29) {\n\t var params = _ref29.params,\n\t credentials = _ref29.credentials;\n\t\n\t return fetch(FOLLOW_IMPORT_URL, {\n\t body: params,\n\t method: 'POST',\n\t headers: authHeaders(credentials)\n\t }).then(function (response) {\n\t return response.ok;\n\t });\n\t};\n\t\n\tvar deleteAccount = function deleteAccount(_ref30) {\n\t var credentials = _ref30.credentials,\n\t password = _ref30.password;\n\t\n\t var form = new FormData();\n\t\n\t form.append('password', password);\n\t\n\t return fetch(DELETE_ACCOUNT_URL, {\n\t body: form,\n\t method: 'POST',\n\t headers: authHeaders(credentials)\n\t }).then(function (response) {\n\t return response.json();\n\t });\n\t};\n\t\n\tvar changePassword = function changePassword(_ref31) {\n\t var credentials = _ref31.credentials,\n\t password = _ref31.password,\n\t newPassword = _ref31.newPassword,\n\t newPasswordConfirmation = _ref31.newPasswordConfirmation;\n\t\n\t var form = new FormData();\n\t\n\t form.append('password', password);\n\t form.append('new_password', newPassword);\n\t form.append('new_password_confirmation', newPasswordConfirmation);\n\t\n\t return fetch(CHANGE_PASSWORD_URL, {\n\t body: form,\n\t method: 'POST',\n\t headers: authHeaders(credentials)\n\t }).then(function (response) {\n\t return response.json();\n\t });\n\t};\n\t\n\tvar fetchMutes = function fetchMutes(_ref32) {\n\t var credentials = _ref32.credentials;\n\t\n\t var url = '/api/qvitter/mutes.json';\n\t\n\t return fetch(url, {\n\t headers: authHeaders(credentials)\n\t }).then(function (data) {\n\t return data.json();\n\t });\n\t};\n\t\n\tvar fetchBlocks = function fetchBlocks(_ref33) {\n\t var page = _ref33.page,\n\t credentials = _ref33.credentials;\n\t\n\t return fetch(BLOCKS_URL, {\n\t headers: authHeaders(credentials)\n\t }).then(function (data) {\n\t if (data.ok) {\n\t return data.json();\n\t }\n\t throw new Error('Error fetching blocks', data);\n\t });\n\t};\n\t\n\tvar fetchOAuthTokens = function fetchOAuthTokens(_ref34) {\n\t var credentials = _ref34.credentials;\n\t\n\t var url = '/api/oauth_tokens.json';\n\t\n\t return fetch(url, {\n\t headers: authHeaders(credentials)\n\t }).then(function (data) {\n\t return data.json();\n\t });\n\t};\n\t\n\tvar revokeOAuthToken = function revokeOAuthToken(_ref35) {\n\t var id = _ref35.id,\n\t credentials = _ref35.credentials;\n\t\n\t var url = '/api/oauth_tokens/' + id;\n\t\n\t return fetch(url, {\n\t headers: authHeaders(credentials),\n\t method: 'DELETE'\n\t });\n\t};\n\t\n\tvar suggestions = function suggestions(_ref36) {\n\t var credentials = _ref36.credentials;\n\t\n\t return fetch(SUGGESTIONS_URL, {\n\t headers: authHeaders(credentials)\n\t }).then(function (data) {\n\t return data.json();\n\t });\n\t};\n\t\n\tvar markNotificationsAsSeen = function markNotificationsAsSeen(_ref37) {\n\t var id = _ref37.id,\n\t credentials = _ref37.credentials;\n\t\n\t var body = new FormData();\n\t\n\t body.append('latest_id', id);\n\t\n\t return fetch(QVITTER_USER_NOTIFICATIONS_READ_URL, {\n\t body: body,\n\t headers: authHeaders(credentials),\n\t method: 'POST'\n\t }).then(function (data) {\n\t return data.json();\n\t });\n\t};\n\t\n\tvar apiService = {\n\t verifyCredentials: verifyCredentials,\n\t fetchTimeline: fetchTimeline,\n\t fetchConversation: fetchConversation,\n\t fetchStatus: fetchStatus,\n\t fetchFriends: fetchFriends,\n\t exportFriends: exportFriends,\n\t fetchFollowers: fetchFollowers,\n\t followUser: followUser,\n\t unfollowUser: unfollowUser,\n\t blockUser: blockUser,\n\t unblockUser: unblockUser,\n\t fetchUser: fetchUser,\n\t favorite: favorite,\n\t unfavorite: unfavorite,\n\t retweet: retweet,\n\t unretweet: unretweet,\n\t postStatus: postStatus,\n\t deleteStatus: deleteStatus,\n\t uploadMedia: uploadMedia,\n\t fetchAllFollowing: fetchAllFollowing,\n\t setUserMute: setUserMute,\n\t fetchMutes: fetchMutes,\n\t fetchBlocks: fetchBlocks,\n\t fetchOAuthTokens: fetchOAuthTokens,\n\t revokeOAuthToken: revokeOAuthToken,\n\t register: register,\n\t getCaptcha: getCaptcha,\n\t updateAvatar: updateAvatar,\n\t updateBg: updateBg,\n\t updateProfile: updateProfile,\n\t updateBanner: updateBanner,\n\t externalProfile: externalProfile,\n\t followImport: followImport,\n\t deleteAccount: deleteAccount,\n\t changePassword: changePassword,\n\t fetchFollowRequests: fetchFollowRequests,\n\t approveUser: approveUser,\n\t denyUser: denyUser,\n\t suggestions: suggestions,\n\t markNotificationsAsSeen: markNotificationsAsSeen\n\t};\n\t\n\texports.default = apiService;\n\n/***/ }),\n/* 19 */,\n/* 20 */,\n/* 21 */,\n/* 22 */,\n/* 23 */,\n/* 24 */,\n/* 25 */,\n/* 26 */,\n/* 27 */,\n/* 28 */,\n/* 29 */,\n/* 30 */,\n/* 31 */,\n/* 32 */,\n/* 33 */,\n/* 34 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(389)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(297),\n\t /* template */\n\t __webpack_require__(679),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 35 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _includes2 = __webpack_require__(597);\n\t\n\tvar _includes3 = _interopRequireDefault(_includes2);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar generateProfileLink = function generateProfileLink(id, screenName, restrictedNicknames) {\n\t var complicated = isExternal(screenName) || (0, _includes3.default)(restrictedNicknames, screenName);\n\t return {\n\t name: complicated ? 'external-user-profile' : 'user-profile',\n\t params: complicated ? { id: id } : { name: screenName }\n\t };\n\t};\n\t\n\tvar isExternal = function isExternal(screenName) {\n\t return screenName && screenName.includes('@');\n\t};\n\t\n\texports.default = generateProfileLink;\n\n/***/ }),\n/* 36 */,\n/* 37 */,\n/* 38 */,\n/* 39 */,\n/* 40 */,\n/* 41 */,\n/* 42 */,\n/* 43 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(431)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(299),\n\t /* template */\n\t __webpack_require__(739),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 44 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\texports.alphaBlend = exports.getContrastRatio = exports.invert = exports.mixrgb = exports.hex2rgb = exports.rgb2hex = undefined;\n\t\n\tvar _keys = __webpack_require__(24);\n\t\n\tvar _keys2 = _interopRequireDefault(_keys);\n\t\n\tvar _slicedToArray2 = __webpack_require__(9);\n\t\n\tvar _slicedToArray3 = _interopRequireDefault(_slicedToArray2);\n\t\n\tvar _typeof2 = __webpack_require__(66);\n\t\n\tvar _typeof3 = _interopRequireDefault(_typeof2);\n\t\n\tvar _map4 = __webpack_require__(31);\n\t\n\tvar _map5 = _interopRequireDefault(_map4);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar rgb2hex = function rgb2hex(r, g, b) {\n\t if (r === null || typeof r === 'undefined') {\n\t return undefined;\n\t }\n\t if (r[0] === '#') {\n\t return r;\n\t }\n\t if ((typeof r === 'undefined' ? 'undefined' : (0, _typeof3.default)(r)) === 'object') {\n\t var _r = r;\n\t r = _r.r;\n\t g = _r.g;\n\t b = _r.b;\n\t }\n\t\n\t var _map2 = (0, _map5.default)([r, g, b], function (val) {\n\t val = Math.ceil(val);\n\t val = val < 0 ? 0 : val;\n\t val = val > 255 ? 255 : val;\n\t return val;\n\t });\n\t\n\t var _map3 = (0, _slicedToArray3.default)(_map2, 3);\n\t\n\t r = _map3[0];\n\t g = _map3[1];\n\t b = _map3[2];\n\t\n\t return '#' + ((1 << 24) + (r << 16) + (g << 8) + b).toString(16).slice(1);\n\t};\n\t\n\tvar c2linear = function c2linear(bit) {\n\t var c = bit / 255;\n\t if (c < 0.03928) {\n\t return c / 12.92;\n\t } else {\n\t return Math.pow((c + 0.055) / 1.055, 2.4);\n\t }\n\t};\n\t\n\tvar srgbToLinear = function srgbToLinear(srgb) {\n\t return 'rgb'.split('').reduce(function (acc, c) {\n\t acc[c] = c2linear(srgb[c]);return acc;\n\t }, {});\n\t};\n\t\n\tvar relativeLuminance = function relativeLuminance(srgb) {\n\t var _srgbToLinear = srgbToLinear(srgb),\n\t r = _srgbToLinear.r,\n\t g = _srgbToLinear.g,\n\t b = _srgbToLinear.b;\n\t\n\t return 0.2126 * r + 0.7152 * g + 0.0722 * b;\n\t};\n\t\n\tvar getContrastRatio = function getContrastRatio(a, b) {\n\t var la = relativeLuminance(a);\n\t var lb = relativeLuminance(b);\n\t\n\t var _ref = la > lb ? [la, lb] : [lb, la],\n\t _ref2 = (0, _slicedToArray3.default)(_ref, 2),\n\t l1 = _ref2[0],\n\t l2 = _ref2[1];\n\t\n\t return (l1 + 0.05) / (l2 + 0.05);\n\t};\n\t\n\tvar alphaBlend = function alphaBlend(fg, fga, bg) {\n\t if (fga === 1 || typeof fga === 'undefined') return fg;\n\t return 'rgb'.split('').reduce(function (acc, c) {\n\t acc[c] = fg[c] * fga + bg[c] * (1 - fga);\n\t return acc;\n\t }, {});\n\t};\n\t\n\tvar invert = function invert(rgb) {\n\t return 'rgb'.split('').reduce(function (acc, c) {\n\t acc[c] = 255 - rgb[c];\n\t return acc;\n\t }, {});\n\t};\n\t\n\tvar hex2rgb = function hex2rgb(hex) {\n\t var result = /^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(hex);\n\t return result ? {\n\t r: parseInt(result[1], 16),\n\t g: parseInt(result[2], 16),\n\t b: parseInt(result[3], 16)\n\t } : null;\n\t};\n\t\n\tvar mixrgb = function mixrgb(a, b) {\n\t return (0, _keys2.default)(a).reduce(function (acc, k) {\n\t acc[k] = (a[k] + b[k]) / 2;\n\t return acc;\n\t }, {});\n\t};\n\t\n\texports.rgb2hex = rgb2hex;\n\texports.hex2rgb = hex2rgb;\n\texports.mixrgb = mixrgb;\n\texports.invert = invert;\n\texports.getContrastRatio = getContrastRatio;\n\texports.alphaBlend = alphaBlend;\n\n/***/ }),\n/* 45 */\n/***/ (function(module, exports) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar fileType = function fileType(mimetype) {\n\t if (mimetype.match(/text\\/html/)) {\n\t return 'html';\n\t }\n\t\n\t if (mimetype.match(/image/)) {\n\t return 'image';\n\t }\n\t\n\t if (mimetype.match(/video/)) {\n\t return 'video';\n\t }\n\t\n\t if (mimetype.match(/audio/)) {\n\t return 'audio';\n\t }\n\t\n\t return 'unknown';\n\t};\n\t\n\tvar fileMatchesSomeType = function fileMatchesSomeType(types, file) {\n\t return types.some(function (type) {\n\t return fileType(file.mimetype) === type;\n\t });\n\t};\n\t\n\tvar fileTypeService = {\n\t fileType: fileType,\n\t fileMatchesSomeType: fileMatchesSomeType\n\t};\n\t\n\texports.default = fileTypeService;\n\n/***/ }),\n/* 46 */,\n/* 47 */,\n/* 48 */,\n/* 49 */,\n/* 50 */,\n/* 51 */,\n/* 52 */,\n/* 53 */,\n/* 54 */,\n/* 55 */,\n/* 56 */,\n/* 57 */,\n/* 58 */,\n/* 59 */,\n/* 60 */,\n/* 61 */,\n/* 62 */,\n/* 63 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\texports.getCssShadowFilter = exports.getCssShadow = exports.composePreset = exports.getThemes = exports.generatePreset = exports.generateFonts = exports.generateShadows = exports.generateRadii = exports.generateColors = exports.getTextColor = exports.applyTheme = exports.setPreset = exports.setStyle = undefined;\n\t\n\tvar _promise = __webpack_require__(25);\n\t\n\tvar _promise2 = _interopRequireDefault(_promise);\n\t\n\tvar _slicedToArray2 = __webpack_require__(9);\n\t\n\tvar _slicedToArray3 = _interopRequireDefault(_slicedToArray2);\n\t\n\tvar _entries = __webpack_require__(23);\n\t\n\tvar _entries2 = _interopRequireDefault(_entries);\n\t\n\tvar _extends2 = __webpack_require__(37);\n\t\n\tvar _extends3 = _interopRequireDefault(_extends2);\n\t\n\tvar _typeof2 = __webpack_require__(66);\n\t\n\tvar _typeof3 = _interopRequireDefault(_typeof2);\n\t\n\tvar _assign = __webpack_require__(36);\n\t\n\tvar _assign2 = _interopRequireDefault(_assign);\n\t\n\tvar _times2 = __webpack_require__(616);\n\t\n\tvar _times3 = _interopRequireDefault(_times2);\n\t\n\tvar _chromatism = __webpack_require__(319);\n\t\n\tvar _color_convert = __webpack_require__(44);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar setStyle = function setStyle(href, commit) {\n\t var head = document.head;\n\t var body = document.body;\n\t body.style.display = 'none';\n\t var cssEl = document.createElement('link');\n\t cssEl.setAttribute('rel', 'stylesheet');\n\t cssEl.setAttribute('href', href);\n\t head.appendChild(cssEl);\n\t\n\t var setDynamic = function setDynamic() {\n\t var baseEl = document.createElement('div');\n\t body.appendChild(baseEl);\n\t\n\t var colors = {};\n\t (0, _times3.default)(16, function (n) {\n\t var name = 'base0' + n.toString(16).toUpperCase();\n\t baseEl.setAttribute('class', name);\n\t var color = window.getComputedStyle(baseEl).getPropertyValue('color');\n\t colors[name] = color;\n\t });\n\t\n\t body.removeChild(baseEl);\n\t\n\t var styleEl = document.createElement('style');\n\t head.appendChild(styleEl);\n\t\n\t\n\t body.style.display = 'initial';\n\t };\n\t\n\t cssEl.addEventListener('load', setDynamic);\n\t};\n\t\n\tvar rgb2rgba = function rgb2rgba(rgba) {\n\t return 'rgba(' + rgba.r + ', ' + rgba.g + ', ' + rgba.b + ', ' + rgba.a + ')';\n\t};\n\t\n\tvar getTextColor = function getTextColor(bg, text, preserve) {\n\t var bgIsLight = (0, _chromatism.convert)(bg).hsl.l > 50;\n\t var textIsLight = (0, _chromatism.convert)(text).hsl.l > 50;\n\t\n\t if (bgIsLight && textIsLight || !bgIsLight && !textIsLight) {\n\t var base = typeof text.a !== 'undefined' ? { a: text.a } : {};\n\t var result = (0, _assign2.default)(base, (0, _chromatism.invertLightness)(text).rgb);\n\t if (!preserve && (0, _color_convert.getContrastRatio)(bg, result) < 4.5) {\n\t return (0, _chromatism.contrastRatio)(bg, text).rgb;\n\t }\n\t return result;\n\t }\n\t return text;\n\t};\n\t\n\tvar applyTheme = function applyTheme(input, commit) {\n\t var _generatePreset = generatePreset(input),\n\t rules = _generatePreset.rules,\n\t theme = _generatePreset.theme;\n\t\n\t var head = document.head;\n\t var body = document.body;\n\t body.style.display = 'none';\n\t\n\t var styleEl = document.createElement('style');\n\t head.appendChild(styleEl);\n\t var styleSheet = styleEl.sheet;\n\t\n\t styleSheet.toString();\n\t styleSheet.insertRule('body { ' + rules.radii + ' }', 'index-max');\n\t styleSheet.insertRule('body { ' + rules.colors + ' }', 'index-max');\n\t styleSheet.insertRule('body { ' + rules.shadows + ' }', 'index-max');\n\t styleSheet.insertRule('body { ' + rules.fonts + ' }', 'index-max');\n\t body.style.display = 'initial';\n\t\n\t commit('setOption', { name: 'customTheme', value: input });\n\t commit('setOption', { name: 'colors', value: theme.colors });\n\t};\n\t\n\tvar getCssShadow = function getCssShadow(input, usesDropShadow) {\n\t if (input.length === 0) {\n\t return 'none';\n\t }\n\t\n\t return input.filter(function (_) {\n\t return usesDropShadow ? _.inset : _;\n\t }).map(function (shad) {\n\t return [shad.x, shad.y, shad.blur, shad.spread].map(function (_) {\n\t return _ + 'px';\n\t }).concat([getCssColor(shad.color, shad.alpha), shad.inset ? 'inset' : '']).join(' ');\n\t }).join(', ');\n\t};\n\t\n\tvar getCssShadowFilter = function getCssShadowFilter(input) {\n\t if (input.length === 0) {\n\t return 'none';\n\t }\n\t\n\t return input.filter(function (shad) {\n\t return !shad.inset && Number(shad.spread) === 0;\n\t }).map(function (shad) {\n\t return [shad.x, shad.y, shad.blur / 2].map(function (_) {\n\t return _ + 'px';\n\t }).concat([getCssColor(shad.color, shad.alpha)]).join(' ');\n\t }).map(function (_) {\n\t return 'drop-shadow(' + _ + ')';\n\t }).join(' ');\n\t};\n\t\n\tvar getCssColor = function getCssColor(input, a) {\n\t var rgb = {};\n\t if ((typeof input === 'undefined' ? 'undefined' : (0, _typeof3.default)(input)) === 'object') {\n\t rgb = input;\n\t } else if (typeof input === 'string') {\n\t if (input.startsWith('#')) {\n\t rgb = (0, _color_convert.hex2rgb)(input);\n\t } else if (input.startsWith('--')) {\n\t return 'var(' + input + ')';\n\t } else {\n\t return input;\n\t }\n\t }\n\t return rgb2rgba((0, _extends3.default)({}, rgb, { a: a }));\n\t};\n\t\n\tvar generateColors = function generateColors(input) {\n\t var colors = {};\n\t var opacity = (0, _assign2.default)({\n\t alert: 0.5,\n\t input: 0.5,\n\t faint: 0.5\n\t }, (0, _entries2.default)(input.opacity || {}).reduce(function (acc, _ref) {\n\t var _ref2 = (0, _slicedToArray3.default)(_ref, 2),\n\t k = _ref2[0],\n\t v = _ref2[1];\n\t\n\t if (typeof v !== 'undefined') {\n\t acc[k] = v;\n\t }\n\t return acc;\n\t }, {}));\n\t var col = (0, _entries2.default)(input.colors || input).reduce(function (acc, _ref3) {\n\t var _ref4 = (0, _slicedToArray3.default)(_ref3, 2),\n\t k = _ref4[0],\n\t v = _ref4[1];\n\t\n\t if ((typeof v === 'undefined' ? 'undefined' : (0, _typeof3.default)(v)) === 'object') {\n\t acc[k] = v;\n\t } else {\n\t acc[k] = (0, _color_convert.hex2rgb)(v);\n\t }\n\t return acc;\n\t }, {});\n\t\n\t var isLightOnDark = (0, _chromatism.convert)(col.bg).hsl.l < (0, _chromatism.convert)(col.text).hsl.l;\n\t var mod = isLightOnDark ? 1 : -1;\n\t\n\t colors.text = col.text;\n\t colors.lightText = (0, _chromatism.brightness)(20 * mod, colors.text).rgb;\n\t colors.link = col.link;\n\t colors.faint = col.faint || (0, _assign2.default)({}, col.text);\n\t\n\t colors.bg = col.bg;\n\t colors.lightBg = col.lightBg || (0, _chromatism.brightness)(5, colors.bg).rgb;\n\t\n\t colors.fg = col.fg;\n\t colors.fgText = col.fgText || getTextColor(colors.fg, colors.text);\n\t colors.fgLink = col.fgLink || getTextColor(colors.fg, colors.link, true);\n\t\n\t colors.border = col.border || (0, _chromatism.brightness)(2 * mod, colors.fg).rgb;\n\t\n\t colors.btn = col.btn || (0, _assign2.default)({}, col.fg);\n\t colors.btnText = col.btnText || getTextColor(colors.btn, colors.fgText);\n\t\n\t colors.input = col.input || (0, _assign2.default)({}, col.fg);\n\t colors.inputText = col.inputText || getTextColor(colors.input, colors.lightText);\n\t\n\t colors.panel = col.panel || (0, _assign2.default)({}, col.fg);\n\t colors.panelText = col.panelText || getTextColor(colors.panel, colors.fgText);\n\t colors.panelLink = col.panelLink || getTextColor(colors.panel, colors.fgLink);\n\t colors.panelFaint = col.panelFaint || getTextColor(colors.panel, colors.faint);\n\t\n\t colors.topBar = col.topBar || (0, _assign2.default)({}, col.fg);\n\t colors.topBarText = col.topBarText || getTextColor(colors.topBar, colors.fgText);\n\t colors.topBarLink = col.topBarLink || getTextColor(colors.topBar, colors.fgLink);\n\t\n\t colors.faintLink = col.faintLink || (0, _assign2.default)({}, col.link);\n\t\n\t colors.icon = (0, _color_convert.mixrgb)(colors.bg, colors.text);\n\t\n\t colors.cBlue = col.cBlue || (0, _color_convert.hex2rgb)('#0000FF');\n\t colors.cRed = col.cRed || (0, _color_convert.hex2rgb)('#FF0000');\n\t colors.cGreen = col.cGreen || (0, _color_convert.hex2rgb)('#00FF00');\n\t colors.cOrange = col.cOrange || (0, _color_convert.hex2rgb)('#E3FF00');\n\t\n\t colors.alertError = col.alertError || (0, _assign2.default)({}, colors.cRed);\n\t colors.alertErrorText = getTextColor((0, _color_convert.alphaBlend)(colors.alertError, opacity.alert, colors.bg), colors.text);\n\t colors.alertErrorPanelText = getTextColor((0, _color_convert.alphaBlend)(colors.alertError, opacity.alert, colors.panel), colors.panelText);\n\t\n\t colors.badgeNotification = col.badgeNotification || (0, _assign2.default)({}, colors.cRed);\n\t colors.badgeNotificationText = (0, _chromatism.contrastRatio)(colors.badgeNotification).rgb;\n\t\n\t (0, _entries2.default)(opacity).forEach(function (_ref5) {\n\t var _ref6 = (0, _slicedToArray3.default)(_ref5, 2),\n\t k = _ref6[0],\n\t v = _ref6[1];\n\t\n\t if (typeof v === 'undefined') return;\n\t if (k === 'alert') {\n\t colors.alertError.a = v;\n\t return;\n\t }\n\t if (k === 'faint') {\n\t colors[k + 'Link'].a = v;\n\t colors['panelFaint'].a = v;\n\t }\n\t if (k === 'bg') {\n\t colors['lightBg'].a = v;\n\t }\n\t if (colors[k]) {\n\t colors[k].a = v;\n\t } else {\n\t console.error('Wrong key ' + k);\n\t }\n\t });\n\t\n\t var htmlColors = (0, _entries2.default)(colors).reduce(function (acc, _ref7) {\n\t var _ref8 = (0, _slicedToArray3.default)(_ref7, 2),\n\t k = _ref8[0],\n\t v = _ref8[1];\n\t\n\t if (!v) return acc;\n\t acc.solid[k] = (0, _color_convert.rgb2hex)(v);\n\t acc.complete[k] = typeof v.a === 'undefined' ? (0, _color_convert.rgb2hex)(v) : rgb2rgba(v);\n\t return acc;\n\t }, { complete: {}, solid: {} });\n\t return {\n\t rules: {\n\t colors: (0, _entries2.default)(htmlColors.complete).filter(function (_ref9) {\n\t var _ref10 = (0, _slicedToArray3.default)(_ref9, 2),\n\t k = _ref10[0],\n\t v = _ref10[1];\n\t\n\t return v;\n\t }).map(function (_ref11) {\n\t var _ref12 = (0, _slicedToArray3.default)(_ref11, 2),\n\t k = _ref12[0],\n\t v = _ref12[1];\n\t\n\t return '--' + k + ': ' + v;\n\t }).join(';')\n\t },\n\t theme: {\n\t colors: htmlColors.solid,\n\t opacity: opacity\n\t }\n\t };\n\t};\n\t\n\tvar generateRadii = function generateRadii(input) {\n\t var inputRadii = input.radii || {};\n\t\n\t if (typeof input.btnRadius !== 'undefined') {\n\t inputRadii = (0, _entries2.default)(input).filter(function (_ref13) {\n\t var _ref14 = (0, _slicedToArray3.default)(_ref13, 2),\n\t k = _ref14[0],\n\t v = _ref14[1];\n\t\n\t return k.endsWith('Radius');\n\t }).reduce(function (acc, e) {\n\t acc[e[0].split('Radius')[0]] = e[1];return acc;\n\t }, {});\n\t }\n\t var radii = (0, _entries2.default)(inputRadii).filter(function (_ref15) {\n\t var _ref16 = (0, _slicedToArray3.default)(_ref15, 2),\n\t k = _ref16[0],\n\t v = _ref16[1];\n\t\n\t return v;\n\t }).reduce(function (acc, _ref17) {\n\t var _ref18 = (0, _slicedToArray3.default)(_ref17, 2),\n\t k = _ref18[0],\n\t v = _ref18[1];\n\t\n\t acc[k] = v;\n\t return acc;\n\t }, {\n\t btn: 4,\n\t input: 4,\n\t checkbox: 2,\n\t panel: 10,\n\t avatar: 5,\n\t avatarAlt: 50,\n\t tooltip: 2,\n\t attachment: 5\n\t });\n\t\n\t return {\n\t rules: {\n\t radii: (0, _entries2.default)(radii).filter(function (_ref19) {\n\t var _ref20 = (0, _slicedToArray3.default)(_ref19, 2),\n\t k = _ref20[0],\n\t v = _ref20[1];\n\t\n\t return v;\n\t }).map(function (_ref21) {\n\t var _ref22 = (0, _slicedToArray3.default)(_ref21, 2),\n\t k = _ref22[0],\n\t v = _ref22[1];\n\t\n\t return '--' + k + 'Radius: ' + v + 'px';\n\t }).join(';')\n\t },\n\t theme: {\n\t radii: radii\n\t }\n\t };\n\t};\n\t\n\tvar generateFonts = function generateFonts(input) {\n\t var fonts = (0, _entries2.default)(input.fonts || {}).filter(function (_ref23) {\n\t var _ref24 = (0, _slicedToArray3.default)(_ref23, 2),\n\t k = _ref24[0],\n\t v = _ref24[1];\n\t\n\t return v;\n\t }).reduce(function (acc, _ref25) {\n\t var _ref26 = (0, _slicedToArray3.default)(_ref25, 2),\n\t k = _ref26[0],\n\t v = _ref26[1];\n\t\n\t acc[k] = (0, _entries2.default)(v).filter(function (_ref27) {\n\t var _ref28 = (0, _slicedToArray3.default)(_ref27, 2),\n\t k = _ref28[0],\n\t v = _ref28[1];\n\t\n\t return v;\n\t }).reduce(function (acc, _ref29) {\n\t var _ref30 = (0, _slicedToArray3.default)(_ref29, 2),\n\t k = _ref30[0],\n\t v = _ref30[1];\n\t\n\t acc[k] = v;\n\t return acc;\n\t }, acc[k]);\n\t return acc;\n\t }, {\n\t interface: {\n\t family: 'sans-serif'\n\t },\n\t input: {\n\t family: 'inherit'\n\t },\n\t post: {\n\t family: 'inherit'\n\t },\n\t postCode: {\n\t family: 'monospace'\n\t }\n\t });\n\t\n\t return {\n\t rules: {\n\t fonts: (0, _entries2.default)(fonts).filter(function (_ref31) {\n\t var _ref32 = (0, _slicedToArray3.default)(_ref31, 2),\n\t k = _ref32[0],\n\t v = _ref32[1];\n\t\n\t return v;\n\t }).map(function (_ref33) {\n\t var _ref34 = (0, _slicedToArray3.default)(_ref33, 2),\n\t k = _ref34[0],\n\t v = _ref34[1];\n\t\n\t return '--' + k + 'Font: ' + v.family;\n\t }).join(';')\n\t },\n\t theme: {\n\t fonts: fonts\n\t }\n\t };\n\t};\n\t\n\tvar generateShadows = function generateShadows(input) {\n\t var border = function border(top, shadow) {\n\t return {\n\t x: 0,\n\t y: top ? 1 : -1,\n\t blur: 0,\n\t spread: 0,\n\t color: shadow ? '#000000' : '#FFFFFF',\n\t alpha: 0.2,\n\t inset: true\n\t };\n\t };\n\t var buttonInsetFakeBorders = [border(true, false), border(false, true)];\n\t var inputInsetFakeBorders = [border(true, true), border(false, false)];\n\t var hoverGlow = {\n\t x: 0,\n\t y: 0,\n\t blur: 4,\n\t spread: 0,\n\t color: '--faint',\n\t alpha: 1\n\t };\n\t\n\t var shadows = (0, _extends3.default)({\n\t panel: [{\n\t x: 1,\n\t y: 1,\n\t blur: 4,\n\t spread: 0,\n\t color: '#000000',\n\t alpha: 0.6\n\t }],\n\t topBar: [{\n\t x: 0,\n\t y: 0,\n\t blur: 4,\n\t spread: 0,\n\t color: '#000000',\n\t alpha: 0.6\n\t }],\n\t popup: [{\n\t x: 2,\n\t y: 2,\n\t blur: 3,\n\t spread: 0,\n\t color: '#000000',\n\t alpha: 0.5\n\t }],\n\t avatar: [{\n\t x: 0,\n\t y: 1,\n\t blur: 8,\n\t spread: 0,\n\t color: '#000000',\n\t alpha: 0.7\n\t }],\n\t avatarStatus: [],\n\t panelHeader: [],\n\t button: [{\n\t x: 0,\n\t y: 0,\n\t blur: 2,\n\t spread: 0,\n\t color: '#000000',\n\t alpha: 1\n\t }].concat(buttonInsetFakeBorders),\n\t buttonHover: [hoverGlow].concat(buttonInsetFakeBorders),\n\t buttonPressed: [hoverGlow].concat(inputInsetFakeBorders),\n\t input: [].concat(inputInsetFakeBorders, [{\n\t x: 0,\n\t y: 0,\n\t blur: 2,\n\t inset: true,\n\t spread: 0,\n\t color: '#000000',\n\t alpha: 1\n\t }])\n\t }, input.shadows || {});\n\t\n\t return {\n\t rules: {\n\t shadows: (0, _entries2.default)(shadows).map(function (_ref35) {\n\t var _ref36 = (0, _slicedToArray3.default)(_ref35, 2),\n\t k = _ref36[0],\n\t v = _ref36[1];\n\t\n\t return ['--' + k + 'Shadow: ' + getCssShadow(v), '--' + k + 'ShadowFilter: ' + getCssShadowFilter(v), '--' + k + 'ShadowInset: ' + getCssShadow(v, true)].join(';');\n\t }).join(';')\n\t },\n\t theme: {\n\t shadows: shadows\n\t }\n\t };\n\t};\n\t\n\tvar composePreset = function composePreset(colors, radii, shadows, fonts) {\n\t return {\n\t rules: (0, _extends3.default)({}, shadows.rules, colors.rules, radii.rules, fonts.rules),\n\t theme: (0, _extends3.default)({}, shadows.theme, colors.theme, radii.theme, fonts.theme)\n\t };\n\t};\n\t\n\tvar generatePreset = function generatePreset(input) {\n\t var shadows = generateShadows(input);\n\t var colors = generateColors(input);\n\t var radii = generateRadii(input);\n\t var fonts = generateFonts(input);\n\t\n\t return composePreset(colors, radii, shadows, fonts);\n\t};\n\t\n\tvar getThemes = function getThemes() {\n\t return window.fetch('/static/styles.json').then(function (data) {\n\t return data.json();\n\t }).then(function (themes) {\n\t return _promise2.default.all((0, _entries2.default)(themes).map(function (_ref37) {\n\t var _ref38 = (0, _slicedToArray3.default)(_ref37, 2),\n\t k = _ref38[0],\n\t v = _ref38[1];\n\t\n\t if ((typeof v === 'undefined' ? 'undefined' : (0, _typeof3.default)(v)) === 'object') {\n\t return _promise2.default.resolve([k, v]);\n\t } else if (typeof v === 'string') {\n\t return window.fetch(v).then(function (data) {\n\t return data.json();\n\t }).then(function (theme) {\n\t return [k, theme];\n\t }).catch(function (e) {\n\t console.error(e);\n\t return [];\n\t });\n\t }\n\t }));\n\t }).then(function (promises) {\n\t return promises.filter(function (_ref39) {\n\t var _ref40 = (0, _slicedToArray3.default)(_ref39, 2),\n\t k = _ref40[0],\n\t v = _ref40[1];\n\t\n\t return v;\n\t }).reduce(function (acc, _ref41) {\n\t var _ref42 = (0, _slicedToArray3.default)(_ref41, 2),\n\t k = _ref42[0],\n\t v = _ref42[1];\n\t\n\t acc[k] = v;\n\t return acc;\n\t }, {});\n\t });\n\t};\n\t\n\tvar setPreset = function setPreset(val, commit) {\n\t return getThemes().then(function (themes) {\n\t var theme = themes[val] ? themes[val] : themes['pleroma-dark'];\n\t var isV1 = Array.isArray(theme);\n\t var data = isV1 ? {} : theme.theme;\n\t\n\t if (isV1) {\n\t var bgRgb = (0, _color_convert.hex2rgb)(theme[1]);\n\t var fgRgb = (0, _color_convert.hex2rgb)(theme[2]);\n\t var textRgb = (0, _color_convert.hex2rgb)(theme[3]);\n\t var linkRgb = (0, _color_convert.hex2rgb)(theme[4]);\n\t\n\t var cRedRgb = (0, _color_convert.hex2rgb)(theme[5] || '#FF0000');\n\t var cGreenRgb = (0, _color_convert.hex2rgb)(theme[6] || '#00FF00');\n\t var cBlueRgb = (0, _color_convert.hex2rgb)(theme[7] || '#0000FF');\n\t var cOrangeRgb = (0, _color_convert.hex2rgb)(theme[8] || '#E3FF00');\n\t\n\t data.colors = {\n\t bg: bgRgb,\n\t fg: fgRgb,\n\t text: textRgb,\n\t link: linkRgb,\n\t cRed: cRedRgb,\n\t cBlue: cBlueRgb,\n\t cGreen: cGreenRgb,\n\t cOrange: cOrangeRgb\n\t };\n\t }\n\t\n\t if (!window.themeLoaded) {\n\t applyTheme(data, commit);\n\t }\n\t });\n\t};\n\t\n\texports.setStyle = setStyle;\n\texports.setPreset = setPreset;\n\texports.applyTheme = applyTheme;\n\texports.getTextColor = getTextColor;\n\texports.generateColors = generateColors;\n\texports.generateRadii = generateRadii;\n\texports.generateShadows = generateShadows;\n\texports.generateFonts = generateFonts;\n\texports.generatePreset = generatePreset;\n\texports.getThemes = getThemes;\n\texports.composePreset = composePreset;\n\texports.getCssShadow = getCssShadow;\n\texports.getCssShadowFilter = getCssShadowFilter;\n\n/***/ }),\n/* 64 */,\n/* 65 */,\n/* 66 */,\n/* 67 */,\n/* 68 */,\n/* 69 */,\n/* 70 */,\n/* 71 */,\n/* 72 */,\n/* 73 */,\n/* 74 */,\n/* 75 */,\n/* 76 */,\n/* 77 */,\n/* 78 */,\n/* 79 */,\n/* 80 */,\n/* 81 */,\n/* 82 */,\n/* 83 */,\n/* 84 */,\n/* 85 */,\n/* 86 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(413)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(255),\n\t /* template */\n\t __webpack_require__(716),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 87 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(419)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(291),\n\t /* template */\n\t __webpack_require__(724),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 88 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(390)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(298),\n\t /* template */\n\t __webpack_require__(681),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 89 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _vue = __webpack_require__(8);\n\t\n\tvar _vue2 = _interopRequireDefault(_vue);\n\t\n\t__webpack_require__(383);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\texports.default = _vue2.default.component('tab-switcher', {\n\t name: 'TabSwitcher',\n\t props: ['renderOnlyFocused'],\n\t data: function data() {\n\t return {\n\t active: this.$slots.default.findIndex(function (_) {\n\t return _.tag;\n\t })\n\t };\n\t },\n\t\n\t methods: {\n\t activateTab: function activateTab(index) {\n\t var _this = this;\n\t\n\t return function () {\n\t _this.active = index;\n\t };\n\t }\n\t },\n\t beforeUpdate: function beforeUpdate() {\n\t var currentSlot = this.$slots.default[this.active];\n\t if (!currentSlot.tag) {\n\t this.active = this.$slots.default.findIndex(function (_) {\n\t return _.tag;\n\t });\n\t }\n\t },\n\t render: function render(h) {\n\t var _this2 = this;\n\t\n\t var tabs = this.$slots.default.map(function (slot, index) {\n\t if (!slot.tag) return;\n\t var classesTab = ['tab'];\n\t var classesWrapper = ['tab-wrapper'];\n\t\n\t if (index === _this2.active) {\n\t classesTab.push('active');\n\t classesWrapper.push('active');\n\t }\n\t\n\t return h(\n\t 'div',\n\t { 'class': classesWrapper.join(' ') },\n\t [h(\n\t 'button',\n\t {\n\t attrs: { disabled: slot.data.attrs.disabled },\n\t on: {\n\t 'click': _this2.activateTab(index)\n\t },\n\t 'class': classesTab.join(' ') },\n\t [slot.data.attrs.label]\n\t )]\n\t );\n\t });\n\t\n\t var contents = this.$slots.default.map(function (slot, index) {\n\t if (!slot.tag) return;\n\t var active = index === _this2.active;\n\t if (_this2.renderOnlyFocused) {\n\t return active ? h(\n\t 'div',\n\t { 'class': 'active' },\n\t [slot]\n\t ) : h('div', { 'class': 'hidden' });\n\t }\n\t return h(\n\t 'div',\n\t { 'class': active ? 'active' : 'hidden' },\n\t [slot]\n\t );\n\t });\n\t\n\t return h(\n\t 'div',\n\t { 'class': 'tab-switcher' },\n\t [h(\n\t 'div',\n\t { 'class': 'tabs' },\n\t [tabs]\n\t ), h(\n\t 'div',\n\t { 'class': 'contents' },\n\t [contents]\n\t )]\n\t );\n\t }\n\t});\n\n/***/ }),\n/* 90 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _reduce2 = __webpack_require__(124);\n\t\n\tvar _reduce3 = _interopRequireDefault(_reduce2);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar getOrCreateApp = function getOrCreateApp(_ref) {\n\t var oauth = _ref.oauth,\n\t instance = _ref.instance;\n\t\n\t var url = instance + '/api/v1/apps';\n\t var form = new window.FormData();\n\t\n\t form.append('client_name', 'PleromaFE_' + Math.random());\n\t form.append('redirect_uris', window.location.origin + '/oauth-callback');\n\t form.append('scopes', 'read write follow');\n\t\n\t return window.fetch(url, {\n\t method: 'POST',\n\t body: form\n\t }).then(function (data) {\n\t return data.json();\n\t });\n\t};\n\tvar login = function login(args) {\n\t getOrCreateApp(args).then(function (app) {\n\t args.commit('setClientData', app);\n\t\n\t var data = {\n\t response_type: 'code',\n\t client_id: app.client_id,\n\t redirect_uri: app.redirect_uri,\n\t scope: 'read write follow'\n\t };\n\t\n\t var dataString = (0, _reduce3.default)(data, function (acc, v, k) {\n\t var encoded = k + '=' + encodeURIComponent(v);\n\t if (!acc) {\n\t return encoded;\n\t } else {\n\t return acc + '&' + encoded;\n\t }\n\t }, false);\n\t\n\t var url = args.instance + '/oauth/authorize?' + dataString;\n\t\n\t window.location.href = url;\n\t });\n\t};\n\t\n\tvar getTokenWithCredentials = function getTokenWithCredentials(_ref2) {\n\t var app = _ref2.app,\n\t instance = _ref2.instance,\n\t username = _ref2.username,\n\t password = _ref2.password;\n\t\n\t var url = instance + '/oauth/token';\n\t var form = new window.FormData();\n\t\n\t form.append('client_id', app.client_id);\n\t form.append('client_secret', app.client_secret);\n\t form.append('grant_type', 'password');\n\t form.append('username', username);\n\t form.append('password', password);\n\t\n\t return window.fetch(url, {\n\t method: 'POST',\n\t body: form\n\t }).then(function (data) {\n\t return data.json();\n\t });\n\t};\n\t\n\tvar getToken = function getToken(_ref3) {\n\t var app = _ref3.app,\n\t instance = _ref3.instance,\n\t code = _ref3.code;\n\t\n\t var url = instance + '/oauth/token';\n\t var form = new window.FormData();\n\t\n\t form.append('client_id', app.client_id);\n\t form.append('client_secret', app.client_secret);\n\t form.append('grant_type', 'authorization_code');\n\t form.append('code', code);\n\t form.append('redirect_uri', window.location.origin + '/oauth-callback');\n\t\n\t return window.fetch(url, {\n\t method: 'POST',\n\t body: form\n\t }).then(function (data) {\n\t return data.json();\n\t });\n\t};\n\t\n\tvar oauth = {\n\t login: login,\n\t getToken: getToken,\n\t getTokenWithCredentials: getTokenWithCredentials,\n\t getOrCreateApp: getOrCreateApp\n\t};\n\t\n\texports.default = oauth;\n\n/***/ }),\n/* 91 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\texports.unseenNotificationsFromStore = exports.visibleNotificationsFromStore = exports.visibleTypes = exports.notificationsFromStore = undefined;\n\t\n\tvar _isNan = __webpack_require__(65);\n\t\n\tvar _isNan2 = _interopRequireDefault(_isNan);\n\t\n\tvar _sortBy2 = __webpack_require__(612);\n\t\n\tvar _sortBy3 = _interopRequireDefault(_sortBy2);\n\t\n\tvar _filter2 = __webpack_require__(58);\n\t\n\tvar _filter3 = _interopRequireDefault(_filter2);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar notificationsFromStore = exports.notificationsFromStore = function notificationsFromStore(store) {\n\t return store.state.statuses.notifications.data;\n\t};\n\t\n\tvar visibleTypes = exports.visibleTypes = function visibleTypes(store) {\n\t return [store.state.config.notificationVisibility.likes && 'like', store.state.config.notificationVisibility.mentions && 'mention', store.state.config.notificationVisibility.repeats && 'repeat', store.state.config.notificationVisibility.follows && 'follow'].filter(function (_) {\n\t return _;\n\t });\n\t};\n\t\n\tvar sortById = function sortById(a, b) {\n\t var seqA = Number(a.action.id);\n\t var seqB = Number(b.action.id);\n\t var isSeqA = !(0, _isNan2.default)(seqA);\n\t var isSeqB = !(0, _isNan2.default)(seqB);\n\t if (isSeqA && isSeqB) {\n\t return seqA > seqB ? -1 : 1;\n\t } else if (isSeqA && !isSeqB) {\n\t return 1;\n\t } else if (!isSeqA && isSeqB) {\n\t return -1;\n\t } else {\n\t return a.action.id > b.action.id ? -1 : 1;\n\t }\n\t};\n\t\n\tvar visibleNotificationsFromStore = exports.visibleNotificationsFromStore = function visibleNotificationsFromStore(store) {\n\t var sortedNotifications = notificationsFromStore(store).map(function (_) {\n\t return _;\n\t }).sort(sortById);\n\t sortedNotifications = (0, _sortBy3.default)(sortedNotifications, 'seen');\n\t return sortedNotifications.filter(function (notification) {\n\t return visibleTypes(store).includes(notification.type);\n\t });\n\t};\n\t\n\tvar unseenNotificationsFromStore = exports.unseenNotificationsFromStore = function unseenNotificationsFromStore(store) {\n\t return (0, _filter3.default)(visibleNotificationsFromStore(store), function (_ref) {\n\t var seen = _ref.seen;\n\t return !seen;\n\t });\n\t};\n\n/***/ }),\n/* 92 */,\n/* 93 */,\n/* 94 */,\n/* 95 */,\n/* 96 */,\n/* 97 */,\n/* 98 */,\n/* 99 */,\n/* 100 */,\n/* 101 */,\n/* 102 */,\n/* 103 */,\n/* 104 */,\n/* 105 */,\n/* 106 */,\n/* 107 */,\n/* 108 */,\n/* 109 */,\n/* 110 */,\n/* 111 */,\n/* 112 */,\n/* 113 */,\n/* 114 */,\n/* 115 */,\n/* 116 */,\n/* 117 */,\n/* 118 */,\n/* 119 */,\n/* 120 */,\n/* 121 */,\n/* 122 */,\n/* 123 */,\n/* 124 */,\n/* 125 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(396)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(264),\n\t /* template */\n\t __webpack_require__(689),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 126 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(391)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(283),\n\t /* template */\n\t __webpack_require__(682),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 127 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(416)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(293),\n\t /* template */\n\t __webpack_require__(721),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 128 */,\n/* 129 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _extends2 = __webpack_require__(37);\n\t\n\tvar _extends3 = _interopRequireDefault(_extends2);\n\t\n\tvar _vue = __webpack_require__(8);\n\t\n\tvar _vue2 = _interopRequireDefault(_vue);\n\t\n\tvar _map = __webpack_require__(31);\n\t\n\tvar _map2 = _interopRequireDefault(_map);\n\t\n\tvar _isEmpty = __webpack_require__(121);\n\t\n\tvar _isEmpty2 = _interopRequireDefault(_isEmpty);\n\t\n\t__webpack_require__(384);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar defaultEntryPropsGetter = function defaultEntryPropsGetter(entry) {\n\t return { entry: entry };\n\t};\n\tvar defaultKeyGetter = function defaultKeyGetter(entry) {\n\t return entry.id;\n\t};\n\t\n\tvar withList = function withList(_ref) {\n\t var _ref$getEntryProps = _ref.getEntryProps,\n\t getEntryProps = _ref$getEntryProps === undefined ? defaultEntryPropsGetter : _ref$getEntryProps,\n\t _ref$getKey = _ref.getKey,\n\t getKey = _ref$getKey === undefined ? defaultKeyGetter : _ref$getKey;\n\t return function (ItemComponent) {\n\t return _vue2.default.component('withList', {\n\t props: ['entries', 'entryProps', 'entryListeners'],\n\t render: function render(createElement) {\n\t var _this = this;\n\t\n\t var h = arguments[0];\n\t\n\t return h(\n\t 'div',\n\t { 'class': 'with-list' },\n\t [(0, _map2.default)(this.entries, function (entry, index) {\n\t var props = {\n\t key: getKey(entry, index),\n\t props: (0, _extends3.default)({}, _this.$props.entryProps, getEntryProps(entry, index)),\n\t on: _this.$props.entryListeners\n\t };\n\t return h(ItemComponent, props);\n\t }), (0, _isEmpty2.default)(this.entries) && this.$slots.empty && h(\n\t 'div',\n\t { 'class': 'with-list-empty-content faint' },\n\t [this.$slots.empty]\n\t )]\n\t );\n\t }\n\t });\n\t };\n\t};\n\t\n\texports.default = withList;\n\n/***/ }),\n/* 130 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\t\n\tvar messages = {\n\t ar: __webpack_require__(433),\n\t ca: __webpack_require__(434),\n\t cs: __webpack_require__(435),\n\t de: __webpack_require__(436),\n\t en: __webpack_require__(437),\n\t eo: __webpack_require__(438),\n\t es: __webpack_require__(439),\n\t et: __webpack_require__(440),\n\t fi: __webpack_require__(441),\n\t fr: __webpack_require__(442),\n\t ga: __webpack_require__(443),\n\t he: __webpack_require__(444),\n\t hu: __webpack_require__(445),\n\t it: __webpack_require__(446),\n\t ja: __webpack_require__(447),\n\t ko: __webpack_require__(448),\n\t nb: __webpack_require__(449),\n\t nl: __webpack_require__(450),\n\t oc: __webpack_require__(451),\n\t pl: __webpack_require__(452),\n\t pt: __webpack_require__(453),\n\t ro: __webpack_require__(454),\n\t ru: __webpack_require__(455),\n\t zh: __webpack_require__(456)\n\t};\n\t\n\texports.default = messages;\n\n/***/ }),\n/* 131 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _extends2 = __webpack_require__(37);\n\t\n\tvar _extends3 = _interopRequireDefault(_extends2);\n\t\n\tvar _apiService = __webpack_require__(18);\n\t\n\tvar _apiService2 = _interopRequireDefault(_apiService);\n\t\n\tvar _timeline_fetcherService = __webpack_require__(136);\n\t\n\tvar _timeline_fetcherService2 = _interopRequireDefault(_timeline_fetcherService);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar backendInteractorService = function backendInteractorService(credentials) {\n\t var fetchStatus = function fetchStatus(_ref) {\n\t var id = _ref.id;\n\t\n\t return _apiService2.default.fetchStatus({ id: id, credentials: credentials });\n\t };\n\t\n\t var fetchConversation = function fetchConversation(_ref2) {\n\t var id = _ref2.id;\n\t\n\t return _apiService2.default.fetchConversation({ id: id, credentials: credentials });\n\t };\n\t\n\t var fetchFriends = function fetchFriends(_ref3) {\n\t var id = _ref3.id,\n\t page = _ref3.page;\n\t\n\t return _apiService2.default.fetchFriends({ id: id, page: page, credentials: credentials });\n\t };\n\t\n\t var exportFriends = function exportFriends(_ref4) {\n\t var id = _ref4.id;\n\t\n\t return _apiService2.default.exportFriends({ id: id, credentials: credentials });\n\t };\n\t\n\t var fetchFollowers = function fetchFollowers(_ref5) {\n\t var id = _ref5.id,\n\t page = _ref5.page;\n\t\n\t return _apiService2.default.fetchFollowers({ id: id, page: page, credentials: credentials });\n\t };\n\t\n\t var fetchAllFollowing = function fetchAllFollowing(_ref6) {\n\t var username = _ref6.username;\n\t\n\t return _apiService2.default.fetchAllFollowing({ username: username, credentials: credentials });\n\t };\n\t\n\t var fetchUser = function fetchUser(_ref7) {\n\t var id = _ref7.id;\n\t\n\t return _apiService2.default.fetchUser({ id: id, credentials: credentials });\n\t };\n\t\n\t var followUser = function followUser(id) {\n\t return _apiService2.default.followUser({ credentials: credentials, id: id });\n\t };\n\t\n\t var unfollowUser = function unfollowUser(id) {\n\t return _apiService2.default.unfollowUser({ credentials: credentials, id: id });\n\t };\n\t\n\t var blockUser = function blockUser(id) {\n\t return _apiService2.default.blockUser({ credentials: credentials, id: id });\n\t };\n\t\n\t var unblockUser = function unblockUser(id) {\n\t return _apiService2.default.unblockUser({ credentials: credentials, id: id });\n\t };\n\t\n\t var approveUser = function approveUser(id) {\n\t return _apiService2.default.approveUser({ credentials: credentials, id: id });\n\t };\n\t\n\t var denyUser = function denyUser(id) {\n\t return _apiService2.default.denyUser({ credentials: credentials, id: id });\n\t };\n\t\n\t var startFetching = function startFetching(_ref8) {\n\t var timeline = _ref8.timeline,\n\t store = _ref8.store,\n\t _ref8$userId = _ref8.userId,\n\t userId = _ref8$userId === undefined ? false : _ref8$userId,\n\t tag = _ref8.tag;\n\t\n\t return _timeline_fetcherService2.default.startFetching({ timeline: timeline, store: store, credentials: credentials, userId: userId, tag: tag });\n\t };\n\t\n\t var setUserMute = function setUserMute(_ref9) {\n\t var id = _ref9.id,\n\t _ref9$muted = _ref9.muted,\n\t muted = _ref9$muted === undefined ? true : _ref9$muted;\n\t\n\t return _apiService2.default.setUserMute({ id: id, muted: muted, credentials: credentials });\n\t };\n\t\n\t var fetchMutes = function fetchMutes() {\n\t return _apiService2.default.fetchMutes({ credentials: credentials });\n\t };\n\t var fetchBlocks = function fetchBlocks(params) {\n\t return _apiService2.default.fetchBlocks((0, _extends3.default)({ credentials: credentials }, params));\n\t };\n\t var fetchFollowRequests = function fetchFollowRequests() {\n\t return _apiService2.default.fetchFollowRequests({ credentials: credentials });\n\t };\n\t var fetchOAuthTokens = function fetchOAuthTokens() {\n\t return _apiService2.default.fetchOAuthTokens({ credentials: credentials });\n\t };\n\t var revokeOAuthToken = function revokeOAuthToken(id) {\n\t return _apiService2.default.revokeOAuthToken({ id: id, credentials: credentials });\n\t };\n\t\n\t var getCaptcha = function getCaptcha() {\n\t return _apiService2.default.getCaptcha();\n\t };\n\t var register = function register(params) {\n\t return _apiService2.default.register(params);\n\t };\n\t var updateAvatar = function updateAvatar(_ref10) {\n\t var params = _ref10.params;\n\t return _apiService2.default.updateAvatar({ credentials: credentials, params: params });\n\t };\n\t var updateBg = function updateBg(_ref11) {\n\t var params = _ref11.params;\n\t return _apiService2.default.updateBg({ credentials: credentials, params: params });\n\t };\n\t var updateBanner = function updateBanner(_ref12) {\n\t var params = _ref12.params;\n\t return _apiService2.default.updateBanner({ credentials: credentials, params: params });\n\t };\n\t var updateProfile = function updateProfile(_ref13) {\n\t var params = _ref13.params;\n\t return _apiService2.default.updateProfile({ credentials: credentials, params: params });\n\t };\n\t\n\t var externalProfile = function externalProfile(profileUrl) {\n\t return _apiService2.default.externalProfile({ profileUrl: profileUrl, credentials: credentials });\n\t };\n\t var followImport = function followImport(_ref14) {\n\t var params = _ref14.params;\n\t return _apiService2.default.followImport({ params: params, credentials: credentials });\n\t };\n\t\n\t var deleteAccount = function deleteAccount(_ref15) {\n\t var password = _ref15.password;\n\t return _apiService2.default.deleteAccount({ credentials: credentials, password: password });\n\t };\n\t var changePassword = function changePassword(_ref16) {\n\t var password = _ref16.password,\n\t newPassword = _ref16.newPassword,\n\t newPasswordConfirmation = _ref16.newPasswordConfirmation;\n\t return _apiService2.default.changePassword({ credentials: credentials, password: password, newPassword: newPassword, newPasswordConfirmation: newPasswordConfirmation });\n\t };\n\t\n\t var backendInteractorServiceInstance = {\n\t fetchStatus: fetchStatus,\n\t fetchConversation: fetchConversation,\n\t fetchFriends: fetchFriends,\n\t exportFriends: exportFriends,\n\t fetchFollowers: fetchFollowers,\n\t followUser: followUser,\n\t unfollowUser: unfollowUser,\n\t blockUser: blockUser,\n\t unblockUser: unblockUser,\n\t fetchUser: fetchUser,\n\t fetchAllFollowing: fetchAllFollowing,\n\t verifyCredentials: _apiService2.default.verifyCredentials,\n\t startFetching: startFetching,\n\t setUserMute: setUserMute,\n\t fetchMutes: fetchMutes,\n\t fetchBlocks: fetchBlocks,\n\t fetchOAuthTokens: fetchOAuthTokens,\n\t revokeOAuthToken: revokeOAuthToken,\n\t register: register,\n\t getCaptcha: getCaptcha,\n\t updateAvatar: updateAvatar,\n\t updateBg: updateBg,\n\t updateBanner: updateBanner,\n\t updateProfile: updateProfile,\n\t externalProfile: externalProfile,\n\t followImport: followImport,\n\t deleteAccount: deleteAccount,\n\t changePassword: changePassword,\n\t fetchFollowRequests: fetchFollowRequests,\n\t approveUser: approveUser,\n\t denyUser: denyUser\n\t };\n\t\n\t return backendInteractorServiceInstance;\n\t};\n\t\n\texports.default = backendInteractorService;\n\n/***/ }),\n/* 132 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\texports.getComponentProps = exports.getComponentOptions = undefined;\n\t\n\tvar _isFunction = __webpack_require__(84);\n\t\n\tvar _isFunction2 = _interopRequireDefault(_isFunction);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar getComponentOptions = function getComponentOptions(Component) {\n\t return (0, _isFunction2.default)(Component) ? Component.options : Component;\n\t};\n\t\n\tvar getComponentProps = function getComponentProps(Component) {\n\t return getComponentOptions(Component).props;\n\t};\n\t\n\texports.getComponentOptions = getComponentOptions;\n\texports.getComponentProps = getComponentProps;\n\n/***/ }),\n/* 133 */\n/***/ (function(module, exports) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\tvar fileSizeFormat = function fileSizeFormat(num) {\n\t var exponent;\n\t var unit;\n\t var units = ['B', 'KiB', 'MiB', 'GiB', 'TiB'];\n\t if (num < 1) {\n\t return num + ' ' + units[0];\n\t }\n\t\n\t exponent = Math.min(Math.floor(Math.log(num) / Math.log(1024)), units.length - 1);\n\t num = (num / Math.pow(1024, exponent)).toFixed(2) * 1;\n\t unit = units[exponent];\n\t return { num: num, unit: unit };\n\t};\n\tvar fileSizeFormatService = {\n\t fileSizeFormat: fileSizeFormat\n\t};\n\texports.default = fileSizeFormatService;\n\n/***/ }),\n/* 134 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\texports.requestUnfollow = exports.requestFollow = undefined;\n\t\n\tvar _slicedToArray2 = __webpack_require__(9);\n\t\n\tvar _slicedToArray3 = _interopRequireDefault(_slicedToArray2);\n\t\n\tvar _promise = __webpack_require__(25);\n\t\n\tvar _promise2 = _interopRequireDefault(_promise);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar fetchUser = function fetchUser(attempt, user, store) {\n\t return new _promise2.default(function (resolve, reject) {\n\t setTimeout(function () {\n\t store.state.api.backendInteractor.fetchUser({ id: user.id }).then(function (user) {\n\t return store.commit('addNewUsers', [user]);\n\t }).then(function () {\n\t return resolve([user.following, attempt]);\n\t }).catch(function (e) {\n\t return reject(e);\n\t });\n\t }, 500);\n\t }).then(function (_ref) {\n\t var _ref2 = (0, _slicedToArray3.default)(_ref, 2),\n\t following = _ref2[0],\n\t attempt = _ref2[1];\n\t\n\t if (!following && attempt <= 3) {\n\t return fetchUser(++attempt, user, store);\n\t } else {\n\t return following;\n\t }\n\t });\n\t};\n\t\n\tvar requestFollow = exports.requestFollow = function requestFollow(user, store) {\n\t return new _promise2.default(function (resolve, reject) {\n\t store.state.api.backendInteractor.followUser(user.id).then(function (updated) {\n\t store.commit('addNewUsers', [updated]);\n\t\n\t if (updated.locked) {\n\t resolve({\n\t sent: true,\n\t updated: updated\n\t });\n\t }\n\t\n\t if (updated.following) {\n\t resolve({\n\t sent: false,\n\t updated: updated\n\t });\n\t }\n\t\n\t return fetchUser(1, user, store).then(function (following) {\n\t if (following) {\n\t resolve({\n\t sent: false,\n\t updated: updated\n\t });\n\t } else {\n\t resolve({\n\t sent: false,\n\t updated: updated\n\t });\n\t }\n\t });\n\t });\n\t });\n\t};\n\t\n\tvar requestUnfollow = exports.requestUnfollow = function requestUnfollow(user, store) {\n\t return new _promise2.default(function (resolve, reject) {\n\t store.state.api.backendInteractor.unfollowUser(user.id).then(function (updated) {\n\t store.commit('addNewUsers', [updated]);\n\t resolve({\n\t updated: updated\n\t });\n\t });\n\t });\n\t};\n\n/***/ }),\n/* 135 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _map2 = __webpack_require__(31);\n\t\n\tvar _map3 = _interopRequireDefault(_map2);\n\t\n\tvar _apiService = __webpack_require__(18);\n\t\n\tvar _apiService2 = _interopRequireDefault(_apiService);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar postStatus = function postStatus(_ref) {\n\t var store = _ref.store,\n\t status = _ref.status,\n\t spoilerText = _ref.spoilerText,\n\t visibility = _ref.visibility,\n\t sensitive = _ref.sensitive,\n\t _ref$media = _ref.media,\n\t media = _ref$media === undefined ? [] : _ref$media,\n\t _ref$inReplyToStatusI = _ref.inReplyToStatusId,\n\t inReplyToStatusId = _ref$inReplyToStatusI === undefined ? undefined : _ref$inReplyToStatusI,\n\t _ref$contentType = _ref.contentType,\n\t contentType = _ref$contentType === undefined ? 'text/plain' : _ref$contentType;\n\t\n\t var mediaIds = (0, _map3.default)(media, 'id');\n\t\n\t return _apiService2.default.postStatus({ credentials: store.state.users.currentUser.credentials, status: status, spoilerText: spoilerText, visibility: visibility, sensitive: sensitive, mediaIds: mediaIds, inReplyToStatusId: inReplyToStatusId, contentType: contentType, noAttachmentLinks: store.state.instance.noAttachmentLinks }).then(function (data) {\n\t if (!data.error) {\n\t store.dispatch('addNewStatuses', {\n\t statuses: [data],\n\t timeline: 'friends',\n\t showImmediately: true,\n\t noIdUpdate: true });\n\t }\n\t return data;\n\t }).catch(function (err) {\n\t return {\n\t error: err.message\n\t };\n\t });\n\t};\n\t\n\tvar uploadMedia = function uploadMedia(_ref2) {\n\t var store = _ref2.store,\n\t formData = _ref2.formData;\n\t\n\t var credentials = store.state.users.currentUser.credentials;\n\t\n\t return _apiService2.default.uploadMedia({ credentials: credentials, formData: formData }).then(function (xml) {\n\t var link = xml.getElementsByTagName('link');\n\t\n\t if (link.length === 0) {\n\t link = xml.getElementsByTagName('atom:link');\n\t }\n\t\n\t link = link[0];\n\t\n\t var mediaData = {\n\t id: xml.getElementsByTagName('media_id')[0].textContent,\n\t url: xml.getElementsByTagName('media_url')[0].textContent,\n\t image: link.getAttribute('href'),\n\t mimetype: link.getAttribute('type')\n\t };\n\t\n\t return mediaData;\n\t });\n\t};\n\t\n\tvar statusPosterService = {\n\t postStatus: postStatus,\n\t uploadMedia: uploadMedia\n\t};\n\t\n\texports.default = statusPosterService;\n\n/***/ }),\n/* 136 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _camelCase2 = __webpack_require__(585);\n\t\n\tvar _camelCase3 = _interopRequireDefault(_camelCase2);\n\t\n\tvar _apiService = __webpack_require__(18);\n\t\n\tvar _apiService2 = _interopRequireDefault(_apiService);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar update = function update(_ref) {\n\t var store = _ref.store,\n\t statuses = _ref.statuses,\n\t timeline = _ref.timeline,\n\t showImmediately = _ref.showImmediately,\n\t userId = _ref.userId;\n\t\n\t var ccTimeline = (0, _camelCase3.default)(timeline);\n\t\n\t store.dispatch('setError', { value: false });\n\t\n\t store.dispatch('addNewStatuses', {\n\t timeline: ccTimeline,\n\t userId: userId,\n\t statuses: statuses,\n\t showImmediately: showImmediately\n\t });\n\t};\n\t\n\tvar fetchAndUpdate = function fetchAndUpdate(_ref2) {\n\t var store = _ref2.store,\n\t credentials = _ref2.credentials,\n\t _ref2$timeline = _ref2.timeline,\n\t timeline = _ref2$timeline === undefined ? 'friends' : _ref2$timeline,\n\t _ref2$older = _ref2.older,\n\t older = _ref2$older === undefined ? false : _ref2$older,\n\t _ref2$showImmediately = _ref2.showImmediately,\n\t showImmediately = _ref2$showImmediately === undefined ? false : _ref2$showImmediately,\n\t _ref2$userId = _ref2.userId,\n\t userId = _ref2$userId === undefined ? false : _ref2$userId,\n\t _ref2$tag = _ref2.tag,\n\t tag = _ref2$tag === undefined ? false : _ref2$tag,\n\t until = _ref2.until;\n\t\n\t var args = { timeline: timeline, credentials: credentials };\n\t var rootState = store.rootState || store.state;\n\t var timelineData = rootState.statuses.timelines[(0, _camelCase3.default)(timeline)];\n\t\n\t if (older) {\n\t args['until'] = until || timelineData.minId;\n\t } else {\n\t args['since'] = timelineData.maxId;\n\t }\n\t\n\t args['userId'] = userId;\n\t args['tag'] = tag;\n\t\n\t var numStatusesBeforeFetch = timelineData.statuses.length;\n\t\n\t return _apiService2.default.fetchTimeline(args).then(function (statuses) {\n\t if (!older && statuses.length >= 20 && !timelineData.loading && numStatusesBeforeFetch > 0) {\n\t store.dispatch('queueFlush', { timeline: timeline, id: timelineData.maxId });\n\t }\n\t update({ store: store, statuses: statuses, timeline: timeline, showImmediately: showImmediately, userId: userId });\n\t return statuses;\n\t }, function () {\n\t return store.dispatch('setError', { value: true });\n\t });\n\t};\n\t\n\tvar startFetching = function startFetching(_ref3) {\n\t var _ref3$timeline = _ref3.timeline,\n\t timeline = _ref3$timeline === undefined ? 'friends' : _ref3$timeline,\n\t credentials = _ref3.credentials,\n\t store = _ref3.store,\n\t _ref3$userId = _ref3.userId,\n\t userId = _ref3$userId === undefined ? false : _ref3$userId,\n\t _ref3$tag = _ref3.tag,\n\t tag = _ref3$tag === undefined ? false : _ref3$tag;\n\t\n\t var rootState = store.rootState || store.state;\n\t var timelineData = rootState.statuses.timelines[(0, _camelCase3.default)(timeline)];\n\t var showImmediately = timelineData.visibleStatuses.length === 0;\n\t timelineData.userId = userId;\n\t fetchAndUpdate({ timeline: timeline, credentials: credentials, store: store, showImmediately: showImmediately, userId: userId, tag: tag });\n\t var boundFetchAndUpdate = function boundFetchAndUpdate() {\n\t return fetchAndUpdate({ timeline: timeline, credentials: credentials, store: store, userId: userId, tag: tag });\n\t };\n\t return setInterval(boundFetchAndUpdate, 10000);\n\t};\n\tvar timelineFetcher = {\n\t fetchAndUpdate: fetchAndUpdate,\n\t startFetching: startFetching\n\t};\n\t\n\texports.default = timelineFetcher;\n\n/***/ }),\n/* 137 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\texports.highlightStyle = exports.highlightClass = undefined;\n\t\n\tvar _color_convert = __webpack_require__(44);\n\t\n\tvar highlightStyle = function highlightStyle(prefs) {\n\t if (prefs === undefined) return;\n\t var color = prefs.color,\n\t type = prefs.type;\n\t\n\t if (typeof color !== 'string') return;\n\t var rgb = (0, _color_convert.hex2rgb)(color);\n\t if (rgb == null) return;\n\t var solidColor = 'rgb(' + Math.floor(rgb.r) + ', ' + Math.floor(rgb.g) + ', ' + Math.floor(rgb.b) + ')';\n\t var tintColor = 'rgba(' + Math.floor(rgb.r) + ', ' + Math.floor(rgb.g) + ', ' + Math.floor(rgb.b) + ', .1)';\n\t var tintColor2 = 'rgba(' + Math.floor(rgb.r) + ', ' + Math.floor(rgb.g) + ', ' + Math.floor(rgb.b) + ', .2)';\n\t if (type === 'striped') {\n\t return {\n\t backgroundImage: ['repeating-linear-gradient(135deg,', tintColor + ' ,', tintColor + ' 20px,', tintColor2 + ' 20px,', tintColor2 + ' 40px'].join(' '),\n\t backgroundPosition: '0 0'\n\t };\n\t } else if (type === 'solid') {\n\t return {\n\t backgroundColor: tintColor2\n\t };\n\t } else if (type === 'side') {\n\t return {\n\t backgroundImage: ['linear-gradient(to right,', solidColor + ' ,', solidColor + ' 2px,', 'transparent 6px'].join(' '),\n\t backgroundPosition: '0 0'\n\t };\n\t }\n\t};\n\t\n\tvar highlightClass = function highlightClass(user) {\n\t return 'USER____' + user.screen_name.replace(/\\./g, '_').replace(/@/g, '_AT_');\n\t};\n\t\n\texports.highlightClass = highlightClass;\n\texports.highlightStyle = highlightStyle;\n\n/***/ }),\n/* 138 */,\n/* 139 */,\n/* 140 */,\n/* 141 */,\n/* 142 */,\n/* 143 */,\n/* 144 */,\n/* 145 */,\n/* 146 */,\n/* 147 */,\n/* 148 */,\n/* 149 */,\n/* 150 */,\n/* 151 */,\n/* 152 */,\n/* 153 */,\n/* 154 */,\n/* 155 */,\n/* 156 */,\n/* 157 */,\n/* 158 */,\n/* 159 */,\n/* 160 */,\n/* 161 */,\n/* 162 */,\n/* 163 */,\n/* 164 */,\n/* 165 */,\n/* 166 */,\n/* 167 */,\n/* 168 */,\n/* 169 */,\n/* 170 */,\n/* 171 */,\n/* 172 */,\n/* 173 */,\n/* 174 */,\n/* 175 */,\n/* 176 */,\n/* 177 */,\n/* 178 */,\n/* 179 */,\n/* 180 */,\n/* 181 */,\n/* 182 */,\n/* 183 */,\n/* 184 */,\n/* 185 */,\n/* 186 */,\n/* 187 */,\n/* 188 */,\n/* 189 */,\n/* 190 */,\n/* 191 */,\n/* 192 */,\n/* 193 */,\n/* 194 */,\n/* 195 */,\n/* 196 */,\n/* 197 */,\n/* 198 */,\n/* 199 */,\n/* 200 */,\n/* 201 */,\n/* 202 */,\n/* 203 */,\n/* 204 */,\n/* 205 */,\n/* 206 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(405)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(254),\n\t /* template */\n\t __webpack_require__(703),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 207 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(397)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(257),\n\t /* template */\n\t __webpack_require__(693),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 208 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(418)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(246),\n\t /* template */\n\t __webpack_require__(723),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 209 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(259),\n\t /* template */\n\t __webpack_require__(683),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 210 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(403)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(263),\n\t /* template */\n\t __webpack_require__(701),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 211 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(420)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(271),\n\t /* template */\n\t __webpack_require__(725),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 212 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(401)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(273),\n\t /* template */\n\t __webpack_require__(699),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 213 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(387)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(281),\n\t /* template */\n\t __webpack_require__(677),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 214 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(250),\n\t /* template */\n\t __webpack_require__(706),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 215 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(424)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(294),\n\t /* template */\n\t __webpack_require__(730),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 216 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(305),\n\t /* template */\n\t __webpack_require__(708),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 217 */,\n/* 218 */,\n/* 219 */,\n/* 220 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _keys = __webpack_require__(24);\n\t\n\tvar _keys2 = _interopRequireDefault(_keys);\n\t\n\tvar _assign = __webpack_require__(36);\n\t\n\tvar _assign2 = _interopRequireDefault(_assign);\n\t\n\tvar _vue = __webpack_require__(8);\n\t\n\tvar _vue2 = _interopRequireDefault(_vue);\n\t\n\tvar _vueRouter = __webpack_require__(217);\n\t\n\tvar _vueRouter2 = _interopRequireDefault(_vueRouter);\n\t\n\tvar _routes = __webpack_require__(221);\n\t\n\tvar _routes2 = _interopRequireDefault(_routes);\n\t\n\tvar _App = __webpack_require__(633);\n\t\n\tvar _App2 = _interopRequireDefault(_App);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar afterStoreSetup = function afterStoreSetup(_ref) {\n\t var store = _ref.store,\n\t i18n = _ref.i18n;\n\t\n\t window.fetch('/api/statusnet/config.json').then(function (res) {\n\t return res.json();\n\t }).then(function (data) {\n\t var _data$site = data.site,\n\t name = _data$site.name,\n\t registrationClosed = _data$site.closed,\n\t textlimit = _data$site.textlimit,\n\t uploadlimit = _data$site.uploadlimit,\n\t server = _data$site.server,\n\t vapidPublicKey = _data$site.vapidPublicKey;\n\t\n\t\n\t store.dispatch('setInstanceOption', { name: 'name', value: name });\n\t store.dispatch('setInstanceOption', { name: 'registrationOpen', value: registrationClosed === '0' });\n\t store.dispatch('setInstanceOption', { name: 'textlimit', value: parseInt(textlimit) });\n\t store.dispatch('setInstanceOption', { name: 'server', value: server });\n\t\n\t if (uploadlimit) {\n\t store.dispatch('setInstanceOption', { name: 'uploadlimit', value: parseInt(uploadlimit.uploadlimit) });\n\t store.dispatch('setInstanceOption', { name: 'avatarlimit', value: parseInt(uploadlimit.avatarlimit) });\n\t store.dispatch('setInstanceOption', { name: 'backgroundlimit', value: parseInt(uploadlimit.backgroundlimit) });\n\t store.dispatch('setInstanceOption', { name: 'bannerlimit', value: parseInt(uploadlimit.bannerlimit) });\n\t }\n\t\n\t if (vapidPublicKey) {\n\t store.dispatch('setInstanceOption', { name: 'vapidPublicKey', value: vapidPublicKey });\n\t }\n\t\n\t var apiConfig = data.site.pleromafe;\n\t\n\t window.fetch('/static/config.json').then(function (res) {\n\t return res.json();\n\t }).catch(function (err) {\n\t console.warn('Failed to load static/config.json, continuing without it.');\n\t console.warn(err);\n\t return {};\n\t }).then(function (staticConfig) {\n\t var overrides = window.___pleromafe_dev_overrides || {};\n\t var env = window.___pleromafe_mode.NODE_ENV;\n\t\n\t var config = {};\n\t if (overrides.staticConfigPreference && env === 'development') {\n\t console.warn('OVERRIDING API CONFIG WITH STATIC CONFIG');\n\t config = (0, _assign2.default)({}, apiConfig, staticConfig);\n\t } else {\n\t config = (0, _assign2.default)({}, staticConfig, apiConfig);\n\t }\n\t\n\t var copyInstanceOption = function copyInstanceOption(name) {\n\t store.dispatch('setInstanceOption', { name: name, value: config[name] });\n\t };\n\t\n\t copyInstanceOption('nsfwCensorImage');\n\t copyInstanceOption('background');\n\t copyInstanceOption('hidePostStats');\n\t copyInstanceOption('hideUserStats');\n\t copyInstanceOption('hideFilteredStatuses');\n\t copyInstanceOption('logo');\n\t\n\t store.dispatch('setInstanceOption', {\n\t name: 'logoMask',\n\t value: typeof config.logoMask === 'undefined' ? true : config.logoMask\n\t });\n\t\n\t store.dispatch('setInstanceOption', {\n\t name: 'logoMargin',\n\t value: typeof config.logoMargin === 'undefined' ? 0 : config.logoMargin\n\t });\n\t\n\t copyInstanceOption('redirectRootNoLogin');\n\t copyInstanceOption('redirectRootLogin');\n\t copyInstanceOption('showInstanceSpecificPanel');\n\t copyInstanceOption('scopeOptionsEnabled');\n\t copyInstanceOption('formattingOptionsEnabled');\n\t copyInstanceOption('collapseMessageWithSubject');\n\t copyInstanceOption('loginMethod');\n\t copyInstanceOption('scopeCopy');\n\t copyInstanceOption('subjectLineBehavior');\n\t copyInstanceOption('postContentType');\n\t copyInstanceOption('alwaysShowSubjectInput');\n\t copyInstanceOption('noAttachmentLinks');\n\t copyInstanceOption('showFeaturesPanel');\n\t\n\t if (config.chatDisabled) {\n\t store.dispatch('disableChat');\n\t }\n\t\n\t return store.dispatch('setTheme', config['theme']);\n\t }).then(function () {\n\t var router = new _vueRouter2.default({\n\t mode: 'history',\n\t routes: (0, _routes2.default)(store),\n\t scrollBehavior: function scrollBehavior(to, _from, savedPosition) {\n\t if (to.matched.some(function (m) {\n\t return m.meta.dontScroll;\n\t })) {\n\t return false;\n\t }\n\t return savedPosition || { x: 0, y: 0 };\n\t }\n\t });\n\t\n\t new _vue2.default({\n\t router: router,\n\t store: store,\n\t i18n: i18n,\n\t el: '#app',\n\t render: function render(h) {\n\t return h(_App2.default);\n\t }\n\t });\n\t });\n\t });\n\t\n\t window.fetch('/static/terms-of-service.html').then(function (res) {\n\t return res.text();\n\t }).then(function (html) {\n\t store.dispatch('setInstanceOption', { name: 'tos', value: html });\n\t });\n\t\n\t window.fetch('/api/pleroma/emoji.json').then(function (res) {\n\t return res.json().then(function (values) {\n\t var emoji = (0, _keys2.default)(values).map(function (key) {\n\t return { shortcode: key, image_url: values[key] };\n\t });\n\t store.dispatch('setInstanceOption', { name: 'customEmoji', value: emoji });\n\t store.dispatch('setInstanceOption', { name: 'pleromaBackend', value: true });\n\t }, function (failure) {\n\t store.dispatch('setInstanceOption', { name: 'pleromaBackend', value: false });\n\t });\n\t }, function (error) {\n\t return console.log(error);\n\t });\n\t\n\t window.fetch('/static/emoji.json').then(function (res) {\n\t return res.json();\n\t }).then(function (values) {\n\t var emoji = (0, _keys2.default)(values).map(function (key) {\n\t return { shortcode: key, image_url: false, 'utf': values[key] };\n\t });\n\t store.dispatch('setInstanceOption', { name: 'emoji', value: emoji });\n\t });\n\t\n\t window.fetch('/instance/panel.html').then(function (res) {\n\t return res.text();\n\t }).then(function (html) {\n\t store.dispatch('setInstanceOption', { name: 'instanceSpecificPanelContent', value: html });\n\t });\n\t\n\t window.fetch('/nodeinfo/2.0.json').then(function (res) {\n\t return res.json();\n\t }).then(function (data) {\n\t var metadata = data.metadata;\n\t\n\t var features = metadata.features;\n\t store.dispatch('setInstanceOption', { name: 'mediaProxyAvailable', value: features.includes('media_proxy') });\n\t store.dispatch('setInstanceOption', { name: 'chatAvailable', value: features.includes('chat') });\n\t store.dispatch('setInstanceOption', { name: 'gopherAvailable', value: features.includes('gopher') });\n\t\n\t store.dispatch('setInstanceOption', { name: 'postFormats', value: metadata.postFormats });\n\t\n\t store.dispatch('setInstanceOption', { name: 'restrictedNicknames', value: metadata.restrictedNicknames });\n\t\n\t var suggestions = metadata.suggestions;\n\t store.dispatch('setInstanceOption', { name: 'suggestionsEnabled', value: suggestions.enabled });\n\t store.dispatch('setInstanceOption', { name: 'suggestionsWeb', value: suggestions.web });\n\t });\n\t};\n\t\n\texports.default = afterStoreSetup;\n\n/***/ }),\n/* 221 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _public_timeline = __webpack_require__(659);\n\t\n\tvar _public_timeline2 = _interopRequireDefault(_public_timeline);\n\t\n\tvar _public_and_external_timeline = __webpack_require__(658);\n\t\n\tvar _public_and_external_timeline2 = _interopRequireDefault(_public_and_external_timeline);\n\t\n\tvar _friends_timeline = __webpack_require__(645);\n\t\n\tvar _friends_timeline2 = _interopRequireDefault(_friends_timeline);\n\t\n\tvar _tag_timeline = __webpack_require__(668);\n\t\n\tvar _tag_timeline2 = _interopRequireDefault(_tag_timeline);\n\t\n\tvar _conversationPage = __webpack_require__(637);\n\t\n\tvar _conversationPage2 = _interopRequireDefault(_conversationPage);\n\t\n\tvar _mentions = __webpack_require__(652);\n\t\n\tvar _mentions2 = _interopRequireDefault(_mentions);\n\t\n\tvar _dm_timeline = __webpack_require__(639);\n\t\n\tvar _dm_timeline2 = _interopRequireDefault(_dm_timeline);\n\t\n\tvar _user_profile = __webpack_require__(672);\n\t\n\tvar _user_profile2 = _interopRequireDefault(_user_profile);\n\t\n\tvar _settings = __webpack_require__(663);\n\t\n\tvar _settings2 = _interopRequireDefault(_settings);\n\t\n\tvar _registration = __webpack_require__(661);\n\t\n\tvar _registration2 = _interopRequireDefault(_registration);\n\t\n\tvar _user_settings = __webpack_require__(674);\n\t\n\tvar _user_settings2 = _interopRequireDefault(_user_settings);\n\t\n\tvar _follow_requests = __webpack_require__(643);\n\t\n\tvar _follow_requests2 = _interopRequireDefault(_follow_requests);\n\t\n\tvar _oauth_callback = __webpack_require__(657);\n\t\n\tvar _oauth_callback2 = _interopRequireDefault(_oauth_callback);\n\t\n\tvar _user_search = __webpack_require__(673);\n\t\n\tvar _user_search2 = _interopRequireDefault(_user_search);\n\t\n\tvar _notifications = __webpack_require__(213);\n\t\n\tvar _notifications2 = _interopRequireDefault(_notifications);\n\t\n\tvar _login_form = __webpack_require__(212);\n\t\n\tvar _login_form2 = _interopRequireDefault(_login_form);\n\t\n\tvar _chat_panel = __webpack_require__(207);\n\t\n\tvar _chat_panel2 = _interopRequireDefault(_chat_panel);\n\t\n\tvar _who_to_follow = __webpack_require__(675);\n\t\n\tvar _who_to_follow2 = _interopRequireDefault(_who_to_follow);\n\t\n\tvar _about = __webpack_require__(634);\n\t\n\tvar _about2 = _interopRequireDefault(_about);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\texports.default = function (store) {\n\t return [{ name: 'root',\n\t path: '/',\n\t redirect: function redirect(_to) {\n\t return (store.state.users.currentUser ? store.state.instance.redirectRootLogin : store.state.instance.redirectRootNoLogin) || '/main/all';\n\t }\n\t }, { name: 'public-external-timeline', path: '/main/all', component: _public_and_external_timeline2.default }, { name: 'public-timeline', path: '/main/public', component: _public_timeline2.default }, { name: 'friends', path: '/main/friends', component: _friends_timeline2.default }, { name: 'tag-timeline', path: '/tag/:tag', component: _tag_timeline2.default }, { name: 'conversation', path: '/notice/:id', component: _conversationPage2.default, meta: { dontScroll: true } }, { name: 'external-user-profile', path: '/users/:id', component: _user_profile2.default }, { name: 'mentions', path: '/users/:username/mentions', component: _mentions2.default }, { name: 'dms', path: '/users/:username/dms', component: _dm_timeline2.default }, { name: 'settings', path: '/settings', component: _settings2.default }, { name: 'registration', path: '/registration', component: _registration2.default }, { name: 'registration-token', path: '/registration/:token', component: _registration2.default }, { name: 'friend-requests', path: '/friend-requests', component: _follow_requests2.default }, { name: 'user-settings', path: '/user-settings', component: _user_settings2.default }, { name: 'notifications', path: '/:username/notifications', component: _notifications2.default }, { name: 'login', path: '/login', component: _login_form2.default }, { name: 'chat', path: '/chat', component: _chat_panel2.default, props: function props() {\n\t return { floating: false };\n\t } }, { name: 'oauth-callback', path: '/oauth-callback', component: _oauth_callback2.default, props: function props(route) {\n\t return { code: route.query.code };\n\t } }, { name: 'user-search', path: '/user-search', component: _user_search2.default, props: function props(route) {\n\t return { query: route.query.query };\n\t } }, { name: 'who-to-follow', path: '/who-to-follow', component: _who_to_follow2.default }, { name: 'about', path: '/about', component: _about2.default }, { name: 'user-profile', path: '/(users/)?:name', component: _user_profile2.default }];\n\t};\n\n/***/ }),\n/* 222 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _slicedToArray2 = __webpack_require__(9);\n\t\n\tvar _slicedToArray3 = _interopRequireDefault(_slicedToArray2);\n\t\n\tvar _entries = __webpack_require__(23);\n\t\n\tvar _entries2 = _interopRequireDefault(_entries);\n\t\n\tvar _defineProperty2 = __webpack_require__(140);\n\t\n\tvar _defineProperty3 = _interopRequireDefault(_defineProperty2);\n\t\n\tvar _extends3 = __webpack_require__(37);\n\t\n\tvar _extends4 = _interopRequireDefault(_extends3);\n\t\n\tvar _keys = __webpack_require__(24);\n\t\n\tvar _keys2 = _interopRequireDefault(_keys);\n\t\n\tvar _vue = __webpack_require__(8);\n\t\n\tvar _vue2 = _interopRequireDefault(_vue);\n\t\n\tvar _isEmpty = __webpack_require__(121);\n\t\n\tvar _isEmpty2 = _interopRequireDefault(_isEmpty);\n\t\n\tvar _component_utils = __webpack_require__(132);\n\t\n\t__webpack_require__(385);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar withLoadMore = function withLoadMore(_ref) {\n\t var fetch = _ref.fetch,\n\t select = _ref.select,\n\t destroy = _ref.destroy,\n\t _ref$childPropName = _ref.childPropName,\n\t childPropName = _ref$childPropName === undefined ? 'entries' : _ref$childPropName,\n\t _ref$additionalPropNa = _ref.additionalPropNames,\n\t additionalPropNames = _ref$additionalPropNa === undefined ? [] : _ref$additionalPropNa;\n\t return function (WrappedComponent) {\n\t var originalProps = (0, _keys2.default)((0, _component_utils.getComponentProps)(WrappedComponent));\n\t var props = originalProps.filter(function (v) {\n\t return v !== childPropName;\n\t }).concat(additionalPropNames);\n\t\n\t return _vue2.default.component('withLoadMore', {\n\t render: function render(createElement) {\n\t var h = arguments[0];\n\t\n\t var props = {\n\t props: (0, _extends4.default)({}, this.$props, (0, _defineProperty3.default)({}, childPropName, this.entries)),\n\t on: this.$listeners,\n\t scopedSlots: this.$scopedSlots\n\t };\n\t var children = (0, _entries2.default)(this.$slots).map(function (_ref2) {\n\t var _ref3 = (0, _slicedToArray3.default)(_ref2, 2),\n\t key = _ref3[0],\n\t value = _ref3[1];\n\t\n\t return createElement('template', { slot: key }, value);\n\t });\n\t return h(\n\t 'div',\n\t { 'class': 'with-load-more' },\n\t [h(\n\t WrappedComponent,\n\t props,\n\t [children]\n\t ), h(\n\t 'div',\n\t { 'class': 'with-load-more-footer' },\n\t [this.error && h(\n\t 'a',\n\t {\n\t on: {\n\t 'click': this.fetchEntries\n\t },\n\t 'class': 'alert error' },\n\t [this.$t('general.generic_error')]\n\t ), !this.error && this.loading && h('i', { 'class': 'icon-spin3 animate-spin' }), !this.error && !this.loading && !this.bottomedOut && h(\n\t 'a',\n\t {\n\t on: {\n\t 'click': this.fetchEntries\n\t }\n\t },\n\t [this.$t('general.more')]\n\t )]\n\t )]\n\t );\n\t },\n\t\n\t props: props,\n\t data: function data() {\n\t return {\n\t loading: false,\n\t bottomedOut: false,\n\t error: false\n\t };\n\t },\n\t\n\t computed: {\n\t entries: function entries() {\n\t return select(this.$props, this.$store) || [];\n\t }\n\t },\n\t created: function created() {\n\t window.addEventListener('scroll', this.scrollLoad);\n\t if (this.entries.length === 0) {\n\t this.fetchEntries();\n\t }\n\t },\n\t destroyed: function destroyed() {\n\t window.removeEventListener('scroll', this.scrollLoad);\n\t destroy && destroy(this.$props, this.$store);\n\t },\n\t\n\t methods: {\n\t fetchEntries: function fetchEntries() {\n\t var _this = this;\n\t\n\t if (!this.loading) {\n\t this.loading = true;\n\t this.error = false;\n\t fetch(this.$props, this.$store).then(function (newEntries) {\n\t _this.loading = false;\n\t _this.bottomedOut = (0, _isEmpty2.default)(newEntries);\n\t }).catch(function () {\n\t _this.loading = false;\n\t _this.error = true;\n\t });\n\t }\n\t },\n\t scrollLoad: function scrollLoad(e) {\n\t var bodyBRect = document.body.getBoundingClientRect();\n\t var height = Math.max(bodyBRect.height, -bodyBRect.y);\n\t if (this.loading === false && this.bottomedOut === false && this.$el.offsetHeight > 0 && window.innerHeight + window.pageYOffset >= height - 750) {\n\t this.fetchEntries();\n\t }\n\t }\n\t }\n\t });\n\t };\n\t};\n\t\n\texports.default = withLoadMore;\n\n/***/ }),\n/* 223 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _slicedToArray2 = __webpack_require__(9);\n\t\n\tvar _slicedToArray3 = _interopRequireDefault(_slicedToArray2);\n\t\n\tvar _entries = __webpack_require__(23);\n\t\n\tvar _entries2 = _interopRequireDefault(_entries);\n\t\n\tvar _defineProperty2 = __webpack_require__(140);\n\t\n\tvar _defineProperty3 = _interopRequireDefault(_defineProperty2);\n\t\n\tvar _extends3 = __webpack_require__(37);\n\t\n\tvar _extends4 = _interopRequireDefault(_extends3);\n\t\n\tvar _toConsumableArray2 = __webpack_require__(26);\n\t\n\tvar _toConsumableArray3 = _interopRequireDefault(_toConsumableArray2);\n\t\n\tvar _keys = __webpack_require__(24);\n\t\n\tvar _keys2 = _interopRequireDefault(_keys);\n\t\n\tvar _vue = __webpack_require__(8);\n\t\n\tvar _vue2 = _interopRequireDefault(_vue);\n\t\n\tvar _isEmpty = __webpack_require__(121);\n\t\n\tvar _isEmpty2 = _interopRequireDefault(_isEmpty);\n\t\n\tvar _component_utils = __webpack_require__(132);\n\t\n\t__webpack_require__(386);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar withSubscription = function withSubscription(_ref) {\n\t var fetch = _ref.fetch,\n\t select = _ref.select,\n\t _ref$childPropName = _ref.childPropName,\n\t childPropName = _ref$childPropName === undefined ? 'content' : _ref$childPropName,\n\t _ref$additionalPropNa = _ref.additionalPropNames,\n\t additionalPropNames = _ref$additionalPropNa === undefined ? [] : _ref$additionalPropNa;\n\t return function (WrappedComponent) {\n\t var originalProps = (0, _keys2.default)((0, _component_utils.getComponentProps)(WrappedComponent));\n\t var props = originalProps.filter(function (v) {\n\t return v !== childPropName;\n\t }).concat(additionalPropNames);\n\t\n\t return _vue2.default.component('withSubscription', {\n\t props: [].concat((0, _toConsumableArray3.default)(props), ['refresh']),\n\t render: function render(createElement) {\n\t var h = arguments[0];\n\t\n\t if (!this.error && !this.loading) {\n\t var _props = {\n\t props: (0, _extends4.default)({}, this.$props, (0, _defineProperty3.default)({}, childPropName, this.fetchedData)),\n\t on: this.$listeners,\n\t scopedSlots: this.$scopedSlots\n\t };\n\t var children = (0, _entries2.default)(this.$slots).map(function (_ref2) {\n\t var _ref3 = (0, _slicedToArray3.default)(_ref2, 2),\n\t key = _ref3[0],\n\t value = _ref3[1];\n\t\n\t return createElement('template', { slot: key }, value);\n\t });\n\t return h(\n\t 'div',\n\t { 'class': 'with-subscription' },\n\t [h(\n\t WrappedComponent,\n\t _props,\n\t [children]\n\t )]\n\t );\n\t } else {\n\t return h(\n\t 'div',\n\t { 'class': 'with-subscription-loading' },\n\t [this.error ? h(\n\t 'a',\n\t {\n\t on: {\n\t 'click': this.fetchData\n\t },\n\t 'class': 'alert error' },\n\t [this.$t('general.generic_error')]\n\t ) : h('i', { 'class': 'icon-spin3 animate-spin' })]\n\t );\n\t }\n\t },\n\t data: function data() {\n\t return {\n\t loading: false,\n\t error: false\n\t };\n\t },\n\t\n\t computed: {\n\t fetchedData: function fetchedData() {\n\t return select(this.$props, this.$store);\n\t }\n\t },\n\t created: function created() {\n\t if (this.refresh || (0, _isEmpty2.default)(this.fetchedData)) {\n\t this.fetchData();\n\t }\n\t },\n\t\n\t methods: {\n\t fetchData: function fetchData() {\n\t var _this = this;\n\t\n\t if (!this.loading) {\n\t this.loading = true;\n\t this.error = false;\n\t fetch(this.$props, this.$store).then(function () {\n\t _this.loading = false;\n\t }).catch(function () {\n\t _this.error = true;\n\t _this.loading = false;\n\t });\n\t }\n\t }\n\t }\n\t });\n\t };\n\t};\n\t\n\texports.default = withSubscription;\n\n/***/ }),\n/* 224 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _typeof2 = __webpack_require__(66);\n\t\n\tvar _typeof3 = _interopRequireDefault(_typeof2);\n\t\n\tvar _promise = __webpack_require__(25);\n\t\n\tvar _promise2 = _interopRequireDefault(_promise);\n\t\n\tvar _each2 = __webpack_require__(82);\n\t\n\tvar _each3 = _interopRequireDefault(_each2);\n\t\n\texports.default = createPersistedState;\n\t\n\tvar _lodash = __webpack_require__(472);\n\t\n\tvar _lodash2 = _interopRequireDefault(_lodash);\n\t\n\tvar _objectPath = __webpack_require__(623);\n\t\n\tvar _objectPath2 = _interopRequireDefault(_objectPath);\n\t\n\tvar _localforage = __webpack_require__(460);\n\t\n\tvar _localforage2 = _interopRequireDefault(_localforage);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar loaded = false;\n\t\n\tvar defaultReducer = function defaultReducer(state, paths) {\n\t return paths.length === 0 ? state : paths.reduce(function (substate, path) {\n\t _objectPath2.default.set(substate, path, _objectPath2.default.get(state, path));\n\t return substate;\n\t }, {});\n\t};\n\t\n\tvar saveImmedeatelyActions = ['markNotificationsAsSeen', 'clearCurrentUser', 'setCurrentUser', 'setHighlight', 'setOption', 'setClientData', 'setToken'];\n\t\n\tvar defaultStorage = function () {\n\t return _localforage2.default;\n\t}();\n\t\n\tfunction createPersistedState() {\n\t var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},\n\t _ref$key = _ref.key,\n\t key = _ref$key === undefined ? 'vuex-lz' : _ref$key,\n\t _ref$paths = _ref.paths,\n\t paths = _ref$paths === undefined ? [] : _ref$paths,\n\t _ref$getState = _ref.getState,\n\t getState = _ref$getState === undefined ? function (key, storage) {\n\t var value = storage.getItem(key);\n\t return value;\n\t } : _ref$getState,\n\t _ref$setState = _ref.setState,\n\t setState = _ref$setState === undefined ? function (key, state, storage) {\n\t if (!loaded) {\n\t console.log('waiting for old state to be loaded...');\n\t return _promise2.default.resolve();\n\t } else {\n\t return storage.setItem(key, state);\n\t }\n\t } : _ref$setState,\n\t _ref$reducer = _ref.reducer,\n\t reducer = _ref$reducer === undefined ? defaultReducer : _ref$reducer,\n\t _ref$storage = _ref.storage,\n\t storage = _ref$storage === undefined ? defaultStorage : _ref$storage,\n\t _ref$subscriber = _ref.subscriber,\n\t subscriber = _ref$subscriber === undefined ? function (store) {\n\t return function (handler) {\n\t return store.subscribe(handler);\n\t };\n\t } : _ref$subscriber;\n\t\n\t return getState(key, storage).then(function (savedState) {\n\t return function (store) {\n\t try {\n\t if (savedState !== null && (typeof savedState === 'undefined' ? 'undefined' : (0, _typeof3.default)(savedState)) === 'object') {\n\t var usersState = savedState.users || {};\n\t usersState.usersObject = {};\n\t var users = usersState.users || [];\n\t (0, _each3.default)(users, function (user) {\n\t usersState.usersObject[user.id] = user;\n\t });\n\t savedState.users = usersState;\n\t\n\t store.replaceState((0, _lodash2.default)({}, store.state, savedState));\n\t }\n\t if (store.state.config.customTheme) {\n\t window.themeLoaded = true;\n\t store.dispatch('setOption', {\n\t name: 'customTheme',\n\t value: store.state.config.customTheme\n\t });\n\t }\n\t if (store.state.oauth.token) {\n\t store.dispatch('loginUser', store.state.oauth.token);\n\t }\n\t loaded = true;\n\t } catch (e) {\n\t console.log(\"Couldn't load state\");\n\t console.error(e);\n\t loaded = true;\n\t }\n\t subscriber(store)(function (mutation, state) {\n\t try {\n\t if (saveImmedeatelyActions.includes(mutation.type)) {\n\t setState(key, reducer(state, paths), storage).then(function (success) {\n\t if (typeof success !== 'undefined') {\n\t if (mutation.type === 'setOption' || mutation.type === 'setCurrentUser') {\n\t store.dispatch('settingsSaved', { success: success });\n\t }\n\t }\n\t }, function (error) {\n\t if (mutation.type === 'setOption' || mutation.type === 'setCurrentUser') {\n\t store.dispatch('settingsSaved', { error: error });\n\t }\n\t });\n\t }\n\t } catch (e) {\n\t console.log(\"Couldn't persist state:\");\n\t console.log(e);\n\t }\n\t });\n\t };\n\t });\n\t}\n\n/***/ }),\n/* 225 */\n/***/ (function(module, exports) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\texports.default = function (store) {\n\t store.subscribe(function (mutation, state) {\n\t var vapidPublicKey = state.instance.vapidPublicKey;\n\t var webPushNotification = state.config.webPushNotifications;\n\t var permission = state.interface.notificationPermission === 'granted';\n\t var user = state.users.currentUser;\n\t\n\t var isUserMutation = mutation.type === 'setCurrentUser';\n\t var isVapidMutation = mutation.type === 'setInstanceOption' && mutation.payload.name === 'vapidPublicKey';\n\t var isPermMutation = mutation.type === 'setNotificationPermission' && mutation.payload === 'granted';\n\t var isUserConfigMutation = mutation.type === 'setOption' && mutation.payload.name === 'webPushNotifications';\n\t var isVisibilityMutation = mutation.type === 'setOption' && mutation.payload.name === 'notificationVisibility';\n\t\n\t if (isUserMutation || isVapidMutation || isPermMutation || isUserConfigMutation || isVisibilityMutation) {\n\t if (user && vapidPublicKey && permission && webPushNotification) {\n\t return store.dispatch('registerPushNotifications');\n\t } else if (isUserConfigMutation && !webPushNotification) {\n\t return store.dispatch('unregisterPushNotifications');\n\t }\n\t }\n\t });\n\t};\n\n/***/ }),\n/* 226 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _backend_interactor_service = __webpack_require__(131);\n\t\n\tvar _backend_interactor_service2 = _interopRequireDefault(_backend_interactor_service);\n\t\n\tvar _phoenix = __webpack_require__(624);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar api = {\n\t state: {\n\t backendInteractor: (0, _backend_interactor_service2.default)(),\n\t fetchers: {},\n\t socket: null,\n\t chatDisabled: false,\n\t followRequests: []\n\t },\n\t mutations: {\n\t setBackendInteractor: function setBackendInteractor(state, backendInteractor) {\n\t state.backendInteractor = backendInteractor;\n\t },\n\t addFetcher: function addFetcher(state, _ref) {\n\t var timeline = _ref.timeline,\n\t fetcher = _ref.fetcher;\n\t\n\t state.fetchers[timeline] = fetcher;\n\t },\n\t removeFetcher: function removeFetcher(state, _ref2) {\n\t var timeline = _ref2.timeline;\n\t\n\t delete state.fetchers[timeline];\n\t },\n\t setWsToken: function setWsToken(state, token) {\n\t state.wsToken = token;\n\t },\n\t setSocket: function setSocket(state, socket) {\n\t state.socket = socket;\n\t },\n\t setChatDisabled: function setChatDisabled(state, value) {\n\t state.chatDisabled = value;\n\t },\n\t setFollowRequests: function setFollowRequests(state, value) {\n\t state.followRequests = value;\n\t }\n\t },\n\t actions: {\n\t startFetching: function startFetching(store, _ref3) {\n\t var _ref3$timeline = _ref3.timeline,\n\t timeline = _ref3$timeline === undefined ? 'friends' : _ref3$timeline,\n\t _ref3$tag = _ref3.tag,\n\t tag = _ref3$tag === undefined ? false : _ref3$tag,\n\t _ref3$userId = _ref3.userId,\n\t userId = _ref3$userId === undefined ? false : _ref3$userId;\n\t\n\t if (store.state.fetchers[timeline]) return;\n\t\n\t var fetcher = store.state.backendInteractor.startFetching({ timeline: timeline, store: store, userId: userId, tag: tag });\n\t store.commit('addFetcher', { timeline: timeline, fetcher: fetcher });\n\t },\n\t stopFetching: function stopFetching(store, timeline) {\n\t var fetcher = store.state.fetchers[timeline];\n\t window.clearInterval(fetcher);\n\t store.commit('removeFetcher', { timeline: timeline });\n\t },\n\t setWsToken: function setWsToken(store, token) {\n\t store.commit('setWsToken', token);\n\t },\n\t initializeSocket: function initializeSocket(store) {\n\t if (!store.state.chatDisabled) {\n\t var token = store.state.wsToken;\n\t var socket = new _phoenix.Socket('/socket', { params: { token: token } });\n\t socket.connect();\n\t store.dispatch('initializeChat', socket);\n\t }\n\t },\n\t disableChat: function disableChat(store) {\n\t store.commit('setChatDisabled', true);\n\t },\n\t removeFollowRequest: function removeFollowRequest(store, request) {\n\t var requests = store.state.followRequests.filter(function (it) {\n\t return it !== request;\n\t });\n\t store.commit('setFollowRequests', requests);\n\t }\n\t }\n\t};\n\t\n\texports.default = api;\n\n/***/ }),\n/* 227 */\n/***/ (function(module, exports) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\tvar chat = {\n\t state: {\n\t messages: [],\n\t channel: { state: '' },\n\t socket: null\n\t },\n\t mutations: {\n\t setChannel: function setChannel(state, channel) {\n\t state.channel = channel;\n\t },\n\t setSocket: function setSocket(state, socket) {\n\t state.socket = socket;\n\t },\n\t addMessage: function addMessage(state, message) {\n\t state.messages.push(message);\n\t state.messages = state.messages.slice(-19, 20);\n\t },\n\t setMessages: function setMessages(state, messages) {\n\t state.messages = messages.slice(-19, 20);\n\t }\n\t },\n\t actions: {\n\t disconnectFromChat: function disconnectFromChat(store) {\n\t store.state.socket.disconnect();\n\t },\n\t initializeChat: function initializeChat(store, socket) {\n\t var channel = socket.channel('chat:public');\n\t store.commit('setSocket', socket);\n\t channel.on('new_msg', function (msg) {\n\t store.commit('addMessage', msg);\n\t });\n\t channel.on('messages', function (_ref) {\n\t var messages = _ref.messages;\n\t\n\t store.commit('setMessages', messages);\n\t });\n\t channel.join();\n\t store.commit('setChannel', channel);\n\t }\n\t }\n\t};\n\t\n\texports.default = chat;\n\n/***/ }),\n/* 228 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _vue = __webpack_require__(8);\n\t\n\tvar _style_setter = __webpack_require__(63);\n\t\n\tvar browserLocale = (window.navigator.language || 'en').split('-')[0];\n\t\n\tvar defaultState = {\n\t colors: {},\n\t collapseMessageWithSubject: undefined,\n\t hideAttachments: false,\n\t hideAttachmentsInConv: false,\n\t maxThumbnails: 16,\n\t hideNsfw: true,\n\t preloadImage: true,\n\t loopVideo: true,\n\t loopVideoSilentOnly: true,\n\t autoLoad: true,\n\t streaming: false,\n\t hoverPreview: true,\n\t pauseOnUnfocused: true,\n\t stopGifs: false,\n\t replyVisibility: 'all',\n\t notificationVisibility: {\n\t follows: true,\n\t mentions: true,\n\t likes: true,\n\t repeats: true\n\t },\n\t webPushNotifications: false,\n\t muteWords: [],\n\t highlight: {},\n\t interfaceLanguage: browserLocale,\n\t scopeCopy: undefined,\n\t subjectLineBehavior: undefined,\n\t alwaysShowSubjectInput: undefined,\n\t postContentType: undefined };\n\t\n\tvar config = {\n\t state: defaultState,\n\t mutations: {\n\t setOption: function setOption(state, _ref) {\n\t var name = _ref.name,\n\t value = _ref.value;\n\t\n\t (0, _vue.set)(state, name, value);\n\t },\n\t setHighlight: function setHighlight(state, _ref2) {\n\t var user = _ref2.user,\n\t color = _ref2.color,\n\t type = _ref2.type;\n\t\n\t var data = this.state.config.highlight[user];\n\t if (color || type) {\n\t (0, _vue.set)(state.highlight, user, { color: color || data.color, type: type || data.type });\n\t } else {\n\t (0, _vue.delete)(state.highlight, user);\n\t }\n\t }\n\t },\n\t actions: {\n\t setHighlight: function setHighlight(_ref3, _ref4) {\n\t var commit = _ref3.commit,\n\t dispatch = _ref3.dispatch;\n\t var user = _ref4.user,\n\t color = _ref4.color,\n\t type = _ref4.type;\n\t\n\t commit('setHighlight', { user: user, color: color, type: type });\n\t },\n\t setOption: function setOption(_ref5, _ref6) {\n\t var commit = _ref5.commit,\n\t dispatch = _ref5.dispatch;\n\t var name = _ref6.name,\n\t value = _ref6.value;\n\t\n\t commit('setOption', { name: name, value: value });\n\t switch (name) {\n\t case 'theme':\n\t (0, _style_setter.setPreset)(value, commit);\n\t break;\n\t case 'customTheme':\n\t (0, _style_setter.applyTheme)(value, commit);\n\t }\n\t }\n\t }\n\t};\n\t\n\texports.default = config;\n\n/***/ }),\n/* 229 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _toConsumableArray2 = __webpack_require__(26);\n\t\n\tvar _toConsumableArray3 = _interopRequireDefault(_toConsumableArray2);\n\t\n\tvar _slicedToArray2 = __webpack_require__(9);\n\t\n\tvar _slicedToArray3 = _interopRequireDefault(_slicedToArray2);\n\t\n\tvar _entries = __webpack_require__(23);\n\t\n\tvar _entries2 = _interopRequireDefault(_entries);\n\t\n\tvar _capitalize2 = __webpack_require__(198);\n\t\n\tvar _capitalize3 = _interopRequireDefault(_capitalize2);\n\t\n\texports.humanizeErrors = humanizeErrors;\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tfunction humanizeErrors(errors) {\n\t return (0, _entries2.default)(errors).reduce(function (errs, _ref) {\n\t var _ref2 = (0, _slicedToArray3.default)(_ref, 2),\n\t k = _ref2[0],\n\t val = _ref2[1];\n\t\n\t var message = val.reduce(function (acc, message) {\n\t var key = (0, _capitalize3.default)(k.replace(/_/g, ' '));\n\t return acc + [key, message].join(' ') + '. ';\n\t }, '');\n\t return [].concat((0, _toConsumableArray3.default)(errs), [message]);\n\t }, []);\n\t}\n\n/***/ }),\n/* 230 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _vue = __webpack_require__(8);\n\t\n\tvar _style_setter = __webpack_require__(63);\n\t\n\tvar defaultState = {\n\t name: 'Pleroma FE',\n\t registrationOpen: true,\n\t textlimit: 5000,\n\t server: 'http://localhost:4040/',\n\t theme: 'pleroma-dark',\n\t background: '/static/aurora_borealis.jpg',\n\t logo: '/static/logo.png',\n\t logoMask: true,\n\t logoMargin: '.2em',\n\t redirectRootNoLogin: '/main/all',\n\t redirectRootLogin: '/main/friends',\n\t showInstanceSpecificPanel: false,\n\t scopeOptionsEnabled: true,\n\t formattingOptionsEnabled: false,\n\t alwaysShowSubjectInput: true,\n\t collapseMessageWithSubject: false,\n\t hidePostStats: false,\n\t hideUserStats: false,\n\t hideFilteredStatuses: false,\n\t disableChat: false,\n\t scopeCopy: true,\n\t subjectLineBehavior: 'email',\n\t postContentType: 'text/plain',\n\t loginMethod: 'password',\n\t nsfwCensorImage: undefined,\n\t vapidPublicKey: undefined,\n\t noAttachmentLinks: false,\n\t showFeaturesPanel: true,\n\t\n\t pleromaBackend: true,\n\t emoji: [],\n\t customEmoji: [],\n\t restrictedNicknames: [],\n\t postFormats: [],\n\t\n\t mediaProxyAvailable: false,\n\t chatAvailable: false,\n\t gopherAvailable: false,\n\t suggestionsEnabled: false,\n\t suggestionsWeb: '',\n\t\n\t instanceSpecificPanelContent: '',\n\t tos: ''\n\t};\n\t\n\tvar instance = {\n\t state: defaultState,\n\t mutations: {\n\t setInstanceOption: function setInstanceOption(state, _ref) {\n\t var name = _ref.name,\n\t value = _ref.value;\n\t\n\t if (typeof value !== 'undefined') {\n\t (0, _vue.set)(state, name, value);\n\t }\n\t }\n\t },\n\t actions: {\n\t setInstanceOption: function setInstanceOption(_ref2, _ref3) {\n\t var commit = _ref2.commit,\n\t dispatch = _ref2.dispatch;\n\t var name = _ref3.name,\n\t value = _ref3.value;\n\t\n\t commit('setInstanceOption', { name: name, value: value });\n\t switch (name) {\n\t case 'name':\n\t dispatch('setPageTitle');\n\t break;\n\t }\n\t },\n\t setTheme: function setTheme(_ref4, themeName) {\n\t var commit = _ref4.commit;\n\t\n\t commit('setInstanceOption', { name: 'theme', value: themeName });\n\t return (0, _style_setter.setPreset)(themeName, commit);\n\t }\n\t }\n\t};\n\t\n\texports.default = instance;\n\n/***/ }),\n/* 231 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _vue = __webpack_require__(8);\n\t\n\tvar defaultState = {\n\t settings: {\n\t currentSaveStateNotice: null,\n\t noticeClearTimeout: null,\n\t notificationPermission: null\n\t },\n\t browserSupport: {\n\t cssFilter: window.CSS && window.CSS.supports && (window.CSS.supports('filter', 'drop-shadow(0 0)') || window.CSS.supports('-webkit-filter', 'drop-shadow(0 0)'))\n\t }\n\t};\n\t\n\tvar interfaceMod = {\n\t state: defaultState,\n\t mutations: {\n\t settingsSaved: function settingsSaved(state, _ref) {\n\t var success = _ref.success,\n\t error = _ref.error;\n\t\n\t if (success) {\n\t if (state.noticeClearTimeout) {\n\t clearTimeout(state.noticeClearTimeout);\n\t }\n\t (0, _vue.set)(state.settings, 'currentSaveStateNotice', { error: false, data: success });\n\t (0, _vue.set)(state.settings, 'noticeClearTimeout', setTimeout(function () {\n\t return (0, _vue.delete)(state.settings, 'currentSaveStateNotice');\n\t }, 2000));\n\t } else {\n\t (0, _vue.set)(state.settings, 'currentSaveStateNotice', { error: true, errorData: error });\n\t }\n\t },\n\t setNotificationPermission: function setNotificationPermission(state, permission) {\n\t state.notificationPermission = permission;\n\t }\n\t },\n\t actions: {\n\t setPageTitle: function setPageTitle(_ref2) {\n\t var rootState = _ref2.rootState;\n\t var option = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';\n\t\n\t document.title = option + ' ' + rootState.instance.name;\n\t },\n\t settingsSaved: function settingsSaved(_ref3, _ref4) {\n\t var commit = _ref3.commit,\n\t dispatch = _ref3.dispatch;\n\t var success = _ref4.success,\n\t error = _ref4.error;\n\t\n\t commit('settingsSaved', { success: success, error: error });\n\t },\n\t setNotificationPermission: function setNotificationPermission(_ref5, permission) {\n\t var commit = _ref5.commit;\n\t\n\t commit('setNotificationPermission', permission);\n\t }\n\t }\n\t};\n\t\n\texports.default = interfaceMod;\n\n/***/ }),\n/* 232 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _file_typeService = __webpack_require__(45);\n\t\n\tvar _file_typeService2 = _interopRequireDefault(_file_typeService);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar mediaViewer = {\n\t state: {\n\t media: [],\n\t currentIndex: 0,\n\t activated: false\n\t },\n\t mutations: {\n\t setMedia: function setMedia(state, media) {\n\t state.media = media;\n\t },\n\t setCurrent: function setCurrent(state, index) {\n\t state.activated = true;\n\t state.currentIndex = index;\n\t },\n\t close: function close(state) {\n\t state.activated = false;\n\t }\n\t },\n\t actions: {\n\t setMedia: function setMedia(_ref, attachments) {\n\t var commit = _ref.commit;\n\t\n\t var media = attachments.filter(function (attachment) {\n\t var type = _file_typeService2.default.fileType(attachment.mimetype);\n\t return type === 'image' || type === 'video';\n\t });\n\t commit('setMedia', media);\n\t },\n\t setCurrent: function setCurrent(_ref2, current) {\n\t var commit = _ref2.commit,\n\t state = _ref2.state;\n\t\n\t var index = state.media.indexOf(current);\n\t commit('setCurrent', index || 0);\n\t },\n\t closeMediaViewer: function closeMediaViewer(_ref3) {\n\t var commit = _ref3.commit;\n\t\n\t commit('close');\n\t }\n\t }\n\t};\n\t\n\texports.default = mediaViewer;\n\n/***/ }),\n/* 233 */\n/***/ (function(module, exports) {\n\n\t\"use strict\";\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\tvar oauth = {\n\t state: {\n\t client_id: false,\n\t client_secret: false,\n\t token: false\n\t },\n\t mutations: {\n\t setClientData: function setClientData(state, data) {\n\t state.client_id = data.client_id;\n\t state.client_secret = data.client_secret;\n\t },\n\t setToken: function setToken(state, token) {\n\t state.token = token;\n\t }\n\t }\n\t};\n\t\n\texports.default = oauth;\n\n/***/ }),\n/* 234 */\n/***/ (function(module, exports) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\tvar oauthTokens = {\n\t state: {\n\t tokens: []\n\t },\n\t actions: {\n\t fetchTokens: function fetchTokens(_ref) {\n\t var rootState = _ref.rootState,\n\t commit = _ref.commit;\n\t\n\t rootState.api.backendInteractor.fetchOAuthTokens().then(function (tokens) {\n\t commit('swapTokens', tokens);\n\t });\n\t },\n\t revokeToken: function revokeToken(_ref2, id) {\n\t var rootState = _ref2.rootState,\n\t commit = _ref2.commit,\n\t state = _ref2.state;\n\t\n\t rootState.api.backendInteractor.revokeOAuthToken(id).then(function (response) {\n\t if (response.status === 201) {\n\t commit('swapTokens', state.tokens.filter(function (token) {\n\t return token.id !== id;\n\t }));\n\t }\n\t });\n\t }\n\t },\n\t mutations: {\n\t swapTokens: function swapTokens(state, tokens) {\n\t state.tokens = tokens;\n\t }\n\t }\n\t};\n\t\n\texports.default = oauthTokens;\n\n/***/ }),\n/* 235 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\texports.mutations = exports.prepareStatus = exports.defaultState = undefined;\n\t\n\tvar _slicedToArray2 = __webpack_require__(9);\n\t\n\tvar _slicedToArray3 = _interopRequireDefault(_slicedToArray2);\n\t\n\tvar _entries = __webpack_require__(23);\n\t\n\tvar _entries2 = _interopRequireDefault(_entries);\n\t\n\tvar _isNan = __webpack_require__(65);\n\t\n\tvar _isNan2 = _interopRequireDefault(_isNan);\n\t\n\tvar _set = __webpack_require__(138);\n\t\n\tvar _set2 = _interopRequireDefault(_set);\n\t\n\tvar _isArray2 = __webpack_require__(4);\n\t\n\tvar _isArray3 = _interopRequireDefault(_isArray2);\n\t\n\tvar _last2 = __webpack_require__(123);\n\t\n\tvar _last3 = _interopRequireDefault(_last2);\n\t\n\tvar _first2 = __webpack_require__(593);\n\t\n\tvar _first3 = _interopRequireDefault(_first2);\n\t\n\tvar _merge2 = __webpack_require__(200);\n\t\n\tvar _merge3 = _interopRequireDefault(_merge2);\n\t\n\tvar _minBy2 = __webpack_require__(603);\n\t\n\tvar _minBy3 = _interopRequireDefault(_minBy2);\n\t\n\tvar _maxBy2 = __webpack_require__(601);\n\t\n\tvar _maxBy3 = _interopRequireDefault(_maxBy2);\n\t\n\tvar _find2 = __webpack_require__(59);\n\t\n\tvar _find3 = _interopRequireDefault(_find2);\n\t\n\tvar _each2 = __webpack_require__(82);\n\t\n\tvar _each3 = _interopRequireDefault(_each2);\n\t\n\tvar _slice2 = __webpack_require__(611);\n\t\n\tvar _slice3 = _interopRequireDefault(_slice2);\n\t\n\tvar _remove2 = __webpack_require__(609);\n\t\n\tvar _remove3 = _interopRequireDefault(_remove2);\n\t\n\tvar _apiService = __webpack_require__(18);\n\t\n\tvar _apiService2 = _interopRequireDefault(_apiService);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar emptyTl = function emptyTl() {\n\t var userId = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0;\n\t return {\n\t statuses: [],\n\t statusesObject: {},\n\t faves: [],\n\t visibleStatuses: [],\n\t visibleStatusesObject: {},\n\t newStatusCount: 0,\n\t maxId: 0,\n\t minId: 0,\n\t minVisibleId: 0,\n\t loading: false,\n\t followers: [],\n\t friends: [],\n\t userId: userId,\n\t flushMarker: 0\n\t };\n\t};\n\t\n\tvar defaultState = exports.defaultState = function defaultState() {\n\t return {\n\t allStatuses: [],\n\t allStatusesObject: {},\n\t maxId: 0,\n\t notifications: {\n\t desktopNotificationSilence: true,\n\t maxId: 0,\n\t minId: Number.POSITIVE_INFINITY,\n\t data: [],\n\t idStore: {},\n\t loading: false,\n\t error: false,\n\t fetcherId: null\n\t },\n\t favorites: new _set2.default(),\n\t error: false,\n\t timelines: {\n\t mentions: emptyTl(),\n\t public: emptyTl(),\n\t user: emptyTl(),\n\t favorites: emptyTl(),\n\t media: emptyTl(),\n\t publicAndExternal: emptyTl(),\n\t friends: emptyTl(),\n\t tag: emptyTl(),\n\t dms: emptyTl()\n\t }\n\t };\n\t};\n\t\n\tvar prepareStatus = exports.prepareStatus = function prepareStatus(status) {\n\t status.deleted = false;\n\t\n\t status.attachments = status.attachments || [];\n\t\n\t return status;\n\t};\n\t\n\tvar visibleNotificationTypes = function visibleNotificationTypes(rootState) {\n\t return [rootState.config.notificationVisibility.likes && 'like', rootState.config.notificationVisibility.mentions && 'mention', rootState.config.notificationVisibility.repeats && 'repeat', rootState.config.notificationVisibility.follows && 'follow'].filter(function (_) {\n\t return _;\n\t });\n\t};\n\t\n\tvar mergeOrAdd = function mergeOrAdd(arr, obj, item) {\n\t var oldItem = obj[item.id];\n\t\n\t if (oldItem) {\n\t (0, _merge3.default)(oldItem, item);\n\t\n\t oldItem.attachments.splice(oldItem.attachments.length);\n\t return { item: oldItem, new: false };\n\t } else {\n\t prepareStatus(item);\n\t arr.push(item);\n\t obj[item.id] = item;\n\t return { item: item, new: true };\n\t }\n\t};\n\t\n\tvar sortById = function sortById(a, b) {\n\t var seqA = Number(a.id);\n\t var seqB = Number(b.id);\n\t var isSeqA = !(0, _isNan2.default)(seqA);\n\t var isSeqB = !(0, _isNan2.default)(seqB);\n\t if (isSeqA && isSeqB) {\n\t return seqA > seqB ? -1 : 1;\n\t } else if (isSeqA && !isSeqB) {\n\t return 1;\n\t } else if (!isSeqA && isSeqB) {\n\t return -1;\n\t } else {\n\t return a.id > b.id ? -1 : 1;\n\t }\n\t};\n\t\n\tvar sortTimeline = function sortTimeline(timeline) {\n\t timeline.visibleStatuses = timeline.visibleStatuses.sort(sortById);\n\t timeline.statuses = timeline.statuses.sort(sortById);\n\t timeline.minVisibleId = ((0, _last3.default)(timeline.visibleStatuses) || {}).id;\n\t return timeline;\n\t};\n\t\n\tvar addNewStatuses = function addNewStatuses(state, _ref) {\n\t var statuses = _ref.statuses,\n\t _ref$showImmediately = _ref.showImmediately,\n\t showImmediately = _ref$showImmediately === undefined ? false : _ref$showImmediately,\n\t timeline = _ref.timeline,\n\t _ref$user = _ref.user,\n\t user = _ref$user === undefined ? {} : _ref$user,\n\t _ref$noIdUpdate = _ref.noIdUpdate,\n\t noIdUpdate = _ref$noIdUpdate === undefined ? false : _ref$noIdUpdate,\n\t userId = _ref.userId;\n\t\n\t if (!(0, _isArray3.default)(statuses)) {\n\t return false;\n\t }\n\t\n\t var allStatuses = state.allStatuses;\n\t var allStatusesObject = state.allStatusesObject;\n\t var timelineObject = state.timelines[timeline];\n\t\n\t var maxNew = statuses.length > 0 ? (0, _maxBy3.default)(statuses, 'id').id : 0;\n\t var minNew = statuses.length > 0 ? (0, _minBy3.default)(statuses, 'id').id : 0;\n\t var newer = timeline && maxNew > timelineObject.maxId && statuses.length > 0;\n\t var older = timeline && (minNew < timelineObject.minId || timelineObject.minId === 0) && statuses.length > 0;\n\t\n\t if (!noIdUpdate && newer) {\n\t timelineObject.maxId = maxNew;\n\t }\n\t if (!noIdUpdate && older) {\n\t timelineObject.minId = minNew;\n\t }\n\t\n\t if ((timeline === 'user' || timeline === 'media') && timelineObject.userId !== userId) {\n\t return;\n\t }\n\t\n\t var addStatus = function addStatus(data, showImmediately) {\n\t var addToTimeline = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true;\n\t\n\t var result = mergeOrAdd(allStatuses, allStatusesObject, data);\n\t var status = result.item;\n\t\n\t if (result.new) {\n\t if (status.type === 'status' && (0, _find3.default)(status.attentions, { id: user.id })) {\n\t var mentions = state.timelines.mentions;\n\t\n\t if (timelineObject !== mentions) {\n\t mergeOrAdd(mentions.statuses, mentions.statusesObject, status);\n\t mentions.newStatusCount += 1;\n\t\n\t sortTimeline(mentions);\n\t }\n\t }\n\t if (status.visibility === 'direct') {\n\t var dms = state.timelines.dms;\n\t\n\t mergeOrAdd(dms.statuses, dms.statusesObject, status);\n\t dms.newStatusCount += 1;\n\t\n\t sortTimeline(dms);\n\t }\n\t }\n\t\n\t var resultForCurrentTimeline = void 0;\n\t\n\t if (timeline && addToTimeline) {\n\t resultForCurrentTimeline = mergeOrAdd(timelineObject.statuses, timelineObject.statusesObject, status);\n\t }\n\t\n\t if (timeline && showImmediately) {\n\t mergeOrAdd(timelineObject.visibleStatuses, timelineObject.visibleStatusesObject, status);\n\t } else if (timeline && addToTimeline && resultForCurrentTimeline.new) {\n\t timelineObject.newStatusCount += 1;\n\t }\n\t\n\t return status;\n\t };\n\t\n\t var favoriteStatus = function favoriteStatus(favorite, counter) {\n\t var status = (0, _find3.default)(allStatuses, { id: favorite.in_reply_to_status_id });\n\t if (status) {\n\t if (favorite.user.id === user.id) {\n\t status.favorited = true;\n\t } else {\n\t status.fave_num += 1;\n\t }\n\t }\n\t return status;\n\t };\n\t\n\t var processors = {\n\t 'status': function status(_status) {\n\t addStatus(_status, showImmediately);\n\t },\n\t 'retweet': function retweet(status) {\n\t var retweetedStatus = addStatus(status.retweeted_status, false, false);\n\t\n\t var retweet = void 0;\n\t\n\t if (timeline && (0, _find3.default)(timelineObject.statuses, function (s) {\n\t if (s.retweeted_status) {\n\t return s.id === retweetedStatus.id || s.retweeted_status.id === retweetedStatus.id;\n\t } else {\n\t return s.id === retweetedStatus.id;\n\t }\n\t })) {\n\t retweet = addStatus(status, false, false);\n\t } else {\n\t retweet = addStatus(status, showImmediately);\n\t }\n\t\n\t retweet.retweeted_status = retweetedStatus;\n\t },\n\t 'favorite': function favorite(_favorite) {\n\t if (!state.favorites.has(_favorite.id)) {\n\t state.favorites.add(_favorite.id);\n\t favoriteStatus(_favorite);\n\t }\n\t },\n\t 'deletion': function deletion(_deletion) {\n\t var uri = _deletion.uri;\n\t\n\t var status = (0, _find3.default)(allStatuses, { uri: uri });\n\t if (!status) {\n\t return;\n\t }\n\t\n\t (0, _remove3.default)(state.notifications.data, function (_ref2) {\n\t var id = _ref2.action.id;\n\t return id === status.id;\n\t });\n\t\n\t (0, _remove3.default)(allStatuses, { uri: uri });\n\t if (timeline) {\n\t (0, _remove3.default)(timelineObject.statuses, { uri: uri });\n\t (0, _remove3.default)(timelineObject.visibleStatuses, { uri: uri });\n\t }\n\t },\n\t 'follow': function follow(_follow) {},\n\t 'default': function _default(unknown) {\n\t console.log('unknown status type');\n\t console.log(unknown);\n\t }\n\t };\n\t\n\t (0, _each3.default)(statuses, function (status) {\n\t var type = status.type;\n\t var processor = processors[type] || processors['default'];\n\t processor(status);\n\t });\n\t\n\t if (timeline) {\n\t sortTimeline(timelineObject);\n\t }\n\t};\n\t\n\tvar addNewNotifications = function addNewNotifications(state, _ref3) {\n\t var dispatch = _ref3.dispatch,\n\t notifications = _ref3.notifications,\n\t older = _ref3.older,\n\t visibleNotificationTypes = _ref3.visibleNotificationTypes;\n\t\n\t var allStatuses = state.allStatuses;\n\t var allStatusesObject = state.allStatusesObject;\n\t (0, _each3.default)(notifications, function (notification) {\n\t notification.action = mergeOrAdd(allStatuses, allStatusesObject, notification.action).item;\n\t notification.status = notification.status && mergeOrAdd(allStatuses, allStatusesObject, notification.status).item;\n\t\n\t if (!state.notifications.idStore.hasOwnProperty(notification.id)) {\n\t state.notifications.maxId = notification.id > state.notifications.maxId ? notification.id : state.notifications.maxId;\n\t state.notifications.minId = notification.id < state.notifications.minId ? notification.id : state.notifications.minId;\n\t\n\t state.notifications.data.push(notification);\n\t state.notifications.idStore[notification.id] = notification;\n\t\n\t if ('Notification' in window && window.Notification.permission === 'granted') {\n\t var notifObj = {};\n\t var action = notification.action;\n\t var title = action.user.name;\n\t notifObj.icon = action.user.profile_image_url;\n\t notifObj.body = action.text;\n\t if (action.attachments && action.attachments.length > 0 && !action.nsfw && action.attachments[0].mimetype.startsWith('image/')) {\n\t notifObj.image = action.attachments[0].url;\n\t }\n\t\n\t if (!notification.seen && !state.notifications.desktopNotificationSilence && visibleNotificationTypes.includes(notification.type)) {\n\t var _notification = new window.Notification(title, notifObj);\n\t\n\t setTimeout(_notification.close.bind(_notification), 5000);\n\t }\n\t }\n\t } else if (notification.seen) {\n\t state.notifications.idStore[notification.id].seen = true;\n\t }\n\t });\n\t};\n\t\n\tvar removeStatus = function removeStatus(state, _ref4) {\n\t var timeline = _ref4.timeline,\n\t userId = _ref4.userId;\n\t\n\t var timelineObject = state.timelines[timeline];\n\t if (userId) {\n\t (0, _remove3.default)(timelineObject.statuses, { user: { id: userId } });\n\t (0, _remove3.default)(timelineObject.visibleStatuses, { user: { id: userId } });\n\t timelineObject.minVisibleId = timelineObject.visibleStatuses.length > 0 ? (0, _last3.default)(timelineObject.visibleStatuses).id : 0;\n\t timelineObject.maxId = timelineObject.statuses.length > 0 ? (0, _first3.default)(timelineObject.statuses).id : 0;\n\t }\n\t};\n\t\n\tvar mutations = exports.mutations = {\n\t addNewStatuses: addNewStatuses,\n\t addNewNotifications: addNewNotifications,\n\t removeStatus: removeStatus,\n\t showNewStatuses: function showNewStatuses(state, _ref5) {\n\t var timeline = _ref5.timeline;\n\t\n\t var oldTimeline = state.timelines[timeline];\n\t\n\t oldTimeline.newStatusCount = 0;\n\t oldTimeline.visibleStatuses = (0, _slice3.default)(oldTimeline.statuses, 0, 50);\n\t oldTimeline.minVisibleId = (0, _last3.default)(oldTimeline.visibleStatuses).id;\n\t oldTimeline.minId = oldTimeline.minVisibleId;\n\t oldTimeline.visibleStatusesObject = {};\n\t (0, _each3.default)(oldTimeline.visibleStatuses, function (status) {\n\t oldTimeline.visibleStatusesObject[status.id] = status;\n\t });\n\t },\n\t setNotificationFetcher: function setNotificationFetcher(state, _ref6) {\n\t var fetcherId = _ref6.fetcherId;\n\t\n\t state.notifications.fetcherId = fetcherId;\n\t },\n\t resetStatuses: function resetStatuses(state) {\n\t var emptyState = defaultState();\n\t (0, _entries2.default)(emptyState).forEach(function (_ref7) {\n\t var _ref8 = (0, _slicedToArray3.default)(_ref7, 2),\n\t key = _ref8[0],\n\t value = _ref8[1];\n\t\n\t state[key] = value;\n\t });\n\t },\n\t clearTimeline: function clearTimeline(state, _ref9) {\n\t var timeline = _ref9.timeline;\n\t\n\t state.timelines[timeline] = emptyTl(state.timelines[timeline].userId);\n\t },\n\t setFavorited: function setFavorited(state, _ref10) {\n\t var status = _ref10.status,\n\t value = _ref10.value;\n\t\n\t var newStatus = state.allStatusesObject[status.id];\n\t newStatus.favorited = value;\n\t },\n\t setFavoritedConfirm: function setFavoritedConfirm(state, _ref11) {\n\t var status = _ref11.status;\n\t\n\t var newStatus = state.allStatusesObject[status.id];\n\t newStatus.favorited = status.favorited;\n\t newStatus.fave_num = status.fave_num;\n\t },\n\t setRetweeted: function setRetweeted(state, _ref12) {\n\t var status = _ref12.status,\n\t value = _ref12.value;\n\t\n\t var newStatus = state.allStatusesObject[status.id];\n\t newStatus.repeated = value;\n\t },\n\t setDeleted: function setDeleted(state, _ref13) {\n\t var status = _ref13.status;\n\t\n\t var newStatus = state.allStatusesObject[status.id];\n\t newStatus.deleted = true;\n\t },\n\t setLoading: function setLoading(state, _ref14) {\n\t var timeline = _ref14.timeline,\n\t value = _ref14.value;\n\t\n\t state.timelines[timeline].loading = value;\n\t },\n\t setNsfw: function setNsfw(state, _ref15) {\n\t var id = _ref15.id,\n\t nsfw = _ref15.nsfw;\n\t\n\t var newStatus = state.allStatusesObject[id];\n\t newStatus.nsfw = nsfw;\n\t },\n\t setError: function setError(state, _ref16) {\n\t var value = _ref16.value;\n\t\n\t state.error = value;\n\t },\n\t setNotificationsLoading: function setNotificationsLoading(state, _ref17) {\n\t var value = _ref17.value;\n\t\n\t state.notifications.loading = value;\n\t },\n\t setNotificationsError: function setNotificationsError(state, _ref18) {\n\t var value = _ref18.value;\n\t\n\t state.notifications.error = value;\n\t },\n\t setNotificationsSilence: function setNotificationsSilence(state, _ref19) {\n\t var value = _ref19.value;\n\t\n\t state.notifications.desktopNotificationSilence = value;\n\t },\n\t markNotificationsAsSeen: function markNotificationsAsSeen(state) {\n\t (0, _each3.default)(state.notifications.data, function (notification) {\n\t notification.seen = true;\n\t });\n\t },\n\t queueFlush: function queueFlush(state, _ref20) {\n\t var timeline = _ref20.timeline,\n\t id = _ref20.id;\n\t\n\t state.timelines[timeline].flushMarker = id;\n\t }\n\t};\n\t\n\tvar statuses = {\n\t state: defaultState(),\n\t actions: {\n\t addNewStatuses: function addNewStatuses(_ref21, _ref22) {\n\t var rootState = _ref21.rootState,\n\t commit = _ref21.commit;\n\t var statuses = _ref22.statuses,\n\t _ref22$showImmediatel = _ref22.showImmediately,\n\t showImmediately = _ref22$showImmediatel === undefined ? false : _ref22$showImmediatel,\n\t _ref22$timeline = _ref22.timeline,\n\t timeline = _ref22$timeline === undefined ? false : _ref22$timeline,\n\t _ref22$noIdUpdate = _ref22.noIdUpdate,\n\t noIdUpdate = _ref22$noIdUpdate === undefined ? false : _ref22$noIdUpdate,\n\t userId = _ref22.userId;\n\t\n\t commit('addNewStatuses', { statuses: statuses, showImmediately: showImmediately, timeline: timeline, noIdUpdate: noIdUpdate, user: rootState.users.currentUser, userId: userId });\n\t },\n\t addNewNotifications: function addNewNotifications(_ref23, _ref24) {\n\t var rootState = _ref23.rootState,\n\t commit = _ref23.commit,\n\t dispatch = _ref23.dispatch;\n\t var notifications = _ref24.notifications,\n\t older = _ref24.older;\n\t\n\t commit('addNewNotifications', { visibleNotificationTypes: visibleNotificationTypes(rootState), dispatch: dispatch, notifications: notifications, older: older });\n\t },\n\t setError: function setError(_ref25, _ref26) {\n\t var rootState = _ref25.rootState,\n\t commit = _ref25.commit;\n\t var value = _ref26.value;\n\t\n\t commit('setError', { value: value });\n\t },\n\t setNotificationsLoading: function setNotificationsLoading(_ref27, _ref28) {\n\t var rootState = _ref27.rootState,\n\t commit = _ref27.commit;\n\t var value = _ref28.value;\n\t\n\t commit('setNotificationsLoading', { value: value });\n\t },\n\t setNotificationsError: function setNotificationsError(_ref29, _ref30) {\n\t var rootState = _ref29.rootState,\n\t commit = _ref29.commit;\n\t var value = _ref30.value;\n\t\n\t commit('setNotificationsError', { value: value });\n\t },\n\t setNotificationsSilence: function setNotificationsSilence(_ref31, _ref32) {\n\t var rootState = _ref31.rootState,\n\t commit = _ref31.commit;\n\t var value = _ref32.value;\n\t\n\t commit('setNotificationsSilence', { value: value });\n\t },\n\t stopFetchingNotifications: function stopFetchingNotifications(_ref33) {\n\t var rootState = _ref33.rootState,\n\t commit = _ref33.commit;\n\t\n\t if (rootState.statuses.notifications.fetcherId) {\n\t window.clearInterval(rootState.statuses.notifications.fetcherId);\n\t }\n\t commit('setNotificationFetcher', { fetcherId: null });\n\t },\n\t deleteStatus: function deleteStatus(_ref34, status) {\n\t var rootState = _ref34.rootState,\n\t commit = _ref34.commit;\n\t\n\t commit('setDeleted', { status: status });\n\t _apiService2.default.deleteStatus({ id: status.id, credentials: rootState.users.currentUser.credentials });\n\t },\n\t favorite: function favorite(_ref35, status) {\n\t var rootState = _ref35.rootState,\n\t commit = _ref35.commit;\n\t\n\t commit('setFavorited', { status: status, value: true });\n\t _apiService2.default.favorite({ id: status.id, credentials: rootState.users.currentUser.credentials }).then(function (response) {\n\t if (response.ok) {\n\t return response.json();\n\t } else {\n\t return {};\n\t }\n\t }).then(function (status) {\n\t commit('setFavoritedConfirm', { status: status });\n\t });\n\t },\n\t unfavorite: function unfavorite(_ref36, status) {\n\t var rootState = _ref36.rootState,\n\t commit = _ref36.commit;\n\t\n\t commit('setFavorited', { status: status, value: false });\n\t _apiService2.default.unfavorite({ id: status.id, credentials: rootState.users.currentUser.credentials }).then(function (response) {\n\t if (response.ok) {\n\t return response.json();\n\t } else {\n\t return {};\n\t }\n\t }).then(function (status) {\n\t commit('setFavoritedConfirm', { status: status });\n\t });\n\t },\n\t retweet: function retweet(_ref37, status) {\n\t var rootState = _ref37.rootState,\n\t commit = _ref37.commit;\n\t\n\t commit('setRetweeted', { status: status, value: true });\n\t _apiService2.default.retweet({ id: status.id, credentials: rootState.users.currentUser.credentials });\n\t },\n\t unretweet: function unretweet(_ref38, status) {\n\t var rootState = _ref38.rootState,\n\t commit = _ref38.commit;\n\t\n\t commit('setRetweeted', { status: status, value: false });\n\t _apiService2.default.unretweet({ id: status.id, credentials: rootState.users.currentUser.credentials });\n\t },\n\t queueFlush: function queueFlush(_ref39, _ref40) {\n\t var rootState = _ref39.rootState,\n\t commit = _ref39.commit;\n\t var timeline = _ref40.timeline,\n\t id = _ref40.id;\n\t\n\t commit('queueFlush', { timeline: timeline, id: id });\n\t },\n\t markNotificationsAsSeen: function markNotificationsAsSeen(_ref41) {\n\t var rootState = _ref41.rootState,\n\t commit = _ref41.commit;\n\t\n\t commit('markNotificationsAsSeen');\n\t _apiService2.default.markNotificationsAsSeen({\n\t id: rootState.statuses.notifications.maxId,\n\t credentials: rootState.users.currentUser.credentials\n\t });\n\t }\n\t },\n\t mutations: mutations\n\t};\n\t\n\texports.default = statuses;\n\n/***/ }),\n/* 236 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\texports.defaultState = exports.getters = exports.mutations = exports.mergeOrAdd = undefined;\n\t\n\tvar _regenerator = __webpack_require__(141);\n\t\n\tvar _regenerator2 = _interopRequireDefault(_regenerator);\n\t\n\tvar _asyncToGenerator2 = __webpack_require__(139);\n\t\n\tvar _asyncToGenerator3 = _interopRequireDefault(_asyncToGenerator2);\n\t\n\tvar _slicedToArray2 = __webpack_require__(9);\n\t\n\tvar _slicedToArray3 = _interopRequireDefault(_slicedToArray2);\n\t\n\tvar _entries = __webpack_require__(23);\n\t\n\tvar _entries2 = _interopRequireDefault(_entries);\n\t\n\tvar _promise = __webpack_require__(25);\n\t\n\tvar _promise2 = _interopRequireDefault(_promise);\n\t\n\tvar _find2 = __webpack_require__(59);\n\t\n\tvar _find3 = _interopRequireDefault(_find2);\n\t\n\tvar _merge2 = __webpack_require__(200);\n\t\n\tvar _merge3 = _interopRequireDefault(_merge2);\n\t\n\tvar _each2 = __webpack_require__(82);\n\t\n\tvar _each3 = _interopRequireDefault(_each2);\n\t\n\tvar _map2 = __webpack_require__(31);\n\t\n\tvar _map3 = _interopRequireDefault(_map2);\n\t\n\tvar _compact2 = __webpack_require__(587);\n\t\n\tvar _compact3 = _interopRequireDefault(_compact2);\n\t\n\tvar _backend_interactor_service = __webpack_require__(131);\n\t\n\tvar _backend_interactor_service2 = _interopRequireDefault(_backend_interactor_service);\n\t\n\tvar _vue = __webpack_require__(8);\n\t\n\tvar _push = __webpack_require__(245);\n\t\n\tvar _oauth = __webpack_require__(90);\n\t\n\tvar _oauth2 = _interopRequireDefault(_oauth);\n\t\n\tvar _errors = __webpack_require__(229);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar mergeOrAdd = exports.mergeOrAdd = function mergeOrAdd(arr, obj, item) {\n\t if (!item) {\n\t return false;\n\t }\n\t var oldItem = obj[item.id];\n\t if (oldItem) {\n\t (0, _merge3.default)(oldItem, item);\n\t return { item: oldItem, new: false };\n\t } else {\n\t arr.push(item);\n\t obj[item.id] = item;\n\t if (item.screen_name && !item.screen_name.includes('@')) {\n\t obj[item.screen_name] = item;\n\t }\n\t return { item: item, new: true };\n\t }\n\t};\n\t\n\tvar getNotificationPermission = function getNotificationPermission() {\n\t var Notification = window.Notification;\n\t\n\t if (!Notification) return _promise2.default.resolve(null);\n\t if (Notification.permission === 'default') return Notification.requestPermission();\n\t return _promise2.default.resolve(Notification.permission);\n\t};\n\t\n\tvar mutations = exports.mutations = {\n\t setMuted: function setMuted(state, _ref) {\n\t var id = _ref.user.id,\n\t muted = _ref.muted;\n\t\n\t var user = state.usersObject[id];\n\t (0, _vue.set)(user, 'muted', muted);\n\t },\n\t setCurrentUser: function setCurrentUser(state, user) {\n\t state.lastLoginName = user.screen_name;\n\t state.currentUser = (0, _merge3.default)(state.currentUser || {}, user);\n\t },\n\t clearCurrentUser: function clearCurrentUser(state) {\n\t state.currentUser = false;\n\t state.lastLoginName = false;\n\t },\n\t beginLogin: function beginLogin(state) {\n\t state.loggingIn = true;\n\t },\n\t endLogin: function endLogin(state) {\n\t state.loggingIn = false;\n\t },\n\t addFriends: function addFriends(state, _ref2) {\n\t var id = _ref2.id,\n\t friends = _ref2.friends,\n\t page = _ref2.page;\n\t\n\t var user = state.usersObject[id];\n\t (0, _each3.default)(friends, function (friend) {\n\t if (!(0, _find3.default)(user.friends, { id: friend.id })) {\n\t user.friends.push(friend);\n\t }\n\t });\n\t user.friendsPage = page + 1;\n\t },\n\t addFollowers: function addFollowers(state, _ref3) {\n\t var id = _ref3.id,\n\t followers = _ref3.followers,\n\t page = _ref3.page;\n\t\n\t var user = state.usersObject[id];\n\t (0, _each3.default)(followers, function (follower) {\n\t if (!(0, _find3.default)(user.followers, { id: follower.id })) {\n\t user.followers.push(follower);\n\t }\n\t });\n\t user.followersPage = page + 1;\n\t },\n\t clearFriends: function clearFriends(state, userId) {\n\t var user = state.usersObject[userId];\n\t if (!user) {\n\t return;\n\t }\n\t user.friends = [];\n\t user.friendsPage = 0;\n\t },\n\t clearFollowers: function clearFollowers(state, userId) {\n\t var user = state.usersObject[userId];\n\t if (!user) {\n\t return;\n\t }\n\t user.followers = [];\n\t user.followersPage = 0;\n\t },\n\t addNewUsers: function addNewUsers(state, users) {\n\t (0, _each3.default)(users, function (user) {\n\t return mergeOrAdd(state.users, state.usersObject, user);\n\t });\n\t },\n\t saveBlocks: function saveBlocks(state, blockIds) {\n\t state.currentUser.blockIds = blockIds;\n\t },\n\t saveMutes: function saveMutes(state, muteIds) {\n\t state.currentUser.muteIds = muteIds;\n\t },\n\t setUserForStatus: function setUserForStatus(state, status) {\n\t status.user = state.usersObject[status.user.id];\n\t },\n\t setUserForNotification: function setUserForNotification(state, notification) {\n\t notification.action.user = state.usersObject[notification.action.user.id];\n\t notification.from_profile = state.usersObject[notification.action.user.id];\n\t },\n\t setColor: function setColor(state, _ref4) {\n\t var id = _ref4.user.id,\n\t highlighted = _ref4.highlighted;\n\t\n\t var user = state.usersObject[id];\n\t (0, _vue.set)(user, 'highlight', highlighted);\n\t },\n\t signUpPending: function signUpPending(state) {\n\t state.signUpPending = true;\n\t state.signUpErrors = [];\n\t },\n\t signUpSuccess: function signUpSuccess(state) {\n\t state.signUpPending = false;\n\t },\n\t signUpFailure: function signUpFailure(state, errors) {\n\t state.signUpPending = false;\n\t state.signUpErrors = errors;\n\t }\n\t};\n\t\n\tvar getters = exports.getters = {\n\t userById: function userById(state) {\n\t return function (id) {\n\t return state.users.find(function (user) {\n\t return user.id === id;\n\t });\n\t };\n\t },\n\t userByName: function userByName(state) {\n\t return function (name) {\n\t return state.users.find(function (user) {\n\t return user.screen_name && user.screen_name.toLowerCase() === name.toLowerCase();\n\t });\n\t };\n\t }\n\t};\n\t\n\tvar defaultState = exports.defaultState = {\n\t loggingIn: false,\n\t lastLoginName: false,\n\t currentUser: false,\n\t users: [],\n\t usersObject: {},\n\t signUpPending: false,\n\t signUpErrors: []\n\t};\n\t\n\tvar users = {\n\t state: defaultState,\n\t mutations: mutations,\n\t getters: getters,\n\t actions: {\n\t fetchUser: function fetchUser(store, id) {\n\t return store.rootState.api.backendInteractor.fetchUser({ id: id }).then(function (user) {\n\t return store.commit('addNewUsers', [user]);\n\t });\n\t },\n\t fetchBlocks: function fetchBlocks(store) {\n\t return store.rootState.api.backendInteractor.fetchBlocks().then(function (blocks) {\n\t store.commit('saveBlocks', (0, _map3.default)(blocks, 'id'));\n\t store.commit('addNewUsers', blocks);\n\t return blocks;\n\t });\n\t },\n\t blockUser: function blockUser(store, id) {\n\t return store.rootState.api.backendInteractor.blockUser(id).then(function (user) {\n\t return store.commit('addNewUsers', [user]);\n\t });\n\t },\n\t unblockUser: function unblockUser(store, id) {\n\t return store.rootState.api.backendInteractor.unblockUser(id).then(function (user) {\n\t return store.commit('addNewUsers', [user]);\n\t });\n\t },\n\t fetchMutes: function fetchMutes(store) {\n\t return store.rootState.api.backendInteractor.fetchMutes().then(function (mutedUsers) {\n\t (0, _each3.default)(mutedUsers, function (user) {\n\t user.muted = true;\n\t });\n\t store.commit('addNewUsers', mutedUsers);\n\t store.commit('saveMutes', (0, _map3.default)(mutedUsers, 'id'));\n\t });\n\t },\n\t muteUser: function muteUser(store, id) {\n\t return store.state.api.backendInteractor.setUserMute({ id: id, muted: true }).then(function (user) {\n\t return store.commit('addNewUsers', [user]);\n\t });\n\t },\n\t unmuteUser: function unmuteUser(store, id) {\n\t return store.state.api.backendInteractor.setUserMute({ id: id, muted: false }).then(function (user) {\n\t return store.commit('addNewUsers', [user]);\n\t });\n\t },\n\t addFriends: function addFriends(_ref5, fetchBy) {\n\t var rootState = _ref5.rootState,\n\t commit = _ref5.commit;\n\t\n\t return new _promise2.default(function (resolve, reject) {\n\t var user = rootState.users.usersObject[fetchBy];\n\t var page = user.friendsPage || 1;\n\t rootState.api.backendInteractor.fetchFriends({ id: user.id, page: page }).then(function (friends) {\n\t commit('addFriends', { id: user.id, friends: friends, page: page });\n\t resolve(friends);\n\t }).catch(function () {\n\t reject();\n\t });\n\t });\n\t },\n\t addFollowers: function addFollowers(_ref6, fetchBy) {\n\t var rootState = _ref6.rootState,\n\t commit = _ref6.commit;\n\t\n\t var user = rootState.users.usersObject[fetchBy];\n\t var page = user.followersPage || 1;\n\t return rootState.api.backendInteractor.fetchFollowers({ id: user.id, page: page }).then(function (followers) {\n\t commit('addFollowers', { id: user.id, followers: followers, page: page });\n\t return followers;\n\t });\n\t },\n\t clearFriends: function clearFriends(_ref7, userId) {\n\t var commit = _ref7.commit;\n\t\n\t commit('clearFriends', userId);\n\t },\n\t clearFollowers: function clearFollowers(_ref8, userId) {\n\t var commit = _ref8.commit;\n\t\n\t commit('clearFollowers', userId);\n\t },\n\t registerPushNotifications: function registerPushNotifications(store) {\n\t var token = store.state.currentUser.credentials;\n\t var vapidPublicKey = store.rootState.instance.vapidPublicKey;\n\t var isEnabled = store.rootState.config.webPushNotifications;\n\t var notificationVisibility = store.rootState.config.notificationVisibility;\n\t\n\t (0, _push.registerPushNotifications)(isEnabled, vapidPublicKey, token, notificationVisibility);\n\t },\n\t unregisterPushNotifications: function unregisterPushNotifications(store) {\n\t var token = store.state.currentUser.credentials;\n\t\n\t (0, _push.unregisterPushNotifications)(token);\n\t },\n\t addNewStatuses: function addNewStatuses(store, _ref9) {\n\t var statuses = _ref9.statuses;\n\t\n\t var users = (0, _map3.default)(statuses, 'user');\n\t var retweetedUsers = (0, _compact3.default)((0, _map3.default)(statuses, 'retweeted_status.user'));\n\t store.commit('addNewUsers', users);\n\t store.commit('addNewUsers', retweetedUsers);\n\t\n\t (0, _each3.default)(statuses, function (status) {\n\t store.commit('setUserForStatus', status);\n\t });\n\t\n\t (0, _each3.default)((0, _compact3.default)((0, _map3.default)(statuses, 'retweeted_status')), function (status) {\n\t store.commit('setUserForStatus', status);\n\t });\n\t },\n\t addNewNotifications: function addNewNotifications(store, _ref10) {\n\t var notifications = _ref10.notifications;\n\t\n\t var users = (0, _map3.default)(notifications, 'from_profile');\n\t var notificationIds = notifications.map(function (_) {\n\t return _.id;\n\t });\n\t store.commit('addNewUsers', users);\n\t\n\t var notificationsObject = store.rootState.statuses.notifications.idStore;\n\t var relevantNotifications = (0, _entries2.default)(notificationsObject).filter(function (_ref11) {\n\t var _ref12 = (0, _slicedToArray3.default)(_ref11, 2),\n\t k = _ref12[0],\n\t val = _ref12[1];\n\t\n\t return notificationIds.includes(k);\n\t }).map(function (_ref13) {\n\t var _ref14 = (0, _slicedToArray3.default)(_ref13, 2),\n\t k = _ref14[0],\n\t val = _ref14[1];\n\t\n\t return val;\n\t });\n\t\n\t (0, _each3.default)(relevantNotifications, function (notification) {\n\t store.commit('setUserForNotification', notification);\n\t });\n\t },\n\t signUp: function () {\n\t var _ref15 = (0, _asyncToGenerator3.default)(_regenerator2.default.mark(function _callee(store, userInfo) {\n\t var rootState, response, data, app, result, _data, errors;\n\t\n\t return _regenerator2.default.wrap(function _callee$(_context) {\n\t while (1) {\n\t switch (_context.prev = _context.next) {\n\t case 0:\n\t store.commit('signUpPending');\n\t\n\t rootState = store.rootState;\n\t _context.next = 4;\n\t return rootState.api.backendInteractor.register(userInfo);\n\t\n\t case 4:\n\t response = _context.sent;\n\t\n\t if (!response.ok) {\n\t _context.next = 18;\n\t break;\n\t }\n\t\n\t data = {\n\t oauth: rootState.oauth,\n\t instance: rootState.instance.server\n\t };\n\t _context.next = 9;\n\t return _oauth2.default.getOrCreateApp(data);\n\t\n\t case 9:\n\t app = _context.sent;\n\t _context.next = 12;\n\t return _oauth2.default.getTokenWithCredentials({\n\t app: app,\n\t instance: data.instance,\n\t username: userInfo.username,\n\t password: userInfo.password\n\t });\n\t\n\t case 12:\n\t result = _context.sent;\n\t\n\t store.commit('signUpSuccess');\n\t store.commit('setToken', result.access_token);\n\t store.dispatch('loginUser', result.access_token);\n\t _context.next = 26;\n\t break;\n\t\n\t case 18:\n\t _context.next = 20;\n\t return response.json();\n\t\n\t case 20:\n\t _data = _context.sent;\n\t errors = JSON.parse(_data.error);\n\t\n\t if (errors.ap_id) {\n\t errors.username = errors.ap_id;\n\t delete errors.ap_id;\n\t }\n\t errors = (0, _errors.humanizeErrors)(errors);\n\t store.commit('signUpFailure', errors);\n\t throw Error(errors);\n\t\n\t case 26:\n\t case 'end':\n\t return _context.stop();\n\t }\n\t }\n\t }, _callee, this);\n\t }));\n\t\n\t function signUp(_x, _x2) {\n\t return _ref15.apply(this, arguments);\n\t }\n\t\n\t return signUp;\n\t }(),\n\t getCaptcha: function () {\n\t var _ref16 = (0, _asyncToGenerator3.default)(_regenerator2.default.mark(function _callee2(store) {\n\t return _regenerator2.default.wrap(function _callee2$(_context2) {\n\t while (1) {\n\t switch (_context2.prev = _context2.next) {\n\t case 0:\n\t _context2.next = 2;\n\t return store.rootState.api.backendInteractor.getCaptcha();\n\t\n\t case 2:\n\t return _context2.abrupt('return', _context2.sent);\n\t\n\t case 3:\n\t case 'end':\n\t return _context2.stop();\n\t }\n\t }\n\t }, _callee2, this);\n\t }));\n\t\n\t function getCaptcha(_x3) {\n\t return _ref16.apply(this, arguments);\n\t }\n\t\n\t return getCaptcha;\n\t }(),\n\t logout: function logout(store) {\n\t store.commit('clearCurrentUser');\n\t store.dispatch('disconnectFromChat');\n\t store.commit('setToken', false);\n\t store.dispatch('stopFetching', 'friends');\n\t store.commit('setBackendInteractor', (0, _backend_interactor_service2.default)());\n\t store.dispatch('stopFetchingNotifications');\n\t store.commit('resetStatuses');\n\t },\n\t loginUser: function loginUser(store, accessToken) {\n\t return new _promise2.default(function (resolve, reject) {\n\t var commit = store.commit;\n\t commit('beginLogin');\n\t store.rootState.api.backendInteractor.verifyCredentials(accessToken).then(function (data) {\n\t if (!data.error) {\n\t var user = data;\n\t\n\t user.credentials = accessToken;\n\t user.blockIds = [];\n\t user.muteIds = [];\n\t commit('setCurrentUser', user);\n\t commit('addNewUsers', [user]);\n\t\n\t getNotificationPermission().then(function (permission) {\n\t return commit('setNotificationPermission', permission);\n\t });\n\t\n\t commit('setBackendInteractor', (0, _backend_interactor_service2.default)(accessToken));\n\t\n\t if (user.token) {\n\t store.dispatch('setWsToken', user.token);\n\t\n\t store.dispatch('initializeSocket');\n\t }\n\t\n\t store.dispatch('startFetching', { timeline: 'friends' });\n\t\n\t store.dispatch('fetchMutes');\n\t\n\t store.rootState.api.backendInteractor.fetchFriends({ id: user.id }).then(function (friends) {\n\t return commit('addNewUsers', friends);\n\t });\n\t } else {\n\t var response = data.error;\n\t\n\t commit('endLogin');\n\t if (response.status === 401) {\n\t reject('Wrong username or password');\n\t } else {\n\t reject('An error occurred, please try again');\n\t }\n\t }\n\t commit('endLogin');\n\t resolve();\n\t }).catch(function (error) {\n\t console.log(error);\n\t commit('endLogin');\n\t reject('Failed to connect to server, try again');\n\t });\n\t });\n\t }\n\t }\n\t};\n\t\n\texports.default = users;\n\n/***/ }),\n/* 237 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\texports.splitIntoWords = exports.addPositionToWords = exports.wordAtPosition = exports.replaceWord = undefined;\n\t\n\tvar _find2 = __webpack_require__(59);\n\t\n\tvar _find3 = _interopRequireDefault(_find2);\n\t\n\tvar _reduce2 = __webpack_require__(124);\n\t\n\tvar _reduce3 = _interopRequireDefault(_reduce2);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar replaceWord = exports.replaceWord = function replaceWord(str, toReplace, replacement) {\n\t return str.slice(0, toReplace.start) + replacement + str.slice(toReplace.end);\n\t};\n\t\n\tvar wordAtPosition = exports.wordAtPosition = function wordAtPosition(str, pos) {\n\t var words = splitIntoWords(str);\n\t var wordsWithPosition = addPositionToWords(words);\n\t\n\t return (0, _find3.default)(wordsWithPosition, function (_ref) {\n\t var start = _ref.start,\n\t end = _ref.end;\n\t return start <= pos && end > pos;\n\t });\n\t};\n\t\n\tvar addPositionToWords = exports.addPositionToWords = function addPositionToWords(words) {\n\t return (0, _reduce3.default)(words, function (result, word) {\n\t var data = {\n\t word: word,\n\t start: 0,\n\t end: word.length\n\t };\n\t\n\t if (result.length > 0) {\n\t var previous = result.pop();\n\t\n\t data.start += previous.end;\n\t data.end += previous.end;\n\t\n\t result.push(previous);\n\t }\n\t\n\t result.push(data);\n\t\n\t return result;\n\t }, []);\n\t};\n\t\n\tvar splitIntoWords = exports.splitIntoWords = function splitIntoWords(str) {\n\t var regex = /\\b/;\n\t var triggers = /[@#:]+$/;\n\t\n\t var split = str.split(regex);\n\t\n\t var words = (0, _reduce3.default)(split, function (result, word) {\n\t if (result.length > 0) {\n\t var previous = result.pop();\n\t var matches = previous.match(triggers);\n\t if (matches) {\n\t previous = previous.replace(triggers, '');\n\t word = matches[0] + word;\n\t }\n\t result.push(previous);\n\t }\n\t result.push(word);\n\t\n\t return result;\n\t }, []);\n\t\n\t return words;\n\t};\n\t\n\tvar completion = {\n\t wordAtPosition: wordAtPosition,\n\t addPositionToWords: addPositionToWords,\n\t splitIntoWords: splitIntoWords,\n\t replaceWord: replaceWord\n\t};\n\t\n\texports.default = completion;\n\n/***/ }),\n/* 238 */\n/***/ (function(module, exports) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\tvar qvitterStatusType = function qvitterStatusType(status) {\n\t if (status.is_post_verb) {\n\t return 'status';\n\t }\n\t\n\t if (status.retweeted_status) {\n\t return 'retweet';\n\t }\n\t\n\t if (typeof status.uri === 'string' && status.uri.match(/(fave|objectType=Favourite)/) || typeof status.text === 'string' && status.text.match(/favorited/)) {\n\t return 'favorite';\n\t }\n\t\n\t if (status.text.match(/deleted notice {{tag/) || status.qvitter_delete_notice) {\n\t return 'deletion';\n\t }\n\t\n\t if (status.text.match(/started following/) || status.activity_type === 'follow') {\n\t return 'follow';\n\t }\n\t\n\t return 'unknown';\n\t};\n\t\n\tvar parseUser = exports.parseUser = function parseUser(data) {\n\t var output = {};\n\t var masto = data.hasOwnProperty('acct');\n\t\n\t var mastoShort = masto && !data.hasOwnProperty('avatar');\n\t\n\t output.id = String(data.id);\n\t\n\t if (masto) {\n\t output.screen_name = data.acct;\n\t\n\t if (mastoShort) {\n\t return output;\n\t }\n\t\n\t output.name = null;\n\t output.name_html = data.display_name;\n\t\n\t output.description = null;\n\t output.description_html = data.note;\n\t\n\t output.profile_image_url = data.avatar;\n\t output.profile_image_url_original = data.avatar;\n\t\n\t output.cover_photo = data.header;\n\t\n\t output.friends_count = data.following_count;\n\t\n\t output.bot = data.bot;\n\t\n\t output.statusnet_profile_url = data.url;\n\t\n\t if (data.pleroma) {\n\t var pleroma = data.pleroma;\n\t output.follows_you = pleroma.follows_you;\n\t output.statusnet_blocking = pleroma.statusnet_blocking;\n\t output.muted = pleroma.muted;\n\t }\n\t\n\t output.is_local = !output.screen_name.includes('@');\n\t } else {\n\t output.screen_name = data.screen_name;\n\t\n\t output.name = data.name;\n\t output.name_html = data.name_html;\n\t\n\t output.description = data.description;\n\t output.description_html = data.description_html;\n\t\n\t output.profile_image_url = data.profile_image_url;\n\t output.profile_image_url_original = data.profile_image_url_original;\n\t\n\t output.cover_photo = data.cover_photo;\n\t\n\t output.friends_count = data.friends_count;\n\t\n\t output.bot = null;\n\t\n\t output.statusnet_profile_url = data.statusnet_profile_url;\n\t\n\t output.statusnet_blocking = data.statusnet_blocking;\n\t\n\t output.is_local = data.is_local;\n\t output.role = data.role;\n\t output.show_role = data.show_role;\n\t\n\t output.follows_you = data.follows_you;\n\t\n\t output.muted = data.muted;\n\t\n\t output.rights = data.rights;\n\t output.no_rich_text = data.no_rich_text;\n\t output.default_scope = data.default_scope;\n\t output.hide_follows = data.hide_follows;\n\t output.hide_followers = data.hide_followers;\n\t output.background_image = data.background_image;\n\t\n\t output.following = data.following;\n\t\n\t output.token = data.token;\n\t }\n\t\n\t output.created_at = new Date(data.created_at);\n\t output.locked = data.locked;\n\t output.followers_count = data.followers_count;\n\t output.statuses_count = data.statuses_count;\n\t output.friends = [];\n\t output.followers = [];\n\t if (data.pleroma) {\n\t output.follow_request_count = data.pleroma.follow_request_count;\n\t }\n\t\n\t return output;\n\t};\n\t\n\tvar parseAttachment = function parseAttachment(data) {\n\t var output = {};\n\t var masto = !data.hasOwnProperty('oembed');\n\t\n\t if (masto) {\n\t output.mimetype = data.type;\n\t output.meta = data.meta;\n\t } else {\n\t output.mimetype = data.mimetype;\n\t output.meta = null;\n\t }\n\t\n\t output.url = data.url;\n\t output.description = data.description;\n\t\n\t return output;\n\t};\n\t\n\tvar parseStatus = exports.parseStatus = function parseStatus(data) {\n\t var output = {};\n\t var masto = data.hasOwnProperty('account');\n\t\n\t if (masto) {\n\t output.favorited = data.favourited;\n\t output.fave_num = data.favourites_count;\n\t\n\t output.repeated = data.reblogged;\n\t output.repeat_num = data.reblogs_count;\n\t\n\t output.type = data.reblog ? 'retweet' : 'status';\n\t output.nsfw = data.sensitive;\n\t\n\t output.statusnet_html = data.content;\n\t\n\t output.text = data.content;\n\t\n\t output.in_reply_to_status_id = data.in_reply_to_id;\n\t output.in_reply_to_user_id = data.in_reply_to_account_id;\n\t\n\t output.in_reply_to_screen_name = null;\n\t\n\t output.statusnet_conversation_id = data.id;\n\t\n\t if (output.type === 'retweet') {\n\t output.retweeted_status = parseStatus(data.reblog);\n\t }\n\t\n\t output.summary = data.spoiler_text;\n\t output.summary_html = data.spoiler_text;\n\t output.external_url = data.url;\n\t\n\t output.is_local = false;\n\t } else {\n\t output.favorited = data.favorited;\n\t output.fave_num = data.fave_num;\n\t\n\t output.repeated = data.repeated;\n\t output.repeat_num = data.repeat_num;\n\t\n\t output.type = qvitterStatusType(data);\n\t\n\t if (data.nsfw === undefined) {\n\t output.nsfw = isNsfw(data);\n\t if (data.retweeted_status) {\n\t output.nsfw = data.retweeted_status.nsfw;\n\t }\n\t } else {\n\t output.nsfw = data.nsfw;\n\t }\n\t\n\t output.statusnet_html = data.statusnet_html;\n\t output.text = data.text;\n\t\n\t output.in_reply_to_status_id = data.in_reply_to_status_id;\n\t output.in_reply_to_user_id = data.in_reply_to_user_id;\n\t output.in_reply_to_screen_name = data.in_reply_to_screen_name;\n\t\n\t output.statusnet_conversation_id = data.statusnet_conversation_id;\n\t\n\t if (output.type === 'retweet') {\n\t output.retweeted_status = parseStatus(data.retweeted_status);\n\t }\n\t\n\t output.summary = data.summary;\n\t output.summary_html = data.summary_html;\n\t output.external_url = data.external_url;\n\t output.is_local = data.is_local;\n\t }\n\t\n\t output.id = String(data.id);\n\t output.visibility = data.visibility;\n\t output.card = data.card;\n\t output.created_at = new Date(data.created_at);\n\t\n\t output.in_reply_to_status_id = output.in_reply_to_status_id ? String(output.in_reply_to_status_id) : null;\n\t output.in_reply_to_user_id = output.in_reply_to_user_id ? String(output.in_reply_to_user_id) : null;\n\t\n\t output.user = parseUser(masto ? data.account : data.user);\n\t\n\t output.attentions = ((masto ? data.mentions : data.attentions) || []).map(parseUser);\n\t\n\t output.attachments = ((masto ? data.media_attachments : data.attachments) || []).map(parseAttachment);\n\t\n\t var retweetedStatus = masto ? data.reblog : data.retweeted_status;\n\t if (retweetedStatus) {\n\t output.retweeted_status = parseStatus(retweetedStatus);\n\t }\n\t\n\t return output;\n\t};\n\t\n\tvar parseNotification = exports.parseNotification = function parseNotification(data) {\n\t var mastoDict = {\n\t 'favourite': 'like',\n\t 'reblog': 'repeat'\n\t };\n\t var masto = !data.hasOwnProperty('ntype');\n\t var output = {};\n\t\n\t if (masto) {\n\t output.type = mastoDict[data.type] || data.type;\n\t output.seen = null;\n\t output.status = parseStatus(data.status);\n\t output.action = output.status;\n\t output.from_profile = parseUser(data.account);\n\t } else {\n\t var parsedNotice = parseStatus(data.notice);\n\t output.type = data.ntype;\n\t output.seen = Boolean(data.is_seen);\n\t output.status = output.type === 'like' ? parseStatus(data.notice.favorited_status) : parsedNotice;\n\t output.action = parsedNotice;\n\t output.from_profile = parseUser(data.from_profile);\n\t }\n\t\n\t output.created_at = new Date(data.created_at);\n\t output.id = data.id;\n\t\n\t return output;\n\t};\n\t\n\tvar isNsfw = function isNsfw(status) {\n\t var nsfwRegex = /#nsfw/i;\n\t return (status.tags || []).includes('nsfw') || !!status.text.match(nsfwRegex);\n\t};\n\n/***/ }),\n/* 239 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _create = __webpack_require__(311);\n\t\n\tvar _create2 = _interopRequireDefault(_create);\n\t\n\tvar _stringify = __webpack_require__(64);\n\t\n\tvar _stringify2 = _interopRequireDefault(_stringify);\n\t\n\texports.StatusCodeError = StatusCodeError;\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tfunction StatusCodeError(statusCode, body, options, response) {\n\t this.name = 'StatusCodeError';\n\t this.statusCode = statusCode;\n\t this.message = statusCode + ' - ' + (JSON && _stringify2.default ? (0, _stringify2.default)(body) : body);\n\t this.error = body;\n\t this.options = options;\n\t this.response = response;\n\t\n\t if (Error.captureStackTrace) {\n\t Error.captureStackTrace(this);\n\t }\n\t}\n\tStatusCodeError.prototype = (0, _create2.default)(Error.prototype);\n\tStatusCodeError.prototype.constructor = StatusCodeError;\n\n/***/ }),\n/* 240 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _apiService = __webpack_require__(18);\n\t\n\tvar _apiService2 = _interopRequireDefault(_apiService);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar fetchAndUpdate = function fetchAndUpdate(_ref) {\n\t var store = _ref.store,\n\t credentials = _ref.credentials;\n\t\n\t return _apiService2.default.fetchFollowRequests({ credentials: credentials }).then(function (requests) {\n\t store.commit('setFollowRequests', requests);\n\t }, function () {}).catch(function () {});\n\t};\n\t\n\tvar startFetching = function startFetching(_ref2) {\n\t var credentials = _ref2.credentials,\n\t store = _ref2.store;\n\t\n\t fetchAndUpdate({ credentials: credentials, store: store });\n\t var boundFetchAndUpdate = function boundFetchAndUpdate() {\n\t return fetchAndUpdate({ credentials: credentials, store: store });\n\t };\n\t return setInterval(boundFetchAndUpdate, 10000);\n\t};\n\t\n\tvar followRequestFetcher = {\n\t startFetching: startFetching\n\t};\n\t\n\texports.default = followRequestFetcher;\n\n/***/ }),\n/* 241 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\texports.extractTagFromUrl = exports.mentionMatchesUrl = undefined;\n\t\n\tvar _slicedToArray2 = __webpack_require__(9);\n\t\n\tvar _slicedToArray3 = _interopRequireDefault(_slicedToArray2);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar mentionMatchesUrl = exports.mentionMatchesUrl = function mentionMatchesUrl(attention, url) {\n\t if (url === attention.statusnet_profile_url) {\n\t return true;\n\t }\n\t\n\t var _attention$screen_nam = attention.screen_name.split('@'),\n\t _attention$screen_nam2 = (0, _slicedToArray3.default)(_attention$screen_nam, 2),\n\t namepart = _attention$screen_nam2[0],\n\t instancepart = _attention$screen_nam2[1];\n\t\n\t var matchstring = new RegExp('://' + instancepart + '/.*' + namepart + '$', 'g');\n\t\n\t return !!url.match(matchstring);\n\t};\n\t\n\tvar extractTagFromUrl = exports.extractTagFromUrl = function extractTagFromUrl(url) {\n\t var regex = /tag[s]*\\/(\\w+)$/g;\n\t var result = regex.exec(url);\n\t if (!result) {\n\t return false;\n\t }\n\t return result[1];\n\t};\n\n/***/ }),\n/* 242 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _utils = __webpack_require__(243);\n\t\n\tvar _utils2 = _interopRequireDefault(_utils);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar search = function search(_ref) {\n\t var query = _ref.query,\n\t store = _ref.store;\n\t\n\t return _utils2.default.request({\n\t store: store,\n\t url: '/api/pleroma/search_user',\n\t params: {\n\t query: query\n\t }\n\t }).then(function (data) {\n\t return data.json();\n\t });\n\t};\n\tvar UserSearch = {\n\t search: search\n\t};\n\t\n\texports.default = UserSearch;\n\n/***/ }),\n/* 243 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _keys = __webpack_require__(24);\n\t\n\tvar _keys2 = _interopRequireDefault(_keys);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar queryParams = function queryParams(params) {\n\t return (0, _keys2.default)(params).map(function (k) {\n\t return encodeURIComponent(k) + '=' + encodeURIComponent(params[k]);\n\t }).join('&');\n\t};\n\t\n\tvar headers = function headers(store) {\n\t var accessToken = store.state.oauth.token;\n\t if (accessToken) {\n\t return { 'Authorization': 'Bearer ' + accessToken };\n\t } else {\n\t return {};\n\t }\n\t};\n\t\n\tvar request = function request(_ref) {\n\t var _ref$method = _ref.method,\n\t method = _ref$method === undefined ? 'GET' : _ref$method,\n\t url = _ref.url,\n\t params = _ref.params,\n\t store = _ref.store;\n\t\n\t var instance = store.state.instance.server;\n\t var fullUrl = '' + instance + url;\n\t\n\t if (method === 'GET' && params) {\n\t fullUrl = fullUrl + ('?' + queryParams(params));\n\t }\n\t\n\t return window.fetch(fullUrl, {\n\t method: method,\n\t headers: headers(store),\n\t credentials: 'same-origin'\n\t });\n\t};\n\t\n\tvar utils = {\n\t queryParams: queryParams,\n\t request: request\n\t};\n\t\n\texports.default = utils;\n\n/***/ }),\n/* 244 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _toConsumableArray2 = __webpack_require__(26);\n\t\n\tvar _toConsumableArray3 = _interopRequireDefault(_toConsumableArray2);\n\t\n\tvar _apiService = __webpack_require__(18);\n\t\n\tvar _apiService2 = _interopRequireDefault(_apiService);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar update = function update(_ref) {\n\t var store = _ref.store,\n\t notifications = _ref.notifications,\n\t older = _ref.older;\n\t\n\t store.dispatch('setNotificationsError', { value: false });\n\t\n\t store.dispatch('addNewNotifications', { notifications: notifications, older: older });\n\t};\n\t\n\tvar fetchAndUpdate = function fetchAndUpdate(_ref2) {\n\t var store = _ref2.store,\n\t credentials = _ref2.credentials,\n\t _ref2$older = _ref2.older,\n\t older = _ref2$older === undefined ? false : _ref2$older;\n\t\n\t var args = { credentials: credentials };\n\t var rootState = store.rootState || store.state;\n\t var timelineData = rootState.statuses.notifications;\n\t\n\t if (older) {\n\t if (timelineData.minId !== Number.POSITIVE_INFINITY) {\n\t args['until'] = timelineData.minId;\n\t }\n\t } else {\n\t var notifications = timelineData.data;\n\t var unread = notifications.filter(function (n) {\n\t return !n.seen;\n\t }).map(function (n) {\n\t return n.id;\n\t });\n\t if (!unread.length) {\n\t args['since'] = timelineData.maxId;\n\t } else {\n\t args['since'] = Math.min.apply(Math, (0, _toConsumableArray3.default)(unread)) - 1;\n\t if (timelineData.maxId !== Math.max.apply(Math, (0, _toConsumableArray3.default)(unread))) {\n\t args['until'] = Math.max.apply(Math, (0, _toConsumableArray3.default)(unread).concat([args['since'] + 20]));\n\t }\n\t }\n\t }\n\t\n\t args['timeline'] = 'notifications';\n\t\n\t return _apiService2.default.fetchTimeline(args).then(function (notifications) {\n\t update({ store: store, notifications: notifications, older: older });\n\t return notifications;\n\t }, function () {\n\t return store.dispatch('setNotificationsError', { value: true });\n\t }).catch(function () {\n\t return store.dispatch('setNotificationsError', { value: true });\n\t });\n\t};\n\t\n\tvar startFetching = function startFetching(_ref3) {\n\t var credentials = _ref3.credentials,\n\t store = _ref3.store;\n\t\n\t fetchAndUpdate({ credentials: credentials, store: store });\n\t var boundFetchAndUpdate = function boundFetchAndUpdate() {\n\t return fetchAndUpdate({ credentials: credentials, store: store });\n\t };\n\t\n\t setTimeout(function () {\n\t return store.dispatch('setNotificationsSilence', false);\n\t }, 10000);\n\t return setInterval(boundFetchAndUpdate, 10000);\n\t};\n\t\n\tvar notificationsFetcher = {\n\t fetchAndUpdate: fetchAndUpdate,\n\t startFetching: startFetching\n\t};\n\t\n\texports.default = notificationsFetcher;\n\n/***/ }),\n/* 245 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _slicedToArray2 = __webpack_require__(9);\n\t\n\tvar _slicedToArray3 = _interopRequireDefault(_slicedToArray2);\n\t\n\tvar _stringify = __webpack_require__(64);\n\t\n\tvar _stringify2 = _interopRequireDefault(_stringify);\n\t\n\tvar _promise = __webpack_require__(25);\n\t\n\tvar _promise2 = _interopRequireDefault(_promise);\n\t\n\tvar _toConsumableArray2 = __webpack_require__(26);\n\t\n\tvar _toConsumableArray3 = _interopRequireDefault(_toConsumableArray2);\n\t\n\texports.registerPushNotifications = registerPushNotifications;\n\texports.unregisterPushNotifications = unregisterPushNotifications;\n\t\n\tvar _runtime = __webpack_require__(626);\n\t\n\tvar _runtime2 = _interopRequireDefault(_runtime);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tfunction urlBase64ToUint8Array(base64String) {\n\t var padding = '='.repeat((4 - base64String.length % 4) % 4);\n\t var base64 = (base64String + padding).replace(/-/g, '+').replace(/_/g, '/');\n\t\n\t var rawData = window.atob(base64);\n\t return Uint8Array.from([].concat((0, _toConsumableArray3.default)(rawData)).map(function (char) {\n\t return char.charCodeAt(0);\n\t }));\n\t}\n\t\n\tfunction isPushSupported() {\n\t return 'serviceWorker' in navigator && 'PushManager' in window;\n\t}\n\t\n\tfunction getOrCreateServiceWorker() {\n\t return _runtime2.default.register().catch(function (err) {\n\t return console.error('Unable to get or create a service worker.', err);\n\t });\n\t}\n\t\n\tfunction subscribePush(registration, isEnabled, vapidPublicKey) {\n\t if (!isEnabled) return _promise2.default.reject(new Error('Web Push is disabled in config'));\n\t if (!vapidPublicKey) return _promise2.default.reject(new Error('VAPID public key is not found'));\n\t\n\t var subscribeOptions = {\n\t userVisibleOnly: true,\n\t applicationServerKey: urlBase64ToUint8Array(vapidPublicKey)\n\t };\n\t return registration.pushManager.subscribe(subscribeOptions);\n\t}\n\t\n\tfunction unsubscribePush(registration) {\n\t return registration.pushManager.getSubscription().then(function (subscribtion) {\n\t if (subscribtion === null) {\n\t return;\n\t }\n\t return subscribtion.unsubscribe();\n\t });\n\t}\n\t\n\tfunction deleteSubscriptionFromBackEnd(token) {\n\t return window.fetch('/api/v1/push/subscription/', {\n\t method: 'DELETE',\n\t headers: {\n\t 'Content-Type': 'application/json',\n\t 'Authorization': 'Bearer ' + token\n\t }\n\t }).then(function (response) {\n\t if (!response.ok) throw new Error('Bad status code from server.');\n\t return response;\n\t });\n\t}\n\t\n\tfunction sendSubscriptionToBackEnd(subscription, token, notificationVisibility) {\n\t return window.fetch('/api/v1/push/subscription/', {\n\t method: 'POST',\n\t headers: {\n\t 'Content-Type': 'application/json',\n\t 'Authorization': 'Bearer ' + token\n\t },\n\t body: (0, _stringify2.default)({\n\t subscription: subscription,\n\t data: {\n\t alerts: {\n\t follow: notificationVisibility.follows,\n\t favourite: notificationVisibility.likes,\n\t mention: notificationVisibility.mentions,\n\t reblog: notificationVisibility.repeats\n\t }\n\t }\n\t })\n\t }).then(function (response) {\n\t if (!response.ok) throw new Error('Bad status code from server.');\n\t return response.json();\n\t }).then(function (responseData) {\n\t if (!responseData.id) throw new Error('Bad response from server.');\n\t return responseData;\n\t });\n\t}\n\t\n\tfunction registerPushNotifications(isEnabled, vapidPublicKey, token, notificationVisibility) {\n\t if (isPushSupported()) {\n\t getOrCreateServiceWorker().then(function (registration) {\n\t return subscribePush(registration, isEnabled, vapidPublicKey);\n\t }).then(function (subscription) {\n\t return sendSubscriptionToBackEnd(subscription, token, notificationVisibility);\n\t }).catch(function (e) {\n\t return console.warn('Failed to setup Web Push Notifications: ' + e.message);\n\t });\n\t }\n\t}\n\t\n\tfunction unregisterPushNotifications(token) {\n\t if (isPushSupported()) {\n\t _promise2.default.all([deleteSubscriptionFromBackEnd(token), getOrCreateServiceWorker().then(function (registration) {\n\t return unsubscribePush(registration).then(function (result) {\n\t return [registration, result];\n\t });\n\t }).then(function (_ref) {\n\t var _ref2 = (0, _slicedToArray3.default)(_ref, 2),\n\t registration = _ref2[0],\n\t unsubResult = _ref2[1];\n\t\n\t if (!unsubResult) {\n\t console.warn('Push subscription cancellation wasn\\'t successful, killing SW anyway...');\n\t }\n\t return registration.unregister().then(function (result) {\n\t if (!result) {\n\t console.warn('Failed to kill SW');\n\t }\n\t });\n\t })]).catch(function (e) {\n\t return console.warn('Failed to disable Web Push Notifications: ' + e.message);\n\t });\n\t }\n\t}\n\n/***/ }),\n/* 246 */\n/***/ (function(module, exports) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\texports.default = {\n\t props: ['name', 'label', 'value', 'fallback', 'disabled'],\n\t computed: {\n\t present: function present() {\n\t return typeof this.value !== 'undefined';\n\t }\n\t }\n\t};\n\n/***/ }),\n/* 247 */\n/***/ (function(module, exports) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\texports.default = {\n\t props: ['large', 'contrast'],\n\t computed: {\n\t hint: function hint() {\n\t var levelVal = this.contrast.aaa ? 'aaa' : this.contrast.aa ? 'aa' : 'bad';\n\t var level = this.$t('settings.style.common.contrast.level.' + levelVal);\n\t var context = this.$t('settings.style.common.contrast.context.text');\n\t var ratio = this.contrast.text;\n\t return this.$t('settings.style.common.contrast.hint', { level: level, context: context, ratio: ratio });\n\t },\n\t hint_18pt: function hint_18pt() {\n\t var levelVal = this.contrast.laaa ? 'aaa' : this.contrast.laa ? 'aa' : 'bad';\n\t var level = this.$t('settings.style.common.contrast.level.' + levelVal);\n\t var context = this.$t('settings.style.common.contrast.context.18pt');\n\t var ratio = this.contrast.text;\n\t return this.$t('settings.style.common.contrast.hint', { level: level, context: context, ratio: ratio });\n\t }\n\t }\n\t};\n\n/***/ }),\n/* 248 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _stringify = __webpack_require__(64);\n\t\n\tvar _stringify2 = _interopRequireDefault(_stringify);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\texports.default = {\n\t props: ['exportObject', 'importLabel', 'exportLabel', 'importFailedText', 'validator', 'onImport', 'onImportFailure'],\n\t data: function data() {\n\t return {\n\t importFailed: false\n\t };\n\t },\n\t\n\t methods: {\n\t exportData: function exportData() {\n\t var stringified = (0, _stringify2.default)(this.exportObject);\n\t var e = document.createElement('a');\n\t e.setAttribute('download', 'pleroma_theme.json');\n\t e.setAttribute('href', 'data:application/json;base64,' + window.btoa(stringified));\n\t e.style.display = 'none';\n\t\n\t document.body.appendChild(e);\n\t e.click();\n\t document.body.removeChild(e);\n\t },\n\t importData: function importData() {\n\t var _this = this;\n\t\n\t this.importFailed = false;\n\t var filePicker = document.createElement('input');\n\t filePicker.setAttribute('type', 'file');\n\t filePicker.setAttribute('accept', '.json');\n\t\n\t filePicker.addEventListener('change', function (event) {\n\t if (event.target.files[0]) {\n\t var reader = new FileReader();\n\t reader.onload = function (_ref) {\n\t var target = _ref.target;\n\t\n\t try {\n\t var parsed = JSON.parse(target.result);\n\t var valid = _this.validator(parsed);\n\t if (valid) {\n\t _this.onImport(parsed);\n\t } else {\n\t _this.importFailed = true;\n\t }\n\t } catch (e) {\n\t _this.importFailed = true;\n\t }\n\t };\n\t reader.readAsText(event.target.files[0]);\n\t }\n\t });\n\t\n\t document.body.appendChild(filePicker);\n\t filePicker.click();\n\t document.body.removeChild(filePicker);\n\t }\n\t }\n\t};\n\n/***/ }),\n/* 249 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _keys = __webpack_require__(24);\n\t\n\tvar _keys2 = _interopRequireDefault(_keys);\n\t\n\tvar _map2 = __webpack_require__(31);\n\t\n\tvar _map3 = _interopRequireDefault(_map2);\n\t\n\tvar _messages = __webpack_require__(130);\n\t\n\tvar _messages2 = _interopRequireDefault(_messages);\n\t\n\tvar _iso = __webpack_require__(432);\n\t\n\tvar _iso2 = _interopRequireDefault(_iso);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\texports.default = {\n\t computed: {\n\t languageCodes: function languageCodes() {\n\t return (0, _keys2.default)(_messages2.default);\n\t },\n\t languageNames: function languageNames() {\n\t return (0, _map3.default)(this.languageCodes, _iso2.default.getName);\n\t },\n\t\n\t\n\t language: {\n\t get: function get() {\n\t return this.$store.state.config.interfaceLanguage;\n\t },\n\t set: function set(val) {\n\t this.$store.dispatch('setOption', { name: 'interfaceLanguage', value: val });\n\t this.$i18n.locale = val;\n\t }\n\t }\n\t }\n\t};\n\n/***/ }),\n/* 250 */\n/***/ (function(module, exports) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\texports.default = {\n\t props: ['name', 'value', 'fallback', 'disabled'],\n\t computed: {\n\t present: function present() {\n\t return typeof this.value !== 'undefined';\n\t }\n\t }\n\t};\n\n/***/ }),\n/* 251 */\n/***/ (function(module, exports) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\texports.default = {\n\t props: ['name', 'value', 'fallback', 'disabled', 'label', 'max', 'min', 'step', 'hardMin', 'hardMax'],\n\t computed: {\n\t present: function present() {\n\t return typeof this.value !== 'undefined';\n\t }\n\t }\n\t};\n\n/***/ }),\n/* 252 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _assign = __webpack_require__(36);\n\t\n\tvar _assign2 = _interopRequireDefault(_assign);\n\t\n\tvar _user_panel = __webpack_require__(671);\n\t\n\tvar _user_panel2 = _interopRequireDefault(_user_panel);\n\t\n\tvar _nav_panel = __webpack_require__(655);\n\t\n\tvar _nav_panel2 = _interopRequireDefault(_nav_panel);\n\t\n\tvar _notifications = __webpack_require__(213);\n\t\n\tvar _notifications2 = _interopRequireDefault(_notifications);\n\t\n\tvar _user_finder = __webpack_require__(670);\n\t\n\tvar _user_finder2 = _interopRequireDefault(_user_finder);\n\t\n\tvar _instance_specific_panel = __webpack_require__(211);\n\t\n\tvar _instance_specific_panel2 = _interopRequireDefault(_instance_specific_panel);\n\t\n\tvar _features_panel = __webpack_require__(210);\n\t\n\tvar _features_panel2 = _interopRequireDefault(_features_panel);\n\t\n\tvar _who_to_follow_panel = __webpack_require__(676);\n\t\n\tvar _who_to_follow_panel2 = _interopRequireDefault(_who_to_follow_panel);\n\t\n\tvar _chat_panel = __webpack_require__(207);\n\t\n\tvar _chat_panel2 = _interopRequireDefault(_chat_panel);\n\t\n\tvar _media_modal = __webpack_require__(650);\n\t\n\tvar _media_modal2 = _interopRequireDefault(_media_modal);\n\t\n\tvar _side_drawer = __webpack_require__(665);\n\t\n\tvar _side_drawer2 = _interopRequireDefault(_side_drawer);\n\t\n\tvar _mobile_post_status_modal = __webpack_require__(653);\n\t\n\tvar _mobile_post_status_modal2 = _interopRequireDefault(_mobile_post_status_modal);\n\t\n\tvar _notification_utils = __webpack_require__(91);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\texports.default = {\n\t name: 'app',\n\t components: {\n\t UserPanel: _user_panel2.default,\n\t NavPanel: _nav_panel2.default,\n\t Notifications: _notifications2.default,\n\t UserFinder: _user_finder2.default,\n\t InstanceSpecificPanel: _instance_specific_panel2.default,\n\t FeaturesPanel: _features_panel2.default,\n\t WhoToFollowPanel: _who_to_follow_panel2.default,\n\t ChatPanel: _chat_panel2.default,\n\t MediaModal: _media_modal2.default,\n\t SideDrawer: _side_drawer2.default,\n\t MobilePostStatusModal: _mobile_post_status_modal2.default\n\t },\n\t data: function data() {\n\t return {\n\t mobileActivePanel: 'timeline',\n\t finderHidden: true,\n\t supportsMask: window.CSS && window.CSS.supports && (window.CSS.supports('mask-size', 'contain') || window.CSS.supports('-webkit-mask-size', 'contain') || window.CSS.supports('-moz-mask-size', 'contain') || window.CSS.supports('-ms-mask-size', 'contain') || window.CSS.supports('-o-mask-size', 'contain'))\n\t };\n\t },\n\t created: function created() {\n\t this.$i18n.locale = this.$store.state.config.interfaceLanguage;\n\t },\n\t\n\t computed: {\n\t currentUser: function currentUser() {\n\t return this.$store.state.users.currentUser;\n\t },\n\t background: function background() {\n\t return this.currentUser.background_image || this.$store.state.instance.background;\n\t },\n\t enableMask: function enableMask() {\n\t return this.supportsMask && this.$store.state.instance.logoMask;\n\t },\n\t logoStyle: function logoStyle() {\n\t return {\n\t 'visibility': this.enableMask ? 'hidden' : 'visible'\n\t };\n\t },\n\t logoMaskStyle: function logoMaskStyle() {\n\t return this.enableMask ? {\n\t 'mask-image': 'url(' + this.$store.state.instance.logo + ')'\n\t } : {\n\t 'background-color': this.enableMask ? '' : 'transparent'\n\t };\n\t },\n\t logoBgStyle: function logoBgStyle() {\n\t return (0, _assign2.default)({\n\t 'margin': this.$store.state.instance.logoMargin + ' 0',\n\t opacity: this.finderHidden ? 1 : 0\n\t }, this.enableMask ? {} : {\n\t 'background-color': this.enableMask ? '' : 'transparent'\n\t });\n\t },\n\t logo: function logo() {\n\t return this.$store.state.instance.logo;\n\t },\n\t bgStyle: function bgStyle() {\n\t return {\n\t 'background-image': 'url(' + this.background + ')'\n\t };\n\t },\n\t bgAppStyle: function bgAppStyle() {\n\t return {\n\t '--body-background-image': 'url(' + this.background + ')'\n\t };\n\t },\n\t sitename: function sitename() {\n\t return this.$store.state.instance.name;\n\t },\n\t chat: function chat() {\n\t return this.$store.state.chat.channel.state === 'joined';\n\t },\n\t suggestionsEnabled: function suggestionsEnabled() {\n\t return this.$store.state.instance.suggestionsEnabled;\n\t },\n\t showInstanceSpecificPanel: function showInstanceSpecificPanel() {\n\t return this.$store.state.instance.showInstanceSpecificPanel;\n\t },\n\t unseenNotifications: function unseenNotifications() {\n\t return (0, _notification_utils.unseenNotificationsFromStore)(this.$store);\n\t },\n\t unseenNotificationsCount: function unseenNotificationsCount() {\n\t return this.unseenNotifications.length;\n\t },\n\t showFeaturesPanel: function showFeaturesPanel() {\n\t return this.$store.state.instance.showFeaturesPanel;\n\t }\n\t },\n\t methods: {\n\t scrollToTop: function scrollToTop() {\n\t window.scrollTo(0, 0);\n\t },\n\t logout: function logout() {\n\t this.$router.replace('/main/public');\n\t this.$store.dispatch('logout');\n\t },\n\t onFinderToggled: function onFinderToggled(hidden) {\n\t this.finderHidden = hidden;\n\t },\n\t toggleMobileSidebar: function toggleMobileSidebar() {\n\t this.$refs.sideDrawer.toggleDrawer();\n\t }\n\t }\n\t};\n\n/***/ }),\n/* 253 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _instance_specific_panel = __webpack_require__(211);\n\t\n\tvar _instance_specific_panel2 = _interopRequireDefault(_instance_specific_panel);\n\t\n\tvar _features_panel = __webpack_require__(210);\n\t\n\tvar _features_panel2 = _interopRequireDefault(_features_panel);\n\t\n\tvar _terms_of_service_panel = __webpack_require__(669);\n\t\n\tvar _terms_of_service_panel2 = _interopRequireDefault(_terms_of_service_panel);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar About = {\n\t components: {\n\t InstanceSpecificPanel: _instance_specific_panel2.default,\n\t FeaturesPanel: _features_panel2.default,\n\t TermsOfServicePanel: _terms_of_service_panel2.default\n\t },\n\t computed: {\n\t showFeaturesPanel: function showFeaturesPanel() {\n\t return this.$store.state.instance.showFeaturesPanel;\n\t }\n\t }\n\t};\n\t\n\texports.default = About;\n\n/***/ }),\n/* 254 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _stillImage = __webpack_require__(127);\n\t\n\tvar _stillImage2 = _interopRequireDefault(_stillImage);\n\t\n\tvar _video_attachment = __webpack_require__(216);\n\t\n\tvar _video_attachment2 = _interopRequireDefault(_video_attachment);\n\t\n\tvar _nsfw = __webpack_require__(629);\n\t\n\tvar _nsfw2 = _interopRequireDefault(_nsfw);\n\t\n\tvar _file_typeService = __webpack_require__(45);\n\t\n\tvar _file_typeService2 = _interopRequireDefault(_file_typeService);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar Attachment = {\n\t props: ['attachment', 'nsfw', 'statusId', 'size', 'allowPlay', 'setMedia'],\n\t data: function data() {\n\t return {\n\t nsfwImage: this.$store.state.instance.nsfwCensorImage || _nsfw2.default,\n\t hideNsfwLocal: this.$store.state.config.hideNsfw,\n\t preloadImage: this.$store.state.config.preloadImage,\n\t loading: false,\n\t img: _file_typeService2.default.fileType(this.attachment.mimetype) === 'image' && document.createElement('img'),\n\t modalOpen: false,\n\t showHidden: false\n\t };\n\t },\n\t\n\t components: {\n\t StillImage: _stillImage2.default,\n\t VideoAttachment: _video_attachment2.default\n\t },\n\t computed: {\n\t usePlaceHolder: function usePlaceHolder() {\n\t return this.size === 'hide' || this.type === 'unknown';\n\t },\n\t referrerpolicy: function referrerpolicy() {\n\t return this.$store.state.instance.mediaProxyAvailable ? '' : 'no-referrer';\n\t },\n\t type: function type() {\n\t return _file_typeService2.default.fileType(this.attachment.mimetype);\n\t },\n\t hidden: function hidden() {\n\t return this.nsfw && this.hideNsfwLocal && !this.showHidden;\n\t },\n\t isEmpty: function isEmpty() {\n\t return this.type === 'html' && !this.attachment.oembed || this.type === 'unknown';\n\t },\n\t isSmall: function isSmall() {\n\t return this.size === 'small';\n\t },\n\t fullwidth: function fullwidth() {\n\t return this.type === 'html' || this.type === 'audio';\n\t }\n\t },\n\t methods: {\n\t linkClicked: function linkClicked(_ref) {\n\t var target = _ref.target;\n\t\n\t if (target.tagName === 'A') {\n\t window.open(target.href, '_blank');\n\t }\n\t },\n\t openModal: function openModal(event) {\n\t var modalTypes = this.$store.state.config.playVideosInModal ? ['image', 'video'] : ['image'];\n\t if (_file_typeService2.default.fileMatchesSomeType(modalTypes, this.attachment) || this.usePlaceHolder) {\n\t event.stopPropagation();\n\t event.preventDefault();\n\t this.setMedia();\n\t this.$store.dispatch('setCurrent', this.attachment);\n\t }\n\t },\n\t toggleHidden: function toggleHidden(event) {\n\t var _this = this;\n\t\n\t if (this.$store.state.config.useOneClickNsfw && !this.showHidden) {\n\t this.openModal(event);\n\t return;\n\t }\n\t if (this.img && !this.preloadImage) {\n\t if (this.img.onload) {\n\t this.img.onload();\n\t } else {\n\t this.loading = true;\n\t this.img.src = this.attachment.url;\n\t this.img.onload = function () {\n\t _this.loading = false;\n\t _this.showHidden = !_this.showHidden;\n\t };\n\t }\n\t } else {\n\t this.showHidden = !this.showHidden;\n\t }\n\t }\n\t }\n\t};\n\t\n\texports.default = Attachment;\n\n/***/ }),\n/* 255 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _user_card = __webpack_require__(43);\n\t\n\tvar _user_card2 = _interopRequireDefault(_user_card);\n\t\n\tvar _user_avatar = __webpack_require__(88);\n\t\n\tvar _user_avatar2 = _interopRequireDefault(_user_avatar);\n\t\n\tvar _user_profile_link_generator = __webpack_require__(35);\n\t\n\tvar _user_profile_link_generator2 = _interopRequireDefault(_user_profile_link_generator);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar BasicUserCard = {\n\t props: ['user'],\n\t data: function data() {\n\t return {\n\t userExpanded: false\n\t };\n\t },\n\t\n\t components: {\n\t UserCard: _user_card2.default,\n\t UserAvatar: _user_avatar2.default\n\t },\n\t methods: {\n\t toggleUserExpanded: function toggleUserExpanded() {\n\t this.userExpanded = !this.userExpanded;\n\t },\n\t userProfileLink: function userProfileLink(user) {\n\t return (0, _user_profile_link_generator2.default)(user.id, user.screen_name, this.$store.state.instance.restrictedNicknames);\n\t }\n\t }\n\t};\n\t\n\texports.default = BasicUserCard;\n\n/***/ }),\n/* 256 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _basic_user_card = __webpack_require__(86);\n\t\n\tvar _basic_user_card2 = _interopRequireDefault(_basic_user_card);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar BlockCard = {\n\t props: ['userId'],\n\t data: function data() {\n\t return {\n\t progress: false\n\t };\n\t },\n\t\n\t computed: {\n\t user: function user() {\n\t return this.$store.getters.userById(this.userId);\n\t },\n\t blocked: function blocked() {\n\t return this.user.statusnet_blocking;\n\t }\n\t },\n\t components: {\n\t BasicUserCard: _basic_user_card2.default\n\t },\n\t methods: {\n\t unblockUser: function unblockUser() {\n\t var _this = this;\n\t\n\t this.progress = true;\n\t this.$store.dispatch('unblockUser', this.user.id).then(function () {\n\t _this.progress = false;\n\t });\n\t },\n\t blockUser: function blockUser() {\n\t var _this2 = this;\n\t\n\t this.progress = true;\n\t this.$store.dispatch('blockUser', this.user.id).then(function () {\n\t _this2.progress = false;\n\t });\n\t }\n\t }\n\t};\n\t\n\texports.default = BlockCard;\n\n/***/ }),\n/* 257 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _user_profile_link_generator = __webpack_require__(35);\n\t\n\tvar _user_profile_link_generator2 = _interopRequireDefault(_user_profile_link_generator);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar chatPanel = {\n\t props: ['floating'],\n\t data: function data() {\n\t return {\n\t currentMessage: '',\n\t channel: null,\n\t collapsed: true\n\t };\n\t },\n\t\n\t computed: {\n\t messages: function messages() {\n\t return this.$store.state.chat.messages;\n\t }\n\t },\n\t methods: {\n\t submit: function submit(message) {\n\t this.$store.state.chat.channel.push('new_msg', { text: message }, 10000);\n\t this.currentMessage = '';\n\t },\n\t togglePanel: function togglePanel() {\n\t this.collapsed = !this.collapsed;\n\t },\n\t userProfileLink: function userProfileLink(user) {\n\t return (0, _user_profile_link_generator2.default)(user.id, user.username, this.$store.state.instance.restrictedNicknames);\n\t }\n\t }\n\t};\n\t\n\texports.default = chatPanel;\n\n/***/ }),\n/* 258 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _find2 = __webpack_require__(59);\n\t\n\tvar _find3 = _interopRequireDefault(_find2);\n\t\n\tvar _conversation = __webpack_require__(209);\n\t\n\tvar _conversation2 = _interopRequireDefault(_conversation);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar conversationPage = {\n\t components: {\n\t Conversation: _conversation2.default\n\t },\n\t computed: {\n\t statusoid: function statusoid() {\n\t var id = this.$route.params.id;\n\t var statuses = this.$store.state.statuses.allStatuses;\n\t var status = (0, _find3.default)(statuses, { id: id });\n\t\n\t return status;\n\t }\n\t }\n\t};\n\t\n\texports.default = conversationPage;\n\n/***/ }),\n/* 259 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _isNan = __webpack_require__(65);\n\t\n\tvar _isNan2 = _interopRequireDefault(_isNan);\n\t\n\tvar _filter2 = __webpack_require__(58);\n\t\n\tvar _filter3 = _interopRequireDefault(_filter2);\n\t\n\tvar _reduce2 = __webpack_require__(124);\n\t\n\tvar _reduce3 = _interopRequireDefault(_reduce2);\n\t\n\tvar _status = __webpack_require__(87);\n\t\n\tvar _status2 = _interopRequireDefault(_status);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar sortById = function sortById(a, b) {\n\t var seqA = Number(a.id);\n\t var seqB = Number(b.id);\n\t var isSeqA = !(0, _isNan2.default)(seqA);\n\t var isSeqB = !(0, _isNan2.default)(seqB);\n\t if (isSeqA && isSeqB) {\n\t return seqA < seqB ? -1 : 1;\n\t } else if (isSeqA && !isSeqB) {\n\t return -1;\n\t } else if (!isSeqA && isSeqB) {\n\t return 1;\n\t } else {\n\t return a.id < b.id ? -1 : 1;\n\t }\n\t};\n\t\n\tvar sortAndFilterConversation = function sortAndFilterConversation(conversation) {\n\t conversation = (0, _filter3.default)(conversation, function (status) {\n\t return status.type !== 'retweet';\n\t });\n\t return conversation.filter(function (_) {\n\t return _;\n\t }).sort(sortById);\n\t};\n\t\n\tvar conversation = {\n\t data: function data() {\n\t return {\n\t highlight: null\n\t };\n\t },\n\t\n\t props: ['statusoid', 'collapsable'],\n\t computed: {\n\t status: function status() {\n\t return this.statusoid;\n\t },\n\t statusId: function statusId() {\n\t if (this.statusoid.retweeted_status) {\n\t return this.statusoid.retweeted_status.id;\n\t } else {\n\t return this.statusoid.id;\n\t }\n\t },\n\t conversation: function conversation() {\n\t if (!this.status) {\n\t return [];\n\t }\n\t\n\t var conversationId = this.status.statusnet_conversation_id;\n\t var statuses = this.$store.state.statuses.allStatuses;\n\t var conversation = (0, _filter3.default)(statuses, { statusnet_conversation_id: conversationId });\n\t return sortAndFilterConversation(conversation);\n\t },\n\t replies: function replies() {\n\t var i = 1;\n\t return (0, _reduce3.default)(this.conversation, function (result, _ref) {\n\t var id = _ref.id,\n\t in_reply_to_status_id = _ref.in_reply_to_status_id;\n\t\n\t var irid = in_reply_to_status_id;\n\t\n\t if (irid) {\n\t result[irid] = result[irid] || [];\n\t result[irid].push({\n\t name: '#' + i,\n\t id: id\n\t });\n\t }\n\t i++;\n\t return result;\n\t }, {});\n\t }\n\t },\n\t components: {\n\t Status: _status2.default\n\t },\n\t created: function created() {\n\t this.fetchConversation();\n\t },\n\t\n\t watch: {\n\t '$route': 'fetchConversation'\n\t },\n\t methods: {\n\t fetchConversation: function fetchConversation() {\n\t var _this = this;\n\t\n\t if (this.status) {\n\t var conversationId = this.status.statusnet_conversation_id;\n\t this.$store.state.api.backendInteractor.fetchConversation({ id: conversationId }).then(function (statuses) {\n\t return _this.$store.dispatch('addNewStatuses', { statuses: statuses });\n\t }).then(function () {\n\t return _this.setHighlight(_this.statusId);\n\t });\n\t } else {\n\t var id = this.$route.params.id;\n\t this.$store.state.api.backendInteractor.fetchStatus({ id: id }).then(function (status) {\n\t return _this.$store.dispatch('addNewStatuses', { statuses: [status] });\n\t }).then(function () {\n\t return _this.fetchConversation();\n\t });\n\t }\n\t },\n\t getReplies: function getReplies(id) {\n\t return this.replies[id] || [];\n\t },\n\t focused: function focused(id) {\n\t return id === this.statusId;\n\t },\n\t setHighlight: function setHighlight(id) {\n\t this.highlight = id;\n\t }\n\t }\n\t};\n\t\n\texports.default = conversation;\n\n/***/ }),\n/* 260 */\n/***/ (function(module, exports) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\tvar DeleteButton = {\n\t props: ['status'],\n\t methods: {\n\t deleteStatus: function deleteStatus() {\n\t var confirmed = window.confirm('Do you really want to delete this status?');\n\t if (confirmed) {\n\t this.$store.dispatch('deleteStatus', { id: this.status.id });\n\t }\n\t }\n\t },\n\t computed: {\n\t currentUser: function currentUser() {\n\t return this.$store.state.users.currentUser;\n\t },\n\t canDelete: function canDelete() {\n\t return this.currentUser && this.currentUser.rights.delete_others_notice || this.status.user.id === this.currentUser.id;\n\t }\n\t }\n\t};\n\t\n\texports.default = DeleteButton;\n\n/***/ }),\n/* 261 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _timeline = __webpack_require__(34);\n\t\n\tvar _timeline2 = _interopRequireDefault(_timeline);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar DMs = {\n\t computed: {\n\t timeline: function timeline() {\n\t return this.$store.state.statuses.timelines.dms;\n\t }\n\t },\n\t components: {\n\t Timeline: _timeline2.default\n\t }\n\t};\n\t\n\texports.default = DMs;\n\n/***/ }),\n/* 262 */\n/***/ (function(module, exports) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\tvar FavoriteButton = {\n\t props: ['status', 'loggedIn'],\n\t data: function data() {\n\t return {\n\t hidePostStatsLocal: typeof this.$store.state.config.hidePostStats === 'undefined' ? this.$store.state.instance.hidePostStats : this.$store.state.config.hidePostStats,\n\t animated: false\n\t };\n\t },\n\t\n\t methods: {\n\t favorite: function favorite() {\n\t var _this = this;\n\t\n\t if (!this.status.favorited) {\n\t this.$store.dispatch('favorite', { id: this.status.id });\n\t } else {\n\t this.$store.dispatch('unfavorite', { id: this.status.id });\n\t }\n\t this.animated = true;\n\t setTimeout(function () {\n\t _this.animated = false;\n\t }, 500);\n\t }\n\t },\n\t computed: {\n\t classes: function classes() {\n\t return {\n\t 'icon-star-empty': !this.status.favorited,\n\t 'icon-star': this.status.favorited,\n\t 'animate-spin': this.animated\n\t };\n\t }\n\t }\n\t};\n\t\n\texports.default = FavoriteButton;\n\n/***/ }),\n/* 263 */\n/***/ (function(module, exports) {\n\n\t\"use strict\";\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\tvar FeaturesPanel = {\n\t computed: {\n\t chat: function chat() {\n\t return this.$store.state.instance.chatAvailable && !this.$store.state.chatDisabled;\n\t },\n\t gopher: function gopher() {\n\t return this.$store.state.instance.gopherAvailable;\n\t },\n\t whoToFollow: function whoToFollow() {\n\t return this.$store.state.instance.suggestionsEnabled;\n\t },\n\t mediaProxy: function mediaProxy() {\n\t return this.$store.state.instance.mediaProxyAvailable;\n\t },\n\t scopeOptions: function scopeOptions() {\n\t return this.$store.state.instance.scopeOptionsEnabled;\n\t },\n\t textlimit: function textlimit() {\n\t return this.$store.state.instance.textlimit;\n\t }\n\t }\n\t};\n\t\n\texports.default = FeaturesPanel;\n\n/***/ }),\n/* 264 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _basic_user_card = __webpack_require__(86);\n\t\n\tvar _basic_user_card2 = _interopRequireDefault(_basic_user_card);\n\t\n\tvar _follow_manipulate = __webpack_require__(134);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar FollowCard = {\n\t props: ['user', 'noFollowsYou'],\n\t data: function data() {\n\t return {\n\t inProgress: false,\n\t requestSent: false,\n\t updated: false\n\t };\n\t },\n\t\n\t components: {\n\t BasicUserCard: _basic_user_card2.default\n\t },\n\t computed: {\n\t isMe: function isMe() {\n\t return this.$store.state.users.currentUser.id === this.user.id;\n\t },\n\t following: function following() {\n\t return this.updated ? this.updated.following : this.user.following;\n\t },\n\t showFollow: function showFollow() {\n\t return !this.following || this.updated && !this.updated.following;\n\t }\n\t },\n\t methods: {\n\t followUser: function followUser() {\n\t var _this = this;\n\t\n\t this.inProgress = true;\n\t (0, _follow_manipulate.requestFollow)(this.user, this.$store).then(function (_ref) {\n\t var sent = _ref.sent,\n\t updated = _ref.updated;\n\t\n\t _this.inProgress = false;\n\t _this.requestSent = sent;\n\t _this.updated = updated;\n\t });\n\t },\n\t unfollowUser: function unfollowUser() {\n\t var _this2 = this;\n\t\n\t this.inProgress = true;\n\t (0, _follow_manipulate.requestUnfollow)(this.user, this.$store).then(function (_ref2) {\n\t var updated = _ref2.updated;\n\t\n\t _this2.inProgress = false;\n\t _this2.updated = updated;\n\t });\n\t }\n\t }\n\t};\n\t\n\texports.default = FollowCard;\n\n/***/ }),\n/* 265 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _basic_user_card = __webpack_require__(86);\n\t\n\tvar _basic_user_card2 = _interopRequireDefault(_basic_user_card);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar FollowRequestCard = {\n\t props: ['user'],\n\t components: {\n\t BasicUserCard: _basic_user_card2.default\n\t },\n\t methods: {\n\t approveUser: function approveUser() {\n\t this.$store.state.api.backendInteractor.approveUser(this.user.id);\n\t this.$store.dispatch('removeFollowRequest', this.user);\n\t },\n\t denyUser: function denyUser() {\n\t this.$store.state.api.backendInteractor.denyUser(this.user.id);\n\t this.$store.dispatch('removeFollowRequest', this.user);\n\t }\n\t }\n\t};\n\t\n\texports.default = FollowRequestCard;\n\n/***/ }),\n/* 266 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _follow_request_card = __webpack_require__(642);\n\t\n\tvar _follow_request_card2 = _interopRequireDefault(_follow_request_card);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar FollowRequests = {\n\t components: {\n\t FollowRequestCard: _follow_request_card2.default\n\t },\n\t computed: {\n\t requests: function requests() {\n\t return this.$store.state.api.followRequests;\n\t }\n\t }\n\t};\n\t\n\texports.default = FollowRequests;\n\n/***/ }),\n/* 267 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _toConsumableArray2 = __webpack_require__(26);\n\t\n\tvar _toConsumableArray3 = _interopRequireDefault(_toConsumableArray2);\n\t\n\tvar _vue = __webpack_require__(8);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\texports.default = {\n\t props: ['name', 'label', 'value', 'fallback', 'options', 'no-inherit'],\n\t data: function data() {\n\t return {\n\t lValue: this.value,\n\t availableOptions: [this.noInherit ? '' : 'inherit', 'custom'].concat((0, _toConsumableArray3.default)(this.options || []), ['serif', 'monospace', 'sans-serif']).filter(function (_) {\n\t return _;\n\t })\n\t };\n\t },\n\t beforeUpdate: function beforeUpdate() {\n\t this.lValue = this.value;\n\t },\n\t\n\t computed: {\n\t present: function present() {\n\t return typeof this.lValue !== 'undefined';\n\t },\n\t dValue: function dValue() {\n\t return this.lValue || this.fallback || {};\n\t },\n\t\n\t family: {\n\t get: function get() {\n\t return this.dValue.family;\n\t },\n\t set: function set(v) {\n\t (0, _vue.set)(this.lValue, 'family', v);\n\t this.$emit('input', this.lValue);\n\t }\n\t },\n\t isCustom: function isCustom() {\n\t return this.preset === 'custom';\n\t },\n\t\n\t preset: {\n\t get: function get() {\n\t if (this.family === 'serif' || this.family === 'sans-serif' || this.family === 'monospace' || this.family === 'inherit') {\n\t return this.family;\n\t } else {\n\t return 'custom';\n\t }\n\t },\n\t set: function set(v) {\n\t this.family = v === 'custom' ? '' : v;\n\t }\n\t }\n\t }\n\t};\n\n/***/ }),\n/* 268 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _timeline = __webpack_require__(34);\n\t\n\tvar _timeline2 = _interopRequireDefault(_timeline);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar FriendsTimeline = {\n\t components: {\n\t Timeline: _timeline2.default\n\t },\n\t computed: {\n\t timeline: function timeline() {\n\t return this.$store.state.statuses.timelines.friends;\n\t }\n\t }\n\t};\n\t\n\texports.default = FriendsTimeline;\n\n/***/ }),\n/* 269 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _dropRight2 = __webpack_require__(591);\n\t\n\tvar _dropRight3 = _interopRequireDefault(_dropRight2);\n\t\n\tvar _last2 = __webpack_require__(123);\n\t\n\tvar _last3 = _interopRequireDefault(_last2);\n\t\n\tvar _chunk2 = __webpack_require__(586);\n\t\n\tvar _chunk3 = _interopRequireDefault(_chunk2);\n\t\n\tvar _attachment = __webpack_require__(206);\n\t\n\tvar _attachment2 = _interopRequireDefault(_attachment);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar Gallery = {\n\t data: function data() {\n\t return {\n\t width: 500\n\t };\n\t },\n\t props: ['attachments', 'nsfw', 'setMedia'],\n\t components: { Attachment: _attachment2.default },\n\t mounted: function mounted() {\n\t this.resize();\n\t window.addEventListener('resize', this.resize);\n\t },\n\t destroyed: function destroyed() {\n\t window.removeEventListener('resize', this.resize);\n\t },\n\t\n\t computed: {\n\t rows: function rows() {\n\t if (!this.attachments) {\n\t return [];\n\t }\n\t var rows = (0, _chunk3.default)(this.attachments, 3);\n\t if ((0, _last3.default)(rows).length === 1 && rows.length > 1) {\n\t var lastAttachment = (0, _last3.default)(rows)[0];\n\t var allButLastRow = (0, _dropRight3.default)(rows);\n\t (0, _last3.default)(allButLastRow).push(lastAttachment);\n\t return allButLastRow;\n\t }\n\t return rows;\n\t },\n\t rowHeight: function rowHeight() {\n\t var _this = this;\n\t\n\t return function (itemsPerRow) {\n\t return { 'height': _this.width / (itemsPerRow + 0.6) + 'px' };\n\t };\n\t },\n\t useContainFit: function useContainFit() {\n\t return this.$store.state.config.useContainFit;\n\t }\n\t },\n\t methods: {\n\t resize: function resize() {\n\t var width = Math.floor(this.$el.getBoundingClientRect().width / 10) * 10;\n\t if (this.width !== width) {\n\t this.width = width;\n\t }\n\t }\n\t }\n\t};\n\t\n\texports.default = Gallery;\n\n/***/ }),\n/* 270 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _typeof2 = __webpack_require__(66);\n\t\n\tvar _typeof3 = _interopRequireDefault(_typeof2);\n\t\n\tvar _cropperjs = __webpack_require__(381);\n\t\n\tvar _cropperjs2 = _interopRequireDefault(_cropperjs);\n\t\n\t__webpack_require__(382);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar ImageCropper = {\n\t props: {\n\t trigger: {\n\t type: [String, window.Element],\n\t required: true\n\t },\n\t submitHandler: {\n\t type: Function,\n\t required: true\n\t },\n\t cropperOptions: {\n\t type: Object,\n\t default: function _default() {\n\t return {\n\t aspectRatio: 1,\n\t autoCropArea: 1,\n\t viewMode: 1,\n\t movable: false,\n\t zoomable: false,\n\t guides: false\n\t };\n\t }\n\t },\n\t mimes: {\n\t type: String,\n\t default: 'image/png, image/gif, image/jpeg, image/bmp, image/x-icon'\n\t },\n\t saveButtonLabel: {\n\t type: String\n\t },\n\t cancelButtonLabel: {\n\t type: String\n\t }\n\t },\n\t data: function data() {\n\t return {\n\t cropper: undefined,\n\t dataUrl: undefined,\n\t filename: undefined,\n\t submitting: false,\n\t submitError: null\n\t };\n\t },\n\t\n\t computed: {\n\t saveText: function saveText() {\n\t return this.saveButtonLabel || this.$t('image_cropper.save');\n\t },\n\t cancelText: function cancelText() {\n\t return this.cancelButtonLabel || this.$t('image_cropper.cancel');\n\t },\n\t submitErrorMsg: function submitErrorMsg() {\n\t return this.submitError && this.submitError instanceof Error ? this.submitError.toString() : this.submitError;\n\t }\n\t },\n\t methods: {\n\t destroy: function destroy() {\n\t if (this.cropper) {\n\t this.cropper.destroy();\n\t }\n\t this.$refs.input.value = '';\n\t this.dataUrl = undefined;\n\t this.$emit('close');\n\t },\n\t submit: function submit() {\n\t var _this = this;\n\t\n\t this.submitting = true;\n\t this.avatarUploadError = null;\n\t this.submitHandler(this.cropper, this.file).then(function () {\n\t return _this.destroy();\n\t }).catch(function (err) {\n\t _this.submitError = err;\n\t }).finally(function () {\n\t _this.submitting = false;\n\t });\n\t },\n\t pickImage: function pickImage() {\n\t this.$refs.input.click();\n\t },\n\t createCropper: function createCropper() {\n\t this.cropper = new _cropperjs2.default(this.$refs.img, this.cropperOptions);\n\t },\n\t getTriggerDOM: function getTriggerDOM() {\n\t return (0, _typeof3.default)(this.trigger) === 'object' ? this.trigger : document.querySelector(this.trigger);\n\t },\n\t readFile: function readFile() {\n\t var _this2 = this;\n\t\n\t var fileInput = this.$refs.input;\n\t if (fileInput.files != null && fileInput.files[0] != null) {\n\t this.file = fileInput.files[0];\n\t var reader = new window.FileReader();\n\t reader.onload = function (e) {\n\t _this2.dataUrl = e.target.result;\n\t _this2.$emit('open');\n\t };\n\t reader.readAsDataURL(this.file);\n\t this.$emit('changed', this.file, reader);\n\t }\n\t },\n\t clearError: function clearError() {\n\t this.submitError = null;\n\t }\n\t },\n\t mounted: function mounted() {\n\t var trigger = this.getTriggerDOM();\n\t if (!trigger) {\n\t this.$emit('error', 'No image make trigger found.', 'user');\n\t } else {\n\t trigger.addEventListener('click', this.pickImage);\n\t }\n\t\n\t var fileInput = this.$refs.input;\n\t fileInput.addEventListener('change', this.readFile);\n\t },\n\t\n\t beforeDestroy: function beforeDestroy() {\n\t var trigger = this.getTriggerDOM();\n\t if (trigger) {\n\t trigger.removeEventListener('click', this.pickImage);\n\t }\n\t var fileInput = this.$refs.input;\n\t fileInput.removeEventListener('change', this.readFile);\n\t }\n\t};\n\t\n\texports.default = ImageCropper;\n\n/***/ }),\n/* 271 */\n/***/ (function(module, exports) {\n\n\t\"use strict\";\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\tvar InstanceSpecificPanel = {\n\t computed: {\n\t instanceSpecificPanelContent: function instanceSpecificPanelContent() {\n\t return this.$store.state.instance.instanceSpecificPanelContent;\n\t },\n\t show: function show() {\n\t return !this.$store.state.config.hideISP;\n\t }\n\t }\n\t};\n\t\n\texports.default = InstanceSpecificPanel;\n\n/***/ }),\n/* 272 */\n/***/ (function(module, exports) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\tvar LinkPreview = {\n\t name: 'LinkPreview',\n\t props: ['card', 'size', 'nsfw'],\n\t computed: {\n\t useImage: function useImage() {\n\t return this.card.image && !this.nsfw && this.size !== 'hide';\n\t },\n\t useDescription: function useDescription() {\n\t return this.card.description && /\\S/.test(this.card.description);\n\t }\n\t }\n\t};\n\t\n\texports.default = LinkPreview;\n\n/***/ }),\n/* 273 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _oauth = __webpack_require__(90);\n\t\n\tvar _oauth2 = _interopRequireDefault(_oauth);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar LoginForm = {\n\t data: function data() {\n\t return {\n\t user: {},\n\t authError: false\n\t };\n\t },\n\t computed: {\n\t loginMethod: function loginMethod() {\n\t return this.$store.state.instance.loginMethod;\n\t },\n\t loggingIn: function loggingIn() {\n\t return this.$store.state.users.loggingIn;\n\t },\n\t registrationOpen: function registrationOpen() {\n\t return this.$store.state.instance.registrationOpen;\n\t }\n\t },\n\t methods: {\n\t oAuthLogin: function oAuthLogin() {\n\t _oauth2.default.login({\n\t oauth: this.$store.state.oauth,\n\t instance: this.$store.state.instance.server,\n\t commit: this.$store.commit\n\t });\n\t },\n\t submit: function submit() {\n\t var _this = this;\n\t\n\t var data = {\n\t oauth: this.$store.state.oauth,\n\t instance: this.$store.state.instance.server\n\t };\n\t this.clearError();\n\t _oauth2.default.getOrCreateApp(data).then(function (app) {\n\t _oauth2.default.getTokenWithCredentials({\n\t app: app,\n\t instance: data.instance,\n\t username: _this.user.username,\n\t password: _this.user.password\n\t }).then(function (result) {\n\t if (result.error) {\n\t _this.authError = result.error;\n\t _this.user.password = '';\n\t return;\n\t }\n\t _this.$store.commit('setToken', result.access_token);\n\t _this.$store.dispatch('loginUser', result.access_token);\n\t _this.$router.push({ name: 'friends' });\n\t });\n\t });\n\t },\n\t clearError: function clearError() {\n\t this.authError = false;\n\t }\n\t }\n\t};\n\t\n\texports.default = LoginForm;\n\n/***/ }),\n/* 274 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _stillImage = __webpack_require__(127);\n\t\n\tvar _stillImage2 = _interopRequireDefault(_stillImage);\n\t\n\tvar _video_attachment = __webpack_require__(216);\n\t\n\tvar _video_attachment2 = _interopRequireDefault(_video_attachment);\n\t\n\tvar _file_typeService = __webpack_require__(45);\n\t\n\tvar _file_typeService2 = _interopRequireDefault(_file_typeService);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar MediaModal = {\n\t components: {\n\t StillImage: _stillImage2.default,\n\t VideoAttachment: _video_attachment2.default\n\t },\n\t computed: {\n\t showing: function showing() {\n\t return this.$store.state.mediaViewer.activated;\n\t },\n\t media: function media() {\n\t return this.$store.state.mediaViewer.media;\n\t },\n\t currentIndex: function currentIndex() {\n\t return this.$store.state.mediaViewer.currentIndex;\n\t },\n\t currentMedia: function currentMedia() {\n\t return this.media[this.currentIndex];\n\t },\n\t canNavigate: function canNavigate() {\n\t return this.media.length > 1;\n\t },\n\t type: function type() {\n\t return this.currentMedia ? _file_typeService2.default.fileType(this.currentMedia.mimetype) : null;\n\t }\n\t },\n\t methods: {\n\t hide: function hide() {\n\t this.$store.dispatch('closeMediaViewer');\n\t },\n\t goPrev: function goPrev() {\n\t if (this.canNavigate) {\n\t var prevIndex = this.currentIndex === 0 ? this.media.length - 1 : this.currentIndex - 1;\n\t this.$store.dispatch('setCurrent', this.media[prevIndex]);\n\t }\n\t },\n\t goNext: function goNext() {\n\t if (this.canNavigate) {\n\t var nextIndex = this.currentIndex === this.media.length - 1 ? 0 : this.currentIndex + 1;\n\t this.$store.dispatch('setCurrent', this.media[nextIndex]);\n\t }\n\t },\n\t handleKeyupEvent: function handleKeyupEvent(e) {\n\t if (this.showing && e.keyCode === 27) {\n\t this.hide();\n\t }\n\t },\n\t handleKeydownEvent: function handleKeydownEvent(e) {\n\t if (!this.showing) {\n\t return;\n\t }\n\t\n\t if (e.keyCode === 39) {\n\t this.goNext();\n\t } else if (e.keyCode === 37) {\n\t this.goPrev();\n\t }\n\t }\n\t },\n\t mounted: function mounted() {\n\t document.addEventListener('keyup', this.handleKeyupEvent);\n\t document.addEventListener('keydown', this.handleKeydownEvent);\n\t },\n\t destroyed: function destroyed() {\n\t document.removeEventListener('keyup', this.handleKeyupEvent);\n\t document.removeEventListener('keydown', this.handleKeydownEvent);\n\t }\n\t};\n\t\n\texports.default = MediaModal;\n\n/***/ }),\n/* 275 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _status_posterService = __webpack_require__(135);\n\t\n\tvar _status_posterService2 = _interopRequireDefault(_status_posterService);\n\t\n\tvar _file_size_format = __webpack_require__(133);\n\t\n\tvar _file_size_format2 = _interopRequireDefault(_file_size_format);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar mediaUpload = {\n\t data: function data() {\n\t return {\n\t uploading: false,\n\t uploadReady: true\n\t };\n\t },\n\t\n\t methods: {\n\t uploadFile: function uploadFile(file) {\n\t var self = this;\n\t var store = this.$store;\n\t if (file.size > store.state.instance.uploadlimit) {\n\t var filesize = _file_size_format2.default.fileSizeFormat(file.size);\n\t var allowedsize = _file_size_format2.default.fileSizeFormat(store.state.instance.uploadlimit);\n\t self.$emit('upload-failed', 'file_too_big', { filesize: filesize.num, filesizeunit: filesize.unit, allowedsize: allowedsize.num, allowedsizeunit: allowedsize.unit });\n\t return;\n\t }\n\t var formData = new FormData();\n\t formData.append('media', file);\n\t\n\t self.$emit('uploading');\n\t self.uploading = true;\n\t\n\t _status_posterService2.default.uploadMedia({ store: store, formData: formData }).then(function (fileData) {\n\t self.$emit('uploaded', fileData);\n\t self.uploading = false;\n\t }, function (error) {\n\t self.$emit('upload-failed', 'default');\n\t self.uploading = false;\n\t });\n\t },\n\t fileDrop: function fileDrop(e) {\n\t if (e.dataTransfer.files.length > 0) {\n\t e.preventDefault();\n\t this.uploadFile(e.dataTransfer.files[0]);\n\t }\n\t },\n\t fileDrag: function fileDrag(e) {\n\t var types = e.dataTransfer.types;\n\t if (types.contains('Files')) {\n\t e.dataTransfer.dropEffect = 'copy';\n\t } else {\n\t e.dataTransfer.dropEffect = 'none';\n\t }\n\t },\n\t clearFile: function clearFile() {\n\t var _this = this;\n\t\n\t this.uploadReady = false;\n\t this.$nextTick(function () {\n\t _this.uploadReady = true;\n\t });\n\t },\n\t change: function change(_ref) {\n\t var target = _ref.target;\n\t\n\t for (var i = 0; i < target.files.length; i++) {\n\t var file = target.files[i];\n\t this.uploadFile(file);\n\t }\n\t }\n\t },\n\t props: ['dropFiles'],\n\t watch: {\n\t 'dropFiles': function dropFiles(fileInfos) {\n\t if (!this.uploading) {\n\t this.uploadFile(fileInfos[0]);\n\t }\n\t }\n\t }\n\t};\n\t\n\texports.default = mediaUpload;\n\n/***/ }),\n/* 276 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _timeline = __webpack_require__(34);\n\t\n\tvar _timeline2 = _interopRequireDefault(_timeline);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar Mentions = {\n\t computed: {\n\t timeline: function timeline() {\n\t return this.$store.state.statuses.timelines.mentions;\n\t }\n\t },\n\t components: {\n\t Timeline: _timeline2.default\n\t }\n\t};\n\t\n\texports.default = Mentions;\n\n/***/ }),\n/* 277 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _throttle2 = __webpack_require__(201);\n\t\n\tvar _throttle3 = _interopRequireDefault(_throttle2);\n\t\n\tvar _post_status_form = __webpack_require__(126);\n\t\n\tvar _post_status_form2 = _interopRequireDefault(_post_status_form);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar MobilePostStatusModal = {\n\t components: {\n\t PostStatusForm: _post_status_form2.default\n\t },\n\t data: function data() {\n\t return {\n\t hidden: false,\n\t postFormOpen: false,\n\t scrollingDown: false,\n\t inputActive: false,\n\t oldScrollPos: 0,\n\t amountScrolled: 0\n\t };\n\t },\n\t created: function created() {\n\t window.addEventListener('scroll', this.handleScroll);\n\t window.addEventListener('resize', this.handleOSK);\n\t },\n\t destroyed: function destroyed() {\n\t window.removeEventListener('scroll', this.handleScroll);\n\t window.removeEventListener('resize', this.handleOSK);\n\t },\n\t\n\t computed: {\n\t currentUser: function currentUser() {\n\t return this.$store.state.users.currentUser;\n\t },\n\t isHidden: function isHidden() {\n\t return this.hidden || this.inputActive;\n\t }\n\t },\n\t methods: {\n\t openPostForm: function openPostForm() {\n\t this.postFormOpen = true;\n\t this.hidden = true;\n\t\n\t var el = this.$el.querySelector('textarea');\n\t this.$nextTick(function () {\n\t el.focus();\n\t });\n\t },\n\t closePostForm: function closePostForm() {\n\t this.postFormOpen = false;\n\t this.hidden = false;\n\t },\n\t handleOSK: function handleOSK() {\n\t var smallPhone = window.innerWidth < 350;\n\t var smallPhoneKbOpen = smallPhone && window.innerHeight < 345;\n\t\n\t var biggerPhone = !smallPhone && window.innerWidth < 450;\n\t var biggerPhoneKbOpen = biggerPhone && window.innerHeight < 560;\n\t if (smallPhoneKbOpen || biggerPhoneKbOpen) {\n\t this.inputActive = true;\n\t } else {\n\t this.inputActive = false;\n\t }\n\t },\n\t\n\t handleScroll: (0, _throttle3.default)(function () {\n\t var scrollAmount = window.scrollY - this.oldScrollPos;\n\t var scrollingDown = scrollAmount > 0;\n\t\n\t if (scrollingDown !== this.scrollingDown) {\n\t this.amountScrolled = 0;\n\t this.scrollingDown = scrollingDown;\n\t if (!scrollingDown) {\n\t this.hidden = false;\n\t }\n\t } else if (scrollingDown) {\n\t this.amountScrolled += scrollAmount;\n\t if (this.amountScrolled > 100 && !this.hidden) {\n\t this.hidden = true;\n\t }\n\t }\n\t\n\t this.oldScrollPos = window.scrollY;\n\t this.scrollingDown = scrollingDown;\n\t }, 100)\n\t }\n\t};\n\t\n\texports.default = MobilePostStatusModal;\n\n/***/ }),\n/* 278 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _basic_user_card = __webpack_require__(86);\n\t\n\tvar _basic_user_card2 = _interopRequireDefault(_basic_user_card);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar MuteCard = {\n\t props: ['userId'],\n\t data: function data() {\n\t return {\n\t progress: false\n\t };\n\t },\n\t\n\t computed: {\n\t user: function user() {\n\t return this.$store.getters.userById(this.userId);\n\t },\n\t muted: function muted() {\n\t return this.user.muted;\n\t }\n\t },\n\t components: {\n\t BasicUserCard: _basic_user_card2.default\n\t },\n\t methods: {\n\t unmuteUser: function unmuteUser() {\n\t var _this = this;\n\t\n\t this.progress = true;\n\t this.$store.dispatch('unmuteUser', this.user.id).then(function () {\n\t _this.progress = false;\n\t });\n\t },\n\t muteUser: function muteUser() {\n\t var _this2 = this;\n\t\n\t this.progress = true;\n\t this.$store.dispatch('muteUser', this.user.id).then(function () {\n\t _this2.progress = false;\n\t });\n\t }\n\t }\n\t};\n\t\n\texports.default = MuteCard;\n\n/***/ }),\n/* 279 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _follow_request_fetcher = __webpack_require__(240);\n\t\n\tvar _follow_request_fetcher2 = _interopRequireDefault(_follow_request_fetcher);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar NavPanel = {\n\t created: function created() {\n\t if (this.currentUser && this.currentUser.locked) {\n\t var store = this.$store;\n\t var credentials = store.state.users.currentUser.credentials;\n\t\n\t _follow_request_fetcher2.default.startFetching({ store: store, credentials: credentials });\n\t }\n\t },\n\t\n\t computed: {\n\t currentUser: function currentUser() {\n\t return this.$store.state.users.currentUser;\n\t },\n\t chat: function chat() {\n\t return this.$store.state.chat.channel;\n\t },\n\t followRequestCount: function followRequestCount() {\n\t return this.$store.state.api.followRequests.length;\n\t }\n\t }\n\t};\n\t\n\texports.default = NavPanel;\n\n/***/ }),\n/* 280 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _status = __webpack_require__(87);\n\t\n\tvar _status2 = _interopRequireDefault(_status);\n\t\n\tvar _user_avatar = __webpack_require__(88);\n\t\n\tvar _user_avatar2 = _interopRequireDefault(_user_avatar);\n\t\n\tvar _user_card = __webpack_require__(43);\n\t\n\tvar _user_card2 = _interopRequireDefault(_user_card);\n\t\n\tvar _user_highlighter = __webpack_require__(137);\n\t\n\tvar _user_profile_link_generator = __webpack_require__(35);\n\t\n\tvar _user_profile_link_generator2 = _interopRequireDefault(_user_profile_link_generator);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar Notification = {\n\t data: function data() {\n\t return {\n\t userExpanded: false,\n\t betterShadow: this.$store.state.interface.browserSupport.cssFilter\n\t };\n\t },\n\t\n\t props: ['notification'],\n\t components: {\n\t Status: _status2.default, UserAvatar: _user_avatar2.default, UserCard: _user_card2.default\n\t },\n\t methods: {\n\t toggleUserExpanded: function toggleUserExpanded() {\n\t this.userExpanded = !this.userExpanded;\n\t },\n\t userProfileLink: function userProfileLink(user) {\n\t return (0, _user_profile_link_generator2.default)(user.id, user.screen_name, this.$store.state.instance.restrictedNicknames);\n\t }\n\t },\n\t computed: {\n\t userClass: function userClass() {\n\t return (0, _user_highlighter.highlightClass)(this.notification.action.user);\n\t },\n\t userStyle: function userStyle() {\n\t var highlight = this.$store.state.config.highlight;\n\t var user = this.notification.action.user;\n\t return (0, _user_highlighter.highlightStyle)(highlight[user.screen_name]);\n\t }\n\t }\n\t};\n\t\n\texports.default = Notification;\n\n/***/ }),\n/* 281 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _notification = __webpack_require__(656);\n\t\n\tvar _notification2 = _interopRequireDefault(_notification);\n\t\n\tvar _notifications_fetcherService = __webpack_require__(244);\n\t\n\tvar _notifications_fetcherService2 = _interopRequireDefault(_notifications_fetcherService);\n\t\n\tvar _notification_utils = __webpack_require__(91);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar Notifications = {\n\t created: function created() {\n\t var store = this.$store;\n\t var credentials = store.state.users.currentUser.credentials;\n\t\n\t var fetcherId = _notifications_fetcherService2.default.startFetching({ store: store, credentials: credentials });\n\t this.$store.commit('setNotificationFetcher', { fetcherId: fetcherId });\n\t },\n\t data: function data() {\n\t return {\n\t bottomedOut: false\n\t };\n\t },\n\t\n\t computed: {\n\t notifications: function notifications() {\n\t return (0, _notification_utils.notificationsFromStore)(this.$store);\n\t },\n\t error: function error() {\n\t return this.$store.state.statuses.notifications.error;\n\t },\n\t unseenNotifications: function unseenNotifications() {\n\t return (0, _notification_utils.unseenNotificationsFromStore)(this.$store);\n\t },\n\t visibleNotifications: function visibleNotifications() {\n\t return (0, _notification_utils.visibleNotificationsFromStore)(this.$store);\n\t },\n\t unseenCount: function unseenCount() {\n\t return this.unseenNotifications.length;\n\t },\n\t loading: function loading() {\n\t return this.$store.state.statuses.notifications.loading;\n\t }\n\t },\n\t components: {\n\t Notification: _notification2.default\n\t },\n\t watch: {\n\t unseenCount: function unseenCount(count) {\n\t if (count > 0) {\n\t this.$store.dispatch('setPageTitle', '(' + count + ')');\n\t } else {\n\t this.$store.dispatch('setPageTitle', '');\n\t }\n\t }\n\t },\n\t methods: {\n\t markAsSeen: function markAsSeen() {\n\t this.$store.dispatch('markNotificationsAsSeen', this.visibleNotifications);\n\t },\n\t fetchOlderNotifications: function fetchOlderNotifications() {\n\t var _this = this;\n\t\n\t var store = this.$store;\n\t var credentials = store.state.users.currentUser.credentials;\n\t store.commit('setNotificationsLoading', { value: true });\n\t _notifications_fetcherService2.default.fetchAndUpdate({\n\t store: store,\n\t credentials: credentials,\n\t older: true\n\t }).then(function (notifs) {\n\t store.commit('setNotificationsLoading', { value: false });\n\t if (notifs.length === 0) {\n\t _this.bottomedOut = true;\n\t }\n\t });\n\t }\n\t }\n\t};\n\t\n\texports.default = Notifications;\n\n/***/ }),\n/* 282 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _oauth = __webpack_require__(90);\n\t\n\tvar _oauth2 = _interopRequireDefault(_oauth);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar oac = {\n\t props: ['code'],\n\t mounted: function mounted() {\n\t var _this = this;\n\t\n\t if (this.code) {\n\t _oauth2.default.getToken({\n\t app: this.$store.state.oauth,\n\t instance: this.$store.state.instance.server,\n\t code: this.code\n\t }).then(function (result) {\n\t _this.$store.commit('setToken', result.access_token);\n\t _this.$store.dispatch('loginUser', result.access_token);\n\t _this.$router.push({ name: 'friends' });\n\t });\n\t }\n\t }\n\t};\n\t\n\texports.default = oac;\n\n/***/ }),\n/* 283 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _toConsumableArray2 = __webpack_require__(26);\n\t\n\tvar _toConsumableArray3 = _interopRequireDefault(_toConsumableArray2);\n\t\n\tvar _uniqBy2 = __webpack_require__(620);\n\t\n\tvar _uniqBy3 = _interopRequireDefault(_uniqBy2);\n\t\n\tvar _map2 = __webpack_require__(31);\n\t\n\tvar _map3 = _interopRequireDefault(_map2);\n\t\n\tvar _reject2 = __webpack_require__(608);\n\t\n\tvar _reject3 = _interopRequireDefault(_reject2);\n\t\n\tvar _filter2 = __webpack_require__(58);\n\t\n\tvar _filter3 = _interopRequireDefault(_filter2);\n\t\n\tvar _take2 = __webpack_require__(615);\n\t\n\tvar _take3 = _interopRequireDefault(_take2);\n\t\n\tvar _status_posterService = __webpack_require__(135);\n\t\n\tvar _status_posterService2 = _interopRequireDefault(_status_posterService);\n\t\n\tvar _media_upload = __webpack_require__(651);\n\t\n\tvar _media_upload2 = _interopRequireDefault(_media_upload);\n\t\n\tvar _file_typeService = __webpack_require__(45);\n\t\n\tvar _file_typeService2 = _interopRequireDefault(_file_typeService);\n\t\n\tvar _completion = __webpack_require__(237);\n\t\n\tvar _completion2 = _interopRequireDefault(_completion);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar buildMentionsString = function buildMentionsString(_ref, currentUser) {\n\t var user = _ref.user,\n\t attentions = _ref.attentions;\n\t\n\t var allAttentions = [].concat((0, _toConsumableArray3.default)(attentions));\n\t\n\t allAttentions.unshift(user);\n\t\n\t allAttentions = (0, _uniqBy3.default)(allAttentions, 'id');\n\t allAttentions = (0, _reject3.default)(allAttentions, { id: currentUser.id });\n\t\n\t var mentions = (0, _map3.default)(allAttentions, function (attention) {\n\t return '@' + attention.screen_name;\n\t });\n\t\n\t return mentions.length > 0 ? mentions.join(' ') + ' ' : '';\n\t};\n\t\n\tvar PostStatusForm = {\n\t props: ['replyTo', 'repliedUser', 'attentions', 'copyMessageScope', 'subject'],\n\t components: {\n\t MediaUpload: _media_upload2.default\n\t },\n\t mounted: function mounted() {\n\t this.resize(this.$refs.textarea);\n\t var textLength = this.$refs.textarea.value.length;\n\t this.$refs.textarea.setSelectionRange(textLength, textLength);\n\t\n\t if (this.replyTo) {\n\t this.$refs.textarea.focus();\n\t }\n\t },\n\t data: function data() {\n\t var preset = this.$route.query.message;\n\t var statusText = preset || '';\n\t\n\t var scopeCopy = typeof this.$store.state.config.scopeCopy === 'undefined' ? this.$store.state.instance.scopeCopy : this.$store.state.config.scopeCopy;\n\t\n\t if (this.replyTo) {\n\t var currentUser = this.$store.state.users.currentUser;\n\t statusText = buildMentionsString({ user: this.repliedUser, attentions: this.attentions }, currentUser);\n\t }\n\t\n\t var scope = this.copyMessageScope && scopeCopy || this.copyMessageScope === 'direct' ? this.copyMessageScope : this.$store.state.users.currentUser.default_scope;\n\t\n\t var contentType = typeof this.$store.state.config.postContentType === 'undefined' ? this.$store.state.instance.postContentType : this.$store.state.config.postContentType;\n\t\n\t return {\n\t dropFiles: [],\n\t submitDisabled: false,\n\t error: null,\n\t posting: false,\n\t highlighted: 0,\n\t newStatus: {\n\t spoilerText: this.subject || '',\n\t status: statusText,\n\t nsfw: false,\n\t files: [],\n\t visibility: scope,\n\t contentType: contentType\n\t },\n\t caret: 0\n\t };\n\t },\n\t\n\t computed: {\n\t vis: function vis() {\n\t return {\n\t public: { selected: this.newStatus.visibility === 'public' },\n\t unlisted: { selected: this.newStatus.visibility === 'unlisted' },\n\t private: { selected: this.newStatus.visibility === 'private' },\n\t direct: { selected: this.newStatus.visibility === 'direct' }\n\t };\n\t },\n\t candidates: function candidates() {\n\t var _this = this;\n\t\n\t var firstchar = this.textAtCaret.charAt(0);\n\t if (firstchar === '@') {\n\t var query = this.textAtCaret.slice(1).toUpperCase();\n\t var matchedUsers = (0, _filter3.default)(this.users, function (user) {\n\t return user.screen_name.toUpperCase().startsWith(query) || user.name && user.name.toUpperCase().startsWith(query);\n\t });\n\t if (matchedUsers.length <= 0) {\n\t return false;\n\t }\n\t\n\t return (0, _map3.default)((0, _take3.default)(matchedUsers, 5), function (_ref2, index) {\n\t var screen_name = _ref2.screen_name,\n\t name = _ref2.name,\n\t profile_image_url_original = _ref2.profile_image_url_original;\n\t return {\n\t screen_name: '@' + screen_name,\n\t name: name,\n\t img: profile_image_url_original,\n\t highlighted: index === _this.highlighted\n\t };\n\t });\n\t } else if (firstchar === ':') {\n\t if (this.textAtCaret === ':') {\n\t return;\n\t }\n\t var matchedEmoji = (0, _filter3.default)(this.emoji.concat(this.customEmoji), function (emoji) {\n\t return emoji.shortcode.startsWith(_this.textAtCaret.slice(1));\n\t });\n\t if (matchedEmoji.length <= 0) {\n\t return false;\n\t }\n\t return (0, _map3.default)((0, _take3.default)(matchedEmoji, 5), function (_ref3, index) {\n\t var shortcode = _ref3.shortcode,\n\t image_url = _ref3.image_url,\n\t utf = _ref3.utf;\n\t return {\n\t screen_name: ':' + shortcode + ':',\n\t name: '',\n\t utf: utf || '',\n\t\n\t img: utf ? '' : _this.$store.state.instance.server + image_url,\n\t highlighted: index === _this.highlighted\n\t };\n\t });\n\t } else {\n\t return false;\n\t }\n\t },\n\t textAtCaret: function textAtCaret() {\n\t return (this.wordAtCaret || {}).word || '';\n\t },\n\t wordAtCaret: function wordAtCaret() {\n\t var word = _completion2.default.wordAtPosition(this.newStatus.status, this.caret - 1) || {};\n\t return word;\n\t },\n\t users: function users() {\n\t return this.$store.state.users.users;\n\t },\n\t emoji: function emoji() {\n\t return this.$store.state.instance.emoji || [];\n\t },\n\t customEmoji: function customEmoji() {\n\t return this.$store.state.instance.customEmoji || [];\n\t },\n\t statusLength: function statusLength() {\n\t return this.newStatus.status.length;\n\t },\n\t spoilerTextLength: function spoilerTextLength() {\n\t return this.newStatus.spoilerText.length;\n\t },\n\t statusLengthLimit: function statusLengthLimit() {\n\t return this.$store.state.instance.textlimit;\n\t },\n\t hasStatusLengthLimit: function hasStatusLengthLimit() {\n\t return this.statusLengthLimit > 0;\n\t },\n\t charactersLeft: function charactersLeft() {\n\t return this.statusLengthLimit - (this.statusLength + this.spoilerTextLength);\n\t },\n\t isOverLengthLimit: function isOverLengthLimit() {\n\t return this.hasStatusLengthLimit && this.charactersLeft < 0;\n\t },\n\t scopeOptionsEnabled: function scopeOptionsEnabled() {\n\t return this.$store.state.instance.scopeOptionsEnabled;\n\t },\n\t alwaysShowSubject: function alwaysShowSubject() {\n\t if (typeof this.$store.state.config.alwaysShowSubjectInput !== 'undefined') {\n\t return this.$store.state.config.alwaysShowSubjectInput;\n\t } else if (typeof this.$store.state.instance.alwaysShowSubjectInput !== 'undefined') {\n\t return this.$store.state.instance.alwaysShowSubjectInput;\n\t } else {\n\t return this.$store.state.instance.scopeOptionsEnabled;\n\t }\n\t },\n\t formattingOptionsEnabled: function formattingOptionsEnabled() {\n\t return this.$store.state.instance.formattingOptionsEnabled;\n\t },\n\t postFormats: function postFormats() {\n\t return this.$store.state.instance.postFormats || [];\n\t }\n\t },\n\t methods: {\n\t replace: function replace(replacement) {\n\t this.newStatus.status = _completion2.default.replaceWord(this.newStatus.status, this.wordAtCaret, replacement);\n\t var el = this.$el.querySelector('textarea');\n\t el.focus();\n\t this.caret = 0;\n\t },\n\t replaceCandidate: function replaceCandidate(e) {\n\t var len = this.candidates.length || 0;\n\t if (this.textAtCaret === ':' || e.ctrlKey) {\n\t return;\n\t }\n\t if (len > 0) {\n\t e.preventDefault();\n\t var candidate = this.candidates[this.highlighted];\n\t var replacement = candidate.utf || candidate.screen_name + ' ';\n\t this.newStatus.status = _completion2.default.replaceWord(this.newStatus.status, this.wordAtCaret, replacement);\n\t var el = this.$el.querySelector('textarea');\n\t el.focus();\n\t this.caret = 0;\n\t this.highlighted = 0;\n\t }\n\t },\n\t cycleBackward: function cycleBackward(e) {\n\t var len = this.candidates.length || 0;\n\t if (len > 0) {\n\t e.preventDefault();\n\t this.highlighted -= 1;\n\t if (this.highlighted < 0) {\n\t this.highlighted = this.candidates.length - 1;\n\t }\n\t } else {\n\t this.highlighted = 0;\n\t }\n\t },\n\t cycleForward: function cycleForward(e) {\n\t var len = this.candidates.length || 0;\n\t if (len > 0) {\n\t if (e.shiftKey) {\n\t return;\n\t }\n\t e.preventDefault();\n\t this.highlighted += 1;\n\t if (this.highlighted >= len) {\n\t this.highlighted = 0;\n\t }\n\t } else {\n\t this.highlighted = 0;\n\t }\n\t },\n\t onKeydown: function onKeydown(e) {\n\t e.stopPropagation();\n\t },\n\t setCaret: function setCaret(_ref4) {\n\t var selectionStart = _ref4.target.selectionStart;\n\t\n\t this.caret = selectionStart;\n\t },\n\t postStatus: function postStatus(newStatus) {\n\t var _this2 = this;\n\t\n\t if (this.posting) {\n\t return;\n\t }\n\t if (this.submitDisabled) {\n\t return;\n\t }\n\t\n\t if (this.newStatus.status === '') {\n\t if (this.newStatus.files.length > 0) {\n\t this.newStatus.status = '\\u200B';\n\t } else {\n\t this.error = 'Cannot post an empty status with no files';\n\t return;\n\t }\n\t }\n\t\n\t this.posting = true;\n\t _status_posterService2.default.postStatus({\n\t status: newStatus.status,\n\t spoilerText: newStatus.spoilerText || null,\n\t visibility: newStatus.visibility,\n\t sensitive: newStatus.nsfw,\n\t media: newStatus.files,\n\t store: this.$store,\n\t inReplyToStatusId: this.replyTo,\n\t contentType: newStatus.contentType\n\t }).then(function (data) {\n\t if (!data.error) {\n\t _this2.newStatus = {\n\t status: '',\n\t spoilerText: '',\n\t files: [],\n\t visibility: newStatus.visibility,\n\t contentType: newStatus.contentType\n\t };\n\t _this2.$refs.mediaUpload.clearFile();\n\t _this2.$emit('posted');\n\t var el = _this2.$el.querySelector('textarea');\n\t el.style.height = 'auto';\n\t el.style.height = undefined;\n\t _this2.error = null;\n\t } else {\n\t _this2.error = data.error;\n\t }\n\t _this2.posting = false;\n\t });\n\t },\n\t addMediaFile: function addMediaFile(fileInfo) {\n\t this.newStatus.files.push(fileInfo);\n\t this.enableSubmit();\n\t },\n\t removeMediaFile: function removeMediaFile(fileInfo) {\n\t var index = this.newStatus.files.indexOf(fileInfo);\n\t this.newStatus.files.splice(index, 1);\n\t },\n\t uploadFailed: function uploadFailed(errString, templateArgs) {\n\t templateArgs = templateArgs || {};\n\t this.error = this.$t('upload.error.base') + ' ' + this.$t('upload.error.' + errString, templateArgs);\n\t this.enableSubmit();\n\t },\n\t disableSubmit: function disableSubmit() {\n\t this.submitDisabled = true;\n\t },\n\t enableSubmit: function enableSubmit() {\n\t this.submitDisabled = false;\n\t },\n\t type: function type(fileInfo) {\n\t return _file_typeService2.default.fileType(fileInfo.mimetype);\n\t },\n\t paste: function paste(e) {\n\t if (e.clipboardData.files.length > 0) {\n\t this.dropFiles = [e.clipboardData.files[0]];\n\t }\n\t },\n\t fileDrop: function fileDrop(e) {\n\t if (e.dataTransfer.files.length > 0) {\n\t e.preventDefault();\n\t this.dropFiles = e.dataTransfer.files;\n\t }\n\t },\n\t fileDrag: function fileDrag(e) {\n\t e.dataTransfer.dropEffect = 'copy';\n\t },\n\t resize: function resize(e) {\n\t var target = e.target || e;\n\t if (!(target instanceof window.Element)) {\n\t return;\n\t }\n\t var vertPadding = Number(window.getComputedStyle(target)['padding-top'].substr(0, 1)) + Number(window.getComputedStyle(target)['padding-bottom'].substr(0, 1));\n\t\n\t target.style.height = 'auto';\n\t target.style.height = target.scrollHeight - vertPadding + 'px';\n\t if (target.value === '') {\n\t target.style.height = null;\n\t }\n\t },\n\t clearError: function clearError() {\n\t this.error = null;\n\t },\n\t changeVis: function changeVis(visibility) {\n\t this.newStatus.visibility = visibility;\n\t }\n\t }\n\t};\n\t\n\texports.default = PostStatusForm;\n\n/***/ }),\n/* 284 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _timeline = __webpack_require__(34);\n\t\n\tvar _timeline2 = _interopRequireDefault(_timeline);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar PublicAndExternalTimeline = {\n\t components: {\n\t Timeline: _timeline2.default\n\t },\n\t computed: {\n\t timeline: function timeline() {\n\t return this.$store.state.statuses.timelines.publicAndExternal;\n\t }\n\t },\n\t created: function created() {\n\t this.$store.dispatch('startFetching', { timeline: 'publicAndExternal' });\n\t },\n\t destroyed: function destroyed() {\n\t this.$store.dispatch('stopFetching', 'publicAndExternal');\n\t }\n\t};\n\t\n\texports.default = PublicAndExternalTimeline;\n\n/***/ }),\n/* 285 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _timeline = __webpack_require__(34);\n\t\n\tvar _timeline2 = _interopRequireDefault(_timeline);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar PublicTimeline = {\n\t components: {\n\t Timeline: _timeline2.default\n\t },\n\t computed: {\n\t timeline: function timeline() {\n\t return this.$store.state.statuses.timelines.public;\n\t }\n\t },\n\t created: function created() {\n\t this.$store.dispatch('startFetching', { timeline: 'public' });\n\t },\n\t destroyed: function destroyed() {\n\t this.$store.dispatch('stopFetching', 'public');\n\t }\n\t};\n\t\n\texports.default = PublicTimeline;\n\n/***/ }),\n/* 286 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _regenerator = __webpack_require__(141);\n\t\n\tvar _regenerator2 = _interopRequireDefault(_regenerator);\n\t\n\tvar _asyncToGenerator2 = __webpack_require__(139);\n\t\n\tvar _asyncToGenerator3 = _interopRequireDefault(_asyncToGenerator2);\n\t\n\tvar _extends2 = __webpack_require__(37);\n\t\n\tvar _extends3 = _interopRequireDefault(_extends2);\n\t\n\tvar _vuelidate = __webpack_require__(742);\n\t\n\tvar _validators = __webpack_require__(749);\n\t\n\tvar _vuex = __webpack_require__(219);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar registration = {\n\t mixins: [_vuelidate.validationMixin],\n\t data: function data() {\n\t return {\n\t user: {\n\t email: '',\n\t fullname: '',\n\t username: '',\n\t password: '',\n\t confirm: ''\n\t },\n\t captcha: {}\n\t };\n\t },\n\t validations: {\n\t user: {\n\t email: { required: _validators.required },\n\t username: { required: _validators.required },\n\t fullname: { required: _validators.required },\n\t password: { required: _validators.required },\n\t confirm: {\n\t required: _validators.required,\n\t sameAsPassword: (0, _validators.sameAs)('password')\n\t }\n\t }\n\t },\n\t created: function created() {\n\t if (!this.registrationOpen && !this.token || this.signedIn) {\n\t this.$router.push({ name: 'root' });\n\t }\n\t\n\t this.setCaptcha();\n\t },\n\t\n\t computed: (0, _extends3.default)({\n\t token: function token() {\n\t return this.$route.params.token;\n\t }\n\t }, (0, _vuex.mapState)({\n\t registrationOpen: function registrationOpen(state) {\n\t return state.instance.registrationOpen;\n\t },\n\t signedIn: function signedIn(state) {\n\t return !!state.users.currentUser;\n\t },\n\t isPending: function isPending(state) {\n\t return state.users.signUpPending;\n\t },\n\t serverValidationErrors: function serverValidationErrors(state) {\n\t return state.users.signUpErrors;\n\t },\n\t termsOfService: function termsOfService(state) {\n\t return state.instance.tos;\n\t }\n\t })),\n\t methods: (0, _extends3.default)({}, (0, _vuex.mapActions)(['signUp', 'getCaptcha']), {\n\t submit: function () {\n\t var _ref = (0, _asyncToGenerator3.default)(_regenerator2.default.mark(function _callee() {\n\t return _regenerator2.default.wrap(function _callee$(_context) {\n\t while (1) {\n\t switch (_context.prev = _context.next) {\n\t case 0:\n\t this.user.nickname = this.user.username;\n\t this.user.token = this.token;\n\t\n\t this.user.captcha_solution = this.captcha.solution;\n\t this.user.captcha_token = this.captcha.token;\n\t this.user.captcha_answer_data = this.captcha.answer_data;\n\t\n\t this.$v.$touch();\n\t\n\t if (this.$v.$invalid) {\n\t _context.next = 16;\n\t break;\n\t }\n\t\n\t _context.prev = 7;\n\t _context.next = 10;\n\t return this.signUp(this.user);\n\t\n\t case 10:\n\t this.$router.push({ name: 'friends' });\n\t _context.next = 16;\n\t break;\n\t\n\t case 13:\n\t _context.prev = 13;\n\t _context.t0 = _context['catch'](7);\n\t\n\t console.warn('Registration failed: ' + _context.t0);\n\t\n\t case 16:\n\t case 'end':\n\t return _context.stop();\n\t }\n\t }\n\t }, _callee, this, [[7, 13]]);\n\t }));\n\t\n\t function submit() {\n\t return _ref.apply(this, arguments);\n\t }\n\t\n\t return submit;\n\t }(),\n\t setCaptcha: function setCaptcha() {\n\t var _this = this;\n\t\n\t this.getCaptcha().then(function (cpt) {\n\t _this.captcha = cpt;\n\t });\n\t }\n\t })\n\t};\n\t\n\texports.default = registration;\n\n/***/ }),\n/* 287 */\n/***/ (function(module, exports) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\tvar RetweetButton = {\n\t props: ['status', 'loggedIn', 'visibility'],\n\t data: function data() {\n\t return {\n\t hidePostStatsLocal: typeof this.$store.state.config.hidePostStats === 'undefined' ? this.$store.state.instance.hidePostStats : this.$store.state.config.hidePostStats,\n\t animated: false\n\t };\n\t },\n\t\n\t methods: {\n\t retweet: function retweet() {\n\t var _this = this;\n\t\n\t if (!this.status.repeated) {\n\t this.$store.dispatch('retweet', { id: this.status.id });\n\t } else {\n\t this.$store.dispatch('unretweet', { id: this.status.id });\n\t }\n\t this.animated = true;\n\t setTimeout(function () {\n\t _this.animated = false;\n\t }, 500);\n\t }\n\t },\n\t computed: {\n\t classes: function classes() {\n\t return {\n\t 'retweeted': this.status.repeated,\n\t 'retweeted-empty': !this.status.repeated,\n\t 'animate-spin': this.animated\n\t };\n\t }\n\t }\n\t};\n\t\n\texports.default = RetweetButton;\n\n/***/ }),\n/* 288 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _getOwnPropertyDescriptor = __webpack_require__(313);\n\t\n\tvar _getOwnPropertyDescriptor2 = _interopRequireDefault(_getOwnPropertyDescriptor);\n\t\n\tvar _trim2 = __webpack_require__(619);\n\t\n\tvar _trim3 = _interopRequireDefault(_trim2);\n\t\n\tvar _filter2 = __webpack_require__(58);\n\t\n\tvar _filter3 = _interopRequireDefault(_filter2);\n\t\n\tvar _tab_switcher = __webpack_require__(89);\n\t\n\tvar _tab_switcher2 = _interopRequireDefault(_tab_switcher);\n\t\n\tvar _style_switcher = __webpack_require__(215);\n\t\n\tvar _style_switcher2 = _interopRequireDefault(_style_switcher);\n\t\n\tvar _interface_language_switcher = __webpack_require__(648);\n\t\n\tvar _interface_language_switcher2 = _interopRequireDefault(_interface_language_switcher);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar settings = {\n\t data: function data() {\n\t var user = this.$store.state.config;\n\t var instance = this.$store.state.instance;\n\t\n\t return {\n\t hideAttachmentsLocal: user.hideAttachments,\n\t hideAttachmentsInConvLocal: user.hideAttachmentsInConv,\n\t maxThumbnails: user.maxThumbnails,\n\t hideNsfwLocal: user.hideNsfw,\n\t useOneClickNsfw: user.useOneClickNsfw,\n\t hideISPLocal: user.hideISP,\n\t preloadImage: user.preloadImage,\n\t\n\t hidePostStatsLocal: typeof user.hidePostStats === 'undefined' ? instance.hidePostStats : user.hidePostStats,\n\t hidePostStatsDefault: this.$t('settings.values.' + instance.hidePostStats),\n\t\n\t hideUserStatsLocal: typeof user.hideUserStats === 'undefined' ? instance.hideUserStats : user.hideUserStats,\n\t hideUserStatsDefault: this.$t('settings.values.' + instance.hideUserStats),\n\t\n\t hideFilteredStatusesLocal: typeof user.hideFilteredStatuses === 'undefined' ? instance.hideFilteredStatuses : user.hideFilteredStatuses,\n\t hideFilteredStatusesDefault: this.$t('settings.values.' + instance.hideFilteredStatuses),\n\t\n\t notificationVisibilityLocal: user.notificationVisibility,\n\t replyVisibilityLocal: user.replyVisibility,\n\t loopVideoLocal: user.loopVideo,\n\t muteWordsString: user.muteWords.join('\\n'),\n\t autoLoadLocal: user.autoLoad,\n\t streamingLocal: user.streaming,\n\t pauseOnUnfocusedLocal: user.pauseOnUnfocused,\n\t hoverPreviewLocal: user.hoverPreview,\n\t\n\t collapseMessageWithSubjectLocal: typeof user.collapseMessageWithSubject === 'undefined' ? instance.collapseMessageWithSubject : user.collapseMessageWithSubject,\n\t collapseMessageWithSubjectDefault: this.$t('settings.values.' + instance.collapseMessageWithSubject),\n\t\n\t subjectLineBehaviorLocal: typeof user.subjectLineBehavior === 'undefined' ? instance.subjectLineBehavior : user.subjectLineBehavior,\n\t subjectLineBehaviorDefault: instance.subjectLineBehavior,\n\t\n\t postContentTypeLocal: typeof user.postContentType === 'undefined' ? instance.postContentType : user.postContentType,\n\t postContentTypeDefault: instance.postContentType,\n\t\n\t alwaysShowSubjectInputLocal: typeof user.alwaysShowSubjectInput === 'undefined' ? instance.alwaysShowSubjectInput : user.alwaysShowSubjectInput,\n\t alwaysShowSubjectInputDefault: instance.alwaysShowSubjectInput,\n\t\n\t scopeCopyLocal: typeof user.scopeCopy === 'undefined' ? instance.scopeCopy : user.scopeCopy,\n\t scopeCopyDefault: this.$t('settings.values.' + instance.scopeCopy),\n\t\n\t stopGifs: user.stopGifs,\n\t webPushNotificationsLocal: user.webPushNotifications,\n\t loopVideoSilentOnlyLocal: user.loopVideosSilentOnly,\n\t loopSilentAvailable: (0, _getOwnPropertyDescriptor2.default)(HTMLVideoElement.prototype, 'mozHasAudio') || (0, _getOwnPropertyDescriptor2.default)(HTMLMediaElement.prototype, 'webkitAudioDecodedByteCount') || (0, _getOwnPropertyDescriptor2.default)(HTMLMediaElement.prototype, 'audioTracks'),\n\t playVideosInModal: user.playVideosInModal,\n\t useContainFit: user.useContainFit\n\t };\n\t },\n\t\n\t components: {\n\t TabSwitcher: _tab_switcher2.default,\n\t StyleSwitcher: _style_switcher2.default,\n\t InterfaceLanguageSwitcher: _interface_language_switcher2.default\n\t },\n\t computed: {\n\t user: function user() {\n\t return this.$store.state.users.currentUser;\n\t },\n\t currentSaveStateNotice: function currentSaveStateNotice() {\n\t return this.$store.state.interface.settings.currentSaveStateNotice;\n\t },\n\t postFormats: function postFormats() {\n\t return this.$store.state.instance.postFormats || [];\n\t },\n\t instanceSpecificPanelPresent: function instanceSpecificPanelPresent() {\n\t return this.$store.state.instance.showInstanceSpecificPanel;\n\t }\n\t },\n\t watch: {\n\t hideAttachmentsLocal: function hideAttachmentsLocal(value) {\n\t this.$store.dispatch('setOption', { name: 'hideAttachments', value: value });\n\t },\n\t hideAttachmentsInConvLocal: function hideAttachmentsInConvLocal(value) {\n\t this.$store.dispatch('setOption', { name: 'hideAttachmentsInConv', value: value });\n\t },\n\t hidePostStatsLocal: function hidePostStatsLocal(value) {\n\t this.$store.dispatch('setOption', { name: 'hidePostStats', value: value });\n\t },\n\t hideUserStatsLocal: function hideUserStatsLocal(value) {\n\t this.$store.dispatch('setOption', { name: 'hideUserStats', value: value });\n\t },\n\t hideFilteredStatusesLocal: function hideFilteredStatusesLocal(value) {\n\t this.$store.dispatch('setOption', { name: 'hideFilteredStatuses', value: value });\n\t },\n\t hideNsfwLocal: function hideNsfwLocal(value) {\n\t this.$store.dispatch('setOption', { name: 'hideNsfw', value: value });\n\t },\n\t useOneClickNsfw: function useOneClickNsfw(value) {\n\t this.$store.dispatch('setOption', { name: 'useOneClickNsfw', value: value });\n\t },\n\t preloadImage: function preloadImage(value) {\n\t this.$store.dispatch('setOption', { name: 'preloadImage', value: value });\n\t },\n\t hideISPLocal: function hideISPLocal(value) {\n\t this.$store.dispatch('setOption', { name: 'hideISP', value: value });\n\t },\n\t 'notificationVisibilityLocal.likes': function notificationVisibilityLocalLikes(value) {\n\t this.$store.dispatch('setOption', { name: 'notificationVisibility', value: this.$store.state.config.notificationVisibility });\n\t },\n\t 'notificationVisibilityLocal.follows': function notificationVisibilityLocalFollows(value) {\n\t this.$store.dispatch('setOption', { name: 'notificationVisibility', value: this.$store.state.config.notificationVisibility });\n\t },\n\t 'notificationVisibilityLocal.repeats': function notificationVisibilityLocalRepeats(value) {\n\t this.$store.dispatch('setOption', { name: 'notificationVisibility', value: this.$store.state.config.notificationVisibility });\n\t },\n\t 'notificationVisibilityLocal.mentions': function notificationVisibilityLocalMentions(value) {\n\t this.$store.dispatch('setOption', { name: 'notificationVisibility', value: this.$store.state.config.notificationVisibility });\n\t },\n\t replyVisibilityLocal: function replyVisibilityLocal(value) {\n\t this.$store.dispatch('setOption', { name: 'replyVisibility', value: value });\n\t },\n\t loopVideoLocal: function loopVideoLocal(value) {\n\t this.$store.dispatch('setOption', { name: 'loopVideo', value: value });\n\t },\n\t loopVideoSilentOnlyLocal: function loopVideoSilentOnlyLocal(value) {\n\t this.$store.dispatch('setOption', { name: 'loopVideoSilentOnly', value: value });\n\t },\n\t autoLoadLocal: function autoLoadLocal(value) {\n\t this.$store.dispatch('setOption', { name: 'autoLoad', value: value });\n\t },\n\t streamingLocal: function streamingLocal(value) {\n\t this.$store.dispatch('setOption', { name: 'streaming', value: value });\n\t },\n\t pauseOnUnfocusedLocal: function pauseOnUnfocusedLocal(value) {\n\t this.$store.dispatch('setOption', { name: 'pauseOnUnfocused', value: value });\n\t },\n\t hoverPreviewLocal: function hoverPreviewLocal(value) {\n\t this.$store.dispatch('setOption', { name: 'hoverPreview', value: value });\n\t },\n\t muteWordsString: function muteWordsString(value) {\n\t value = (0, _filter3.default)(value.split('\\n'), function (word) {\n\t return (0, _trim3.default)(word).length > 0;\n\t });\n\t this.$store.dispatch('setOption', { name: 'muteWords', value: value });\n\t },\n\t collapseMessageWithSubjectLocal: function collapseMessageWithSubjectLocal(value) {\n\t this.$store.dispatch('setOption', { name: 'collapseMessageWithSubject', value: value });\n\t },\n\t scopeCopyLocal: function scopeCopyLocal(value) {\n\t this.$store.dispatch('setOption', { name: 'scopeCopy', value: value });\n\t },\n\t alwaysShowSubjectInputLocal: function alwaysShowSubjectInputLocal(value) {\n\t this.$store.dispatch('setOption', { name: 'alwaysShowSubjectInput', value: value });\n\t },\n\t subjectLineBehaviorLocal: function subjectLineBehaviorLocal(value) {\n\t this.$store.dispatch('setOption', { name: 'subjectLineBehavior', value: value });\n\t },\n\t postContentTypeLocal: function postContentTypeLocal(value) {\n\t this.$store.dispatch('setOption', { name: 'postContentType', value: value });\n\t },\n\t stopGifs: function stopGifs(value) {\n\t this.$store.dispatch('setOption', { name: 'stopGifs', value: value });\n\t },\n\t webPushNotificationsLocal: function webPushNotificationsLocal(value) {\n\t this.$store.dispatch('setOption', { name: 'webPushNotifications', value: value });\n\t if (value) this.$store.dispatch('registerPushNotifications');\n\t },\n\t playVideosInModal: function playVideosInModal(value) {\n\t this.$store.dispatch('setOption', { name: 'playVideosInModal', value: value });\n\t },\n\t useContainFit: function useContainFit(value) {\n\t this.$store.dispatch('setOption', { name: 'useContainFit', value: value });\n\t },\n\t maxThumbnails: function maxThumbnails(value) {\n\t value = this.maxThumbnails = Math.floor(Math.max(value, 0));\n\t this.$store.dispatch('setOption', { name: 'maxThumbnails', value: value });\n\t }\n\t }\n\t};\n\t\n\texports.default = settings;\n\n/***/ }),\n/* 289 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _assign = __webpack_require__(36);\n\t\n\tvar _assign2 = _interopRequireDefault(_assign);\n\t\n\tvar _color_input = __webpack_require__(208);\n\t\n\tvar _color_input2 = _interopRequireDefault(_color_input);\n\t\n\tvar _opacity_input = __webpack_require__(214);\n\t\n\tvar _opacity_input2 = _interopRequireDefault(_opacity_input);\n\t\n\tvar _style_setter = __webpack_require__(63);\n\t\n\tvar _color_convert = __webpack_require__(44);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\texports.default = {\n\t props: ['value', 'fallback', 'ready'],\n\t data: function data() {\n\t return {\n\t selectedId: 0,\n\t\n\t cValue: this.value || this.fallback || []\n\t };\n\t },\n\t\n\t components: {\n\t ColorInput: _color_input2.default,\n\t OpacityInput: _opacity_input2.default\n\t },\n\t methods: {\n\t add: function add() {\n\t this.cValue.push((0, _assign2.default)({}, this.selected));\n\t this.selectedId = this.cValue.length - 1;\n\t },\n\t del: function del() {\n\t this.cValue.splice(this.selectedId, 1);\n\t this.selectedId = this.cValue.length === 0 ? undefined : this.selectedId - 1;\n\t },\n\t moveUp: function moveUp() {\n\t var movable = this.cValue.splice(this.selectedId, 1)[0];\n\t this.cValue.splice(this.selectedId - 1, 0, movable);\n\t this.selectedId -= 1;\n\t },\n\t moveDn: function moveDn() {\n\t var movable = this.cValue.splice(this.selectedId, 1)[0];\n\t this.cValue.splice(this.selectedId + 1, 0, movable);\n\t this.selectedId += 1;\n\t }\n\t },\n\t beforeUpdate: function beforeUpdate() {\n\t this.cValue = this.value || this.fallback;\n\t },\n\t\n\t computed: {\n\t selected: function selected() {\n\t if (this.ready && this.cValue.length > 0) {\n\t return this.cValue[this.selectedId];\n\t } else {\n\t return {\n\t x: 0,\n\t y: 0,\n\t blur: 0,\n\t spread: 0,\n\t inset: false,\n\t color: '#000000',\n\t alpha: 1\n\t };\n\t }\n\t },\n\t moveUpValid: function moveUpValid() {\n\t return this.ready && this.selectedId > 0;\n\t },\n\t moveDnValid: function moveDnValid() {\n\t return this.ready && this.selectedId < this.cValue.length - 1;\n\t },\n\t present: function present() {\n\t return this.ready && typeof this.cValue[this.selectedId] !== 'undefined' && !this.usingFallback;\n\t },\n\t usingFallback: function usingFallback() {\n\t return typeof this.value === 'undefined';\n\t },\n\t rgb: function rgb() {\n\t return (0, _color_convert.hex2rgb)(this.selected.color);\n\t },\n\t style: function style() {\n\t return this.ready ? {\n\t boxShadow: (0, _style_setter.getCssShadow)(this.cValue)\n\t } : {};\n\t }\n\t }\n\t};\n\n/***/ }),\n/* 290 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _user_card = __webpack_require__(43);\n\t\n\tvar _user_card2 = _interopRequireDefault(_user_card);\n\t\n\tvar _notification_utils = __webpack_require__(91);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar deltaCoord = function deltaCoord(oldCoord, newCoord) {\n\t return [newCoord[0] - oldCoord[0], newCoord[1] - oldCoord[1]];\n\t};\n\t\n\tvar touchEventCoord = function touchEventCoord(e) {\n\t return [e.touches[0].screenX, e.touches[0].screenY];\n\t};\n\t\n\tvar SideDrawer = {\n\t props: ['logout'],\n\t data: function data() {\n\t return {\n\t closed: true,\n\t touchCoord: [0, 0]\n\t };\n\t },\n\t components: { UserCard: _user_card2.default },\n\t computed: {\n\t currentUser: function currentUser() {\n\t return this.$store.state.users.currentUser;\n\t },\n\t chat: function chat() {\n\t return this.$store.state.chat.channel.state === 'joined';\n\t },\n\t unseenNotifications: function unseenNotifications() {\n\t return (0, _notification_utils.unseenNotificationsFromStore)(this.$store);\n\t },\n\t unseenNotificationsCount: function unseenNotificationsCount() {\n\t return this.unseenNotifications.length;\n\t },\n\t suggestionsEnabled: function suggestionsEnabled() {\n\t return this.$store.state.instance.suggestionsEnabled;\n\t },\n\t logo: function logo() {\n\t return this.$store.state.instance.logo;\n\t },\n\t sitename: function sitename() {\n\t return this.$store.state.instance.name;\n\t },\n\t followRequestCount: function followRequestCount() {\n\t return this.$store.state.api.followRequests.length;\n\t }\n\t },\n\t methods: {\n\t toggleDrawer: function toggleDrawer() {\n\t this.closed = !this.closed;\n\t },\n\t doLogout: function doLogout() {\n\t this.logout();\n\t this.toggleDrawer();\n\t },\n\t touchStart: function touchStart(e) {\n\t this.touchCoord = touchEventCoord(e);\n\t },\n\t touchMove: function touchMove(e) {\n\t var delta = deltaCoord(this.touchCoord, touchEventCoord(e));\n\t if (delta[0] < -30 && Math.abs(delta[1]) < Math.abs(delta[0]) && !this.closed) {\n\t this.toggleDrawer();\n\t }\n\t }\n\t }\n\t};\n\t\n\texports.default = SideDrawer;\n\n/***/ }),\n/* 291 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _unescape2 = __webpack_require__(203);\n\t\n\tvar _unescape3 = _interopRequireDefault(_unescape2);\n\t\n\tvar _find2 = __webpack_require__(59);\n\t\n\tvar _find3 = _interopRequireDefault(_find2);\n\t\n\tvar _filter2 = __webpack_require__(58);\n\t\n\tvar _filter3 = _interopRequireDefault(_filter2);\n\t\n\tvar _attachment = __webpack_require__(206);\n\t\n\tvar _attachment2 = _interopRequireDefault(_attachment);\n\t\n\tvar _favorite_button = __webpack_require__(641);\n\t\n\tvar _favorite_button2 = _interopRequireDefault(_favorite_button);\n\t\n\tvar _retweet_button = __webpack_require__(662);\n\t\n\tvar _retweet_button2 = _interopRequireDefault(_retweet_button);\n\t\n\tvar _delete_button = __webpack_require__(638);\n\t\n\tvar _delete_button2 = _interopRequireDefault(_delete_button);\n\t\n\tvar _post_status_form = __webpack_require__(126);\n\t\n\tvar _post_status_form2 = _interopRequireDefault(_post_status_form);\n\t\n\tvar _user_card = __webpack_require__(43);\n\t\n\tvar _user_card2 = _interopRequireDefault(_user_card);\n\t\n\tvar _user_avatar = __webpack_require__(88);\n\t\n\tvar _user_avatar2 = _interopRequireDefault(_user_avatar);\n\t\n\tvar _gallery = __webpack_require__(646);\n\t\n\tvar _gallery2 = _interopRequireDefault(_gallery);\n\t\n\tvar _linkPreview = __webpack_require__(649);\n\t\n\tvar _linkPreview2 = _interopRequireDefault(_linkPreview);\n\t\n\tvar _user_profile_link_generator = __webpack_require__(35);\n\t\n\tvar _user_profile_link_generator2 = _interopRequireDefault(_user_profile_link_generator);\n\t\n\tvar _file_type = __webpack_require__(45);\n\t\n\tvar _file_type2 = _interopRequireDefault(_file_type);\n\t\n\tvar _user_highlighter = __webpack_require__(137);\n\t\n\tvar _matcherService = __webpack_require__(241);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar Status = {\n\t name: 'Status',\n\t props: ['statusoid', 'expandable', 'inConversation', 'focused', 'highlight', 'compact', 'replies', 'isPreview', 'noHeading', 'inlineExpanded'],\n\t data: function data() {\n\t return {\n\t replying: false,\n\t expanded: false,\n\t unmuted: false,\n\t userExpanded: false,\n\t preview: null,\n\t showPreview: false,\n\t showingTall: this.inConversation && this.focused,\n\t showingLongSubject: false,\n\t expandingSubject: typeof this.$store.state.config.collapseMessageWithSubject === 'undefined' ? !this.$store.state.instance.collapseMessageWithSubject : !this.$store.state.config.collapseMessageWithSubject,\n\t betterShadow: this.$store.state.interface.browserSupport.cssFilter\n\t };\n\t },\n\t\n\t computed: {\n\t localCollapseSubjectDefault: function localCollapseSubjectDefault() {\n\t return typeof this.$store.state.config.collapseMessageWithSubject === 'undefined' ? this.$store.state.instance.collapseMessageWithSubject : this.$store.state.config.collapseMessageWithSubject;\n\t },\n\t muteWords: function muteWords() {\n\t return this.$store.state.config.muteWords;\n\t },\n\t repeaterClass: function repeaterClass() {\n\t var user = this.statusoid.user;\n\t return (0, _user_highlighter.highlightClass)(user);\n\t },\n\t userClass: function userClass() {\n\t var user = this.retweet ? this.statusoid.retweeted_status.user : this.statusoid.user;\n\t return (0, _user_highlighter.highlightClass)(user);\n\t },\n\t deleted: function deleted() {\n\t return this.statusoid.deleted;\n\t },\n\t repeaterStyle: function repeaterStyle() {\n\t var user = this.statusoid.user;\n\t var highlight = this.$store.state.config.highlight;\n\t return (0, _user_highlighter.highlightStyle)(highlight[user.screen_name]);\n\t },\n\t userStyle: function userStyle() {\n\t if (this.noHeading) return;\n\t var user = this.retweet ? this.statusoid.retweeted_status.user : this.statusoid.user;\n\t var highlight = this.$store.state.config.highlight;\n\t return (0, _user_highlighter.highlightStyle)(highlight[user.screen_name]);\n\t },\n\t hideAttachments: function hideAttachments() {\n\t return this.$store.state.config.hideAttachments && !this.inConversation || this.$store.state.config.hideAttachmentsInConv && this.inConversation;\n\t },\n\t userProfileLink: function userProfileLink() {\n\t return this.generateUserProfileLink(this.status.user.id, this.status.user.screen_name);\n\t },\n\t replyProfileLink: function replyProfileLink() {\n\t if (this.isReply) {\n\t return this.generateUserProfileLink(this.status.in_reply_to_user_id, this.replyToName);\n\t }\n\t },\n\t retweet: function retweet() {\n\t return !!this.statusoid.retweeted_status;\n\t },\n\t retweeter: function retweeter() {\n\t return this.statusoid.user.name || this.statusoid.user.screen_name;\n\t },\n\t retweeterHtml: function retweeterHtml() {\n\t return this.statusoid.user.name_html;\n\t },\n\t retweeterProfileLink: function retweeterProfileLink() {\n\t return this.generateUserProfileLink(this.statusoid.user.id, this.statusoid.user.screen_name);\n\t },\n\t status: function status() {\n\t if (this.retweet) {\n\t return this.statusoid.retweeted_status;\n\t } else {\n\t return this.statusoid;\n\t }\n\t },\n\t loggedIn: function loggedIn() {\n\t return !!this.$store.state.users.currentUser;\n\t },\n\t muteWordHits: function muteWordHits() {\n\t var statusText = this.status.text.toLowerCase();\n\t var hits = (0, _filter3.default)(this.muteWords, function (muteWord) {\n\t return statusText.includes(muteWord.toLowerCase());\n\t });\n\t\n\t return hits;\n\t },\n\t muted: function muted() {\n\t return !this.unmuted && (this.status.user.muted || this.muteWordHits.length > 0);\n\t },\n\t hideFilteredStatuses: function hideFilteredStatuses() {\n\t return typeof this.$store.state.config.hideFilteredStatuses === 'undefined' ? this.$store.state.instance.hideFilteredStatuses : this.$store.state.config.hideFilteredStatuses;\n\t },\n\t hideStatus: function hideStatus() {\n\t return this.hideReply || this.deleted || this.muted && this.hideFilteredStatuses;\n\t },\n\t isFocused: function isFocused() {\n\t if (this.focused) {\n\t return true;\n\t } else if (!this.inConversation) {\n\t return false;\n\t }\n\t\n\t return this.status.id === this.highlight;\n\t },\n\t tallStatus: function tallStatus() {\n\t var lengthScore = this.status.statusnet_html.split(/ 20;\n\t },\n\t longSubject: function longSubject() {\n\t return this.status.summary.length > 900;\n\t },\n\t isReply: function isReply() {\n\t return !!(this.status.in_reply_to_status_id && this.status.in_reply_to_user_id);\n\t },\n\t replyToName: function replyToName() {\n\t var user = this.$store.state.users.usersObject[this.status.in_reply_to_user_id];\n\t if (user) {\n\t return user.screen_name;\n\t } else {\n\t return this.status.in_reply_to_screen_name;\n\t }\n\t },\n\t hideReply: function hideReply() {\n\t if (this.$store.state.config.replyVisibility === 'all') {\n\t return false;\n\t }\n\t if (this.inlineExpanded || this.expanded || this.inConversation || !this.isReply) {\n\t return false;\n\t }\n\t if (this.status.user.id === this.$store.state.users.currentUser.id) {\n\t return false;\n\t }\n\t if (this.status.type === 'retweet') {\n\t return false;\n\t }\n\t var checkFollowing = this.$store.state.config.replyVisibility === 'following';\n\t for (var i = 0; i < this.status.attentions.length; ++i) {\n\t if (this.status.user.id === this.status.attentions[i].id) {\n\t continue;\n\t }\n\t if (checkFollowing && this.status.attentions[i].following) {\n\t return false;\n\t }\n\t if (this.status.attentions[i].id === this.$store.state.users.currentUser.id) {\n\t return false;\n\t }\n\t }\n\t return this.status.attentions.length > 0;\n\t },\n\t hideSubjectStatus: function hideSubjectStatus() {\n\t if (this.tallStatus && !this.localCollapseSubjectDefault) {\n\t return false;\n\t }\n\t return !this.expandingSubject && this.status.summary;\n\t },\n\t hideTallStatus: function hideTallStatus() {\n\t if (this.status.summary && this.localCollapseSubjectDefault) {\n\t return false;\n\t }\n\t if (this.showingTall) {\n\t return false;\n\t }\n\t return this.tallStatus;\n\t },\n\t showingMore: function showingMore() {\n\t return this.tallStatus && this.showingTall || this.status.summary && this.expandingSubject;\n\t },\n\t nsfwClickthrough: function nsfwClickthrough() {\n\t if (!this.status.nsfw) {\n\t return false;\n\t }\n\t if (this.status.summary && this.localCollapseSubjectDefault) {\n\t return false;\n\t }\n\t return true;\n\t },\n\t replySubject: function replySubject() {\n\t if (!this.status.summary) return '';\n\t var decodedSummary = (0, _unescape3.default)(this.status.summary);\n\t var behavior = typeof this.$store.state.config.subjectLineBehavior === 'undefined' ? this.$store.state.instance.subjectLineBehavior : this.$store.state.config.subjectLineBehavior;\n\t var startsWithRe = decodedSummary.match(/^re[: ]/i);\n\t if (behavior !== 'noop' && startsWithRe || behavior === 'masto') {\n\t return decodedSummary;\n\t } else if (behavior === 'email') {\n\t return 're: '.concat(decodedSummary);\n\t } else if (behavior === 'noop') {\n\t return '';\n\t }\n\t },\n\t attachmentSize: function attachmentSize() {\n\t if (this.$store.state.config.hideAttachments && !this.inConversation || this.$store.state.config.hideAttachmentsInConv && this.inConversation || this.status.attachments.length > this.maxThumbnails) {\n\t return 'hide';\n\t } else if (this.compact) {\n\t return 'small';\n\t }\n\t return 'normal';\n\t },\n\t galleryTypes: function galleryTypes() {\n\t if (this.attachmentSize === 'hide') {\n\t return [];\n\t }\n\t return this.$store.state.config.playVideosInModal ? ['image', 'video'] : ['image'];\n\t },\n\t galleryAttachments: function galleryAttachments() {\n\t var _this = this;\n\t\n\t return this.status.attachments.filter(function (file) {\n\t return _file_type2.default.fileMatchesSomeType(_this.galleryTypes, file);\n\t });\n\t },\n\t nonGalleryAttachments: function nonGalleryAttachments() {\n\t var _this2 = this;\n\t\n\t return this.status.attachments.filter(function (file) {\n\t return !_file_type2.default.fileMatchesSomeType(_this2.galleryTypes, file);\n\t });\n\t },\n\t maxThumbnails: function maxThumbnails() {\n\t return this.$store.state.config.maxThumbnails;\n\t }\n\t },\n\t components: {\n\t Attachment: _attachment2.default,\n\t FavoriteButton: _favorite_button2.default,\n\t RetweetButton: _retweet_button2.default,\n\t DeleteButton: _delete_button2.default,\n\t PostStatusForm: _post_status_form2.default,\n\t UserCard: _user_card2.default,\n\t UserAvatar: _user_avatar2.default,\n\t Gallery: _gallery2.default,\n\t LinkPreview: _linkPreview2.default\n\t },\n\t methods: {\n\t visibilityIcon: function visibilityIcon(visibility) {\n\t switch (visibility) {\n\t case 'private':\n\t return 'icon-lock';\n\t case 'unlisted':\n\t return 'icon-lock-open-alt';\n\t case 'direct':\n\t return 'icon-mail-alt';\n\t default:\n\t return 'icon-globe';\n\t }\n\t },\n\t linkClicked: function linkClicked(event) {\n\t var target = event.target;\n\t\n\t if (target.tagName === 'SPAN') {\n\t target = target.parentNode;\n\t }\n\t if (target.tagName === 'A') {\n\t if (target.className.match(/mention/)) {\n\t var href = target.href;\n\t var attn = this.status.attentions.find(function (attn) {\n\t return (0, _matcherService.mentionMatchesUrl)(attn, href);\n\t });\n\t if (attn) {\n\t event.stopPropagation();\n\t event.preventDefault();\n\t var link = this.generateUserProfileLink(attn.id, attn.screen_name);\n\t this.$router.push(link);\n\t return;\n\t }\n\t }\n\t if (target.className.match(/hashtag/)) {\n\t var tag = (0, _matcherService.extractTagFromUrl)(target.href);\n\t if (tag) {\n\t var _link = this.generateTagLink(tag);\n\t this.$router.push(_link);\n\t return;\n\t }\n\t }\n\t window.open(target.href, '_blank');\n\t }\n\t },\n\t toggleReplying: function toggleReplying() {\n\t this.replying = !this.replying;\n\t },\n\t gotoOriginal: function gotoOriginal(id) {\n\t if (this.inConversation) {\n\t this.$emit('goto', id);\n\t }\n\t },\n\t toggleExpanded: function toggleExpanded() {\n\t this.$emit('toggleExpanded');\n\t },\n\t toggleMute: function toggleMute() {\n\t this.unmuted = !this.unmuted;\n\t },\n\t toggleUserExpanded: function toggleUserExpanded() {\n\t this.userExpanded = !this.userExpanded;\n\t },\n\t toggleShowMore: function toggleShowMore() {\n\t if (this.showingTall) {\n\t this.showingTall = false;\n\t } else if (this.expandingSubject && this.status.summary) {\n\t this.expandingSubject = false;\n\t } else if (this.hideTallStatus) {\n\t this.showingTall = true;\n\t } else if (this.hideSubjectStatus && this.status.summary) {\n\t this.expandingSubject = true;\n\t }\n\t },\n\t replyEnter: function replyEnter(id, event) {\n\t var _this3 = this;\n\t\n\t this.showPreview = true;\n\t var targetId = id;\n\t var statuses = this.$store.state.statuses.allStatuses;\n\t\n\t if (!this.preview) {\n\t this.preview = (0, _find3.default)(statuses, { 'id': targetId });\n\t\n\t if (!this.preview) {\n\t this.$store.state.api.backendInteractor.fetchStatus({ id: id }).then(function (status) {\n\t _this3.preview = status;\n\t });\n\t }\n\t } else if (this.preview.id !== targetId) {\n\t this.preview = (0, _find3.default)(statuses, { 'id': targetId });\n\t }\n\t },\n\t replyLeave: function replyLeave() {\n\t this.showPreview = false;\n\t },\n\t generateUserProfileLink: function generateUserProfileLink(id, name) {\n\t return (0, _user_profile_link_generator2.default)(id, name, this.$store.state.instance.restrictedNicknames);\n\t },\n\t generateTagLink: function generateTagLink(tag) {\n\t return '/tag/' + tag;\n\t },\n\t setMedia: function setMedia() {\n\t var _this4 = this;\n\t\n\t var attachments = this.attachmentSize === 'hide' ? this.status.attachments : this.galleryAttachments;\n\t return function () {\n\t return _this4.$store.dispatch('setMedia', attachments);\n\t };\n\t }\n\t },\n\t watch: {\n\t 'highlight': function highlight(id) {\n\t if (this.status.id === id) {\n\t var rect = this.$el.getBoundingClientRect();\n\t if (rect.top < 100) {\n\t window.scrollBy(0, rect.top - 100);\n\t } else if (rect.height >= window.innerHeight - 50) {\n\t window.scrollBy(0, rect.top - 100);\n\t } else if (rect.bottom > window.innerHeight - 50) {\n\t window.scrollBy(0, rect.bottom - window.innerHeight + 50);\n\t }\n\t }\n\t }\n\t },\n\t filters: {\n\t capitalize: function capitalize(str) {\n\t return str.charAt(0).toUpperCase() + str.slice(1);\n\t }\n\t }\n\t};\n\t\n\texports.default = Status;\n\n/***/ }),\n/* 292 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _status = __webpack_require__(87);\n\t\n\tvar _status2 = _interopRequireDefault(_status);\n\t\n\tvar _conversation = __webpack_require__(209);\n\t\n\tvar _conversation2 = _interopRequireDefault(_conversation);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar statusOrConversation = {\n\t props: ['statusoid'],\n\t data: function data() {\n\t return {\n\t expanded: false\n\t };\n\t },\n\t\n\t components: {\n\t Status: _status2.default,\n\t Conversation: _conversation2.default\n\t },\n\t methods: {\n\t toggleExpanded: function toggleExpanded() {\n\t this.expanded = !this.expanded;\n\t }\n\t }\n\t};\n\t\n\texports.default = statusOrConversation;\n\n/***/ }),\n/* 293 */\n/***/ (function(module, exports) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\tvar StillImage = {\n\t props: ['src', 'referrerpolicy', 'mimetype', 'imageLoadError'],\n\t data: function data() {\n\t return {\n\t stopGifs: this.$store.state.config.stopGifs\n\t };\n\t },\n\t\n\t computed: {\n\t animated: function animated() {\n\t return this.stopGifs && (this.mimetype === 'image/gif' || this.src.endsWith('.gif'));\n\t }\n\t },\n\t methods: {\n\t onLoad: function onLoad() {\n\t var canvas = this.$refs.canvas;\n\t if (!canvas) return;\n\t var width = this.$refs.src.naturalWidth;\n\t var height = this.$refs.src.naturalHeight;\n\t canvas.width = width;\n\t canvas.height = height;\n\t canvas.getContext('2d').drawImage(this.$refs.src, 0, 0, width, height);\n\t },\n\t onError: function onError() {\n\t this.imageLoadError && this.imageLoadError();\n\t }\n\t }\n\t};\n\t\n\texports.default = StillImage;\n\n/***/ }),\n/* 294 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _isNan = __webpack_require__(65);\n\t\n\tvar _isNan2 = _interopRequireDefault(_isNan);\n\t\n\tvar _set2 = __webpack_require__(138);\n\t\n\tvar _set3 = _interopRequireDefault(_set2);\n\t\n\tvar _assign = __webpack_require__(36);\n\t\n\tvar _assign2 = _interopRequireDefault(_assign);\n\t\n\tvar _keys = __webpack_require__(24);\n\t\n\tvar _keys2 = _interopRequireDefault(_keys);\n\t\n\tvar _values = __webpack_require__(314);\n\t\n\tvar _values2 = _interopRequireDefault(_values);\n\t\n\tvar _toConsumableArray2 = __webpack_require__(26);\n\t\n\tvar _toConsumableArray3 = _interopRequireDefault(_toConsumableArray2);\n\t\n\tvar _slicedToArray2 = __webpack_require__(9);\n\t\n\tvar _slicedToArray3 = _interopRequireDefault(_slicedToArray2);\n\t\n\tvar _entries = __webpack_require__(23);\n\t\n\tvar _entries2 = _interopRequireDefault(_entries);\n\t\n\tvar _color_convert = __webpack_require__(44);\n\t\n\tvar _vue = __webpack_require__(8);\n\t\n\tvar _style_setter = __webpack_require__(63);\n\t\n\tvar _color_input = __webpack_require__(208);\n\t\n\tvar _color_input2 = _interopRequireDefault(_color_input);\n\t\n\tvar _range_input = __webpack_require__(660);\n\t\n\tvar _range_input2 = _interopRequireDefault(_range_input);\n\t\n\tvar _opacity_input = __webpack_require__(214);\n\t\n\tvar _opacity_input2 = _interopRequireDefault(_opacity_input);\n\t\n\tvar _shadow_control = __webpack_require__(664);\n\t\n\tvar _shadow_control2 = _interopRequireDefault(_shadow_control);\n\t\n\tvar _font_control = __webpack_require__(644);\n\t\n\tvar _font_control2 = _interopRequireDefault(_font_control);\n\t\n\tvar _contrast_ratio = __webpack_require__(636);\n\t\n\tvar _contrast_ratio2 = _interopRequireDefault(_contrast_ratio);\n\t\n\tvar _tab_switcher = __webpack_require__(89);\n\t\n\tvar _tab_switcher2 = _interopRequireDefault(_tab_switcher);\n\t\n\tvar _preview = __webpack_require__(667);\n\t\n\tvar _preview2 = _interopRequireDefault(_preview);\n\t\n\tvar _export_import = __webpack_require__(640);\n\t\n\tvar _export_import2 = _interopRequireDefault(_export_import);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar v1OnlyNames = ['bg', 'fg', 'text', 'link', 'cRed', 'cGreen', 'cBlue', 'cOrange'].map(function (_) {\n\t return _ + 'ColorLocal';\n\t});\n\t\n\texports.default = {\n\t data: function data() {\n\t return {\n\t availableStyles: [],\n\t selected: this.$store.state.config.theme,\n\t\n\t previewShadows: {},\n\t previewColors: {},\n\t previewRadii: {},\n\t previewFonts: {},\n\t\n\t shadowsInvalid: true,\n\t colorsInvalid: true,\n\t radiiInvalid: true,\n\t\n\t keepColor: false,\n\t keepShadows: false,\n\t keepOpacity: false,\n\t keepRoundness: false,\n\t keepFonts: false,\n\t\n\t textColorLocal: '',\n\t linkColorLocal: '',\n\t\n\t bgColorLocal: '',\n\t bgOpacityLocal: undefined,\n\t\n\t fgColorLocal: '',\n\t fgTextColorLocal: undefined,\n\t fgLinkColorLocal: undefined,\n\t\n\t btnColorLocal: undefined,\n\t btnTextColorLocal: undefined,\n\t btnOpacityLocal: undefined,\n\t\n\t inputColorLocal: undefined,\n\t inputTextColorLocal: undefined,\n\t inputOpacityLocal: undefined,\n\t\n\t panelColorLocal: undefined,\n\t panelTextColorLocal: undefined,\n\t panelLinkColorLocal: undefined,\n\t panelFaintColorLocal: undefined,\n\t panelOpacityLocal: undefined,\n\t\n\t topBarColorLocal: undefined,\n\t topBarTextColorLocal: undefined,\n\t topBarLinkColorLocal: undefined,\n\t\n\t alertErrorColorLocal: undefined,\n\t\n\t badgeOpacityLocal: undefined,\n\t badgeNotificationColorLocal: undefined,\n\t\n\t borderColorLocal: undefined,\n\t borderOpacityLocal: undefined,\n\t\n\t faintColorLocal: undefined,\n\t faintOpacityLocal: undefined,\n\t faintLinkColorLocal: undefined,\n\t\n\t cRedColorLocal: '',\n\t cBlueColorLocal: '',\n\t cGreenColorLocal: '',\n\t cOrangeColorLocal: '',\n\t\n\t shadowSelected: undefined,\n\t shadowsLocal: {},\n\t fontsLocal: {},\n\t\n\t btnRadiusLocal: '',\n\t inputRadiusLocal: '',\n\t checkboxRadiusLocal: '',\n\t panelRadiusLocal: '',\n\t avatarRadiusLocal: '',\n\t avatarAltRadiusLocal: '',\n\t attachmentRadiusLocal: '',\n\t tooltipRadiusLocal: ''\n\t };\n\t },\n\t created: function created() {\n\t var self = this;\n\t\n\t (0, _style_setter.getThemes)().then(function (themesComplete) {\n\t self.availableStyles = themesComplete;\n\t });\n\t },\n\t mounted: function mounted() {\n\t this.normalizeLocalState(this.$store.state.config.customTheme);\n\t if (typeof this.shadowSelected === 'undefined') {\n\t this.shadowSelected = this.shadowsAvailable[0];\n\t }\n\t },\n\t\n\t computed: {\n\t selectedVersion: function selectedVersion() {\n\t return Array.isArray(this.selected) ? 1 : 2;\n\t },\n\t currentColors: function currentColors() {\n\t return {\n\t bg: this.bgColorLocal,\n\t text: this.textColorLocal,\n\t link: this.linkColorLocal,\n\t\n\t fg: this.fgColorLocal,\n\t fgText: this.fgTextColorLocal,\n\t fgLink: this.fgLinkColorLocal,\n\t\n\t panel: this.panelColorLocal,\n\t panelText: this.panelTextColorLocal,\n\t panelLink: this.panelLinkColorLocal,\n\t panelFaint: this.panelFaintColorLocal,\n\t\n\t input: this.inputColorLocal,\n\t inputText: this.inputTextColorLocal,\n\t\n\t topBar: this.topBarColorLocal,\n\t topBarText: this.topBarTextColorLocal,\n\t topBarLink: this.topBarLinkColorLocal,\n\t\n\t btn: this.btnColorLocal,\n\t btnText: this.btnTextColorLocal,\n\t\n\t alertError: this.alertErrorColorLocal,\n\t badgeNotification: this.badgeNotificationColorLocal,\n\t\n\t faint: this.faintColorLocal,\n\t faintLink: this.faintLinkColorLocal,\n\t border: this.borderColorLocal,\n\t\n\t cRed: this.cRedColorLocal,\n\t cBlue: this.cBlueColorLocal,\n\t cGreen: this.cGreenColorLocal,\n\t cOrange: this.cOrangeColorLocal\n\t };\n\t },\n\t currentOpacity: function currentOpacity() {\n\t return {\n\t bg: this.bgOpacityLocal,\n\t btn: this.btnOpacityLocal,\n\t input: this.inputOpacityLocal,\n\t panel: this.panelOpacityLocal,\n\t topBar: this.topBarOpacityLocal,\n\t border: this.borderOpacityLocal,\n\t faint: this.faintOpacityLocal\n\t };\n\t },\n\t currentRadii: function currentRadii() {\n\t return {\n\t btn: this.btnRadiusLocal,\n\t input: this.inputRadiusLocal,\n\t checkbox: this.checkboxRadiusLocal,\n\t panel: this.panelRadiusLocal,\n\t avatar: this.avatarRadiusLocal,\n\t avatarAlt: this.avatarAltRadiusLocal,\n\t tooltip: this.tooltipRadiusLocal,\n\t attachment: this.attachmentRadiusLocal\n\t };\n\t },\n\t preview: function preview() {\n\t return (0, _style_setter.composePreset)(this.previewColors, this.previewRadii, this.previewShadows, this.previewFonts);\n\t },\n\t previewTheme: function previewTheme() {\n\t if (!this.preview.theme.colors) return { colors: {}, opacity: {}, radii: {}, shadows: {}, fonts: {} };\n\t return this.preview.theme;\n\t },\n\t previewContrast: function previewContrast() {\n\t if (!this.previewTheme.colors.bg) return {};\n\t var colors = this.previewTheme.colors;\n\t var opacity = this.previewTheme.opacity;\n\t if (!colors.bg) return {};\n\t var hints = function hints(ratio) {\n\t return {\n\t text: ratio.toPrecision(3) + ':1',\n\t\n\t aa: ratio >= 4.5,\n\t aaa: ratio >= 7,\n\t\n\t laa: ratio >= 3,\n\t laaa: ratio >= 4.5\n\t };\n\t };\n\t\n\t var fgs = {\n\t text: (0, _color_convert.hex2rgb)(colors.text),\n\t panelText: (0, _color_convert.hex2rgb)(colors.panelText),\n\t panelLink: (0, _color_convert.hex2rgb)(colors.panelLink),\n\t btnText: (0, _color_convert.hex2rgb)(colors.btnText),\n\t topBarText: (0, _color_convert.hex2rgb)(colors.topBarText),\n\t inputText: (0, _color_convert.hex2rgb)(colors.inputText),\n\t\n\t link: (0, _color_convert.hex2rgb)(colors.link),\n\t topBarLink: (0, _color_convert.hex2rgb)(colors.topBarLink),\n\t\n\t red: (0, _color_convert.hex2rgb)(colors.cRed),\n\t green: (0, _color_convert.hex2rgb)(colors.cGreen),\n\t blue: (0, _color_convert.hex2rgb)(colors.cBlue),\n\t orange: (0, _color_convert.hex2rgb)(colors.cOrange)\n\t };\n\t\n\t var bgs = {\n\t bg: (0, _color_convert.hex2rgb)(colors.bg),\n\t btn: (0, _color_convert.hex2rgb)(colors.btn),\n\t panel: (0, _color_convert.hex2rgb)(colors.panel),\n\t topBar: (0, _color_convert.hex2rgb)(colors.topBar),\n\t input: (0, _color_convert.hex2rgb)(colors.input),\n\t alertError: (0, _color_convert.hex2rgb)(colors.alertError),\n\t badgeNotification: (0, _color_convert.hex2rgb)(colors.badgeNotification)\n\t };\n\t\n\t var ratios = {\n\t bgText: (0, _color_convert.getContrastRatio)((0, _color_convert.alphaBlend)(bgs.bg, opacity.bg, fgs.text), fgs.text),\n\t bgLink: (0, _color_convert.getContrastRatio)((0, _color_convert.alphaBlend)(bgs.bg, opacity.bg, fgs.link), fgs.link),\n\t bgRed: (0, _color_convert.getContrastRatio)((0, _color_convert.alphaBlend)(bgs.bg, opacity.bg, fgs.red), fgs.red),\n\t bgGreen: (0, _color_convert.getContrastRatio)((0, _color_convert.alphaBlend)(bgs.bg, opacity.bg, fgs.green), fgs.green),\n\t bgBlue: (0, _color_convert.getContrastRatio)((0, _color_convert.alphaBlend)(bgs.bg, opacity.bg, fgs.blue), fgs.blue),\n\t bgOrange: (0, _color_convert.getContrastRatio)((0, _color_convert.alphaBlend)(bgs.bg, opacity.bg, fgs.orange), fgs.orange),\n\t\n\t tintText: (0, _color_convert.getContrastRatio)((0, _color_convert.alphaBlend)(bgs.bg, 0.5, fgs.panelText), fgs.text),\n\t\n\t panelText: (0, _color_convert.getContrastRatio)((0, _color_convert.alphaBlend)(bgs.panel, opacity.panel, fgs.panelText), fgs.panelText),\n\t panelLink: (0, _color_convert.getContrastRatio)((0, _color_convert.alphaBlend)(bgs.panel, opacity.panel, fgs.panelLink), fgs.panelLink),\n\t\n\t btnText: (0, _color_convert.getContrastRatio)((0, _color_convert.alphaBlend)(bgs.btn, opacity.btn, fgs.btnText), fgs.btnText),\n\t\n\t inputText: (0, _color_convert.getContrastRatio)((0, _color_convert.alphaBlend)(bgs.input, opacity.input, fgs.inputText), fgs.inputText),\n\t\n\t topBarText: (0, _color_convert.getContrastRatio)((0, _color_convert.alphaBlend)(bgs.topBar, opacity.topBar, fgs.topBarText), fgs.topBarText),\n\t topBarLink: (0, _color_convert.getContrastRatio)((0, _color_convert.alphaBlend)(bgs.topBar, opacity.topBar, fgs.topBarLink), fgs.topBarLink)\n\t };\n\t\n\t return (0, _entries2.default)(ratios).reduce(function (acc, _ref) {\n\t var _ref2 = (0, _slicedToArray3.default)(_ref, 2),\n\t k = _ref2[0],\n\t v = _ref2[1];\n\t\n\t acc[k] = hints(v);return acc;\n\t }, {});\n\t },\n\t previewRules: function previewRules() {\n\t if (!this.preview.rules) return '';\n\t return [].concat((0, _toConsumableArray3.default)((0, _values2.default)(this.preview.rules)), ['color: var(--text)', 'font-family: var(--interfaceFont, sans-serif)']).join(';');\n\t },\n\t shadowsAvailable: function shadowsAvailable() {\n\t return (0, _keys2.default)(this.previewTheme.shadows).sort();\n\t },\n\t\n\t currentShadowOverriden: {\n\t get: function get() {\n\t return !!this.currentShadow;\n\t },\n\t set: function set(val) {\n\t if (val) {\n\t (0, _vue.set)(this.shadowsLocal, this.shadowSelected, this.currentShadowFallback.map(function (_) {\n\t return (0, _assign2.default)({}, _);\n\t }));\n\t } else {\n\t (0, _vue.delete)(this.shadowsLocal, this.shadowSelected);\n\t }\n\t }\n\t },\n\t currentShadowFallback: function currentShadowFallback() {\n\t return this.previewTheme.shadows[this.shadowSelected];\n\t },\n\t\n\t currentShadow: {\n\t get: function get() {\n\t return this.shadowsLocal[this.shadowSelected];\n\t },\n\t set: function set(v) {\n\t (0, _vue.set)(this.shadowsLocal, this.shadowSelected, v);\n\t }\n\t },\n\t themeValid: function themeValid() {\n\t return !this.shadowsInvalid && !this.colorsInvalid && !this.radiiInvalid;\n\t },\n\t exportedTheme: function exportedTheme() {\n\t var saveEverything = !this.keepFonts && !this.keepShadows && !this.keepOpacity && !this.keepRoundness && !this.keepColor;\n\t\n\t var theme = {};\n\t\n\t if (this.keepFonts || saveEverything) {\n\t theme.fonts = this.fontsLocal;\n\t }\n\t if (this.keepShadows || saveEverything) {\n\t theme.shadows = this.shadowsLocal;\n\t }\n\t if (this.keepOpacity || saveEverything) {\n\t theme.opacity = this.currentOpacity;\n\t }\n\t if (this.keepColor || saveEverything) {\n\t theme.colors = this.currentColors;\n\t }\n\t if (this.keepRoundness || saveEverything) {\n\t theme.radii = this.currentRadii;\n\t }\n\t\n\t return {\n\t _pleroma_theme_version: 2, theme: theme\n\t };\n\t }\n\t },\n\t components: {\n\t ColorInput: _color_input2.default,\n\t OpacityInput: _opacity_input2.default,\n\t RangeInput: _range_input2.default,\n\t ContrastRatio: _contrast_ratio2.default,\n\t ShadowControl: _shadow_control2.default,\n\t FontControl: _font_control2.default,\n\t TabSwitcher: _tab_switcher2.default,\n\t Preview: _preview2.default,\n\t ExportImport: _export_import2.default\n\t },\n\t methods: {\n\t setCustomTheme: function setCustomTheme() {\n\t this.$store.dispatch('setOption', {\n\t name: 'customTheme',\n\t value: {\n\t shadows: this.shadowsLocal,\n\t fonts: this.fontsLocal,\n\t opacity: this.currentOpacity,\n\t colors: this.currentColors,\n\t radii: this.currentRadii\n\t }\n\t });\n\t },\n\t onImport: function onImport(parsed) {\n\t if (parsed._pleroma_theme_version === 1) {\n\t this.normalizeLocalState(parsed, 1);\n\t } else if (parsed._pleroma_theme_version === 2) {\n\t this.normalizeLocalState(parsed.theme, 2);\n\t }\n\t },\n\t importValidator: function importValidator(parsed) {\n\t var version = parsed._pleroma_theme_version;\n\t return version >= 1 || version <= 2;\n\t },\n\t clearAll: function clearAll() {\n\t var state = this.$store.state.config.customTheme;\n\t var version = state.colors ? 2 : 'l1';\n\t this.normalizeLocalState(this.$store.state.config.customTheme, version);\n\t },\n\t clearV1: function clearV1() {\n\t var _this = this;\n\t\n\t (0, _keys2.default)(this.$data).filter(function (_) {\n\t return _.endsWith('ColorLocal') || _.endsWith('OpacityLocal');\n\t }).filter(function (_) {\n\t return !v1OnlyNames.includes(_);\n\t }).forEach(function (key) {\n\t (0, _vue.set)(_this.$data, key, undefined);\n\t });\n\t },\n\t clearRoundness: function clearRoundness() {\n\t var _this2 = this;\n\t\n\t (0, _keys2.default)(this.$data).filter(function (_) {\n\t return _.endsWith('RadiusLocal');\n\t }).forEach(function (key) {\n\t (0, _vue.set)(_this2.$data, key, undefined);\n\t });\n\t },\n\t clearOpacity: function clearOpacity() {\n\t var _this3 = this;\n\t\n\t (0, _keys2.default)(this.$data).filter(function (_) {\n\t return _.endsWith('OpacityLocal');\n\t }).forEach(function (key) {\n\t (0, _vue.set)(_this3.$data, key, undefined);\n\t });\n\t },\n\t clearShadows: function clearShadows() {\n\t this.shadowsLocal = {};\n\t },\n\t clearFonts: function clearFonts() {\n\t this.fontsLocal = {};\n\t },\n\t normalizeLocalState: function normalizeLocalState(input) {\n\t var _this4 = this;\n\t\n\t var version = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;\n\t\n\t var colors = input.colors || input;\n\t var radii = input.radii || input;\n\t var opacity = input.opacity;\n\t var shadows = input.shadows || {};\n\t var fonts = input.fonts || {};\n\t\n\t if (version === 0) {\n\t if (input.version) version = input.version;\n\t\n\t if (typeof colors.text === 'undefined' && typeof colors.fg !== 'undefined') {\n\t version = 1;\n\t }\n\t\n\t if (typeof colors.text !== 'undefined' && typeof colors.fg !== 'undefined') {\n\t version = 2;\n\t }\n\t }\n\t\n\t if (version === 1) {\n\t this.fgColorLocal = (0, _color_convert.rgb2hex)(colors.btn);\n\t this.textColorLocal = (0, _color_convert.rgb2hex)(colors.fg);\n\t }\n\t\n\t if (!this.keepColor) {\n\t this.clearV1();\n\t var keys = new _set3.default(version !== 1 ? (0, _keys2.default)(colors) : []);\n\t if (version === 1 || version === 'l1') {\n\t keys.add('bg').add('link').add('cRed').add('cBlue').add('cGreen').add('cOrange');\n\t }\n\t\n\t keys.forEach(function (key) {\n\t _this4[key + 'ColorLocal'] = (0, _color_convert.rgb2hex)(colors[key]);\n\t });\n\t }\n\t\n\t if (!this.keepRoundness) {\n\t this.clearRoundness();\n\t (0, _entries2.default)(radii).forEach(function (_ref3) {\n\t var _ref4 = (0, _slicedToArray3.default)(_ref3, 2),\n\t k = _ref4[0],\n\t v = _ref4[1];\n\t\n\t var key = k.endsWith('Radius') ? k.split('Radius')[0] : k;\n\t _this4[key + 'RadiusLocal'] = v;\n\t });\n\t }\n\t\n\t if (!this.keepShadows) {\n\t this.clearShadows();\n\t this.shadowsLocal = shadows;\n\t this.shadowSelected = this.shadowsAvailable[0];\n\t }\n\t\n\t if (!this.keepFonts) {\n\t this.clearFonts();\n\t this.fontsLocal = fonts;\n\t }\n\t\n\t if (opacity && !this.keepOpacity) {\n\t this.clearOpacity();\n\t (0, _entries2.default)(opacity).forEach(function (_ref5) {\n\t var _ref6 = (0, _slicedToArray3.default)(_ref5, 2),\n\t k = _ref6[0],\n\t v = _ref6[1];\n\t\n\t if (typeof v === 'undefined' || v === null || (0, _isNan2.default)(v)) return;\n\t _this4[k + 'OpacityLocal'] = v;\n\t });\n\t }\n\t }\n\t },\n\t watch: {\n\t currentRadii: function currentRadii() {\n\t try {\n\t this.previewRadii = (0, _style_setter.generateRadii)({ radii: this.currentRadii });\n\t this.radiiInvalid = false;\n\t } catch (e) {\n\t this.radiiInvalid = true;\n\t console.warn(e);\n\t }\n\t },\n\t\n\t shadowsLocal: {\n\t handler: function handler() {\n\t try {\n\t this.previewShadows = (0, _style_setter.generateShadows)({ shadows: this.shadowsLocal });\n\t this.shadowsInvalid = false;\n\t } catch (e) {\n\t this.shadowsInvalid = true;\n\t console.warn(e);\n\t }\n\t },\n\t\n\t deep: true\n\t },\n\t fontsLocal: {\n\t handler: function handler() {\n\t try {\n\t this.previewFonts = (0, _style_setter.generateFonts)({ fonts: this.fontsLocal });\n\t this.fontsInvalid = false;\n\t } catch (e) {\n\t this.fontsInvalid = true;\n\t console.warn(e);\n\t }\n\t },\n\t\n\t deep: true\n\t },\n\t currentColors: function currentColors() {\n\t try {\n\t this.previewColors = (0, _style_setter.generateColors)({\n\t opacity: this.currentOpacity,\n\t colors: this.currentColors\n\t });\n\t this.colorsInvalid = false;\n\t } catch (e) {\n\t this.colorsInvalid = true;\n\t console.warn(e);\n\t }\n\t },\n\t currentOpacity: function currentOpacity() {\n\t try {\n\t this.previewColors = (0, _style_setter.generateColors)({\n\t opacity: this.currentOpacity,\n\t colors: this.currentColors\n\t });\n\t } catch (e) {\n\t console.warn(e);\n\t }\n\t },\n\t selected: function selected() {\n\t if (this.selectedVersion === 1) {\n\t if (!this.keepRoundness) {\n\t this.clearRoundness();\n\t }\n\t\n\t if (!this.keepShadows) {\n\t this.clearShadows();\n\t }\n\t\n\t if (!this.keepOpacity) {\n\t this.clearOpacity();\n\t }\n\t\n\t if (!this.keepColor) {\n\t this.clearV1();\n\t\n\t this.bgColorLocal = this.selected[1];\n\t this.fgColorLocal = this.selected[2];\n\t this.textColorLocal = this.selected[3];\n\t this.linkColorLocal = this.selected[4];\n\t this.cRedColorLocal = this.selected[5];\n\t this.cGreenColorLocal = this.selected[6];\n\t this.cBlueColorLocal = this.selected[7];\n\t this.cOrangeColorLocal = this.selected[8];\n\t }\n\t } else if (this.selectedVersion >= 2) {\n\t this.normalizeLocalState(this.selected.theme, 2);\n\t }\n\t }\n\t }\n\t};\n\n/***/ }),\n/* 295 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _timeline = __webpack_require__(34);\n\t\n\tvar _timeline2 = _interopRequireDefault(_timeline);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar TagTimeline = {\n\t created: function created() {\n\t this.$store.commit('clearTimeline', { timeline: 'tag' });\n\t this.$store.dispatch('startFetching', { timeline: 'tag', tag: this.tag });\n\t },\n\t\n\t components: {\n\t Timeline: _timeline2.default\n\t },\n\t computed: {\n\t tag: function tag() {\n\t return this.$route.params.tag;\n\t },\n\t timeline: function timeline() {\n\t return this.$store.state.statuses.timelines.tag;\n\t }\n\t },\n\t watch: {\n\t tag: function tag() {\n\t this.$store.commit('clearTimeline', { timeline: 'tag' });\n\t this.$store.dispatch('startFetching', { timeline: 'tag', tag: this.tag });\n\t }\n\t },\n\t destroyed: function destroyed() {\n\t this.$store.dispatch('stopFetching', 'tag');\n\t }\n\t};\n\t\n\texports.default = TagTimeline;\n\n/***/ }),\n/* 296 */\n/***/ (function(module, exports) {\n\n\t\"use strict\";\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\tvar TermsOfServicePanel = {\n\t computed: {\n\t content: function content() {\n\t return this.$store.state.instance.tos;\n\t }\n\t }\n\t};\n\t\n\texports.default = TermsOfServicePanel;\n\n/***/ }),\n/* 297 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _throttle2 = __webpack_require__(201);\n\t\n\tvar _throttle3 = _interopRequireDefault(_throttle2);\n\t\n\tvar _status = __webpack_require__(87);\n\t\n\tvar _status2 = _interopRequireDefault(_status);\n\t\n\tvar _timeline_fetcherService = __webpack_require__(136);\n\t\n\tvar _timeline_fetcherService2 = _interopRequireDefault(_timeline_fetcherService);\n\t\n\tvar _status_or_conversation = __webpack_require__(666);\n\t\n\tvar _status_or_conversation2 = _interopRequireDefault(_status_or_conversation);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar Timeline = {\n\t props: ['timeline', 'timelineName', 'title', 'userId', 'tag', 'embedded', 'count'],\n\t data: function data() {\n\t return {\n\t paused: false,\n\t unfocused: false,\n\t bottomedOut: false\n\t };\n\t },\n\t\n\t computed: {\n\t timelineError: function timelineError() {\n\t return this.$store.state.statuses.error;\n\t },\n\t newStatusCount: function newStatusCount() {\n\t return this.timeline.newStatusCount;\n\t },\n\t newStatusCountStr: function newStatusCountStr() {\n\t if (this.timeline.flushMarker !== 0) {\n\t return '';\n\t } else {\n\t return ' (' + this.newStatusCount + ')';\n\t }\n\t },\n\t classes: function classes() {\n\t return {\n\t root: ['timeline'].concat(!this.embedded ? ['panel', 'panel-default'] : []),\n\t header: ['timeline-heading'].concat(!this.embedded ? ['panel-heading'] : []),\n\t body: ['timeline-body'].concat(!this.embedded ? ['panel-body'] : []),\n\t footer: ['timeline-footer'].concat(!this.embedded ? ['panel-footer'] : [])\n\t };\n\t }\n\t },\n\t components: {\n\t Status: _status2.default,\n\t StatusOrConversation: _status_or_conversation2.default\n\t },\n\t created: function created() {\n\t var store = this.$store;\n\t var credentials = store.state.users.currentUser.credentials;\n\t var showImmediately = this.timeline.visibleStatuses.length === 0;\n\t\n\t window.addEventListener('scroll', this.scrollLoad);\n\t\n\t if (this.timelineName === 'friends' && !credentials) {\n\t return false;\n\t }\n\t\n\t _timeline_fetcherService2.default.fetchAndUpdate({\n\t store: store,\n\t credentials: credentials,\n\t timeline: this.timelineName,\n\t showImmediately: showImmediately,\n\t userId: this.userId,\n\t tag: this.tag\n\t });\n\t },\n\t mounted: function mounted() {\n\t if (typeof document.hidden !== 'undefined') {\n\t document.addEventListener('visibilitychange', this.handleVisibilityChange, false);\n\t this.unfocused = document.hidden;\n\t }\n\t window.addEventListener('keydown', this.handleShortKey);\n\t },\n\t destroyed: function destroyed() {\n\t window.removeEventListener('scroll', this.scrollLoad);\n\t window.removeEventListener('keydown', this.handleShortKey);\n\t if (typeof document.hidden !== 'undefined') document.removeEventListener('visibilitychange', this.handleVisibilityChange, false);\n\t this.$store.commit('setLoading', { timeline: this.timelineName, value: false });\n\t },\n\t\n\t methods: {\n\t handleShortKey: function handleShortKey(e) {\n\t if (e.key === '.') this.showNewStatuses();\n\t },\n\t showNewStatuses: function showNewStatuses() {\n\t if (this.newStatusCount === 0) return;\n\t\n\t if (this.timeline.flushMarker !== 0) {\n\t this.$store.commit('clearTimeline', { timeline: this.timelineName });\n\t this.$store.commit('queueFlush', { timeline: this.timelineName, id: 0 });\n\t this.fetchOlderStatuses();\n\t } else {\n\t this.$store.commit('showNewStatuses', { timeline: this.timelineName });\n\t this.paused = false;\n\t }\n\t },\n\t\n\t fetchOlderStatuses: (0, _throttle3.default)(function () {\n\t var _this = this;\n\t\n\t var store = this.$store;\n\t var credentials = store.state.users.currentUser.credentials;\n\t store.commit('setLoading', { timeline: this.timelineName, value: true });\n\t _timeline_fetcherService2.default.fetchAndUpdate({\n\t store: store,\n\t credentials: credentials,\n\t timeline: this.timelineName,\n\t older: true,\n\t showImmediately: true,\n\t userId: this.userId,\n\t tag: this.tag\n\t }).then(function (statuses) {\n\t store.commit('setLoading', { timeline: _this.timelineName, value: false });\n\t if (statuses && statuses.length === 0) {\n\t _this.bottomedOut = true;\n\t }\n\t });\n\t }, 1000, undefined),\n\t scrollLoad: function scrollLoad(e) {\n\t var bodyBRect = document.body.getBoundingClientRect();\n\t var height = Math.max(bodyBRect.height, -bodyBRect.y);\n\t if (this.timeline.loading === false && this.$store.state.config.autoLoad && this.$el.offsetHeight > 0 && window.innerHeight + window.pageYOffset >= height - 750) {\n\t this.fetchOlderStatuses();\n\t }\n\t },\n\t handleVisibilityChange: function handleVisibilityChange() {\n\t this.unfocused = document.hidden;\n\t }\n\t },\n\t watch: {\n\t newStatusCount: function newStatusCount(count) {\n\t if (!this.$store.state.config.streaming) {\n\t return;\n\t }\n\t if (count > 0) {\n\t var doc = document.documentElement;\n\t var top = (window.pageYOffset || doc.scrollTop) - (doc.clientTop || 0);\n\t if (top < 15 && !this.paused && !(this.unfocused && this.$store.state.config.pauseOnUnfocused)) {\n\t this.showNewStatuses();\n\t } else {\n\t this.paused = true;\n\t }\n\t }\n\t }\n\t }\n\t};\n\t\n\texports.default = Timeline;\n\n/***/ }),\n/* 298 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _stillImage = __webpack_require__(127);\n\t\n\tvar _stillImage2 = _interopRequireDefault(_stillImage);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar UserAvatar = {\n\t props: ['src', 'betterShadow', 'compact'],\n\t data: function data() {\n\t return {\n\t showPlaceholder: false\n\t };\n\t },\n\t\n\t components: {\n\t StillImage: _stillImage2.default\n\t },\n\t computed: {\n\t imgSrc: function imgSrc() {\n\t return this.showPlaceholder ? '/images/avi.png' : this.src;\n\t }\n\t },\n\t methods: {\n\t imageLoadError: function imageLoadError() {\n\t this.showPlaceholder = true;\n\t }\n\t }\n\t};\n\t\n\texports.default = UserAvatar;\n\n/***/ }),\n/* 299 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _user_avatar = __webpack_require__(88);\n\t\n\tvar _user_avatar2 = _interopRequireDefault(_user_avatar);\n\t\n\tvar _color_convert = __webpack_require__(44);\n\t\n\tvar _follow_manipulate = __webpack_require__(134);\n\t\n\tvar _user_profile_link_generator = __webpack_require__(35);\n\t\n\tvar _user_profile_link_generator2 = _interopRequireDefault(_user_profile_link_generator);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\texports.default = {\n\t props: ['user', 'switcher', 'selected', 'hideBio', 'rounded', 'bordered'],\n\t data: function data() {\n\t return {\n\t followRequestInProgress: false,\n\t followRequestSent: false,\n\t hideUserStatsLocal: typeof this.$store.state.config.hideUserStats === 'undefined' ? this.$store.state.instance.hideUserStats : this.$store.state.config.hideUserStats,\n\t betterShadow: this.$store.state.interface.browserSupport.cssFilter\n\t };\n\t },\n\t\n\t computed: {\n\t classes: function classes() {\n\t return [{\n\t 'user-card-rounded-t': this.rounded === 'top',\n\t 'user-card-rounded': this.rounded === true,\n\t 'user-card-bordered': this.bordered === true }];\n\t },\n\t style: function style() {\n\t var color = this.$store.state.config.customTheme.colors ? this.$store.state.config.customTheme.colors.bg : this.$store.state.config.colors.bg;\n\t\n\t if (color) {\n\t var rgb = typeof color === 'string' ? (0, _color_convert.hex2rgb)(color) : color;\n\t var tintColor = 'rgba(' + Math.floor(rgb.r) + ', ' + Math.floor(rgb.g) + ', ' + Math.floor(rgb.b) + ', .5)';\n\t\n\t var gradient = [[tintColor, this.hideBio ? '60%' : ''], this.hideBio ? [color, '100%'] : [tintColor, '']].map(function (_) {\n\t return _.join(' ');\n\t }).join(', ');\n\t\n\t return {\n\t backgroundColor: 'rgb(' + Math.floor(rgb.r * 0.53) + ', ' + Math.floor(rgb.g * 0.56) + ', ' + Math.floor(rgb.b * 0.59) + ')',\n\t backgroundImage: ['linear-gradient(to bottom, ' + gradient + ')', 'url(' + this.user.cover_photo + ')'].join(', ')\n\t };\n\t }\n\t },\n\t isOtherUser: function isOtherUser() {\n\t return this.user.id !== this.$store.state.users.currentUser.id;\n\t },\n\t subscribeUrl: function subscribeUrl() {\n\t var serverUrl = new URL(this.user.statusnet_profile_url);\n\t return serverUrl.protocol + '//' + serverUrl.host + '/main/ostatus';\n\t },\n\t loggedIn: function loggedIn() {\n\t return this.$store.state.users.currentUser;\n\t },\n\t dailyAvg: function dailyAvg() {\n\t var days = Math.ceil((new Date() - new Date(this.user.created_at)) / (60 * 60 * 24 * 1000));\n\t return Math.round(this.user.statuses_count / days);\n\t },\n\t\n\t userHighlightType: {\n\t get: function get() {\n\t var data = this.$store.state.config.highlight[this.user.screen_name];\n\t return data && data.type || 'disabled';\n\t },\n\t set: function set(type) {\n\t var data = this.$store.state.config.highlight[this.user.screen_name];\n\t if (type !== 'disabled') {\n\t this.$store.dispatch('setHighlight', { user: this.user.screen_name, color: data && data.color || '#FFFFFF', type: type });\n\t } else {\n\t this.$store.dispatch('setHighlight', { user: this.user.screen_name, color: undefined });\n\t }\n\t }\n\t },\n\t userHighlightColor: {\n\t get: function get() {\n\t var data = this.$store.state.config.highlight[this.user.screen_name];\n\t return data && data.color;\n\t },\n\t set: function set(color) {\n\t this.$store.dispatch('setHighlight', { user: this.user.screen_name, color: color });\n\t }\n\t },\n\t visibleRole: function visibleRole() {\n\t var validRole = this.user.role === 'admin' || this.user.role === 'moderator';\n\t var showRole = this.isOtherUser || this.user.show_role;\n\t\n\t return validRole && showRole && this.user.role;\n\t }\n\t },\n\t components: {\n\t UserAvatar: _user_avatar2.default\n\t },\n\t methods: {\n\t followUser: function followUser() {\n\t var _this = this;\n\t\n\t var store = this.$store;\n\t this.followRequestInProgress = true;\n\t (0, _follow_manipulate.requestFollow)(this.user, store).then(function (_ref) {\n\t var sent = _ref.sent;\n\t\n\t _this.followRequestInProgress = false;\n\t _this.followRequestSent = sent;\n\t });\n\t },\n\t unfollowUser: function unfollowUser() {\n\t var _this2 = this;\n\t\n\t var store = this.$store;\n\t this.followRequestInProgress = true;\n\t (0, _follow_manipulate.requestUnfollow)(this.user, store).then(function () {\n\t _this2.followRequestInProgress = false;\n\t store.commit('removeStatus', { timeline: 'friends', userId: _this2.user.id });\n\t });\n\t },\n\t blockUser: function blockUser() {\n\t var _this3 = this;\n\t\n\t var store = this.$store;\n\t store.state.api.backendInteractor.blockUser(this.user.id).then(function (blockedUser) {\n\t store.commit('addNewUsers', [blockedUser]);\n\t store.commit('removeStatus', { timeline: 'friends', userId: _this3.user.id });\n\t store.commit('removeStatus', { timeline: 'public', userId: _this3.user.id });\n\t store.commit('removeStatus', { timeline: 'publicAndExternal', userId: _this3.user.id });\n\t });\n\t },\n\t unblockUser: function unblockUser() {\n\t var store = this.$store;\n\t store.state.api.backendInteractor.unblockUser(this.user.id).then(function (unblockedUser) {\n\t return store.commit('addNewUsers', [unblockedUser]);\n\t });\n\t },\n\t toggleMute: function toggleMute() {\n\t var store = this.$store;\n\t store.commit('setMuted', { user: this.user, muted: !this.user.muted });\n\t store.state.api.backendInteractor.setUserMute(this.user);\n\t },\n\t setProfileView: function setProfileView(v) {\n\t if (this.switcher) {\n\t var store = this.$store;\n\t store.commit('setProfileView', { v: v });\n\t }\n\t },\n\t linkClicked: function linkClicked(_ref2) {\n\t var target = _ref2.target;\n\t\n\t if (target.tagName === 'SPAN') {\n\t target = target.parentNode;\n\t }\n\t if (target.tagName === 'A') {\n\t window.open(target.href, '_blank');\n\t }\n\t },\n\t userProfileLink: function userProfileLink(user) {\n\t return (0, _user_profile_link_generator2.default)(user.id, user.screen_name, this.$store.state.instance.restrictedNicknames);\n\t }\n\t }\n\t};\n\n/***/ }),\n/* 300 */\n/***/ (function(module, exports) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\tvar UserFinder = {\n\t data: function data() {\n\t return {\n\t username: undefined,\n\t hidden: true,\n\t error: false,\n\t loading: false\n\t };\n\t },\n\t methods: {\n\t findUser: function findUser(username) {\n\t this.$router.push({ name: 'user-search', query: { query: username } });\n\t this.$refs.userSearchInput.focus();\n\t },\n\t toggleHidden: function toggleHidden() {\n\t this.hidden = !this.hidden;\n\t this.$emit('toggled', this.hidden);\n\t }\n\t }\n\t};\n\t\n\texports.default = UserFinder;\n\n/***/ }),\n/* 301 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _login_form = __webpack_require__(212);\n\t\n\tvar _login_form2 = _interopRequireDefault(_login_form);\n\t\n\tvar _post_status_form = __webpack_require__(126);\n\t\n\tvar _post_status_form2 = _interopRequireDefault(_post_status_form);\n\t\n\tvar _user_card = __webpack_require__(43);\n\t\n\tvar _user_card2 = _interopRequireDefault(_user_card);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar UserPanel = {\n\t computed: {\n\t user: function user() {\n\t return this.$store.state.users.currentUser;\n\t }\n\t },\n\t components: {\n\t LoginForm: _login_form2.default,\n\t PostStatusForm: _post_status_form2.default,\n\t UserCard: _user_card2.default\n\t }\n\t};\n\t\n\texports.default = UserPanel;\n\n/***/ }),\n/* 302 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _vueCompose = __webpack_require__(205);\n\t\n\tvar _get = __webpack_require__(120);\n\t\n\tvar _get2 = _interopRequireDefault(_get);\n\t\n\tvar _user_card = __webpack_require__(43);\n\t\n\tvar _user_card2 = _interopRequireDefault(_user_card);\n\t\n\tvar _follow_card = __webpack_require__(125);\n\t\n\tvar _follow_card2 = _interopRequireDefault(_follow_card);\n\t\n\tvar _timeline = __webpack_require__(34);\n\t\n\tvar _timeline2 = _interopRequireDefault(_timeline);\n\t\n\tvar _with_load_more = __webpack_require__(222);\n\t\n\tvar _with_load_more2 = _interopRequireDefault(_with_load_more);\n\t\n\tvar _with_list = __webpack_require__(129);\n\t\n\tvar _with_list2 = _interopRequireDefault(_with_list);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar FollowerList = (0, _vueCompose.compose)((0, _with_load_more2.default)({\n\t fetch: function fetch(props, $store) {\n\t return $store.dispatch('addFollowers', props.userId);\n\t },\n\t select: function select(props, $store) {\n\t return (0, _get2.default)($store.getters.userById(props.userId), 'followers', []);\n\t },\n\t destory: function destory(props, $store) {\n\t return $store.dispatch('clearFollowers', props.userId);\n\t },\n\t childPropName: 'entries',\n\t additionalPropNames: ['userId']\n\t}), (0, _with_list2.default)({ getEntryProps: function getEntryProps(user) {\n\t return { user: user };\n\t } }))(_follow_card2.default);\n\t\n\tvar FriendList = (0, _vueCompose.compose)((0, _with_load_more2.default)({\n\t fetch: function fetch(props, $store) {\n\t return $store.dispatch('addFriends', props.userId);\n\t },\n\t select: function select(props, $store) {\n\t return (0, _get2.default)($store.getters.userById(props.userId), 'friends', []);\n\t },\n\t destory: function destory(props, $store) {\n\t return $store.dispatch('clearFriends', props.userId);\n\t },\n\t childPropName: 'entries',\n\t additionalPropNames: ['userId']\n\t}), (0, _with_list2.default)({ getEntryProps: function getEntryProps(user) {\n\t return { user: user };\n\t } }))(_follow_card2.default);\n\t\n\tvar UserProfile = {\n\t data: function data() {\n\t return {\n\t error: false\n\t };\n\t },\n\t created: function created() {\n\t var _this = this;\n\t\n\t this.$store.commit('clearTimeline', { timeline: 'user' });\n\t this.$store.commit('clearTimeline', { timeline: 'favorites' });\n\t this.$store.commit('clearTimeline', { timeline: 'media' });\n\t this.$store.dispatch('startFetching', { timeline: 'user', userId: this.fetchBy });\n\t this.$store.dispatch('startFetching', { timeline: 'media', userId: this.fetchBy });\n\t this.startFetchFavorites();\n\t if (!this.user.id) {\n\t this.$store.dispatch('fetchUser', this.fetchBy).catch(function (reason) {\n\t var errorMessage = (0, _get2.default)(reason, 'error.error');\n\t if (errorMessage === 'No user with such user_id') {\n\t _this.error = _this.$t('user_profile.profile_does_not_exist');\n\t } else if (errorMessage) {\n\t _this.error = errorMessage;\n\t } else {\n\t _this.error = _this.$t('user_profile.profile_loading_error');\n\t }\n\t });\n\t }\n\t },\n\t destroyed: function destroyed() {\n\t this.cleanUp();\n\t },\n\t\n\t computed: {\n\t timeline: function timeline() {\n\t return this.$store.state.statuses.timelines.user;\n\t },\n\t favorites: function favorites() {\n\t return this.$store.state.statuses.timelines.favorites;\n\t },\n\t media: function media() {\n\t return this.$store.state.statuses.timelines.media;\n\t },\n\t userId: function userId() {\n\t return this.$route.params.id || this.user.id;\n\t },\n\t userName: function userName() {\n\t return this.$route.params.name || this.user.screen_name;\n\t },\n\t isUs: function isUs() {\n\t return this.userId && this.$store.state.users.currentUser.id && this.userId === this.$store.state.users.currentUser.id;\n\t },\n\t userInStore: function userInStore() {\n\t if (this.isExternal) {\n\t return this.$store.getters.userById(this.userId);\n\t }\n\t return this.$store.getters.userByName(this.userName);\n\t },\n\t user: function user() {\n\t if (this.timeline.statuses[0]) {\n\t return this.timeline.statuses[0].user;\n\t }\n\t if (this.userInStore) {\n\t return this.userInStore;\n\t }\n\t return {};\n\t },\n\t fetchBy: function fetchBy() {\n\t return this.isExternal ? this.userId : this.userName;\n\t },\n\t isExternal: function isExternal() {\n\t return this.$route.name === 'external-user-profile';\n\t },\n\t followsTabVisible: function followsTabVisible() {\n\t return this.isUs || !this.user.hide_follows;\n\t },\n\t followersTabVisible: function followersTabVisible() {\n\t return this.isUs || !this.user.hide_followers;\n\t }\n\t },\n\t methods: {\n\t startFetchFavorites: function startFetchFavorites() {\n\t if (this.isUs) {\n\t this.$store.dispatch('startFetching', { timeline: 'favorites', userId: this.fetchBy });\n\t }\n\t },\n\t startUp: function startUp() {\n\t this.$store.dispatch('startFetching', { timeline: 'user', userId: this.fetchBy });\n\t this.$store.dispatch('startFetching', { timeline: 'media', userId: this.fetchBy });\n\t\n\t this.startFetchFavorites();\n\t },\n\t cleanUp: function cleanUp() {\n\t this.$store.dispatch('stopFetching', 'user');\n\t this.$store.dispatch('stopFetching', 'favorites');\n\t this.$store.dispatch('stopFetching', 'media');\n\t this.$store.commit('clearTimeline', { timeline: 'user' });\n\t this.$store.commit('clearTimeline', { timeline: 'favorites' });\n\t this.$store.commit('clearTimeline', { timeline: 'media' });\n\t }\n\t },\n\t watch: {\n\t userName: function userName() {\n\t if (this.isExternal) {\n\t return;\n\t }\n\t this.cleanUp();\n\t this.startUp();\n\t },\n\t userId: function userId() {\n\t if (!this.isExternal) {\n\t return;\n\t }\n\t this.cleanUp();\n\t this.startUp();\n\t },\n\t $route: function $route() {\n\t this.$refs.tabSwitcher.activateTab(0)();\n\t }\n\t },\n\t components: {\n\t UserCard: _user_card2.default,\n\t Timeline: _timeline2.default,\n\t FollowerList: FollowerList,\n\t FriendList: FriendList\n\t }\n\t};\n\t\n\texports.default = UserProfile;\n\n/***/ }),\n/* 303 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _follow_card = __webpack_require__(125);\n\t\n\tvar _follow_card2 = _interopRequireDefault(_follow_card);\n\t\n\tvar _user_search = __webpack_require__(242);\n\t\n\tvar _user_search2 = _interopRequireDefault(_user_search);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar userSearch = {\n\t components: {\n\t FollowCard: _follow_card2.default\n\t },\n\t props: ['query'],\n\t data: function data() {\n\t return {\n\t username: '',\n\t users: [],\n\t loading: false\n\t };\n\t },\n\t mounted: function mounted() {\n\t this.search(this.query);\n\t },\n\t\n\t watch: {\n\t query: function query(newV) {\n\t this.search(newV);\n\t }\n\t },\n\t methods: {\n\t newQuery: function newQuery(query) {\n\t this.$router.push({ name: 'user-search', query: { query: query } });\n\t this.$refs.userSearchInput.focus();\n\t },\n\t search: function search(query) {\n\t var _this = this;\n\t\n\t if (!query) {\n\t this.users = [];\n\t return;\n\t }\n\t this.loading = true;\n\t _user_search2.default.search({ query: query, store: this.$store }).then(function (res) {\n\t _this.loading = false;\n\t _this.users = res;\n\t });\n\t }\n\t }\n\t};\n\t\n\texports.default = userSearch;\n\n/***/ }),\n/* 304 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _stringify = __webpack_require__(64);\n\t\n\tvar _stringify2 = _interopRequireDefault(_stringify);\n\t\n\tvar _vueCompose = __webpack_require__(205);\n\t\n\tvar _unescape = __webpack_require__(203);\n\t\n\tvar _unescape2 = _interopRequireDefault(_unescape);\n\t\n\tvar _get = __webpack_require__(120);\n\t\n\tvar _get2 = _interopRequireDefault(_get);\n\t\n\tvar _tab_switcher = __webpack_require__(89);\n\t\n\tvar _tab_switcher2 = _interopRequireDefault(_tab_switcher);\n\t\n\tvar _image_cropper = __webpack_require__(647);\n\t\n\tvar _image_cropper2 = _interopRequireDefault(_image_cropper);\n\t\n\tvar _style_switcher = __webpack_require__(215);\n\t\n\tvar _style_switcher2 = _interopRequireDefault(_style_switcher);\n\t\n\tvar _file_size_format = __webpack_require__(133);\n\t\n\tvar _file_size_format2 = _interopRequireDefault(_file_size_format);\n\t\n\tvar _block_card = __webpack_require__(635);\n\t\n\tvar _block_card2 = _interopRequireDefault(_block_card);\n\t\n\tvar _mute_card = __webpack_require__(654);\n\t\n\tvar _mute_card2 = _interopRequireDefault(_mute_card);\n\t\n\tvar _with_subscription = __webpack_require__(223);\n\t\n\tvar _with_subscription2 = _interopRequireDefault(_with_subscription);\n\t\n\tvar _with_list = __webpack_require__(129);\n\t\n\tvar _with_list2 = _interopRequireDefault(_with_list);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar BlockList = (0, _vueCompose.compose)((0, _with_subscription2.default)({\n\t fetch: function fetch(props, $store) {\n\t return $store.dispatch('fetchBlocks');\n\t },\n\t select: function select(props, $store) {\n\t return (0, _get2.default)($store.state.users.currentUser, 'blockIds', []);\n\t },\n\t childPropName: 'entries'\n\t}), (0, _with_list2.default)({ getEntryProps: function getEntryProps(userId) {\n\t return { userId: userId };\n\t } }))(_block_card2.default);\n\t\n\tvar MuteList = (0, _vueCompose.compose)((0, _with_subscription2.default)({\n\t fetch: function fetch(props, $store) {\n\t return $store.dispatch('fetchMutes');\n\t },\n\t select: function select(props, $store) {\n\t return (0, _get2.default)($store.state.users.currentUser, 'muteIds', []);\n\t },\n\t childPropName: 'entries'\n\t}), (0, _with_list2.default)({ getEntryProps: function getEntryProps(userId) {\n\t return { userId: userId };\n\t } }))(_mute_card2.default);\n\t\n\tvar UserSettings = {\n\t data: function data() {\n\t return {\n\t newName: this.$store.state.users.currentUser.name,\n\t newBio: (0, _unescape2.default)(this.$store.state.users.currentUser.description),\n\t newLocked: this.$store.state.users.currentUser.locked,\n\t newNoRichText: this.$store.state.users.currentUser.no_rich_text,\n\t newDefaultScope: this.$store.state.users.currentUser.default_scope,\n\t hideFollows: this.$store.state.users.currentUser.hide_follows,\n\t hideFollowers: this.$store.state.users.currentUser.hide_followers,\n\t showRole: this.$store.state.users.currentUser.show_role,\n\t role: this.$store.state.users.currentUser.role,\n\t followList: null,\n\t followImportError: false,\n\t followsImported: false,\n\t enableFollowsExport: true,\n\t pickAvatarBtnVisible: true,\n\t bannerUploading: false,\n\t backgroundUploading: false,\n\t followListUploading: false,\n\t bannerPreview: null,\n\t backgroundPreview: null,\n\t bannerUploadError: null,\n\t backgroundUploadError: null,\n\t deletingAccount: false,\n\t deleteAccountConfirmPasswordInput: '',\n\t deleteAccountError: false,\n\t changePasswordInputs: ['', '', ''],\n\t changedPassword: false,\n\t changePasswordError: false,\n\t activeTab: 'profile'\n\t };\n\t },\n\t created: function created() {\n\t this.$store.dispatch('fetchTokens');\n\t },\n\t\n\t components: {\n\t StyleSwitcher: _style_switcher2.default,\n\t TabSwitcher: _tab_switcher2.default,\n\t ImageCropper: _image_cropper2.default,\n\t BlockList: BlockList,\n\t MuteList: MuteList\n\t },\n\t computed: {\n\t user: function user() {\n\t return this.$store.state.users.currentUser;\n\t },\n\t pleromaBackend: function pleromaBackend() {\n\t return this.$store.state.instance.pleromaBackend;\n\t },\n\t scopeOptionsEnabled: function scopeOptionsEnabled() {\n\t return this.$store.state.instance.scopeOptionsEnabled;\n\t },\n\t vis: function vis() {\n\t return {\n\t public: { selected: this.newDefaultScope === 'public' },\n\t unlisted: { selected: this.newDefaultScope === 'unlisted' },\n\t private: { selected: this.newDefaultScope === 'private' },\n\t direct: { selected: this.newDefaultScope === 'direct' }\n\t };\n\t },\n\t currentSaveStateNotice: function currentSaveStateNotice() {\n\t return this.$store.state.interface.settings.currentSaveStateNotice;\n\t },\n\t oauthTokens: function oauthTokens() {\n\t return this.$store.state.oauthTokens.tokens.map(function (oauthToken) {\n\t return {\n\t id: oauthToken.id,\n\t appName: oauthToken.app_name,\n\t validUntil: new Date(oauthToken.valid_until).toLocaleDateString()\n\t };\n\t });\n\t }\n\t },\n\t methods: {\n\t updateProfile: function updateProfile() {\n\t var _this = this;\n\t\n\t var name = this.newName;\n\t var description = this.newBio;\n\t var locked = this.newLocked;\n\t\n\t var default_scope = this.newDefaultScope;\n\t var no_rich_text = this.newNoRichText;\n\t var hide_follows = this.hideFollows;\n\t var hide_followers = this.hideFollowers;\n\t var show_role = this.showRole;\n\t\n\t this.$store.state.api.backendInteractor.updateProfile({\n\t params: {\n\t name: name,\n\t description: description,\n\t locked: locked,\n\t\n\t default_scope: default_scope,\n\t no_rich_text: no_rich_text,\n\t hide_follows: hide_follows,\n\t hide_followers: hide_followers,\n\t show_role: show_role\n\t } }).then(function (user) {\n\t if (!user.error) {\n\t _this.$store.commit('addNewUsers', [user]);\n\t _this.$store.commit('setCurrentUser', user);\n\t }\n\t });\n\t },\n\t changeVis: function changeVis(visibility) {\n\t this.newDefaultScope = visibility;\n\t },\n\t uploadFile: function uploadFile(slot, e) {\n\t var _this2 = this;\n\t\n\t var file = e.target.files[0];\n\t if (!file) {\n\t return;\n\t }\n\t if (file.size > this.$store.state.instance[slot + 'limit']) {\n\t var filesize = _file_size_format2.default.fileSizeFormat(file.size);\n\t var allowedsize = _file_size_format2.default.fileSizeFormat(this.$store.state.instance[slot + 'limit']);\n\t this[slot + 'UploadError'] = this.$t('upload.error.base') + ' ' + this.$t('upload.error.file_too_big', { filesize: filesize.num, filesizeunit: filesize.unit, allowedsize: allowedsize.num, allowedsizeunit: allowedsize.unit });\n\t return;\n\t }\n\t\n\t var reader = new FileReader();\n\t reader.onload = function (_ref) {\n\t var target = _ref.target;\n\t\n\t var img = target.result;\n\t _this2[slot + 'Preview'] = img;\n\t };\n\t reader.readAsDataURL(file);\n\t },\n\t submitAvatar: function submitAvatar(cropper, file) {\n\t var _this3 = this;\n\t\n\t var img = cropper.getCroppedCanvas().toDataURL(file.type);\n\t return this.$store.state.api.backendInteractor.updateAvatar({ params: { img: img } }).then(function (user) {\n\t if (!user.error) {\n\t _this3.$store.commit('addNewUsers', [user]);\n\t _this3.$store.commit('setCurrentUser', user);\n\t } else {\n\t throw new Error(_this3.$t('upload.error.base') + user.error);\n\t }\n\t });\n\t },\n\t clearUploadError: function clearUploadError(slot) {\n\t this[slot + 'UploadError'] = null;\n\t },\n\t submitBanner: function submitBanner() {\n\t var _this4 = this;\n\t\n\t if (!this.bannerPreview) {\n\t return;\n\t }\n\t\n\t var banner = this.bannerPreview;\n\t\n\t var imginfo = new Image();\n\t\n\t var offset_top = void 0,\n\t offset_left = void 0,\n\t width = void 0,\n\t height = void 0;\n\t imginfo.src = banner;\n\t width = imginfo.width;\n\t height = imginfo.height;\n\t offset_top = 0;\n\t offset_left = 0;\n\t this.bannerUploading = true;\n\t this.$store.state.api.backendInteractor.updateBanner({ params: { banner: banner, offset_top: offset_top, offset_left: offset_left, width: width, height: height } }).then(function (data) {\n\t if (!data.error) {\n\t var clone = JSON.parse((0, _stringify2.default)(_this4.$store.state.users.currentUser));\n\t clone.cover_photo = data.url;\n\t _this4.$store.commit('addNewUsers', [clone]);\n\t _this4.$store.commit('setCurrentUser', clone);\n\t _this4.bannerPreview = null;\n\t } else {\n\t _this4.bannerUploadError = _this4.$t('upload.error.base') + data.error;\n\t }\n\t _this4.bannerUploading = false;\n\t });\n\t },\n\t submitBg: function submitBg() {\n\t var _this5 = this;\n\t\n\t if (!this.backgroundPreview) {\n\t return;\n\t }\n\t var img = this.backgroundPreview;\n\t\n\t var imginfo = new Image();\n\t var cropX = void 0,\n\t cropY = void 0,\n\t cropW = void 0,\n\t cropH = void 0;\n\t imginfo.src = img;\n\t cropX = 0;\n\t cropY = 0;\n\t cropW = imginfo.width;\n\t cropH = imginfo.width;\n\t this.backgroundUploading = true;\n\t this.$store.state.api.backendInteractor.updateBg({ params: { img: img, cropX: cropX, cropY: cropY, cropW: cropW, cropH: cropH } }).then(function (data) {\n\t if (!data.error) {\n\t var clone = JSON.parse((0, _stringify2.default)(_this5.$store.state.users.currentUser));\n\t clone.background_image = data.url;\n\t _this5.$store.commit('addNewUsers', [clone]);\n\t _this5.$store.commit('setCurrentUser', clone);\n\t _this5.backgroundPreview = null;\n\t } else {\n\t _this5.backgroundUploadError = _this5.$t('upload.error.base') + data.error;\n\t }\n\t _this5.backgroundUploading = false;\n\t });\n\t },\n\t importFollows: function importFollows() {\n\t var _this6 = this;\n\t\n\t this.followListUploading = true;\n\t var followList = this.followList;\n\t this.$store.state.api.backendInteractor.followImport({ params: followList }).then(function (status) {\n\t if (status) {\n\t _this6.followsImported = true;\n\t } else {\n\t _this6.followImportError = true;\n\t }\n\t _this6.followListUploading = false;\n\t });\n\t },\n\t exportPeople: function exportPeople(users, filename) {\n\t var UserAddresses = users.map(function (user) {\n\t if (user && user.is_local) {\n\t user.screen_name += '@' + location.hostname;\n\t }\n\t return user.screen_name;\n\t }).join('\\n');\n\t\n\t var fileToDownload = document.createElement('a');\n\t fileToDownload.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(UserAddresses));\n\t fileToDownload.setAttribute('download', filename);\n\t fileToDownload.style.display = 'none';\n\t document.body.appendChild(fileToDownload);\n\t fileToDownload.click();\n\t document.body.removeChild(fileToDownload);\n\t },\n\t exportFollows: function exportFollows() {\n\t var _this7 = this;\n\t\n\t this.enableFollowsExport = false;\n\t this.$store.state.api.backendInteractor.exportFriends({\n\t id: this.$store.state.users.currentUser.id\n\t }).then(function (friendList) {\n\t _this7.exportPeople(friendList, 'friends.csv');\n\t setTimeout(function () {\n\t _this7.enableFollowsExport = true;\n\t }, 2000);\n\t });\n\t },\n\t followListChange: function followListChange() {\n\t var formData = new FormData();\n\t formData.append('list', this.$refs.followlist.files[0]);\n\t this.followList = formData;\n\t },\n\t dismissImported: function dismissImported() {\n\t this.followsImported = false;\n\t this.followImportError = false;\n\t },\n\t confirmDelete: function confirmDelete() {\n\t this.deletingAccount = true;\n\t },\n\t deleteAccount: function deleteAccount() {\n\t var _this8 = this;\n\t\n\t this.$store.state.api.backendInteractor.deleteAccount({ password: this.deleteAccountConfirmPasswordInput }).then(function (res) {\n\t if (res.status === 'success') {\n\t _this8.$store.dispatch('logout');\n\t _this8.$router.push({ name: 'root' });\n\t } else {\n\t _this8.deleteAccountError = res.error;\n\t }\n\t });\n\t },\n\t changePassword: function changePassword() {\n\t var _this9 = this;\n\t\n\t var params = {\n\t password: this.changePasswordInputs[0],\n\t newPassword: this.changePasswordInputs[1],\n\t newPasswordConfirmation: this.changePasswordInputs[2]\n\t };\n\t this.$store.state.api.backendInteractor.changePassword(params).then(function (res) {\n\t if (res.status === 'success') {\n\t _this9.changedPassword = true;\n\t _this9.changePasswordError = false;\n\t _this9.logout();\n\t } else {\n\t _this9.changedPassword = false;\n\t _this9.changePasswordError = res.error;\n\t }\n\t });\n\t },\n\t activateTab: function activateTab(tabName) {\n\t this.activeTab = tabName;\n\t },\n\t logout: function logout() {\n\t this.$store.dispatch('logout');\n\t this.$router.replace('/');\n\t },\n\t revokeToken: function revokeToken(id) {\n\t if (window.confirm(this.$i18n.t('settings.revoke_token') + '?')) {\n\t this.$store.dispatch('revokeToken', id);\n\t }\n\t }\n\t }\n\t};\n\t\n\texports.default = UserSettings;\n\n/***/ }),\n/* 305 */\n/***/ (function(module, exports) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar VideoAttachment = {\n\t props: ['attachment', 'controls'],\n\t data: function data() {\n\t return {\n\t loopVideo: this.$store.state.config.loopVideo\n\t };\n\t },\n\t\n\t methods: {\n\t onVideoDataLoad: function onVideoDataLoad(e) {\n\t var target = e.srcElement || e.target;\n\t if (typeof target.webkitAudioDecodedByteCount !== 'undefined') {\n\t if (target.webkitAudioDecodedByteCount > 0) {\n\t this.loopVideo = this.loopVideo && !this.$store.state.config.loopVideoSilentOnly;\n\t }\n\t } else if (typeof target.mozHasAudio !== 'undefined') {\n\t if (target.mozHasAudio) {\n\t this.loopVideo = this.loopVideo && !this.$store.state.config.loopVideoSilentOnly;\n\t }\n\t } else if (typeof target.audioTracks !== 'undefined') {\n\t if (target.audioTracks.length > 0) {\n\t this.loopVideo = this.loopVideo && !this.$store.state.config.loopVideoSilentOnly;\n\t }\n\t }\n\t }\n\t }\n\t};\n\t\n\texports.default = VideoAttachment;\n\n/***/ }),\n/* 306 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _apiService = __webpack_require__(18);\n\t\n\tvar _apiService2 = _interopRequireDefault(_apiService);\n\t\n\tvar _follow_card = __webpack_require__(125);\n\t\n\tvar _follow_card2 = _interopRequireDefault(_follow_card);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tvar WhoToFollow = {\n\t components: {\n\t FollowCard: _follow_card2.default\n\t },\n\t data: function data() {\n\t return {\n\t users: []\n\t };\n\t },\n\t mounted: function mounted() {\n\t this.getWhoToFollow();\n\t },\n\t\n\t methods: {\n\t showWhoToFollow: function showWhoToFollow(reply) {\n\t var _this = this;\n\t\n\t reply.forEach(function (i, index) {\n\t var user = {\n\t id: 0,\n\t name: i.display_name,\n\t screen_name: i.acct,\n\t profile_image_url: i.avatar || '/images/avi.png'\n\t };\n\t _this.users.push(user);\n\t\n\t _this.$store.state.api.backendInteractor.externalProfile(user.screen_name).then(function (externalUser) {\n\t if (!externalUser.error) {\n\t _this.$store.commit('addNewUsers', [externalUser]);\n\t user.id = externalUser.id;\n\t }\n\t });\n\t });\n\t },\n\t getWhoToFollow: function getWhoToFollow() {\n\t var _this2 = this;\n\t\n\t var credentials = this.$store.state.users.currentUser.credentials;\n\t if (credentials) {\n\t _apiService2.default.suggestions({ credentials: credentials }).then(function (reply) {\n\t _this2.showWhoToFollow(reply);\n\t });\n\t }\n\t }\n\t }\n\t};\n\t\n\texports.default = WhoToFollow;\n\n/***/ }),\n/* 307 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t'use strict';\n\t\n\tObject.defineProperty(exports, \"__esModule\", {\n\t value: true\n\t});\n\t\n\tvar _shuffle2 = __webpack_require__(610);\n\t\n\tvar _shuffle3 = _interopRequireDefault(_shuffle2);\n\t\n\tvar _apiService = __webpack_require__(18);\n\t\n\tvar _apiService2 = _interopRequireDefault(_apiService);\n\t\n\tvar _user_profile_link_generator = __webpack_require__(35);\n\t\n\tvar _user_profile_link_generator2 = _interopRequireDefault(_user_profile_link_generator);\n\t\n\tfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\t\n\tfunction showWhoToFollow(panel, reply) {\n\t var shuffled = (0, _shuffle3.default)(reply);\n\t\n\t panel.usersToFollow.forEach(function (toFollow, index) {\n\t var user = shuffled[index];\n\t var img = user.avatar || '/images/avi.png';\n\t var name = user.acct;\n\t\n\t toFollow.img = img;\n\t toFollow.name = name;\n\t\n\t panel.$store.state.api.backendInteractor.externalProfile(name).then(function (externalUser) {\n\t if (!externalUser.error) {\n\t panel.$store.commit('addNewUsers', [externalUser]);\n\t toFollow.id = externalUser.id;\n\t }\n\t });\n\t });\n\t}\n\t\n\tfunction getWhoToFollow(panel) {\n\t var credentials = panel.$store.state.users.currentUser.credentials;\n\t if (credentials) {\n\t panel.usersToFollow.forEach(function (toFollow) {\n\t toFollow.name = 'Loading...';\n\t });\n\t _apiService2.default.suggestions({ credentials: credentials }).then(function (reply) {\n\t showWhoToFollow(panel, reply);\n\t });\n\t }\n\t}\n\t\n\tvar WhoToFollowPanel = {\n\t data: function data() {\n\t return {\n\t usersToFollow: new Array(3).fill().map(function (x) {\n\t return {\n\t img: '/images/avi.png',\n\t name: '',\n\t id: 0\n\t };\n\t })\n\t };\n\t },\n\t computed: {\n\t user: function user() {\n\t return this.$store.state.users.currentUser.screen_name;\n\t },\n\t suggestionsEnabled: function suggestionsEnabled() {\n\t return this.$store.state.instance.suggestionsEnabled;\n\t }\n\t },\n\t methods: {\n\t userProfileLink: function userProfileLink(id, name) {\n\t return (0, _user_profile_link_generator2.default)(id, name, this.$store.state.instance.restrictedNicknames);\n\t }\n\t },\n\t watch: {\n\t user: function user(_user, oldUser) {\n\t if (this.suggestionsEnabled) {\n\t getWhoToFollow(this);\n\t }\n\t }\n\t },\n\t mounted: function mounted() {\n\t if (this.suggestionsEnabled) {\n\t getWhoToFollow(this);\n\t }\n\t }\n\t};\n\t\n\texports.default = WhoToFollowPanel;\n\n/***/ }),\n/* 308 */,\n/* 309 */,\n/* 310 */,\n/* 311 */,\n/* 312 */,\n/* 313 */,\n/* 314 */,\n/* 315 */,\n/* 316 */,\n/* 317 */,\n/* 318 */,\n/* 319 */,\n/* 320 */,\n/* 321 */,\n/* 322 */,\n/* 323 */,\n/* 324 */,\n/* 325 */,\n/* 326 */,\n/* 327 */,\n/* 328 */,\n/* 329 */,\n/* 330 */,\n/* 331 */,\n/* 332 */,\n/* 333 */,\n/* 334 */,\n/* 335 */,\n/* 336 */,\n/* 337 */,\n/* 338 */,\n/* 339 */,\n/* 340 */,\n/* 341 */,\n/* 342 */,\n/* 343 */,\n/* 344 */,\n/* 345 */,\n/* 346 */,\n/* 347 */,\n/* 348 */,\n/* 349 */,\n/* 350 */,\n/* 351 */,\n/* 352 */,\n/* 353 */,\n/* 354 */,\n/* 355 */,\n/* 356 */,\n/* 357 */,\n/* 358 */,\n/* 359 */,\n/* 360 */,\n/* 361 */,\n/* 362 */,\n/* 363 */,\n/* 364 */,\n/* 365 */,\n/* 366 */,\n/* 367 */,\n/* 368 */,\n/* 369 */,\n/* 370 */,\n/* 371 */,\n/* 372 */,\n/* 373 */,\n/* 374 */,\n/* 375 */,\n/* 376 */,\n/* 377 */,\n/* 378 */,\n/* 379 */,\n/* 380 */,\n/* 381 */,\n/* 382 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 383 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 384 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 385 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 386 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 387 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 388 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 389 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 390 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 391 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 392 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 393 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 394 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 395 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 396 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 397 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 398 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 399 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 400 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 401 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 402 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 403 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 404 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 405 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 406 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 407 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 408 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 409 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 410 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 411 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 412 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 413 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 414 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 415 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 416 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 417 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 418 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 419 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 420 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 421 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 422 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 423 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 424 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 425 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 426 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 427 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 428 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 429 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 430 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 431 */\n/***/ (function(module, exports) {\n\n\t// removed by extract-text-webpack-plugin\n\n/***/ }),\n/* 432 */,\n/* 433 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = {\"chat\":{\"title\":\"الدردشة\"},\"features_panel\":{\"chat\":\"الدردشة\",\"gopher\":\"غوفر\",\"media_proxy\":\"بروكسي الوسائط\",\"scope_options\":\"\",\"text_limit\":\"الحد الأقصى للنص\",\"title\":\"الميّزات\",\"who_to_follow\":\"للمتابعة\"},\"finder\":{\"error_fetching_user\":\"خطأ أثناء جلب صفحة المستخدم\",\"find_user\":\"البحث عن مستخدِم\"},\"general\":{\"apply\":\"تطبيق\",\"submit\":\"إرسال\"},\"login\":{\"login\":\"تسجيل الدخول\",\"logout\":\"الخروج\",\"password\":\"الكلمة السرية\",\"placeholder\":\"مثال lain\",\"register\":\"انشاء حساب\",\"username\":\"إسم المستخدم\"},\"nav\":{\"chat\":\"الدردشة المحلية\",\"friend_requests\":\"طلبات المتابَعة\",\"mentions\":\"الإشارات\",\"public_tl\":\"الخيط الزمني العام\",\"timeline\":\"الخيط الزمني\",\"twkn\":\"كافة الشبكة المعروفة\"},\"notifications\":{\"broken_favorite\":\"منشور مجهول، جارٍ البحث عنه…\",\"favorited_you\":\"أعجِب بمنشورك\",\"followed_you\":\"يُتابعك\",\"load_older\":\"تحميل الإشعارات الأقدم\",\"notifications\":\"الإخطارات\",\"read\":\"مقروء!\",\"repeated_you\":\"شارَك منشورك\"},\"post_status\":{\"account_not_locked_warning\":\"\",\"account_not_locked_warning_link\":\"مقفل\",\"attachments_sensitive\":\"اعتبر المرفقات كلها كمحتوى حساس\",\"content_type\":{\"plain_text\":\"نص صافٍ\"},\"content_warning\":\"الموضوع (اختياري)\",\"default\":\"وصلت للتوّ إلى لوس أنجلس.\",\"direct_warning\":\"\",\"posting\":\"النشر\",\"scope\":{\"direct\":\"\",\"private\":\"\",\"public\":\"علني - يُنشر على الخيوط الزمنية العمومية\",\"unlisted\":\"غير مُدرَج - لا يُنشَر على الخيوط الزمنية العمومية\"}},\"registration\":{\"bio\":\"السيرة الذاتية\",\"email\":\"عنوان البريد الإلكتروني\",\"fullname\":\"الإسم المعروض\",\"password_confirm\":\"تأكيد الكلمة السرية\",\"registration\":\"التسجيل\",\"token\":\"رمز الدعوة\"},\"settings\":{\"attachmentRadius\":\"المُرفَقات\",\"attachments\":\"المُرفَقات\",\"autoload\":\"\",\"avatar\":\"الصورة الرمزية\",\"avatarAltRadius\":\"الصور الرمزية (الإشعارات)\",\"avatarRadius\":\"الصور الرمزية\",\"background\":\"الخلفية\",\"bio\":\"السيرة الذاتية\",\"btnRadius\":\"الأزرار\",\"cBlue\":\"أزرق (الرد، المتابَعة)\",\"cGreen\":\"أخضر (إعادة النشر)\",\"cOrange\":\"برتقالي (مفضلة)\",\"cRed\":\"أحمر (إلغاء)\",\"change_password\":\"تغيير كلمة السر\",\"change_password_error\":\"وقع هناك خلل أثناء تعديل كلمتك السرية.\",\"changed_password\":\"تم تغيير كلمة المرور بنجاح!\",\"collapse_subject\":\"\",\"confirm_new_password\":\"تأكيد كلمة السر الجديدة\",\"current_avatar\":\"صورتك الرمزية الحالية\",\"current_password\":\"كلمة السر الحالية\",\"current_profile_banner\":\"الرأسية الحالية لصفحتك الشخصية\",\"data_import_export_tab\":\"تصدير واستيراد البيانات\",\"default_vis\":\"أسلوب العرض الافتراضي\",\"delete_account\":\"حذف الحساب\",\"delete_account_description\":\"حذف حسابك و كافة منشوراتك نهائيًا.\",\"delete_account_error\":\"\",\"delete_account_instructions\":\"يُرجى إدخال كلمتك السرية أدناه لتأكيد عملية حذف الحساب.\",\"export_theme\":\"حفظ النموذج\",\"filtering\":\"التصفية\",\"filtering_explanation\":\"سيتم إخفاء كافة المنشورات التي تحتوي على هذه الكلمات، كلمة واحدة في كل سطر\",\"follow_export\":\"تصدير الاشتراكات\",\"follow_export_button\":\"تصدير الاشتراكات كملف csv\",\"follow_export_processing\":\"التصدير جارٍ، سوف يُطلَب منك تنزيل ملفك بعد حين\",\"follow_import\":\"استيراد الاشتراكات\",\"follow_import_error\":\"خطأ أثناء استيراد المتابِعين\",\"follows_imported\":\"\",\"foreground\":\"الأمامية\",\"general\":\"الإعدادات العامة\",\"hide_attachments_in_convo\":\"إخفاء المرفقات على المحادثات\",\"hide_attachments_in_tl\":\"إخفاء المرفقات على الخيط الزمني\",\"hide_post_stats\":\"\",\"hide_user_stats\":\"\",\"import_followers_from_a_csv_file\":\"\",\"import_theme\":\"تحميل نموذج\",\"inputRadius\":\"\",\"instance_default\":\"\",\"interfaceLanguage\":\"لغة الواجهة\",\"invalid_theme_imported\":\"\",\"limited_availability\":\"غير متوفر على متصفحك\",\"links\":\"الروابط\",\"lock_account_description\":\"\",\"loop_video\":\"\",\"loop_video_silent_only\":\"\",\"name\":\"الاسم\",\"name_bio\":\"الاسم والسيرة الذاتية\",\"new_password\":\"كلمة السر الجديدة\",\"no_rich_text_description\":\"\",\"notification_visibility\":\"نوع الإشعارات التي تريد عرضها\",\"notification_visibility_follows\":\"يتابع\",\"notification_visibility_likes\":\"الإعجابات\",\"notification_visibility_mentions\":\"الإشارات\",\"notification_visibility_repeats\":\"\",\"nsfw_clickthrough\":\"\",\"oauth_tokens\":\"رموز OAuth\",\"token\":\"رمز\",\"refresh_token\":\"رمز التحديث\",\"valid_until\":\"صالح حتى\",\"revoke_token\":\"سحب\",\"panelRadius\":\"\",\"pause_on_unfocused\":\"\",\"presets\":\"النماذج\",\"profile_background\":\"خلفية الصفحة الشخصية\",\"profile_banner\":\"رأسية الصفحة الشخصية\",\"profile_tab\":\"الملف الشخصي\",\"radii_help\":\"\",\"replies_in_timeline\":\"الردود على الخيط الزمني\",\"reply_link_preview\":\"\",\"reply_visibility_all\":\"عرض كافة الردود\",\"reply_visibility_following\":\"\",\"reply_visibility_self\":\"\",\"saving_err\":\"خطأ أثناء حفظ الإعدادات\",\"saving_ok\":\"تم حفظ الإعدادات\",\"security_tab\":\"الأمان\",\"set_new_avatar\":\"اختيار صورة رمزية جديدة\",\"set_new_profile_background\":\"اختيار خلفية جديدة للملف الشخصي\",\"set_new_profile_banner\":\"اختيار رأسية جديدة للصفحة الشخصية\",\"settings\":\"الإعدادات\",\"stop_gifs\":\"\",\"streaming\":\"\",\"text\":\"النص\",\"theme\":\"المظهر\",\"theme_help\":\"\",\"tooltipRadius\":\"\",\"user_settings\":\"إعدادات المستخدم\",\"values\":{\"false\":\"لا\",\"true\":\"نعم\"}},\"timeline\":{\"collapse\":\"\",\"conversation\":\"محادثة\",\"error_fetching\":\"خطأ أثناء جلب التحديثات\",\"load_older\":\"تحميل المنشورات القديمة\",\"no_retweet_hint\":\"\",\"repeated\":\"\",\"show_new\":\"عرض الجديد\",\"up_to_date\":\"تم تحديثه\"},\"user_card\":{\"approve\":\"قبول\",\"block\":\"حظر\",\"blocked\":\"تم حظره!\",\"deny\":\"رفض\",\"follow\":\"اتبع\",\"followees\":\"\",\"followers\":\"مُتابِعون\",\"following\":\"\",\"follows_you\":\"يتابعك!\",\"mute\":\"كتم\",\"muted\":\"تم كتمه\",\"per_day\":\"في اليوم\",\"remote_follow\":\"مُتابَعة عن بُعد\",\"statuses\":\"المنشورات\"},\"user_profile\":{\"timeline_title\":\"الخيط الزمني للمستخدم\"},\"who_to_follow\":{\"more\":\"المزيد\",\"who_to_follow\":\"للمتابعة\"}}\n\n/***/ }),\n/* 434 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = {\"chat\":{\"title\":\"Xat\"},\"features_panel\":{\"chat\":\"Xat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Proxy per multimèdia\",\"scope_options\":\"Opcions d'abast i visibilitat\",\"text_limit\":\"Límit de text\",\"title\":\"Funcionalitats\",\"who_to_follow\":\"A qui seguir\"},\"finder\":{\"error_fetching_user\":\"No s'ha pogut carregar l'usuari/a\",\"find_user\":\"Find user\"},\"general\":{\"apply\":\"Aplica\",\"submit\":\"Desa\"},\"login\":{\"login\":\"Inicia sessió\",\"logout\":\"Tanca la sessió\",\"password\":\"Contrasenya\",\"placeholder\":\"p.ex.: Maria\",\"register\":\"Registra't\",\"username\":\"Nom d'usuari/a\"},\"nav\":{\"chat\":\"Xat local públic\",\"friend_requests\":\"Soŀlicituds de connexió\",\"mentions\":\"Mencions\",\"public_tl\":\"Flux públic del node\",\"timeline\":\"Flux personal\",\"twkn\":\"Flux de la xarxa coneguda\"},\"notifications\":{\"broken_favorite\":\"No es coneix aquest estat. S'està cercant.\",\"favorited_you\":\"ha marcat un estat teu\",\"followed_you\":\"ha començat a seguir-te\",\"load_older\":\"Carrega més notificacions\",\"notifications\":\"Notificacions\",\"read\":\"Read!\",\"repeated_you\":\"ha repetit el teu estat\"},\"post_status\":{\"account_not_locked_warning\":\"El teu compte no està {0}. Qualsevol persona pot seguir-te per llegir les teves entrades reservades només a seguidores.\",\"account_not_locked_warning_link\":\"bloquejat\",\"attachments_sensitive\":\"Marca l'adjunt com a delicat\",\"content_type\":{\"plain_text\":\"Text pla\"},\"content_warning\":\"Assumpte (opcional)\",\"default\":\"Em sento…\",\"direct_warning\":\"Aquesta entrada només serà visible per les usuràries que etiquetis\",\"posting\":\"Publicació\",\"scope\":{\"direct\":\"Directa - Publica només per les usuàries etiquetades\",\"private\":\"Només seguidors/es - Publica només per comptes que et segueixin\",\"public\":\"Pública - Publica als fluxos públics\",\"unlisted\":\"Silenciosa - No la mostris en fluxos públics\"}},\"registration\":{\"bio\":\"Presentació\",\"email\":\"Correu\",\"fullname\":\"Nom per mostrar\",\"password_confirm\":\"Confirma la contrasenya\",\"registration\":\"Registra't\",\"token\":\"Codi d'invitació\"},\"settings\":{\"attachmentRadius\":\"Adjunts\",\"attachments\":\"Adjunts\",\"autoload\":\"Recarrega automàticament en arribar a sota de tot.\",\"avatar\":\"Avatar\",\"avatarAltRadius\":\"Avatars en les notificacions\",\"avatarRadius\":\"Avatars\",\"background\":\"Fons de pantalla\",\"bio\":\"Presentació\",\"btnRadius\":\"Botons\",\"cBlue\":\"Blau (respon, segueix)\",\"cGreen\":\"Verd (republica)\",\"cOrange\":\"Taronja (marca com a preferit)\",\"cRed\":\"Vermell (canceŀla)\",\"change_password\":\"Canvia la contrasenya\",\"change_password_error\":\"No s'ha pogut canviar la contrasenya\",\"changed_password\":\"S'ha canviat la contrasenya\",\"collapse_subject\":\"Replega les entrades amb títol\",\"confirm_new_password\":\"Confirma la nova contrasenya\",\"current_avatar\":\"L'avatar actual\",\"current_password\":\"La contrasenya actual\",\"current_profile_banner\":\"El fons de perfil actual\",\"data_import_export_tab\":\"Importa o exporta dades\",\"default_vis\":\"Abast per defecte de les entrades\",\"delete_account\":\"Esborra el compte\",\"delete_account_description\":\"Esborra permanentment el teu compte i tots els missatges\",\"delete_account_error\":\"No s'ha pogut esborrar el compte. Si continua el problema, contacta amb l'administració del node\",\"delete_account_instructions\":\"Confirma que vols esborrar el compte escrivint la teva contrasenya aquí sota\",\"export_theme\":\"Desa el tema\",\"filtering\":\"Filtres\",\"filtering_explanation\":\"Es silenciaran totes les entrades que continguin aquestes paraules. Separa-les per línies\",\"follow_export\":\"Exporta la llista de contactes\",\"follow_export_button\":\"Exporta tots els comptes que segueixes a un fitxer CSV\",\"follow_export_processing\":\"S'està processant la petició. Aviat podràs descarregar el fitxer\",\"follow_import\":\"Importa els contactes\",\"follow_import_error\":\"No s'ha pogut importar els contactes\",\"follows_imported\":\"S'han importat els contactes. Trigaran una estoneta en ser processats.\",\"foreground\":\"Primer pla\",\"general\":\"General\",\"hide_attachments_in_convo\":\"Amaga els adjunts en les converses\",\"hide_attachments_in_tl\":\"Amaga els adjunts en el flux d'entrades\",\"import_followers_from_a_csv_file\":\"Importa els contactes des d'un fitxer CSV\",\"import_theme\":\"Carrega un tema\",\"inputRadius\":\"Caixes d'entrada de text\",\"instance_default\":\"(default: {value})\",\"interfaceLanguage\":\"Llengua de la interfície\",\"invalid_theme_imported\":\"No s'ha entès l'arxiu carregat perquè no és un tema vàlid de Pleroma. No s'ha fet cap canvi als temes actuals.\",\"limited_availability\":\"No està disponible en aquest navegador\",\"links\":\"Enllaços\",\"lock_account_description\":\"Restringeix el teu compte només a seguidores aprovades.\",\"loop_video\":\"Reprodueix els vídeos en bucle\",\"loop_video_silent_only\":\"Reprodueix en bucles només els vídeos sense so (com els \\\"GIF\\\" de Mastodon)\",\"name\":\"Nom\",\"name_bio\":\"Nom i presentació\",\"new_password\":\"Contrasenya nova\",\"notification_visibility\":\"Notifica'm quan algú\",\"notification_visibility_follows\":\"Comença a seguir-me\",\"notification_visibility_likes\":\"Marca com a preferida una entrada meva\",\"notification_visibility_mentions\":\"Em menciona\",\"notification_visibility_repeats\":\"Republica una entrada meva\",\"no_rich_text_description\":\"Neteja el formatat de text de totes les entrades\",\"nsfw_clickthrough\":\"Amaga el contingut NSFW darrer d'una imatge clicable\",\"oauth_tokens\":\"Llistats OAuth\",\"token\":\"Token\",\"refresh_token\":\"Actualitza el token\",\"valid_until\":\"Vàlid fins\",\"revoke_token\":\"Revocar\",\"panelRadius\":\"Panells\",\"pause_on_unfocused\":\"Pausa la reproducció en continu quan la pestanya perdi el focus\",\"presets\":\"Temes\",\"profile_background\":\"Fons de pantalla\",\"profile_banner\":\"Fons de perfil\",\"profile_tab\":\"Perfil\",\"radii_help\":\"Configura l'arrodoniment de les vores (en píxels)\",\"replies_in_timeline\":\"Replies in timeline\",\"reply_link_preview\":\"Mostra el missatge citat en passar el ratolí per sobre de l'enllaç de resposta\",\"reply_visibility_all\":\"Mostra totes les respostes\",\"reply_visibility_following\":\"Mostra només les respostes a entrades meves o d'usuàries que jo segueixo\",\"reply_visibility_self\":\"Mostra només les respostes a entrades meves\",\"saving_err\":\"No s'ha pogut desar la configuració\",\"saving_ok\":\"S'ha desat la configuració\",\"security_tab\":\"Seguretat\",\"set_new_avatar\":\"Canvia l'avatar\",\"set_new_profile_background\":\"Canvia el fons de pantalla\",\"set_new_profile_banner\":\"Canvia el fons del perfil\",\"settings\":\"Configuració\",\"stop_gifs\":\"Anima els GIF només en passar-hi el ratolí per sobre\",\"streaming\":\"Carrega automàticament entrades noves quan estigui a dalt de tot\",\"text\":\"Text\",\"theme\":\"Tema\",\"theme_help\":\"Personalitza els colors del tema. Escriu-los en format RGB hexadecimal (#rrggbb)\",\"tooltipRadius\":\"Missatges sobreposats\",\"user_settings\":\"Configuració personal\",\"values\":{\"false\":\"no\",\"true\":\"sí\"}},\"timeline\":{\"collapse\":\"Replega\",\"conversation\":\"Conversa\",\"error_fetching\":\"S'ha produït un error en carregar les entrades\",\"load_older\":\"Carrega entrades anteriors\",\"no_retweet_hint\":\"L'entrada és només per a seguidores o és \\\"directa\\\", i per tant no es pot republicar\",\"repeated\":\"republicat\",\"show_new\":\"Mostra els nous\",\"up_to_date\":\"Actualitzat\"},\"user_card\":{\"approve\":\"Aprova\",\"block\":\"Bloqueja\",\"blocked\":\"Bloquejat!\",\"deny\":\"Denega\",\"follow\":\"Segueix\",\"followees\":\"Segueixo\",\"followers\":\"Seguidors/es\",\"following\":\"Seguint!\",\"follows_you\":\"Et segueix!\",\"mute\":\"Silencia\",\"muted\":\"Silenciat\",\"per_day\":\"per dia\",\"remote_follow\":\"Seguiment remot\",\"statuses\":\"Estats\"},\"user_profile\":{\"timeline_title\":\"Flux personal\"},\"who_to_follow\":{\"more\":\"More\",\"who_to_follow\":\"A qui seguir\"}}\n\n/***/ }),\n/* 435 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = {\"chat\":{\"title\":\"Chat\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Mediální proxy\",\"scope_options\":\"Možnosti rozsahů\",\"text_limit\":\"Textový limit\",\"title\":\"Vlastnosti\",\"who_to_follow\":\"Koho sledovat\"},\"finder\":{\"error_fetching_user\":\"Chyba při načítání uživatele\",\"find_user\":\"Najít uživatele\"},\"general\":{\"apply\":\"Použít\",\"submit\":\"Odeslat\",\"more\":\"Více\",\"generic_error\":\"Vyskytla se chyba\",\"optional\":\"volitelné\"},\"image_cropper\":{\"crop_picture\":\"Oříznout obrázek\",\"save\":\"Uložit\",\"cancel\":\"Zrušit\"},\"login\":{\"login\":\"Přihlásit\",\"description\":\"Přihlásit pomocí OAuth\",\"logout\":\"Odhlásit\",\"password\":\"Heslo\",\"placeholder\":\"např. lain\",\"register\":\"Registrovat\",\"username\":\"Uživatelské jméno\",\"hint\":\"Chcete-li se přidat do diskuze, přihlaste se\"},\"media_modal\":{\"previous\":\"Předchozí\",\"next\":\"Další\"},\"nav\":{\"about\":\"O instanci\",\"back\":\"Zpět\",\"chat\":\"Místní chat\",\"friend_requests\":\"Požadavky o sledování\",\"mentions\":\"Zmínky\",\"dms\":\"Přímé zprávy\",\"public_tl\":\"Veřejná časová osa\",\"timeline\":\"Časová osa\",\"twkn\":\"Celá známá síť\",\"user_search\":\"Hledání uživatelů\",\"who_to_follow\":\"Koho sledovat\",\"preferences\":\"Předvolby\"},\"notifications\":{\"broken_favorite\":\"Neznámý příspěvek, hledám jej…\",\"favorited_you\":\"si oblíbil/a váš příspěvek\",\"followed_you\":\"vás nyní sleduje\",\"load_older\":\"Načíst starší oznámení\",\"notifications\":\"Oznámení\",\"read\":\"Číst!\",\"repeated_you\":\"zopakoval/a váš příspěvek\",\"no_more_notifications\":\"Žádná další oznámení\"},\"post_status\":{\"new_status\":\"Napsat nový příspěvek\",\"account_not_locked_warning\":\"Váš účet není {0}. Kdokoliv vás může sledovat a vidět vaše příspěvky pouze pro sledující.\",\"account_not_locked_warning_link\":\"uzamčen\",\"attachments_sensitive\":\"Označovat přílohy jako citlivé\",\"content_type\":{\"plain_text\":\"Prostý text\",\"text/html\":\"HTML\",\"text/markdown\":\"Markdown\"},\"content_warning\":\"Předmět (volitelný)\",\"default\":\"Právě jsem přistál v L.A.\",\"direct_warning\":\"Tento příspěvek uvidí pouze všichni zmínění uživatelé.\",\"posting\":\"Přispívání\",\"scope\":{\"direct\":\"Přímý - Poslat pouze zmíněným uživatelům\",\"private\":\"Pouze pro sledující - Poslat pouze sledujícím\",\"public\":\"Veřejný - Poslat na veřejné časové osy\",\"unlisted\":\"Neuvedený - Neposlat na veřejné časové osy\"}},\"registration\":{\"bio\":\"O vás\",\"email\":\"E-mail\",\"fullname\":\"Zobrazované jméno\",\"password_confirm\":\"Potvrzení hesla\",\"registration\":\"Registrace\",\"token\":\"Token pozvánky\",\"captcha\":\"CAPTCHA\",\"new_captcha\":\"Kliknutím na obrázek získáte novou CAPTCHA\",\"username_placeholder\":\"např. lain\",\"fullname_placeholder\":\"např. Lain Iwakura\",\"bio_placeholder\":\"např.\\nNazdar, jsem Lain\\nJsem anime dívka žijící v příměstském Japonsku. Možná mě znáte z Wired.\",\"validations\":{\"username_required\":\"nemůže být prázdné\",\"fullname_required\":\"nemůže být prázdné\",\"email_required\":\"nemůže být prázdný\",\"password_required\":\"nemůže být prázdné\",\"password_confirmation_required\":\"nemůže být prázdné\",\"password_confirmation_match\":\"musí být stejné jako heslo\"}},\"settings\":{\"app_name\":\"Název aplikace\",\"attachmentRadius\":\"Přílohy\",\"attachments\":\"Přílohy\",\"autoload\":\"Povolit automatické načítání při rolování dolů\",\"avatar\":\"Avatar\",\"avatarAltRadius\":\"Avatary (oznámení)\",\"avatarRadius\":\"Avatary\",\"background\":\"Pozadí\",\"bio\":\"O vás\",\"blocks_tab\":\"Blokování\",\"btnRadius\":\"Tlačítka\",\"cBlue\":\"Modrá (Odpovědět, sledovat)\",\"cGreen\":\"Zelená (Zopakovat)\",\"cOrange\":\"Oranžová (Oblíbit)\",\"cRed\":\"Červená (Zrušit)\",\"change_password\":\"Změnit heslo\",\"change_password_error\":\"Při změně vašeho hesla se vyskytla chyba.\",\"changed_password\":\"Heslo bylo úspěšně změněno!\",\"collapse_subject\":\"Zabalit příspěvky s předměty\",\"composing\":\"Komponování\",\"confirm_new_password\":\"Potvrďte nové heslo\",\"current_avatar\":\"Váš současný avatar\",\"current_password\":\"Současné heslo\",\"current_profile_banner\":\"Váš současný profilový banner\",\"data_import_export_tab\":\"Import/export dat\",\"default_vis\":\"Výchozí rozsah viditelnosti\",\"delete_account\":\"Smazat účet\",\"delete_account_description\":\"Trvale smaže váš účet a všechny vaše příspěvky.\",\"delete_account_error\":\"Při mazání vašeho účtu nastala chyba. Pokud tato chyba bude trvat, kontaktujte prosím admministrátora vaší instance.\",\"delete_account_instructions\":\"Pro potvrzení smazání účtu napište své heslo do pole níže.\",\"avatar_size_instruction\":\"Doporučená minimální velikost pro avatarové obrázky je 150x150 pixelů.\",\"export_theme\":\"Uložit přednastavení\",\"filtering\":\"Filtrování\",\"filtering_explanation\":\"Všechny příspěvky obsahující tato slova budou skryty. Napište jedno slovo na každý řádek\",\"follow_export\":\"Export sledovaných\",\"follow_export_button\":\"Exportovat vaše sledované do souboru CSV\",\"follow_export_processing\":\"Zpracovávám, brzy si budete moci stáhnout váš soubor\",\"follow_import\":\"Import sledovaných\",\"follow_import_error\":\"Chyba při importování sledovaných\",\"follows_imported\":\"Sledovaní importováni! Jejich zpracování bude chvilku trvat.\",\"foreground\":\"Popředí\",\"general\":\"Obecné\",\"hide_attachments_in_convo\":\"Skrývat přílohy v konverzacích\",\"hide_attachments_in_tl\":\"Skrývat přílohy v časové ose\",\"max_thumbnails\":\"Maximální počet miniatur na příspěvek\",\"hide_isp\":\"Skrýt panel specifický pro instanci\",\"preload_images\":\"Přednačítat obrázky\",\"use_one_click_nsfw\":\"Otevírat citlivé přílohy pouze jedním kliknutím\",\"hide_post_stats\":\"Skrývat statistiky příspěvků (např. počet oblíbení)\",\"hide_user_stats\":\"Skrývat statistiky uživatelů (např. počet sledujících)\",\"hide_filtered_statuses\":\"Skrývat filtrované příspěvky\",\"import_followers_from_a_csv_file\":\"Importovat sledované ze souboru CSV\",\"import_theme\":\"Načíst přednastavení\",\"inputRadius\":\"Vstupní pole\",\"checkboxRadius\":\"Zaškrtávací pole\",\"instance_default\":\"(výchozí: {value})\",\"instance_default_simple\":\"(výchozí)\",\"interface\":\"Rozhraní\",\"interfaceLanguage\":\"Jazyk rozhraní\",\"invalid_theme_imported\":\"Zvolený soubor není podporovaný motiv Pleroma. Nebyly provedeny žádné změny s vaším motivem.\",\"limited_availability\":\"Nedostupné ve vašem prohlížeči\",\"links\":\"Odkazy\",\"lock_account_description\":\"Omezit váš účet pouze na schválené sledující\",\"loop_video\":\"Opakovat videa\",\"loop_video_silent_only\":\"Opakovat pouze videa beze zvuku (t.j. „GIFy“ na Mastodonu)\",\"mutes_tab\":\"Ignorování\",\"play_videos_in_modal\":\"Přehrávat videa přímo v prohlížeči médií\",\"use_contain_fit\":\"Neořezávat přílohu v miniaturách\",\"name\":\"Jméno\",\"name_bio\":\"Jméno a popis\",\"new_password\":\"Nové heslo\",\"notification_visibility\":\"Typy oznámení k zobrazení\",\"notification_visibility_follows\":\"Sledující\",\"notification_visibility_likes\":\"Oblíbení\",\"notification_visibility_mentions\":\"Zmínky\",\"notification_visibility_repeats\":\"Zopakování\",\"no_rich_text_description\":\"Odstranit ze všech příspěvků formátování textu\",\"no_blocks\":\"Žádná blokování\",\"no_mutes\":\"Žádná ignorování\",\"hide_follows_description\":\"Nezobrazovat, koho sleduji\",\"hide_followers_description\":\"Nezobrazovat, kdo mě sleduje\",\"show_admin_badge\":\"Zobrazovat v mém profilu odznak administrátora\",\"show_moderator_badge\":\"Zobrazovat v mém profilu odznak moderátora\",\"nsfw_clickthrough\":\"Povolit prokliknutelné skrývání citlivých příloh\",\"oauth_tokens\":\"Tokeny OAuth\",\"token\":\"Token\",\"refresh_token\":\"Obnovit token\",\"valid_until\":\"Platný do\",\"revoke_token\":\"Odvolat\",\"panelRadius\":\"Panely\",\"pause_on_unfocused\":\"Pozastavit streamování, pokud není záložka prohlížeče v soustředění\",\"presets\":\"Přednastavení\",\"profile_background\":\"Profilové pozadí\",\"profile_banner\":\"Profilový banner\",\"profile_tab\":\"Profil\",\"radii_help\":\"Nastavit zakulacení rohů rozhraní (v pixelech)\",\"replies_in_timeline\":\"Odpovědi v časové ose\",\"reply_link_preview\":\"Povolit náhledy odkazu pro odpověď při přejetí myši\",\"reply_visibility_all\":\"Zobrazit všechny odpovědi\",\"reply_visibility_following\":\"Zobrazit pouze odpovědi směřované na mě nebo uživatele, které sleduji\",\"reply_visibility_self\":\"Zobrazit pouze odpovědi směřované na mě\",\"saving_err\":\"Chyba při ukládání nastavení\",\"saving_ok\":\"Nastavení uložena\",\"security_tab\":\"Bezpečnost\",\"scope_copy\":\"Kopírovat rozsah při odpovídání (přímé zprávy jsou vždy kopírovány)\",\"set_new_avatar\":\"Nastavit nový avatar\",\"set_new_profile_background\":\"Nastavit nové profilové pozadí\",\"set_new_profile_banner\":\"Nastavit nový profilový banner\",\"settings\":\"Nastavení\",\"subject_input_always_show\":\"Vždy zobrazit pole pro předmět\",\"subject_line_behavior\":\"Kopírovat předmět při odpovídání\",\"subject_line_email\":\"Jako u e-mailu: „re: předmět“\",\"subject_line_mastodon\":\"Jako u Mastodonu: zkopírovat tak, jak je\",\"subject_line_noop\":\"Nekopírovat\",\"post_status_content_type\":\"Publikovat typ obsahu příspěvku\",\"stop_gifs\":\"Přehrávat GIFy při přejetí myši\",\"streaming\":\"Povolit automatické streamování nových příspěvků při rolování nahoru\",\"text\":\"Text\",\"theme\":\"Motiv\",\"theme_help\":\"Použijte hexadecimální barevné kódy (#rrggbb) pro přizpůsobení vašeho barevného motivu.\",\"theme_help_v2_1\":\"Zaškrtnutím pole můžete také přepsat barvy a průhlednost některých komponentů, pro smazání všech přednastavení použijte tlačítko „Smazat vše“.\",\"theme_help_v2_2\":\"Ikony pod některými položkami jsou indikátory kontrastu pozadí/textu, pro detailní informace nad nimi přejeďte myší. Prosím berte na vědomí, že při používání kontrastu průhlednosti ukazují indikátory nejhorší možný případ.\",\"tooltipRadius\":\"Popisky/upozornění\",\"upload_a_photo\":\"Nahrát fotku\",\"user_settings\":\"Uživatelská nastavení\",\"values\":{\"false\":\"ne\",\"true\":\"ano\"},\"notifications\":\"Oznámení\",\"enable_web_push_notifications\":\"Povolit webová push oznámení\",\"style\":{\"switcher\":{\"keep_color\":\"Ponechat barvy\",\"keep_shadows\":\"Ponechat stíny\",\"keep_opacity\":\"Ponechat průhlednost\",\"keep_roundness\":\"Ponechat kulatost\",\"keep_fonts\":\"Keep fonts\",\"save_load_hint\":\"Možnosti „Ponechat“ dočasně ponechávají aktuálně nastavené možností při volení či nahrávání motivů, také tyto možnosti ukládají při exportování motivu. Pokud není žádné pole zaškrtnuto, uloží export motivu všechno.\",\"reset\":\"Resetovat\",\"clear_all\":\"Vymazat vše\",\"clear_opacity\":\"Vymazat průhlednost\"},\"common\":{\"color\":\"Barva\",\"opacity\":\"Průhlednost\",\"contrast\":{\"hint\":\"Poměr kontrastu je {ratio}, {level} {context}\",\"level\":{\"aa\":\"splňuje směrnici úrovně AA (minimální)\",\"aaa\":\"splňuje směrnici úrovně AAA (doporučováno)\",\"bad\":\"nesplňuje žádné směrnice přístupnosti\"},\"context\":{\"18pt\":\"pro velký (18+ bodů) text\",\"text\":\"pro text\"}}},\"common_colors\":{\"_tab_label\":\"Obvyklé\",\"main\":\"Obvyklé barvy\",\"foreground_hint\":\"Pro detailnější kontrolu viz záložka „Pokročilé“\",\"rgbo\":\"Ikony, odstíny, odznaky\"},\"advanced_colors\":{\"_tab_label\":\"Pokročilé\",\"alert\":\"Pozadí upozornění\",\"alert_error\":\"Chyba\",\"badge\":\"Pozadí odznaků\",\"badge_notification\":\"Oznámení\",\"panel_header\":\"Záhlaví panelu\",\"top_bar\":\"Vrchní pruh\",\"borders\":\"Okraje\",\"buttons\":\"Tlačítka\",\"inputs\":\"Vstupní pole\",\"faint_text\":\"Vybledlý text\"},\"radii\":{\"_tab_label\":\"Kulatost\"},\"shadows\":{\"_tab_label\":\"Stín a osvětlení\",\"component\":\"Komponent\",\"override\":\"Přepsat\",\"shadow_id\":\"Stín #{value}\",\"blur\":\"Rozmazání\",\"spread\":\"Rozsah\",\"inset\":\"Vsazení\",\"hint\":\"Pro stíny můžete také použít --variable jako hodnotu barvy pro použití proměnných CSS3. Prosím berte na vědomí, že nastavení průhlednosti v tomto případě nebude fungovat.\",\"filter_hint\":{\"always_drop_shadow\":\"Varování, tento stín vždy používá {0}, když to prohlížeč podporuje.\",\"drop_shadow_syntax\":\"{0} nepodporuje parametr {1} a klíčové slovo {2}.\",\"avatar_inset\":\"Prosím berte na vědomí, že kombinování vsazených i nevsazených stínů u avatarů může u průhledných avatarů dát neočekávané výsledky.\",\"spread_zero\":\"Stíny s rozsahem > 0 se zobrazí, jako kdyby byl rozsah nastaven na nulu\",\"inset_classic\":\"Vsazené stíny budou používat {0}\"},\"components\":{\"panel\":\"Panel\",\"panelHeader\":\"Záhlaví panelu\",\"topBar\":\"Vrchní pruh\",\"avatar\":\"Avatar uživatele (v zobrazení profilu)\",\"avatarStatus\":\"Avatar uživatele (v zobrazení příspěvku)\",\"popup\":\"Vyskakovací okna a popisky\",\"button\":\"Tlačítko\",\"buttonHover\":\"Tlačítko (přejetí myši)\",\"buttonPressed\":\"Tlačítko (stisknuto)\",\"buttonPressedHover\":\"Button (stisknuto+přejetí myši)\",\"input\":\"Vstupní pole\"}},\"fonts\":{\"_tab_label\":\"Písma\",\"help\":\"Zvolte písmo, které bude použito pro prvky rozhraní. U možnosti „vlastní“ musíte zadat přesný název písma tak, jak se zobrazuje v systému.\",\"components\":{\"interface\":\"Rozhraní\",\"input\":\"Vstupní pole\",\"post\":\"Text příspěvků\",\"postCode\":\"Neproporcionální text v příspěvku (formátovaný text)\"},\"family\":\"Název písma\",\"size\":\"Velikost (v pixelech)\",\"weight\":\"Tloušťka\",\"custom\":\"Vlastní\"},\"preview\":{\"header\":\"Náhled\",\"content\":\"Obsah\",\"error\":\"Příklad chyby\",\"button\":\"Tlačítko\",\"text\":\"Spousta dalšího {0} a {1}\",\"mono\":\"obsahu\",\"input\":\"Právě jsem přistál v L.A.\",\"faint_link\":\"pomocný manuál\",\"fine_print\":\"Přečtěte si náš {0} a nenaučte se nic užitečného!\",\"header_faint\":\"Tohle je v pohodě\",\"checkbox\":\"Pročetl/a jsem podmínky používání\",\"link\":\"hezký malý odkaz\"}}},\"timeline\":{\"collapse\":\"Zabalit\",\"conversation\":\"Konverzace\",\"error_fetching\":\"Chyba při načítání aktualizací\",\"load_older\":\"Načíst starší příspěvky\",\"no_retweet_hint\":\"Příspěvek je označen jako pouze pro sledující či přímý a nemůže být zopakován\",\"repeated\":\"zopakoval/a\",\"show_new\":\"Zobrazit nové\",\"up_to_date\":\"Aktuální\",\"no_more_statuses\":\"Žádné další příspěvky\",\"no_statuses\":\"Žádné příspěvky\"},\"status\":{\"reply_to\":\"Odpověď uživateli\",\"replies_list\":\"Odpovědi:\"},\"user_card\":{\"approve\":\"Schválit\",\"block\":\"Blokovat\",\"blocked\":\"Blokován/a!\",\"deny\":\"Zamítnout\",\"favorites\":\"Oblíbené\",\"follow\":\"Sledovat\",\"follow_sent\":\"Požadavek odeslán!\",\"follow_progress\":\"Odeslílám požadavek…\",\"follow_again\":\"Odeslat požadavek znovu?\",\"follow_unfollow\":\"Přestat sledovat\",\"followees\":\"Sledovaní\",\"followers\":\"Sledující\",\"following\":\"Sledujete!\",\"follows_you\":\"Sleduje vás!\",\"its_you\":\"Jste to vy!\",\"media\":\"Média\",\"mute\":\"Ignorovat\",\"muted\":\"Ignorován/a\",\"per_day\":\"za den\",\"remote_follow\":\"Vzdálené sledování\",\"statuses\":\"Příspěvky\",\"unblock\":\"Odblokovat\",\"unblock_progress\":\"Odblokuji…\",\"block_progress\":\"Blokuji…\",\"unmute\":\"Přestat ignorovat\",\"unmute_progress\":\"Ruším ignorování…\",\"mute_progress\":\"Ignoruji…\"},\"user_profile\":{\"timeline_title\":\"Uživatelská časová osa\",\"profile_does_not_exist\":\"Omlouváme se, tento profil neexistuje.\",\"profile_loading_error\":\"Omlouváme se, při načítání tohoto profilu se vyskytla chyba.\"},\"who_to_follow\":{\"more\":\"Více\",\"who_to_follow\":\"Koho sledovat\"},\"tool_tip\":{\"media_upload\":\"Nahrát média\",\"repeat\":\"Zopakovat\",\"reply\":\"Odpovědět\",\"favorite\":\"Oblíbit\",\"user_settings\":\"Uživatelské nastavení\"},\"upload\":{\"error\":{\"base\":\"Nahrávání selhalo.\",\"file_too_big\":\"Soubor je příliš velký [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"Zkuste to znovu později\"},\"file_size_units\":{\"B\":\"B\",\"KiB\":\"KiB\",\"MiB\":\"MiB\",\"GiB\":\"GiB\",\"TiB\":\"TiB\"}}}\n\n/***/ }),\n/* 436 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = {\"chat\":{\"title\":\"Chat\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Media Proxy\",\"scope_options\":\"Reichweitenoptionen\",\"text_limit\":\"Textlimit\",\"title\":\"Features\",\"who_to_follow\":\"Who to follow\"},\"finder\":{\"error_fetching_user\":\"Fehler beim Suchen des Benutzers\",\"find_user\":\"Finde Benutzer\"},\"general\":{\"apply\":\"Anwenden\",\"submit\":\"Absenden\"},\"login\":{\"login\":\"Anmelden\",\"description\":\"Mit OAuth anmelden\",\"logout\":\"Abmelden\",\"password\":\"Passwort\",\"placeholder\":\"z.B. lain\",\"register\":\"Registrieren\",\"username\":\"Benutzername\"},\"nav\":{\"back\":\"Zurück\",\"chat\":\"Lokaler Chat\",\"friend_requests\":\"Followanfragen\",\"mentions\":\"Erwähnungen\",\"dms\":\"Direktnachrichten\",\"public_tl\":\"Öffentliche Zeitleiste\",\"timeline\":\"Zeitleiste\",\"twkn\":\"Das gesamte bekannte Netzwerk\",\"user_search\":\"Benutzersuche\",\"preferences\":\"Voreinstellungen\"},\"notifications\":{\"broken_favorite\":\"Unbekannte Nachricht, suche danach...\",\"favorited_you\":\"favorisierte deine Nachricht\",\"followed_you\":\"folgt dir\",\"load_older\":\"Ältere Benachrichtigungen laden\",\"notifications\":\"Benachrichtigungen\",\"read\":\"Gelesen!\",\"repeated_you\":\"wiederholte deine Nachricht\"},\"post_status\":{\"new_status\":\"Neuen Status veröffentlichen\",\"account_not_locked_warning\":\"Dein Profil ist nicht {0}. Wer dir folgen will, kann das jederzeit tun und dann auch deine privaten Beiträge sehen.\",\"account_not_locked_warning_link\":\"gesperrt\",\"attachments_sensitive\":\"Anhänge als heikel markieren\",\"content_type\":{\"plain_text\":\"Nur Text\"},\"content_warning\":\"Betreff (optional)\",\"default\":\"Sitze gerade im Hofbräuhaus.\",\"direct_warning\":\"Dieser Beitrag wird nur für die erwähnten Nutzer sichtbar sein.\",\"posting\":\"Veröffentlichen\",\"scope\":{\"direct\":\"Direkt - Beitrag nur an erwähnte Profile\",\"private\":\"Nur Follower - Beitrag nur für Follower sichtbar\",\"public\":\"Öffentlich - Beitrag an öffentliche Zeitleisten\",\"unlisted\":\"Nicht gelistet - Nicht in öffentlichen Zeitleisten anzeigen\"}},\"registration\":{\"bio\":\"Bio\",\"email\":\"Email\",\"fullname\":\"Angezeigter Name\",\"password_confirm\":\"Passwort bestätigen\",\"registration\":\"Registrierung\",\"token\":\"Einladungsschlüssel\",\"captcha\":\"CAPTCHA\",\"new_captcha\":\"Zum Erstellen eines neuen Captcha auf das Bild klicken.\",\"validations\":{\"username_required\":\"darf nicht leer sein\",\"fullname_required\":\"darf nicht leer sein\",\"email_required\":\"darf nicht leer sein\",\"password_required\":\"darf nicht leer sein\",\"password_confirmation_required\":\"darf nicht leer sein\",\"password_confirmation_match\":\"sollte mit dem Passwort identisch sein.\"}},\"settings\":{\"attachmentRadius\":\"Anhänge\",\"attachments\":\"Anhänge\",\"autoload\":\"Aktiviere automatisches Laden von älteren Beiträgen beim scrollen\",\"avatar\":\"Avatar\",\"avatarAltRadius\":\"Avatare (Benachrichtigungen)\",\"avatarRadius\":\"Avatare\",\"background\":\"Hintergrund\",\"bio\":\"Bio\",\"btnRadius\":\"Buttons\",\"cBlue\":\"Blau (Antworten, Folgt dir)\",\"cGreen\":\"Grün (Retweet)\",\"cOrange\":\"Orange (Favorisieren)\",\"cRed\":\"Rot (Abbrechen)\",\"change_password\":\"Passwort ändern\",\"change_password_error\":\"Es gab ein Problem bei der Änderung des Passworts.\",\"changed_password\":\"Passwort erfolgreich geändert!\",\"collapse_subject\":\"Beiträge mit Betreff einklappen\",\"composing\":\"Verfassen\",\"confirm_new_password\":\"Neues Passwort bestätigen\",\"current_avatar\":\"Dein derzeitiger Avatar\",\"current_password\":\"Aktuelles Passwort\",\"current_profile_banner\":\"Der derzeitige Banner deines Profils\",\"data_import_export_tab\":\"Datenimport/-export\",\"default_vis\":\"Standard-Sichtbarkeitsumfang\",\"delete_account\":\"Account löschen\",\"delete_account_description\":\"Lösche deinen Account und alle deine Nachrichten unwiderruflich.\",\"delete_account_error\":\"Es ist ein Fehler beim Löschen deines Accounts aufgetreten. Tritt dies weiterhin auf, wende dich an den Administrator der Instanz.\",\"delete_account_instructions\":\"Tippe dein Passwort unten in das Feld ein, um die Löschung deines Accounts zu bestätigen.\",\"export_theme\":\"Farbschema speichern\",\"filtering\":\"Filtern\",\"filtering_explanation\":\"Alle Beiträge die diese Wörter enthalten werden ausgeblendet. Ein Wort pro Zeile.\",\"follow_export\":\"Follower exportieren\",\"follow_export_button\":\"Exportiere deine Follows in eine csv-Datei\",\"follow_export_processing\":\"In Bearbeitung. Die Liste steht gleich zum herunterladen bereit.\",\"follow_import\":\"Followers importieren\",\"follow_import_error\":\"Fehler beim importieren der Follower\",\"follows_imported\":\"Followers importiert! Die Bearbeitung kann eine Zeit lang dauern.\",\"foreground\":\"Vordergrund\",\"general\":\"Allgemein\",\"hide_attachments_in_convo\":\"Anhänge in Unterhaltungen ausblenden\",\"hide_attachments_in_tl\":\"Anhänge in der Zeitleiste ausblenden\",\"hide_isp\":\"Instanz-spezifisches Panel ausblenden\",\"preload_images\":\"Bilder vorausladen\",\"hide_post_stats\":\"Beitragsstatistiken verbergen (z.B. die Anzahl der Favoriten)\",\"hide_user_stats\":\"Benutzerstatistiken verbergen (z.B. die Anzahl der Follower)\",\"hide_filtered_statuses\":\"Gefilterte Beiträge verbergen\",\"import_followers_from_a_csv_file\":\"Importiere Follower, denen du folgen möchtest, aus einer CSV-Datei\",\"import_theme\":\"Farbschema laden\",\"inputRadius\":\"Eingabefelder\",\"checkboxRadius\":\"Auswahlfelder\",\"instance_default\":\"(Standard: {value})\",\"instance_default_simple\":\"(Standard)\",\"interface\":\"Oberfläche\",\"interfaceLanguage\":\"Sprache der Oberfläche\",\"invalid_theme_imported\":\"Die ausgewählte Datei ist kein unterstütztes Pleroma-Theme. Keine Änderungen wurden vorgenommen.\",\"limited_availability\":\"In deinem Browser nicht verfügbar\",\"links\":\"Links\",\"lock_account_description\":\"Sperre deinen Account, um neue Follower zu genehmigen oder abzulehnen\",\"loop_video\":\"Videos wiederholen\",\"loop_video_silent_only\":\"Nur Videos ohne Ton wiederholen (z.B. Mastodons \\\"gifs\\\")\",\"name\":\"Name\",\"name_bio\":\"Name & Bio\",\"new_password\":\"Neues Passwort\",\"notification_visibility\":\"Benachrichtigungstypen, die angezeigt werden sollen\",\"notification_visibility_follows\":\"Follows\",\"notification_visibility_likes\":\"Favoriten\",\"notification_visibility_mentions\":\"Erwähnungen\",\"notification_visibility_repeats\":\"Wiederholungen\",\"no_rich_text_description\":\"Rich-Text Formatierungen von allen Beiträgen entfernen\",\"hide_follows_description\":\"Zeige nicht, wem ich folge\",\"hide_followers_description\":\"Zeige nicht, wer mir folgt\",\"nsfw_clickthrough\":\"Aktiviere ausblendbares Overlay für Anhänge, die als NSFW markiert sind\",\"oauth_tokens\":\"OAuth-Token\",\"token\":\"Zeichen\",\"refresh_token\":\"Token aktualisieren\",\"valid_until\":\"Gültig bis\",\"revoke_token\":\"Widerrufen\",\"panelRadius\":\"Panel\",\"pause_on_unfocused\":\"Streaming pausieren, wenn das Tab nicht fokussiert ist\",\"presets\":\"Voreinstellungen\",\"profile_background\":\"Profilhintergrund\",\"profile_banner\":\"Profilbanner\",\"profile_tab\":\"Profil\",\"radii_help\":\"Kantenrundung (in Pixel) der Oberfläche anpassen\",\"replies_in_timeline\":\"Antworten in der Zeitleiste\",\"reply_link_preview\":\"Antwortlink-Vorschau beim Überfahren mit der Maus aktivieren\",\"reply_visibility_all\":\"Alle Antworten zeigen\",\"reply_visibility_following\":\"Zeige nur Antworten an mich oder an Benutzer, denen ich folge\",\"reply_visibility_self\":\"Nur Antworten an mich anzeigen\",\"saving_err\":\"Fehler beim Speichern der Einstellungen\",\"saving_ok\":\"Einstellungen gespeichert\",\"security_tab\":\"Sicherheit\",\"scope_copy\":\"Reichweite beim Antworten übernehmen (Direktnachrichten werden immer kopiert)\",\"set_new_avatar\":\"Setze einen neuen Avatar\",\"set_new_profile_background\":\"Setze einen neuen Hintergrund für dein Profil\",\"set_new_profile_banner\":\"Setze einen neuen Banner für dein Profil\",\"settings\":\"Einstellungen\",\"subject_input_always_show\":\"Betreff-Feld immer anzeigen\",\"subject_line_behavior\":\"Betreff beim Antworten kopieren\",\"subject_line_email\":\"Wie Email: \\\"re: Betreff\\\"\",\"subject_line_mastodon\":\"Wie Mastodon: unverändert kopieren\",\"subject_line_noop\":\"Nicht kopieren\",\"stop_gifs\":\"Play-on-hover GIFs\",\"streaming\":\"Aktiviere automatisches Laden (Streaming) von neuen Beiträgen\",\"text\":\"Text\",\"theme\":\"Farbschema\",\"theme_help\":\"Benutze HTML-Farbcodes (#rrggbb) um dein Farbschema anzupassen\",\"theme_help_v2_1\":\"Du kannst auch die Farben und die Deckkraft bestimmter Komponenten überschreiben, indem du das Kontrollkästchen umschaltest. Verwende die Schaltfläche \\\"Alle löschen\\\", um alle Überschreibungen zurückzusetzen.\",\"theme_help_v2_2\":\"Unter einigen Einträgen befinden sich Symbole für Hintergrund-/Textkontrastindikatoren, für detaillierte Informationen fahre mit der Maus darüber. Bitte beachte, dass bei der Verwendung von Transparenz Kontrastindikatoren den schlechtest möglichen Fall darstellen.\",\"tooltipRadius\":\"Tooltips/Warnungen\",\"user_settings\":\"Benutzereinstellungen\",\"values\":{\"false\":\"nein\",\"true\":\"Ja\"},\"notifications\":\"Benachrichtigungen\",\"enable_web_push_notifications\":\"Web-Pushbenachrichtigungen aktivieren\",\"style\":{\"switcher\":{\"keep_color\":\"Farben beibehalten\",\"keep_shadows\":\"Schatten beibehalten\",\"keep_opacity\":\"Deckkraft beibehalten\",\"keep_roundness\":\"Abrundungen beibehalten\",\"keep_fonts\":\"Schriften beibehalten\",\"save_load_hint\":\"Die \\\"Beibehalten\\\"-Optionen behalten die aktuell eingestellten Optionen beim Auswählen oder Laden von Designs bei, sie speichern diese Optionen auch beim Exportieren eines Designs. Wenn alle Kontrollkästchen deaktiviert sind, wird beim Exportieren des Designs alles gespeichert.\",\"reset\":\"Zurücksetzen\",\"clear_all\":\"Alles leeren\",\"clear_opacity\":\"Deckkraft leeren\"},\"common\":{\"color\":\"Farbe\",\"opacity\":\"Deckkraft\",\"contrast\":{\"hint\":\"Das Kontrastverhältnis ist {ratio}, es {level} {context}\",\"level\":{\"aa\":\"entspricht Level AA Richtlinie (minimum)\",\"aaa\":\"entspricht Level AAA Richtlinie (empfohlen)\",\"bad\":\"entspricht keiner Richtlinien zur Barrierefreiheit\"},\"context\":{\"18pt\":\"für großen (18pt+) Text\",\"text\":\"für Text\"}}},\"common_colors\":{\"_tab_label\":\"Allgemein\",\"main\":\"Allgemeine Farben\",\"foreground_hint\":\"Siehe Reiter \\\"Erweitert\\\" für eine detailliertere Einstellungen\",\"rgbo\":\"Symbole, Betonungen, Kennzeichnungen\"},\"advanced_colors\":{\"_tab_label\":\"Erweitert\",\"alert\":\"Warnhinweis-Hintergrund\",\"alert_error\":\"Fehler\",\"badge\":\"Kennzeichnungs-Hintergrund\",\"badge_notification\":\"Benachrichtigung\",\"panel_header\":\"Panel-Kopf\",\"top_bar\":\"Obere Leiste\",\"borders\":\"Rahmen\",\"buttons\":\"Schaltflächen\",\"inputs\":\"Eingabefelder\",\"faint_text\":\"Verblasster Text\"},\"radii\":{\"_tab_label\":\"Abrundungen\"},\"shadows\":{\"_tab_label\":\"Schatten und Beleuchtung\",\"component\":\"Komponente\",\"override\":\"Überschreiben\",\"shadow_id\":\"Schatten #{value}\",\"blur\":\"Unschärfe\",\"spread\":\"Streuung\",\"inset\":\"Einsatz\",\"hint\":\"Für Schatten kannst du auch --variable als Farbwert verwenden, um CSS3-Variablen zu verwenden. Bitte beachte, dass die Einstellung der Deckkraft in diesem Fall nicht funktioniert.\",\"filter_hint\":{\"always_drop_shadow\":\"Achtung, dieser Schatten verwendet immer {0}, wenn der Browser dies unterstützt.\",\"drop_shadow_syntax\":\"{0} unterstützt Parameter {1} und Schlüsselwort {2} nicht.\",\"avatar_inset\":\"Bitte beachte, dass die Kombination von eingesetzten und nicht eingesetzten Schatten auf Avataren zu unerwarteten Ergebnissen bei transparenten Avataren führen kann.\",\"spread_zero\":\"Schatten mit einer Streuung > 0 erscheinen so, als ob sie auf Null gesetzt wären.\",\"inset_classic\":\"Eingesetzte Schatten werden mit {0} verwendet\"},\"components\":{\"panel\":\"Panel\",\"panelHeader\":\"Panel-Kopf\",\"topBar\":\"Obere Leiste\",\"avatar\":\"Benutzer-Avatar (in der Profilansicht)\",\"avatarStatus\":\"Benutzer-Avatar (in der Beitragsanzeige)\",\"popup\":\"Dialogfenster und Hinweistexte\",\"button\":\"Schaltfläche\",\"buttonHover\":\"Schaltfläche (hover)\",\"buttonPressed\":\"Schaltfläche (gedrückt)\",\"buttonPressedHover\":\"Schaltfläche (gedrückt+hover)\",\"input\":\"Input field\"}},\"fonts\":{\"_tab_label\":\"Schriften\",\"help\":\"Wähl die Schriftart, die für Elemente der Benutzeroberfläche verwendet werden soll. Für \\\" Benutzerdefiniert\\\" musst du den genauen Schriftnamen eingeben, wie er im System angezeigt wird.\",\"components\":{\"interface\":\"Oberfläche\",\"input\":\"Eingabefelder\",\"post\":\"Beitragstext\",\"postCode\":\"Dicktengleicher Text in einem Beitrag (Rich-Text)\"},\"family\":\"Schriftname\",\"size\":\"Größe (in px)\",\"weight\":\"Gewicht (Dicke)\",\"custom\":\"Benutzerdefiniert\"},\"preview\":{\"header\":\"Vorschau\",\"content\":\"Inhalt\",\"error\":\"Beispielfehler\",\"button\":\"Schaltfläche\",\"text\":\"Ein Haufen mehr von {0} und {1}\",\"mono\":\"Inhalt\",\"input\":\"Sitze gerade im Hofbräuhaus.\",\"faint_link\":\"Hilfreiche Anleitung\",\"fine_print\":\"Lies unser {0}, um nichts Nützliches zu lernen!\",\"header_faint\":\"Das ist in Ordnung\",\"checkbox\":\"Ich habe die Allgemeinen Geschäftsbedingungen überflogen\",\"link\":\"ein netter kleiner Link\"}}},\"timeline\":{\"collapse\":\"Einklappen\",\"conversation\":\"Unterhaltung\",\"error_fetching\":\"Fehler beim Laden\",\"load_older\":\"Lade ältere Beiträge\",\"no_retweet_hint\":\"Der Beitrag ist als nur-für-Follower oder als Direktnachricht markiert und kann nicht wiederholt werden.\",\"repeated\":\"wiederholte\",\"show_new\":\"Zeige Neuere\",\"up_to_date\":\"Aktuell\"},\"user_card\":{\"approve\":\"Genehmigen\",\"block\":\"Blockieren\",\"blocked\":\"Blockiert!\",\"deny\":\"Ablehnen\",\"follow\":\"Folgen\",\"follow_sent\":\"Anfrage gesendet!\",\"follow_progress\":\"Anfragen…\",\"follow_again\":\"Anfrage erneut senden?\",\"follow_unfollow\":\"Folgen beenden\",\"followees\":\"Folgt\",\"followers\":\"Followers\",\"following\":\"Folgst du!\",\"follows_you\":\"Folgt dir!\",\"its_you\":\"Das bist du!\",\"mute\":\"Stummschalten\",\"muted\":\"Stummgeschaltet\",\"per_day\":\"pro Tag\",\"remote_follow\":\"Folgen\",\"statuses\":\"Beiträge\"},\"user_profile\":{\"timeline_title\":\"Beiträge\"},\"who_to_follow\":{\"more\":\"Mehr\",\"who_to_follow\":\"Wem soll ich folgen\"},\"tool_tip\":{\"media_upload\":\"Medien hochladen\",\"repeat\":\"Wiederholen\",\"reply\":\"Antworten\",\"favorite\":\"Favorisieren\",\"user_settings\":\"Benutzereinstellungen\"},\"upload\":{\"error\":{\"base\":\"Hochladen fehlgeschlagen.\",\"file_too_big\":\"Datei ist zu groß [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"Bitte versuche es später erneut\"},\"file_size_units\":{\"B\":\"B\",\"KiB\":\"KiB\",\"MiB\":\"MiB\",\"GiB\":\"GiB\",\"TiB\":\"TiB\"}}}\n\n/***/ }),\n/* 437 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = {\"chat\":{\"title\":\"Chat\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Media proxy\",\"scope_options\":\"Scope options\",\"text_limit\":\"Text limit\",\"title\":\"Features\",\"who_to_follow\":\"Who to follow\"},\"finder\":{\"error_fetching_user\":\"Error fetching user\",\"find_user\":\"Find user\"},\"general\":{\"apply\":\"Apply\",\"submit\":\"Submit\",\"more\":\"More\",\"generic_error\":\"An error occured\",\"optional\":\"optional\"},\"image_cropper\":{\"crop_picture\":\"Crop picture\",\"save\":\"Save\",\"cancel\":\"Cancel\"},\"login\":{\"login\":\"Log in\",\"description\":\"Log in with OAuth\",\"logout\":\"Log out\",\"password\":\"Password\",\"placeholder\":\"e.g. lain\",\"register\":\"Register\",\"username\":\"Username\",\"hint\":\"Log in to join the discussion\"},\"media_modal\":{\"previous\":\"Previous\",\"next\":\"Next\"},\"nav\":{\"about\":\"About\",\"back\":\"Back\",\"chat\":\"Local Chat\",\"friend_requests\":\"Follow Requests\",\"mentions\":\"Mentions\",\"dms\":\"Direct Messages\",\"public_tl\":\"Public Timeline\",\"timeline\":\"Timeline\",\"twkn\":\"The Whole Known Network\",\"user_search\":\"User Search\",\"who_to_follow\":\"Who to follow\",\"preferences\":\"Preferences\"},\"notifications\":{\"broken_favorite\":\"Unknown status, searching for it...\",\"favorited_you\":\"favorited your status\",\"followed_you\":\"followed you\",\"load_older\":\"Load older notifications\",\"notifications\":\"Notifications\",\"read\":\"Read!\",\"repeated_you\":\"repeated your status\",\"no_more_notifications\":\"No more notifications\"},\"post_status\":{\"new_status\":\"Post new status\",\"account_not_locked_warning\":\"Your account is not {0}. Anyone can follow you to view your follower-only posts.\",\"account_not_locked_warning_link\":\"locked\",\"attachments_sensitive\":\"Mark attachments as sensitive\",\"content_type\":{\"text/plain\":\"Plain text\",\"text/html\":\"HTML\",\"text/markdown\":\"Markdown\"},\"content_warning\":\"Subject (optional)\",\"default\":\"Just landed in L.A.\",\"direct_warning\":\"This post will only be visible to all the mentioned users.\",\"posting\":\"Posting\",\"scope\":{\"direct\":\"Direct - Post to mentioned users only\",\"private\":\"Followers-only - Post to followers only\",\"public\":\"Public - Post to public timelines\",\"unlisted\":\"Unlisted - Do not post to public timelines\"}},\"registration\":{\"bio\":\"Bio\",\"email\":\"Email\",\"fullname\":\"Display name\",\"password_confirm\":\"Password confirmation\",\"registration\":\"Registration\",\"token\":\"Invite token\",\"captcha\":\"CAPTCHA\",\"new_captcha\":\"Click the image to get a new captcha\",\"username_placeholder\":\"e.g. lain\",\"fullname_placeholder\":\"e.g. Lain Iwakura\",\"bio_placeholder\":\"e.g.\\nHi, I'm Lain\\nI’m an anime girl living in suburban Japan. You may know me from the Wired.\",\"validations\":{\"username_required\":\"cannot be left blank\",\"fullname_required\":\"cannot be left blank\",\"email_required\":\"cannot be left blank\",\"password_required\":\"cannot be left blank\",\"password_confirmation_required\":\"cannot be left blank\",\"password_confirmation_match\":\"should be the same as password\"}},\"settings\":{\"app_name\":\"App name\",\"attachmentRadius\":\"Attachments\",\"attachments\":\"Attachments\",\"autoload\":\"Enable automatic loading when scrolled to the bottom\",\"avatar\":\"Avatar\",\"avatarAltRadius\":\"Avatars (Notifications)\",\"avatarRadius\":\"Avatars\",\"background\":\"Background\",\"bio\":\"Bio\",\"blocks_tab\":\"Blocks\",\"btnRadius\":\"Buttons\",\"cBlue\":\"Blue (Reply, follow)\",\"cGreen\":\"Green (Retweet)\",\"cOrange\":\"Orange (Favorite)\",\"cRed\":\"Red (Cancel)\",\"change_password\":\"Change Password\",\"change_password_error\":\"There was an issue changing your password.\",\"changed_password\":\"Password changed successfully!\",\"collapse_subject\":\"Collapse posts with subjects\",\"composing\":\"Composing\",\"confirm_new_password\":\"Confirm new password\",\"current_avatar\":\"Your current avatar\",\"current_password\":\"Current password\",\"current_profile_banner\":\"Your current profile banner\",\"data_import_export_tab\":\"Data Import / Export\",\"default_vis\":\"Default visibility scope\",\"delete_account\":\"Delete Account\",\"delete_account_description\":\"Permanently delete your account and all your messages.\",\"delete_account_error\":\"There was an issue deleting your account. If this persists please contact your instance administrator.\",\"delete_account_instructions\":\"Type your password in the input below to confirm account deletion.\",\"avatar_size_instruction\":\"The recommended minimum size for avatar images is 150x150 pixels.\",\"export_theme\":\"Save preset\",\"filtering\":\"Filtering\",\"filtering_explanation\":\"All statuses containing these words will be muted, one per line\",\"follow_export\":\"Follow export\",\"follow_export_button\":\"Export your follows to a csv file\",\"follow_export_processing\":\"Processing, you'll soon be asked to download your file\",\"follow_import\":\"Follow import\",\"follow_import_error\":\"Error importing followers\",\"follows_imported\":\"Follows imported! Processing them will take a while.\",\"foreground\":\"Foreground\",\"general\":\"General\",\"hide_attachments_in_convo\":\"Hide attachments in conversations\",\"hide_attachments_in_tl\":\"Hide attachments in timeline\",\"max_thumbnails\":\"Maximum amount of thumbnails per post\",\"hide_isp\":\"Hide instance-specific panel\",\"preload_images\":\"Preload images\",\"use_one_click_nsfw\":\"Open NSFW attachments with just one click\",\"hide_post_stats\":\"Hide post statistics (e.g. the number of favorites)\",\"hide_user_stats\":\"Hide user statistics (e.g. the number of followers)\",\"hide_filtered_statuses\":\"Hide filtered statuses\",\"import_followers_from_a_csv_file\":\"Import follows from a csv file\",\"import_theme\":\"Load preset\",\"inputRadius\":\"Input fields\",\"checkboxRadius\":\"Checkboxes\",\"instance_default\":\"(default: {value})\",\"instance_default_simple\":\"(default)\",\"interface\":\"Interface\",\"interfaceLanguage\":\"Interface language\",\"invalid_theme_imported\":\"The selected file is not a supported Pleroma theme. No changes to your theme were made.\",\"limited_availability\":\"Unavailable in your browser\",\"links\":\"Links\",\"lock_account_description\":\"Restrict your account to approved followers only\",\"loop_video\":\"Loop videos\",\"loop_video_silent_only\":\"Loop only videos without sound (i.e. Mastodon's \\\"gifs\\\")\",\"mutes_tab\":\"Mutes\",\"play_videos_in_modal\":\"Play videos directly in the media viewer\",\"use_contain_fit\":\"Don't crop the attachment in thumbnails\",\"name\":\"Name\",\"name_bio\":\"Name & Bio\",\"new_password\":\"New password\",\"notification_visibility\":\"Types of notifications to show\",\"notification_visibility_follows\":\"Follows\",\"notification_visibility_likes\":\"Likes\",\"notification_visibility_mentions\":\"Mentions\",\"notification_visibility_repeats\":\"Repeats\",\"no_rich_text_description\":\"Strip rich text formatting from all posts\",\"no_blocks\":\"No blocks\",\"no_mutes\":\"No mutes\",\"hide_follows_description\":\"Don't show who I'm following\",\"hide_followers_description\":\"Don't show who's following me\",\"show_admin_badge\":\"Show Admin badge in my profile\",\"show_moderator_badge\":\"Show Moderator badge in my profile\",\"nsfw_clickthrough\":\"Enable clickthrough NSFW attachment hiding\",\"oauth_tokens\":\"OAuth tokens\",\"token\":\"Token\",\"refresh_token\":\"Refresh Token\",\"valid_until\":\"Valid Until\",\"revoke_token\":\"Revoke\",\"panelRadius\":\"Panels\",\"pause_on_unfocused\":\"Pause streaming when tab is not focused\",\"presets\":\"Presets\",\"profile_background\":\"Profile Background\",\"profile_banner\":\"Profile Banner\",\"profile_tab\":\"Profile\",\"radii_help\":\"Set up interface edge rounding (in pixels)\",\"replies_in_timeline\":\"Replies in timeline\",\"reply_link_preview\":\"Enable reply-link preview on mouse hover\",\"reply_visibility_all\":\"Show all replies\",\"reply_visibility_following\":\"Only show replies directed at me or users I'm following\",\"reply_visibility_self\":\"Only show replies directed at me\",\"saving_err\":\"Error saving settings\",\"saving_ok\":\"Settings saved\",\"security_tab\":\"Security\",\"scope_copy\":\"Copy scope when replying (DMs are always copied)\",\"set_new_avatar\":\"Set new avatar\",\"set_new_profile_background\":\"Set new profile background\",\"set_new_profile_banner\":\"Set new profile banner\",\"settings\":\"Settings\",\"subject_input_always_show\":\"Always show subject field\",\"subject_line_behavior\":\"Copy subject when replying\",\"subject_line_email\":\"Like email: \\\"re: subject\\\"\",\"subject_line_mastodon\":\"Like mastodon: copy as is\",\"subject_line_noop\":\"Do not copy\",\"post_status_content_type\":\"Post status content type\",\"stop_gifs\":\"Play-on-hover GIFs\",\"streaming\":\"Enable automatic streaming of new posts when scrolled to the top\",\"text\":\"Text\",\"theme\":\"Theme\",\"theme_help\":\"Use hex color codes (#rrggbb) to customize your color theme.\",\"theme_help_v2_1\":\"You can also override certain component's colors and opacity by toggling the checkbox, use \\\"Clear all\\\" button to clear all overrides.\",\"theme_help_v2_2\":\"Icons underneath some entries are background/text contrast indicators, hover over for detailed info. Please keep in mind that when using transparency contrast indicators show the worst possible case.\",\"tooltipRadius\":\"Tooltips/alerts\",\"upload_a_photo\":\"Upload a photo\",\"user_settings\":\"User Settings\",\"values\":{\"false\":\"no\",\"true\":\"yes\"},\"notifications\":\"Notifications\",\"enable_web_push_notifications\":\"Enable web push notifications\",\"style\":{\"switcher\":{\"keep_color\":\"Keep colors\",\"keep_shadows\":\"Keep shadows\",\"keep_opacity\":\"Keep opacity\",\"keep_roundness\":\"Keep roundness\",\"keep_fonts\":\"Keep fonts\",\"save_load_hint\":\"\\\"Keep\\\" options preserve currently set options when selecting or loading themes, it also stores said options when exporting a theme. When all checkboxes unset, exporting theme will save everything.\",\"reset\":\"Reset\",\"clear_all\":\"Clear all\",\"clear_opacity\":\"Clear opacity\"},\"common\":{\"color\":\"Color\",\"opacity\":\"Opacity\",\"contrast\":{\"hint\":\"Contrast ratio is {ratio}, it {level} {context}\",\"level\":{\"aa\":\"meets Level AA guideline (minimal)\",\"aaa\":\"meets Level AAA guideline (recommended)\",\"bad\":\"doesn't meet any accessibility guidelines\"},\"context\":{\"18pt\":\"for large (18pt+) text\",\"text\":\"for text\"}}},\"common_colors\":{\"_tab_label\":\"Common\",\"main\":\"Common colors\",\"foreground_hint\":\"See \\\"Advanced\\\" tab for more detailed control\",\"rgbo\":\"Icons, accents, badges\"},\"advanced_colors\":{\"_tab_label\":\"Advanced\",\"alert\":\"Alert background\",\"alert_error\":\"Error\",\"badge\":\"Badge background\",\"badge_notification\":\"Notification\",\"panel_header\":\"Panel header\",\"top_bar\":\"Top bar\",\"borders\":\"Borders\",\"buttons\":\"Buttons\",\"inputs\":\"Input fields\",\"faint_text\":\"Faded text\"},\"radii\":{\"_tab_label\":\"Roundness\"},\"shadows\":{\"_tab_label\":\"Shadow and lighting\",\"component\":\"Component\",\"override\":\"Override\",\"shadow_id\":\"Shadow #{value}\",\"blur\":\"Blur\",\"spread\":\"Spread\",\"inset\":\"Inset\",\"hint\":\"For shadows you can also use --variable as a color value to use CSS3 variables. Please note that setting opacity won't work in this case.\",\"filter_hint\":{\"always_drop_shadow\":\"Warning, this shadow always uses {0} when browser supports it.\",\"drop_shadow_syntax\":\"{0} does not support {1} parameter and {2} keyword.\",\"avatar_inset\":\"Please note that combining both inset and non-inset shadows on avatars might give unexpected results with transparent avatars.\",\"spread_zero\":\"Shadows with spread > 0 will appear as if it was set to zero\",\"inset_classic\":\"Inset shadows will be using {0}\"},\"components\":{\"panel\":\"Panel\",\"panelHeader\":\"Panel header\",\"topBar\":\"Top bar\",\"avatar\":\"User avatar (in profile view)\",\"avatarStatus\":\"User avatar (in post display)\",\"popup\":\"Popups and tooltips\",\"button\":\"Button\",\"buttonHover\":\"Button (hover)\",\"buttonPressed\":\"Button (pressed)\",\"buttonPressedHover\":\"Button (pressed+hover)\",\"input\":\"Input field\"}},\"fonts\":{\"_tab_label\":\"Fonts\",\"help\":\"Select font to use for elements of UI. For \\\"custom\\\" you have to enter exact font name as it appears in system.\",\"components\":{\"interface\":\"Interface\",\"input\":\"Input fields\",\"post\":\"Post text\",\"postCode\":\"Monospaced text in a post (rich text)\"},\"family\":\"Font name\",\"size\":\"Size (in px)\",\"weight\":\"Weight (boldness)\",\"custom\":\"Custom\"},\"preview\":{\"header\":\"Preview\",\"content\":\"Content\",\"error\":\"Example error\",\"button\":\"Button\",\"text\":\"A bunch of more {0} and {1}\",\"mono\":\"content\",\"input\":\"Just landed in L.A.\",\"faint_link\":\"helpful manual\",\"fine_print\":\"Read our {0} to learn nothing useful!\",\"header_faint\":\"This is fine\",\"checkbox\":\"I have skimmed over terms and conditions\",\"link\":\"a nice lil' link\"}}},\"timeline\":{\"collapse\":\"Collapse\",\"conversation\":\"Conversation\",\"error_fetching\":\"Error fetching updates\",\"load_older\":\"Load older statuses\",\"no_retweet_hint\":\"Post is marked as followers-only or direct and cannot be repeated\",\"repeated\":\"repeated\",\"show_new\":\"Show new\",\"up_to_date\":\"Up-to-date\",\"no_more_statuses\":\"No more statuses\",\"no_statuses\":\"No statuses\"},\"status\":{\"reply_to\":\"Reply to\",\"replies_list\":\"Replies:\"},\"user_card\":{\"approve\":\"Approve\",\"block\":\"Block\",\"blocked\":\"Blocked!\",\"deny\":\"Deny\",\"favorites\":\"Favorites\",\"follow\":\"Follow\",\"follow_sent\":\"Request sent!\",\"follow_progress\":\"Requesting…\",\"follow_again\":\"Send request again?\",\"follow_unfollow\":\"Unfollow\",\"followees\":\"Following\",\"followers\":\"Followers\",\"following\":\"Following!\",\"follows_you\":\"Follows you!\",\"its_you\":\"It's you!\",\"media\":\"Media\",\"mute\":\"Mute\",\"muted\":\"Muted\",\"per_day\":\"per day\",\"remote_follow\":\"Remote follow\",\"statuses\":\"Statuses\",\"unblock\":\"Unblock\",\"unblock_progress\":\"Unblocking...\",\"block_progress\":\"Blocking...\",\"unmute\":\"Unmute\",\"unmute_progress\":\"Unmuting...\",\"mute_progress\":\"Muting...\"},\"user_profile\":{\"timeline_title\":\"User Timeline\",\"profile_does_not_exist\":\"Sorry, this profile does not exist.\",\"profile_loading_error\":\"Sorry, there was an error loading this profile.\"},\"who_to_follow\":{\"more\":\"More\",\"who_to_follow\":\"Who to follow\"},\"tool_tip\":{\"media_upload\":\"Upload Media\",\"repeat\":\"Repeat\",\"reply\":\"Reply\",\"favorite\":\"Favorite\",\"user_settings\":\"User Settings\"},\"upload\":{\"error\":{\"base\":\"Upload failed.\",\"file_too_big\":\"File too big [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"Try again later\"},\"file_size_units\":{\"B\":\"B\",\"KiB\":\"KiB\",\"MiB\":\"MiB\",\"GiB\":\"GiB\",\"TiB\":\"TiB\"}}}\n\n/***/ }),\n/* 438 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = {\"chat\":{\"title\":\"Babilejo\"},\"features_panel\":{\"chat\":\"Babilejo\",\"gopher\":\"Gopher\",\"media_proxy\":\"Aŭdvidaĵa prokurilo\",\"scope_options\":\"Agordoj de amplekso\",\"text_limit\":\"Teksta limo\",\"title\":\"Funkcioj\",\"who_to_follow\":\"Kiun aboni\"},\"finder\":{\"error_fetching_user\":\"Eraro alportante uzanton\",\"find_user\":\"Trovi uzanton\"},\"general\":{\"apply\":\"Apliki\",\"submit\":\"Sendi\",\"more\":\"Pli\",\"generic_error\":\"Eraro okazis\",\"optional\":\"Malnepra\"},\"image_cropper\":{\"crop_picture\":\"Tondi bildon\",\"save\":\"Konservi\",\"cancel\":\"Nuligi\"},\"login\":{\"login\":\"Saluti\",\"description\":\"Saluti per OAuth\",\"logout\":\"Adiaŭi\",\"password\":\"Pasvorto\",\"placeholder\":\"ekz. lain\",\"register\":\"Registriĝi\",\"username\":\"Salutnomo\",\"hint\":\"Salutu por partopreni la diskutadon\"},\"media_modal\":{\"previous\":\"Antaŭa\",\"next\":\"Sekva\"},\"nav\":{\"about\":\"Pri\",\"back\":\"Reen\",\"chat\":\"Loka babilejo\",\"friend_requests\":\"Abonaj petoj\",\"mentions\":\"Mencioj\",\"dms\":\"Rektaj mesaĝoj\",\"public_tl\":\"Publika tempolinio\",\"timeline\":\"Tempolinio\",\"twkn\":\"La tuta konata reto\",\"user_search\":\"Serĉi uzantojn\",\"who_to_follow\":\"Kiun aboni\",\"preferences\":\"Agordoj\"},\"notifications\":{\"broken_favorite\":\"Nekonata stato, serĉante ĝin…\",\"favorited_you\":\"ŝatis vian staton\",\"followed_you\":\"ekabonis vin\",\"load_older\":\"Enlegi pli malnovajn sciigojn\",\"notifications\":\"Sciigoj\",\"read\":\"Legite!\",\"repeated_you\":\"ripetis vian staton\",\"no_more_notifications\":\"Neniuj pliaj sciigoj\"},\"post_status\":{\"new_status\":\"Afiŝi novan staton\",\"account_not_locked_warning\":\"Via konto ne estas {0}. Iu ajn povas vin aboni por vidi viajn afiŝoj nur por abonantoj.\",\"account_not_locked_warning_link\":\"ŝlosita\",\"attachments_sensitive\":\"Marki kunsendaĵojn kiel konsternajn\",\"content_type\":{\"plain_text\":\"Plata teksto\"},\"content_warning\":\"Temo (malnepra)\",\"default\":\"Ĵus alvenis al la Universala Kongreso!\",\"direct_warning\":\"Ĉi tiu afiŝo estos videbla nur por ĉiuj menciitaj uzantoj.\",\"posting\":\"Afiŝante\",\"scope\":{\"direct\":\"Rekta – Afiŝi nur al menciitaj uzantoj\",\"private\":\"Nur abonantoj – Afiŝi nur al abonantoj\",\"public\":\"Publika – Afiŝi al publikaj tempolinioj\",\"unlisted\":\"Nelistigita – Ne afiŝi al publikaj tempolinioj\"}},\"registration\":{\"bio\":\"Priskribo\",\"email\":\"Retpoŝtadreso\",\"fullname\":\"Vidiga nomo\",\"password_confirm\":\"Konfirmo de pasvorto\",\"registration\":\"Registriĝo\",\"token\":\"Invita ĵetono\",\"captcha\":\"TESTO DE HOMECO\",\"new_captcha\":\"Alklaku la bildon por akiri novan teston\",\"username_placeholder\":\"ekz. lain\",\"fullname_placeholder\":\"ekz. Lain Iwakura\",\"bio_placeholder\":\"ekz.\\nSaluton, mi estas Lain\\nMi estas animea knabino vivante en Japanujo. Eble vi konas min de la retejo « Wired ».\",\"validations\":{\"username_required\":\"ne povas resti malplena\",\"fullname_required\":\"ne povas resti malplena\",\"email_required\":\"ne povas resti malplena\",\"password_required\":\"ne povas resti malplena\",\"password_confirmation_required\":\"ne povas resti malplena\",\"password_confirmation_match\":\"samu la pasvorton\"}},\"settings\":{\"app_name\":\"Nomo de aplikaĵo\",\"attachmentRadius\":\"Kunsendaĵoj\",\"attachments\":\"Kunsendaĵoj\",\"autoload\":\"Ŝalti memfaran enlegadon ĉe subo de paĝo\",\"avatar\":\"Profilbildo\",\"avatarAltRadius\":\"Profilbildoj (sciigoj)\",\"avatarRadius\":\"Profilbildoj\",\"background\":\"Fono\",\"bio\":\"Priskribo\",\"blocks_tab\":\"Baroj\",\"btnRadius\":\"Butonoj\",\"cBlue\":\"Blua (Respondo, abono)\",\"cGreen\":\"Verda (Kunhavigo)\",\"cOrange\":\"Oranĝa (Ŝato)\",\"cRed\":\"Ruĝa (Nuligo)\",\"change_password\":\"Ŝanĝi pasvorton\",\"change_password_error\":\"Okazis eraro dum ŝanĝo de via pasvorto.\",\"changed_password\":\"Pasvorto sukcese ŝanĝiĝis!\",\"collapse_subject\":\"Maletendi afiŝojn kun temoj\",\"composing\":\"Verkante\",\"confirm_new_password\":\"Konfirmu novan pasvorton\",\"current_avatar\":\"Via nuna profilbildo\",\"current_password\":\"Nuna pasvorto\",\"current_profile_banner\":\"Via nuna profila rubando\",\"data_import_export_tab\":\"Enporto / Elporto de datenoj\",\"default_vis\":\"Implicita videbleca amplekso\",\"delete_account\":\"Forigi konton\",\"delete_account_description\":\"Por ĉiam forigi vian konton kaj ĉiujn viajn mesaĝojn\",\"delete_account_error\":\"Okazis eraro dum forigo de via kanto. Se tio daŭre okazados, bonvolu kontakti la administranton de via nodo.\",\"delete_account_instructions\":\"Entajpu sube vian pasvorton por konfirmi forigon de konto.\",\"avatar_size_instruction\":\"La rekomendata malpleja grando de profilbildoj estas 150×150 bilderoj.\",\"export_theme\":\"Konservi antaŭagordon\",\"filtering\":\"Filtrado\",\"filtering_explanation\":\"Ĉiuj statoj kun tiuj ĉi vortoj silentiĝos, po unu linio\",\"follow_export\":\"Abona elporto\",\"follow_export_button\":\"Elporti viajn abonojn al CSV-dosiero\",\"follow_export_processing\":\"Traktante; baldaŭ vi ricevos peton elŝuti la dosieron\",\"follow_import\":\"Abona enporto\",\"follow_import_error\":\"Eraro enportante abonojn\",\"follows_imported\":\"Abonoj enportiĝis! Traktado daŭros iom.\",\"foreground\":\"Malfono\",\"general\":\"Ĝenerala\",\"hide_attachments_in_convo\":\"Kaŝi kunsendaĵojn en interparoloj\",\"hide_attachments_in_tl\":\"Kaŝi kunsendaĵojn en tempolinio\",\"max_thumbnails\":\"Plej multa nombro da bildetoj po afiŝo\",\"hide_isp\":\"Kaŝi nodo-propran breton\",\"preload_images\":\"Antaŭ-enlegi bildojn\",\"use_one_click_nsfw\":\"Malfermi konsternajn kunsendaĵojn per nur unu klako\",\"hide_post_stats\":\"Kaŝi statistikon de afiŝoj (ekz. nombron da ŝatoj)\",\"hide_user_stats\":\"Kaŝi statistikon de uzantoj (ekz. nombron da abonantoj)\",\"hide_filtered_statuses\":\"Kaŝi filtritajn statojn\",\"import_followers_from_a_csv_file\":\"Enporti abonojn el CSV-dosiero\",\"import_theme\":\"Enlegi antaŭagordojn\",\"inputRadius\":\"Enigaj kampoj\",\"checkboxRadius\":\"Markbutonoj\",\"instance_default\":\"(implicita: {value})\",\"instance_default_simple\":\"(implicita)\",\"interface\":\"Fasado\",\"interfaceLanguage\":\"Lingvo de fasado\",\"invalid_theme_imported\":\"La elektita dosiero ne estas subtenata haŭto de Pleromo. Neniuj ŝanĝoj al via haŭto okazis.\",\"limited_availability\":\"Nehavebla en via foliumilo\",\"links\":\"Ligiloj\",\"lock_account_description\":\"Limigi vian konton al nur abonantoj aprobitaj\",\"loop_video\":\"Ripetadi filmojn\",\"loop_video_silent_only\":\"Ripetadi nur filmojn sen sono (ekz. la \\\"GIF-ojn\\\" de Mastodon)\",\"mutes_tab\":\"Silentigoj\",\"play_videos_in_modal\":\"Ludi filmojn rekte en la aŭdvidaĵa spektilo\",\"use_contain_fit\":\"Ne tondi la kunsendaĵon en bildetoj\",\"name\":\"Nomo\",\"name_bio\":\"Nomo kaj priskribo\",\"new_password\":\"Nova pasvorto\",\"notification_visibility\":\"Montrotaj specoj de sciigoj\",\"notification_visibility_follows\":\"Abonoj\",\"notification_visibility_likes\":\"Ŝatoj\",\"notification_visibility_mentions\":\"Mencioj\",\"notification_visibility_repeats\":\"Ripetoj\",\"no_rich_text_description\":\"Forigi riĉtekstajn formojn de ĉiuj afiŝoj\",\"no_blocks\":\"Neniuj baroj\",\"no_mutes\":\"Neniuj silentigoj\",\"hide_follows_description\":\"Ne montri kiun mi sekvas\",\"hide_followers_description\":\"Ne montri kiu min sekvas\",\"show_admin_badge\":\"Montri la insignon de administranto en mia profilo\",\"show_moderator_badge\":\"Montri la insignon de kontrolanto en mia profilo\",\"nsfw_clickthrough\":\"Ŝalti traklakan kaŝon de konsternaj kunsendaĵoj\",\"oauth_tokens\":\"Ĵetonoj de OAuth\",\"token\":\"Ĵetono\",\"refresh_token\":\"Ĵetono de novigo\",\"valid_until\":\"Valida ĝis\",\"revoke_token\":\"Senvalidigi\",\"panelRadius\":\"Bretoj\",\"pause_on_unfocused\":\"Paŭzigi elsendfluon kiam langeto ne estas fokusata\",\"presets\":\"Antaŭagordoj\",\"profile_background\":\"Profila fono\",\"profile_banner\":\"Profila rubando\",\"profile_tab\":\"Profilo\",\"radii_help\":\"Agordi fasadan rondigon de randoj (bildere)\",\"replies_in_timeline\":\"Respondoj en tempolinio\",\"reply_link_preview\":\"Ŝalti respond-ligilan antaŭvidon dum musa ŝvebo\",\"reply_visibility_all\":\"Montri ĉiujn respondojn\",\"reply_visibility_following\":\"Montri nur respondojn por mi aŭ miaj abonatoj\",\"reply_visibility_self\":\"Montri nur respondojn por mi\",\"saving_err\":\"Eraro dum konservo de agordoj\",\"saving_ok\":\"Agordoj konserviĝis\",\"security_tab\":\"Sekureco\",\"scope_copy\":\"Kopii amplekson por respondo (rektaj mesaĝoj ĉiam kopiiĝas)\",\"set_new_avatar\":\"Agordi novan profilbildon\",\"set_new_profile_background\":\"Agordi novan profilan fonon\",\"set_new_profile_banner\":\"Agordi novan profilan rubandon\",\"settings\":\"Agordoj\",\"subject_input_always_show\":\"Ĉiam montri teman kampon\",\"subject_line_behavior\":\"Kopii temon por respondo\",\"subject_line_email\":\"Kiel retpoŝto: \\\"re: temo\\\"\",\"subject_line_mastodon\":\"Kiel Mastodon: kopii senŝanĝe\",\"subject_line_noop\":\"Ne kopii\",\"post_status_content_type\":\"Afiŝi specon de la enhavo de la stato\",\"stop_gifs\":\"Movi GIF-bildojn dum musa ŝvebo\",\"streaming\":\"Ŝalti memfaran fluigon de novaj afiŝoj ĉe la supro de la paĝo\",\"text\":\"Teksto\",\"theme\":\"Haŭto\",\"theme_help\":\"Uzu deksesumajn kolorkodojn (#rrvvbb) por adapti vian koloran haŭton.\",\"theme_help_v2_1\":\"Vi ankaŭ povas superagordi la kolorojn kaj travideblecon de kelkaj eroj per marko de la markbutono; uzu la butonon \\\"Vakigi ĉion\\\" por forigi ĉîujn superagordojn.\",\"theme_help_v2_2\":\"Bildsimboloj sub kelkaj eroj estas indikiloj de kontrasto inter fono kaj teksto; muse ŝvebu por detalaj informoj. Bonvolu memori, ke la indikilo montras la plej malbonan okazeblon dum sia uzo.\",\"tooltipRadius\":\"Ŝpruchelpiloj/avertoj\",\"upload_a_photo\":\"Alŝuti foton\",\"user_settings\":\"Agordoj de uzanto\",\"values\":{\"false\":\"ne\",\"true\":\"jes\"},\"notifications\":\"Sciigoj\",\"enable_web_push_notifications\":\"Ŝalti retajn puŝajn sciigojn\",\"style\":{\"switcher\":{\"keep_color\":\"Konservi kolorojn\",\"keep_shadows\":\"Konservi ombrojn\",\"keep_opacity\":\"Konservi maltravideblecon\",\"keep_roundness\":\"Konservi rondecon\",\"keep_fonts\":\"Konservi tiparojn\",\"save_load_hint\":\"Elektebloj de \\\"konservi\\\" konservas la nuntempajn agordojn dum elektado aŭ enlegado de haŭtoj. Ĝi ankaŭ konservas tiujn agordojn dum elportado de haŭto. Kun ĉiuj markbutonoj nemarkitaj, elporto de la haŭto ĉion konservos.\",\"reset\":\"Restarigi\",\"clear_all\":\"Vakigi ĉion\",\"clear_opacity\":\"Vakigi maltravideblecon\"},\"common\":{\"color\":\"Koloro\",\"opacity\":\"Maltravidebleco\",\"contrast\":{\"hint\":\"Proporcio de kontrasto estas {ratio}, ĝi {level} {context}\",\"level\":{\"aa\":\"plenumas la gvidilon je nivelo AA (malpleja)\",\"aaa\":\"plenumas la gvidilon je nivela AAA (rekomendita)\",\"bad\":\"plenumas neniujn faciluzajn gvidilojn\"},\"context\":{\"18pt\":\"por granda (18pt+) teksto\",\"text\":\"por teksto\"}}},\"common_colors\":{\"_tab_label\":\"Komunaj\",\"main\":\"Komunaj koloroj\",\"foreground_hint\":\"Vidu langeton \\\"Specialaj\\\" por pli detalaj agordoj\",\"rgbo\":\"Bildsimboloj, emfazoj, insignoj\"},\"advanced_colors\":{\"_tab_label\":\"Specialaj\",\"alert\":\"Averta fono\",\"alert_error\":\"Eraro\",\"badge\":\"Insigna fono\",\"badge_notification\":\"Sciigo\",\"panel_header\":\"Kapo de breto\",\"top_bar\":\"Supra breto\",\"borders\":\"Limoj\",\"buttons\":\"Butonoj\",\"inputs\":\"Enigaj kampoj\",\"faint_text\":\"Malvigla teksto\"},\"radii\":{\"_tab_label\":\"Rondeco\"},\"shadows\":{\"_tab_label\":\"Ombro kaj lumo\",\"component\":\"Ero\",\"override\":\"Transpasi\",\"shadow_id\":\"Ombro #{value}\",\"blur\":\"Malklarigo\",\"spread\":\"Vastigo\",\"inset\":\"Internigo\",\"hint\":\"Por ombroj vi ankaŭ povas uzi --variable kiel koloran valoron, por uzi variantojn de CSS3. Bonvolu rimarki, ke tiuokaze agordoj de maltravidebleco ne funkcios.\",\"filter_hint\":{\"always_drop_shadow\":\"Averto: ĉi tiu ombro ĉiam uzas {0} kiam la foliumilo ĝin subtenas.\",\"drop_shadow_syntax\":\"{0} ne subtenas parametron {1} kaj ŝlosilvorton {2}.\",\"avatar_inset\":\"Bonvolu rimarki, ke agordi ambaŭ internajn kaj eksterajn ombrojn por profilbildoj povas redoni neatenditajn rezultojn ĉe profilbildoj travideblaj.\",\"spread_zero\":\"Ombroj kun vastigo > 0 aperos kvazaŭ ĝi estus fakte nulo\",\"inset_classic\":\"Internaj ombroj uzos {0}\"},\"components\":{\"panel\":\"Breto\",\"panelHeader\":\"Kapo de breto\",\"topBar\":\"Supra breto\",\"avatar\":\"Profilbildo de uzanto (en profila vido)\",\"avatarStatus\":\"Profilbildo de uzanto (en afiŝa vido)\",\"popup\":\"Ŝprucaĵoj\",\"button\":\"Butono\",\"buttonHover\":\"Butono (je ŝvebo)\",\"buttonPressed\":\"Butono (premita)\",\"buttonPressedHover\":\"Butono (premita je ŝvebo)\",\"input\":\"Eniga kampo\"}},\"fonts\":{\"_tab_label\":\"Tiparoj\",\"help\":\"Elektu tiparon uzotan por eroj de la fasado. Por \\\"propra\\\" vi devas enigi la precizan nomon de tiparo tiel, kiel ĝi aperas en la sistemo\",\"components\":{\"interface\":\"Fasado\",\"input\":\"Enigaj kampoj\",\"post\":\"Teksto de afiŝo\",\"postCode\":\"Egallarĝa teksto en afiŝo (riĉteksto)\"},\"family\":\"Nomo de tiparo\",\"size\":\"Grando (en bilderoj)\",\"weight\":\"Pezo (graseco)\",\"custom\":\"Propra\"},\"preview\":{\"header\":\"Antaŭrigardo\",\"content\":\"Enhavo\",\"error\":\"Ekzempla eraro\",\"button\":\"Butono\",\"text\":\"Kelko da pliaj {0} kaj {1}\",\"mono\":\"enhavo\",\"input\":\"Ĵus alvenis al la Universala Kongreso!\",\"faint_link\":\"helpan manlibron\",\"fine_print\":\"Legu nian {0} por nenion utilan ekscii!\",\"header_faint\":\"Tio estas en ordo\",\"checkbox\":\"Mi legetis la kondiĉojn de uzado\",\"link\":\"bela eta ligil’\"}}},\"timeline\":{\"collapse\":\"Maletendi\",\"conversation\":\"Interparolo\",\"error_fetching\":\"Eraro dum ĝisdatigo\",\"load_older\":\"Montri pli malnovajn statojn\",\"no_retweet_hint\":\"Afiŝo estas markita kiel rekta aŭ nur por abonantoj, kaj ne eblas ĝin ripeti\",\"repeated\":\"ripetita\",\"show_new\":\"Montri novajn\",\"up_to_date\":\"Ĝisdata\",\"no_more_statuses\":\"Neniuj pliaj statoj\",\"no_statuses\":\"Neniuj statoj\"},\"user_card\":{\"approve\":\"Aprobi\",\"block\":\"Bari\",\"blocked\":\"Barita!\",\"deny\":\"Rifuzi\",\"favorites\":\"Ŝatataj\",\"follow\":\"Aboni\",\"follow_sent\":\"Peto sendiĝis!\",\"follow_progress\":\"Petanta…\",\"follow_again\":\"Ĉu sendi peton denove?\",\"follow_unfollow\":\"Malaboni\",\"followees\":\"Abonatoj\",\"followers\":\"Abonantoj\",\"following\":\"Abonanta!\",\"follows_you\":\"Abonas vin!\",\"its_you\":\"Tio estas vi!\",\"media\":\"Aŭdvidaĵoj\",\"mute\":\"Silentigi\",\"muted\":\"Silentigitaj\",\"per_day\":\"tage\",\"remote_follow\":\"Fore aboni\",\"statuses\":\"Statoj\",\"unblock\":\"Malbari\",\"unblock_progress\":\"Malbaranta…\",\"block_progress\":\"Baranta…\",\"unmute\":\"Malsilentigi\",\"unmute_progress\":\"Malsilentiganta…\",\"mute_progress\":\"Silentiganta…\"},\"user_profile\":{\"timeline_title\":\"Uzanta tempolinio\",\"profile_does_not_exist\":\"Pardonu, ĉi tiu profilo ne ekzistas.\",\"profile_loading_error\":\"Pardonu, eraro okazis dum enlegado de ĉi tiu profilo.\"},\"who_to_follow\":{\"more\":\"Pli\",\"who_to_follow\":\"Kiun aboni\"},\"tool_tip\":{\"media_upload\":\"Alŝuti aŭdvidaĵon\",\"repeat\":\"Ripeti\",\"reply\":\"Respondi\",\"favorite\":\"Ŝati\",\"user_settings\":\"Agordoj de uzanto\"},\"upload\":{\"error\":{\"base\":\"Alŝuto malsukcesis.\",\"file_too_big\":\"Dosiero estas tro granda [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"Reprovu pli poste\"},\"file_size_units\":{\"B\":\"B\",\"KiB\":\"KiB\",\"MiB\":\"MiB\",\"GiB\":\"GiB\",\"TiB\":\"TiB\"}}}\n\n/***/ }),\n/* 439 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = {\"chat\":{\"title\":\"Chat\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Media proxy\",\"scope_options\":\"Opciones del alcance de la visibilidad\",\"text_limit\":\"Límite de carácteres\",\"title\":\"Características\",\"who_to_follow\":\"A quién seguir\"},\"finder\":{\"error_fetching_user\":\"Error al buscar usuario\",\"find_user\":\"Encontrar usuario\"},\"general\":{\"apply\":\"Aplicar\",\"submit\":\"Enviar\",\"more\":\"Más\",\"generic_error\":\"Ha ocurrido un error\"},\"login\":{\"login\":\"Identificación\",\"description\":\"Identificación con OAuth\",\"logout\":\"Salir\",\"password\":\"Contraseña\",\"placeholder\":\"p.ej. lain\",\"register\":\"Registrar\",\"username\":\"Usuario\",\"hint\":\"Inicia sesión para unirte a la discusión\"},\"nav\":{\"about\":\"Sobre\",\"back\":\"Volver\",\"chat\":\"Chat Local\",\"friend_requests\":\"Solicitudes de amistad\",\"mentions\":\"Menciones\",\"dms\":\"Mensajes Directo\",\"public_tl\":\"Línea Temporal Pública\",\"timeline\":\"Línea Temporal\",\"twkn\":\"Toda La Red Conocida\",\"user_search\":\"Búsqueda de Usuarios\",\"who_to_follow\":\"A quién seguir\",\"preferences\":\"Preferencias\"},\"notifications\":{\"broken_favorite\":\"Estado desconocido, buscándolo...\",\"favorited_you\":\"le gusta tu estado\",\"followed_you\":\"empezó a seguirte\",\"load_older\":\"Cargar notificaciones antiguas\",\"notifications\":\"Notificaciones\",\"read\":\"¡Leído!\",\"repeated_you\":\"repite tu estado\",\"no_more_notifications\":\"No hay más notificaciones\"},\"post_status\":{\"new_status\":\"Publicar un nuevo estado\",\"account_not_locked_warning\":\"Tu cuenta no está {0}. Cualquiera puede seguirte y leer las entradas para Solo-Seguidores.\",\"account_not_locked_warning_link\":\"bloqueada\",\"attachments_sensitive\":\"Contenido sensible\",\"content_type\":{\"plain_text\":\"Texto Plano\"},\"content_warning\":\"Tema (opcional)\",\"default\":\"Acabo de aterrizar en L.A.\",\"direct_warning\":\"Esta entrada solo será visible para los usuarios mencionados.\",\"posting\":\"Publicando\",\"scope\":{\"direct\":\"Directo - Solo para los usuarios mencionados.\",\"private\":\"Solo-Seguidores - Solo tus seguidores leeran la entrada\",\"public\":\"Público - Entradas visibles en las Líneas Temporales Públicas\",\"unlisted\":\"Sin Listar - Entradas no visibles en las Líneas Temporales Públicas\"}},\"registration\":{\"bio\":\"Biografía\",\"email\":\"Correo electrónico\",\"fullname\":\"Nombre a mostrar\",\"password_confirm\":\"Confirmación de contraseña\",\"registration\":\"Registro\",\"token\":\"Token de invitación\",\"captcha\":\"CAPTCHA\",\"new_captcha\":\"Click en la imagen para obtener un nuevo captca\",\"validations\":{\"username_required\":\"no puede estar vacío\",\"fullname_required\":\"no puede estar vacío\",\"email_required\":\"no puede estar vacío\",\"password_required\":\"no puede estar vacío\",\"password_confirmation_required\":\"no puede estar vacío\",\"password_confirmation_match\":\"la contraseña no coincide\"}},\"settings\":{\"attachmentRadius\":\"Adjuntos\",\"attachments\":\"Adjuntos\",\"autoload\":\"Activar carga automática al llegar al final de la página\",\"avatar\":\"Avatar\",\"avatarAltRadius\":\"Avatares (Notificaciones)\",\"avatarRadius\":\"Avatares\",\"background\":\"Fondo\",\"bio\":\"Biografía\",\"btnRadius\":\"Botones\",\"cBlue\":\"Azul (Responder, seguir)\",\"cGreen\":\"Verde (Retweet)\",\"cOrange\":\"Naranja (Favorito)\",\"cRed\":\"Rojo (Cancelar)\",\"change_password\":\"Cambiar contraseña\",\"change_password_error\":\"Hubo un problema cambiando la contraseña.\",\"changed_password\":\"Contraseña cambiada correctamente!\",\"collapse_subject\":\"Colapsar entradas con tema\",\"composing\":\"Redactando\",\"confirm_new_password\":\"Confirmar la nueva contraseña\",\"current_avatar\":\"Tu avatar actual\",\"current_password\":\"Contraseña actual\",\"current_profile_banner\":\"Tu cabecera actual\",\"data_import_export_tab\":\"Importar / Exportar Datos\",\"default_vis\":\"Alcance de visibilidad por defecto\",\"delete_account\":\"Eliminar la cuenta\",\"delete_account_description\":\"Eliminar para siempre la cuenta y todos los mensajes.\",\"delete_account_error\":\"Hubo un error al eliminar tu cuenta. Si el fallo persiste, ponte en contacto con el administrador de tu instancia.\",\"delete_account_instructions\":\"Escribe tu contraseña para confirmar la eliminación de tu cuenta.\",\"avatar_size_instruction\":\"El tamaño mínimo recomendado para el avatar es de 150X150 píxeles.\",\"export_theme\":\"Exportar tema\",\"filtering\":\"Filtros\",\"filtering_explanation\":\"Todos los estados que contengan estas palabras serán silenciados, una por línea\",\"follow_export\":\"Exportar personas que tú sigues\",\"follow_export_button\":\"Exporta tus seguidores a un archivo csv\",\"follow_export_processing\":\"Procesando, en breve se te preguntará para guardar el archivo\",\"follow_import\":\"Importar personas que tú sigues\",\"follow_import_error\":\"Error al importal el archivo\",\"follows_imported\":\"¡Importado! Procesarlos llevará tiempo.\",\"foreground\":\"Primer plano\",\"general\":\"General\",\"hide_attachments_in_convo\":\"Ocultar adjuntos en las conversaciones\",\"hide_attachments_in_tl\":\"Ocultar adjuntos en la línea temporal\",\"hide_isp\":\"Ocultar el panel específico de la instancia\",\"preload_images\":\"Precargar las imágenes\",\"use_one_click_nsfw\":\"Abrir los adjuntos NSFW con un solo click.\",\"hide_post_stats\":\"Ocultar las estadísticas de las entradas (p.ej. el número de favoritos)\",\"hide_user_stats\":\"Ocultar las estadísticas del usuario (p.ej. el número de seguidores)\",\"hide_filtered_statuses\":\"Ocultar estados filtrados\",\"import_followers_from_a_csv_file\":\"Importar personas que tú sigues a partir de un archivo csv\",\"import_theme\":\"Importar tema\",\"inputRadius\":\"Campos de entrada\",\"checkboxRadius\":\"Casillas de verificación\",\"instance_default\":\"(por defecto: {value})\",\"instance_default_simple\":\"(por defecto)\",\"interface\":\"Interfaz\",\"interfaceLanguage\":\"Idioma\",\"invalid_theme_imported\":\"El archivo importado no es un tema válido de Pleroma. No se han realizado cambios.\",\"limited_availability\":\"No disponible en tu navegador\",\"links\":\"Enlaces\",\"lock_account_description\":\"Restringir el acceso a tu cuenta solo a seguidores admitidos\",\"loop_video\":\"Vídeos en bucle\",\"loop_video_silent_only\":\"Bucle solo en vídeos sin sonido (p.ej. \\\"gifs\\\" de Mastodon)\",\"play_videos_in_modal\":\"Reproducir los vídeos directamente en el visor de medios\",\"use_contain_fit\":\"No recortar los adjuntos en miniaturas\",\"name\":\"Nombre\",\"name_bio\":\"Nombre y Biografía\",\"new_password\":\"Nueva contraseña\",\"notification_visibility\":\"Tipos de notificaciones a mostrar\",\"notification_visibility_follows\":\"Nuevos seguidores\",\"notification_visibility_likes\":\"Me gustan (Likes)\",\"notification_visibility_mentions\":\"Menciones\",\"notification_visibility_repeats\":\"Repeticiones (Repeats)\",\"no_rich_text_description\":\"Eliminar el formato de texto enriquecido de todas las entradas\",\"hide_follows_description\":\"No mostrar a quién sigo\",\"hide_followers_description\":\"No mostrar quién me sigue\",\"show_admin_badge\":\"Mostrar la placa de administrador en mi perfil\",\"show_moderator_badge\":\"Mostrar la placa de moderador en mi perfil\",\"nsfw_clickthrough\":\"Activar el clic para ocultar los adjuntos NSFW\",\"oauth_tokens\":\"Tokens de OAuth\",\"token\":\"Token\",\"refresh_token\":\"Actualizar el token\",\"valid_until\":\"Válido hasta\",\"revoke_token\":\"Revocar\",\"panelRadius\":\"Paneles\",\"pause_on_unfocused\":\"Parar la transmisión cuando no estés en foco.\",\"presets\":\"Por defecto\",\"profile_background\":\"Fondo del Perfil\",\"profile_banner\":\"Cabecera del Perfil\",\"profile_tab\":\"Perfil\",\"radii_help\":\"Estable el redondeo de las esquinas del interfaz (en píxeles)\",\"replies_in_timeline\":\"Réplicas en la línea temporal\",\"reply_link_preview\":\"Activar la previsualización del enlace de responder al pasar el ratón por encim\",\"reply_visibility_all\":\"Mostrar todas las réplicas\",\"reply_visibility_following\":\"Solo mostrar réplicas para mí o usuarios a los que sigo\",\"reply_visibility_self\":\"Solo mostrar réplicas para mí\",\"saving_err\":\"Error al guardar los ajustes\",\"saving_ok\":\"Ajustes guardados\",\"security_tab\":\"Seguridad\",\"scope_copy\":\"Copiar la visibilidad cuando contestamos (En los mensajes directos (MDs) siempre se copia)\",\"set_new_avatar\":\"Cambiar avatar\",\"set_new_profile_background\":\"Cambiar fondo del perfil\",\"set_new_profile_banner\":\"Cambiar cabecera del perfil\",\"settings\":\"Ajustes\",\"subject_input_always_show\":\"Mostrar siempre el campo del tema\",\"subject_line_behavior\":\"Copiar el tema en las contestaciones\",\"subject_line_email\":\"Tipo email: \\\"re: tema\\\"\",\"subject_line_mastodon\":\"Tipo mastodon: copiar como es\",\"subject_line_noop\":\"No copiar\",\"post_status_content_type\":\"Formato de publicación\",\"stop_gifs\":\"Iniciar GIFs al pasar el ratón\",\"streaming\":\"Habilite la transmisión automática de nuevas publicaciones cuando se desplaza hacia la parte superior\",\"text\":\"Texto\",\"theme\":\"Tema\",\"theme_help\":\"Use códigos de color hexadecimales (#rrggbb) para personalizar su tema de colores.\",\"theme_help_v2_1\":\"También puede invalidar los colores y la opacidad de ciertos componentes si activa la casilla de verificación, use el botón \\\"Borrar todo\\\" para deshacer los cambios.\",\"theme_help_v2_2\":\"Los iconos debajo de algunas entradas son indicadores de contraste de fondo/texto, desplace el ratón para obtener información detallada. Tenga en cuenta que cuando se utilizan indicadores de contraste de transparencia se muestra el peor caso posible.\",\"tooltipRadius\":\"Información/alertas\",\"user_settings\":\"Ajustes de Usuario\",\"values\":{\"false\":\"no\",\"true\":\"sí\"},\"notifications\":\"Notificaciones\",\"enable_web_push_notifications\":\"Habilitar las notificiaciones en el navegador\",\"style\":{\"switcher\":{\"keep_color\":\"Mantener colores\",\"keep_shadows\":\"Mantener sombras\",\"keep_opacity\":\"Mantener opacidad\",\"keep_roundness\":\"Mantener redondeces\",\"keep_fonts\":\"Mantener fuentes\",\"save_load_hint\":\"Las opciones \\\"Mantener\\\" conservan las opciones configuradas actualmente al seleccionar o cargar temas, también almacena dichas opciones al exportar un tema. Cuando se desactiven todas las casillas de verificación, el tema de exportación lo guardará todo.\",\"reset\":\"Reiniciar\",\"clear_all\":\"Limpiar todo\",\"clear_opacity\":\"Limpiar opacidad\"},\"common\":{\"color\":\"Color\",\"opacity\":\"Opacidad\",\"contrast\":{\"hint\":\"El ratio de contraste es {ratio}. {level} {context}\",\"level\":{\"aa\":\"Cumple con la pauta de nivel AA (mínimo)\",\"aaa\":\"Cumple con la pauta de nivel AAA (recomendado)\",\"bad\":\"No cumple con las pautas de accesibilidad\"},\"context\":{\"18pt\":\"para textos grandes (+18pt)\",\"text\":\"para textos\"}}},\"common_colors\":{\"_tab_label\":\"Común\",\"main\":\"Colores comunes\",\"foreground_hint\":\"Vea la pestaña \\\"Avanzado\\\" para un control más detallado\",\"rgbo\":\"Iconos, acentos, insignias\"},\"advanced_colors\":{\"_tab_label\":\"Avanzado\",\"alert\":\"Fondo de Alertas\",\"alert_error\":\"Error\",\"badge\":\"Fondo de Insignias\",\"badge_notification\":\"Notificaciones\",\"panel_header\":\"Cabecera del panel\",\"top_bar\":\"Barra superior\",\"borders\":\"Bordes\",\"buttons\":\"Botones\",\"inputs\":\"Campos de entrada\",\"faint_text\":\"Texto desvanecido\"},\"radii\":{\"_tab_label\":\"Redondez\"},\"shadows\":{\"_tab_label\":\"Sombra e iluminación\",\"component\":\"Componente\",\"override\":\"Sobreescribir\",\"shadow_id\":\"Sombra #{value}\",\"blur\":\"Difuminar\",\"spread\":\"Cantidad\",\"inset\":\"Insertada\",\"hint\":\"Para las sombras, también puede usar --variable como un valor de color para usar las variables CSS3. Tenga en cuenta que establecer la opacidad no funcionará en este caso.\",\"filter_hint\":{\"always_drop_shadow\":\"Advertencia, esta sombra siempre usa {0} cuando el navegador lo soporta.\",\"drop_shadow_syntax\":\"{0} no soporta el parámetro {1} y la palabra clave {2}.\",\"avatar_inset\":\"Tenga en cuenta que la combinación de sombras insertadas como no-insertadas en los avatares, puede dar resultados inesperados con los avatares transparentes.\",\"spread_zero\":\"Sombras con una cantidad > 0 aparecerá como si estuviera puesto a cero\",\"inset_classic\":\"Las sombras insertadas estarán usando {0}\"},\"components\":{\"panel\":\"Panel\",\"panelHeader\":\"Cabecera del panel\",\"topBar\":\"Barra superior\",\"avatar\":\"Avatar del usuario (en la vista del perfil)\",\"avatarStatus\":\"Avatar del usuario (en la vista de la entrada)\",\"popup\":\"Ventanas y textos emergentes (popups & tooltips)\",\"button\":\"Botones\",\"buttonHover\":\"Botón (encima)\",\"buttonPressed\":\"Botón (presionado)\",\"buttonPressedHover\":\"Botón (presionado+encima)\",\"input\":\"Campo de entrada\"}},\"fonts\":{\"_tab_label\":\"Fuentes\",\"help\":\"Seleccione la fuente para utilizar para los elementos de la interfaz de usuario. Para \\\"personalizado\\\", debe ingresar el nombre exacto de la fuente tal como aparece en el sistema.\",\"components\":{\"interface\":\"Interfaz\",\"input\":\"Campos de entrada\",\"post\":\"Texto de publicaciones\",\"postCode\":\"Texto monoespaciado en publicación (texto enriquecido)\"},\"family\":\"Nombre de la fuente\",\"size\":\"Tamaño (en px)\",\"weight\":\"Peso (negrita)\",\"custom\":\"Personalizado\"},\"preview\":{\"header\":\"Vista previa\",\"content\":\"Contenido\",\"error\":\"Ejemplo de error\",\"button\":\"Botón\",\"text\":\"Un montón de {0} y {1}\",\"mono\":\"contenido\",\"input\":\"Acaba de aterrizar en L.A.\",\"faint_link\":\"manual útil\",\"fine_print\":\"¡Lea nuestro {0} para aprender nada útil!\",\"header_faint\":\"Esto está bien\",\"checkbox\":\"He revisado los términos y condiciones\",\"link\":\"un bonito enlace\"}}},\"timeline\":{\"collapse\":\"Colapsar\",\"conversation\":\"Conversación\",\"error_fetching\":\"Error al cargar las actualizaciones\",\"load_older\":\"Cargar actualizaciones anteriores\",\"no_retweet_hint\":\"La publicación está marcada como solo para seguidores o directa y no se puede repetir\",\"repeated\":\"repetida\",\"show_new\":\"Mostrar lo nuevo\",\"up_to_date\":\"Actualizado\",\"no_more_statuses\":\"No hay más estados\"},\"user_card\":{\"approve\":\"Aprovar\",\"block\":\"Bloquear\",\"blocked\":\"¡Bloqueado!\",\"deny\":\"Denegar\",\"favorites\":\"Favoritos\",\"follow\":\"Seguir\",\"follow_sent\":\"¡Solicitud enviada!\",\"follow_progress\":\"Solicitando…\",\"follow_again\":\"¿Enviar solicitud de nuevo?\",\"follow_unfollow\":\"Dejar de seguir\",\"followees\":\"Siguiendo\",\"followers\":\"Seguidores\",\"following\":\"¡Siguiendo!\",\"follows_you\":\"¡Te sigue!\",\"its_you\":\"¡Eres tú!\",\"media\":\"Media\",\"mute\":\"Silenciar\",\"muted\":\"Silenciado\",\"per_day\":\"por día\",\"remote_follow\":\"Seguir\",\"statuses\":\"Estados\"},\"user_profile\":{\"timeline_title\":\"Linea temporal del usuario\"},\"who_to_follow\":{\"more\":\"Más\",\"who_to_follow\":\"A quién seguir\"},\"tool_tip\":{\"media_upload\":\"Subir Medios\",\"repeat\":\"Repetir\",\"reply\":\"Contestar\",\"favorite\":\"Favorito\",\"user_settings\":\"Ajustes de usuario\"},\"upload\":{\"error\":{\"base\":\"Subida fallida.\",\"file_too_big\":\"Archivo demasiado grande [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"Inténtalo más tarde\"},\"file_size_units\":{\"B\":\"B\",\"KiB\":\"KiB\",\"MiB\":\"MiB\",\"GiB\":\"GiB\",\"TiB\":\"TiB\"}}}\n\n/***/ }),\n/* 440 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = {\"finder\":{\"error_fetching_user\":\"Viga kasutaja leidmisel\",\"find_user\":\"Otsi kasutajaid\"},\"general\":{\"submit\":\"Postita\"},\"login\":{\"login\":\"Logi sisse\",\"logout\":\"Logi välja\",\"password\":\"Parool\",\"placeholder\":\"nt lain\",\"register\":\"Registreeru\",\"username\":\"Kasutajanimi\"},\"nav\":{\"mentions\":\"Mainimised\",\"public_tl\":\"Avalik Ajajoon\",\"timeline\":\"Ajajoon\",\"twkn\":\"Kogu Teadaolev Võrgustik\"},\"notifications\":{\"followed_you\":\"alustas sinu jälgimist\",\"notifications\":\"Teavitused\",\"read\":\"Loe!\"},\"post_status\":{\"default\":\"Just sõitsin elektrirongiga Tallinnast Pääskülla.\",\"posting\":\"Postitan\"},\"registration\":{\"bio\":\"Bio\",\"email\":\"E-post\",\"fullname\":\"Kuvatav nimi\",\"password_confirm\":\"Parooli kinnitamine\",\"registration\":\"Registreerimine\"},\"settings\":{\"attachments\":\"Manused\",\"autoload\":\"Luba ajajoone automaatne uuendamine kui ajajoon on põhja keritud\",\"avatar\":\"Profiilipilt\",\"bio\":\"Bio\",\"current_avatar\":\"Sinu praegune profiilipilt\",\"current_profile_banner\":\"Praegune profiilibänner\",\"filtering\":\"Sisu filtreerimine\",\"filtering_explanation\":\"Kõiki staatuseid, mis sisaldavad neid sõnu, ei kuvata. Üks sõna reale.\",\"hide_attachments_in_convo\":\"Peida manused vastlustes\",\"hide_attachments_in_tl\":\"Peida manused ajajoonel\",\"name\":\"Nimi\",\"name_bio\":\"Nimi ja Bio\",\"nsfw_clickthrough\":\"Peida tööks-mittesobivad(NSFW) manuste hiireklõpsu taha\",\"profile_background\":\"Profiilitaust\",\"profile_banner\":\"Profiilibänner\",\"reply_link_preview\":\"Luba algpostituse kuvamine vastustes\",\"set_new_avatar\":\"Vali uus profiilipilt\",\"set_new_profile_background\":\"Vali uus profiilitaust\",\"set_new_profile_banner\":\"Vali uus profiilibänner\",\"settings\":\"Sätted\",\"theme\":\"Teema\",\"user_settings\":\"Kasutaja sätted\"},\"timeline\":{\"conversation\":\"Vestlus\",\"error_fetching\":\"Viga uuenduste laadimisel\",\"load_older\":\"Kuva vanemaid staatuseid\",\"show_new\":\"Näita uusi\",\"up_to_date\":\"Uuendatud\"},\"user_card\":{\"block\":\"Blokeeri\",\"blocked\":\"Blokeeritud!\",\"follow\":\"Jälgi\",\"followees\":\"Jälgitavaid\",\"followers\":\"Jälgijaid\",\"following\":\"Jälgin!\",\"follows_you\":\"Jälgib sind!\",\"mute\":\"Vaigista\",\"muted\":\"Vaigistatud\",\"per_day\":\"päevas\",\"statuses\":\"Staatuseid\"}}\n\n/***/ }),\n/* 441 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = {\"chat\":{\"title\":\"Chat\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Media-välityspalvelin\",\"scope_options\":\"Näkyvyyden rajaus\",\"text_limit\":\"Tekstin pituusraja\",\"title\":\"Ominaisuudet\",\"who_to_follow\":\"Seurausehdotukset\"},\"finder\":{\"error_fetching_user\":\"Virhe hakiessa käyttäjää\",\"find_user\":\"Hae käyttäjä\"},\"general\":{\"apply\":\"Aseta\",\"submit\":\"Lähetä\",\"more\":\"Lisää\",\"generic_error\":\"Virhe tapahtui\"},\"login\":{\"login\":\"Kirjaudu sisään\",\"description\":\"Kirjaudu sisään OAuthilla\",\"logout\":\"Kirjaudu ulos\",\"password\":\"Salasana\",\"placeholder\":\"esim. Seppo\",\"register\":\"Rekisteröidy\",\"username\":\"Käyttäjänimi\"},\"nav\":{\"about\":\"Tietoja\",\"back\":\"Takaisin\",\"chat\":\"Paikallinen Chat\",\"friend_requests\":\"Seurauspyynnöt\",\"mentions\":\"Maininnat\",\"dms\":\"Yksityisviestit\",\"public_tl\":\"Julkinen Aikajana\",\"timeline\":\"Aikajana\",\"twkn\":\"Koko Tunnettu Verkosto\",\"user_search\":\"Käyttäjähaku\",\"who_to_follow\":\"Seurausehdotukset\",\"preferences\":\"Asetukset\"},\"notifications\":{\"broken_favorite\":\"Viestiä ei löydetty...\",\"favorited_you\":\"tykkäsi viestistäsi\",\"followed_you\":\"seuraa sinua\",\"load_older\":\"Lataa vanhempia ilmoituksia\",\"notifications\":\"Ilmoitukset\",\"read\":\"Lue!\",\"repeated_you\":\"toisti viestisi\",\"no_more_notifications\":\"Ei enempää ilmoituksia\"},\"post_status\":{\"new_status\":\"Uusi viesti\",\"account_not_locked_warning\":\"Tilisi ei ole {0}. Kuka vain voi seurata sinua nähdäksesi 'vain-seuraajille' -viestisi\",\"account_not_locked_warning_link\":\"lukittu\",\"attachments_sensitive\":\"Merkkaa liitteet arkaluonteisiksi\",\"content_type\":{\"plain_text\":\"Tavallinen teksti\"},\"content_warning\":\"Aihe (valinnainen)\",\"default\":\"Tulin juuri saunasta.\",\"direct_warning\":\"Tämä viesti näkyy vain mainituille käyttäjille.\",\"posting\":\"Lähetetään\",\"scope\":{\"direct\":\"Yksityisviesti - Näkyy vain mainituille käyttäjille\",\"private\":\"Vain-seuraajille - Näkyy vain seuraajillesi\",\"public\":\"Julkinen - Näkyy julkisilla aikajanoilla\",\"unlisted\":\"Listaamaton - Ei näy julkisilla aikajanoilla\"}},\"registration\":{\"bio\":\"Kuvaus\",\"email\":\"Sähköposti\",\"fullname\":\"Koko nimi\",\"password_confirm\":\"Salasanan vahvistaminen\",\"registration\":\"Rekisteröityminen\",\"token\":\"Kutsuvaltuus\",\"captcha\":\"Varmenne\",\"new_captcha\":\"Paina kuvaa saadaksesi uuden varmenteen\",\"validations\":{\"username_required\":\"ei voi olla tyhjä\",\"fullname_required\":\"ei voi olla tyhjä\",\"email_required\":\"ei voi olla tyhjä\",\"password_required\":\"ei voi olla tyhjä\",\"password_confirmation_required\":\"ei voi olla tyhjä\",\"password_confirmation_match\":\"pitää vastata salasanaa\"}},\"settings\":{\"attachmentRadius\":\"Liitteet\",\"attachments\":\"Liitteet\",\"autoload\":\"Lataa vanhempia viestejä automaattisesti ruudun pohjalla\",\"avatar\":\"Profiilikuva\",\"avatarAltRadius\":\"Profiilikuvat (ilmoitukset)\",\"avatarRadius\":\"Profiilikuvat\",\"background\":\"Tausta\",\"bio\":\"Kuvaus\",\"btnRadius\":\"Napit\",\"cBlue\":\"Sininen (Vastaukset, seuraukset)\",\"cGreen\":\"Vihreä (Toistot)\",\"cOrange\":\"Oranssi (Tykkäykset)\",\"cRed\":\"Punainen (Peruminen)\",\"change_password\":\"Vaihda salasana\",\"change_password_error\":\"Virhe vaihtaessa salasanaa.\",\"changed_password\":\"Salasana vaihdettu!\",\"collapse_subject\":\"Minimoi viestit, joille on asetettu aihe\",\"composing\":\"Viestien laatiminen\",\"confirm_new_password\":\"Vahvista uusi salasana\",\"current_avatar\":\"Nykyinen profiilikuvasi\",\"current_password\":\"Nykyinen salasana\",\"current_profile_banner\":\"Nykyinen julisteesi\",\"data_import_export_tab\":\"Tietojen tuonti / vienti\",\"default_vis\":\"Oletusnäkyvyysrajaus\",\"delete_account\":\"Poista tili\",\"delete_account_description\":\"Poista tilisi ja viestisi pysyvästi.\",\"delete_account_error\":\"Virhe poistaessa tiliäsi. Jos virhe jatkuu, ota yhteyttä palvelimesi ylläpitoon.\",\"delete_account_instructions\":\"Syötä salasanasi vahvistaaksesi tilin poiston.\",\"export_theme\":\"Tallenna teema\",\"filtering\":\"Suodatus\",\"filtering_explanation\":\"Kaikki viestit, jotka sisältävät näitä sanoja, suodatetaan. Yksi sana per rivi.\",\"follow_export\":\"Seurausten vienti\",\"follow_export_button\":\"Vie seurauksesi CSV-tiedostoon\",\"follow_export_processing\":\"Käsitellään, sinua pyydetään lataamaan tiedosto hetken päästä\",\"follow_import\":\"Seurausten tuonti\",\"follow_import_error\":\"Virhe tuodessa seuraksia\",\"follows_imported\":\"Seuraukset tuotu! Niiden käsittely vie hetken.\",\"foreground\":\"Korostus\",\"general\":\"Yleinen\",\"hide_attachments_in_convo\":\"Piilota liitteet keskusteluissa\",\"hide_attachments_in_tl\":\"Piilota liitteet aikajanalla\",\"max_thumbnails\":\"Suurin sallittu määrä liitteitä esikatselussa\",\"hide_isp\":\"Piilota palvelimenkohtainen ruutu\",\"preload_images\":\"Esilataa kuvat\",\"use_one_click_nsfw\":\"Avaa NSFW-liitteet yhdellä painalluksella\",\"hide_post_stats\":\"Piilota viestien statistiikka (esim. tykkäysten määrä)\",\"hide_user_stats\":\"Piilota käyttäjien statistiikka (esim. seuraajien määrä)\",\"import_followers_from_a_csv_file\":\"Tuo seuraukset CSV-tiedostosta\",\"import_theme\":\"Tuo tallennettu teema\",\"inputRadius\":\"Syöttökentät\",\"checkboxRadius\":\"Valintalaatikot\",\"instance_default\":\"(oletus: {value})\",\"instance_default_simple\":\"(oletus)\",\"interface\":\"Käyttöliittymä\",\"interfaceLanguage\":\"Käyttöliittymän kieli\",\"invalid_theme_imported\":\"Tuotu tallennettu teema on epäkelpo, muutoksia ei tehty nykyiseen teemaasi.\",\"limited_availability\":\"Ei saatavilla selaimessasi\",\"links\":\"Linkit\",\"lock_account_description\":\"Vain erikseen hyväksytyt käyttäjät voivat seurata tiliäsi\",\"loop_video\":\"Uudelleentoista videot\",\"loop_video_silent_only\":\"Uudelleentoista ainoastaan äänettömät videot (Video-\\\"giffit\\\")\",\"play_videos_in_modal\":\"Toista videot modaalissa\",\"use_contain_fit\":\"Älä rajaa liitteitä esikatselussa\",\"name\":\"Nimi\",\"name_bio\":\"Nimi ja kuvaus\",\"new_password\":\"Uusi salasana\",\"notification_visibility\":\"Ilmoitusten näkyvyys\",\"notification_visibility_follows\":\"Seuraukset\",\"notification_visibility_likes\":\"Tykkäykset\",\"notification_visibility_mentions\":\"Maininnat\",\"notification_visibility_repeats\":\"Toistot\",\"no_rich_text_description\":\"Älä näytä tekstin muotoilua.\",\"hide_network_description\":\"Älä näytä seurauksiani tai seuraajiani\",\"nsfw_clickthrough\":\"Piilota NSFW liitteet klikkauksen taakse\",\"oauth_tokens\":\"OAuth-merkit\",\"token\":\"Token\",\"refresh_token\":\"Päivitä token\",\"valid_until\":\"Voimassa asti\",\"revoke_token\":\"Peruuttaa\",\"panelRadius\":\"Ruudut\",\"pause_on_unfocused\":\"Pysäytä automaattinen viestien näyttö välilehden ollessa pois fokuksesta\",\"presets\":\"Valmiit teemat\",\"profile_background\":\"Taustakuva\",\"profile_banner\":\"Juliste\",\"profile_tab\":\"Profiili\",\"radii_help\":\"Aseta reunojen pyöristys (pikseleinä)\",\"replies_in_timeline\":\"Keskustelut aikajanalla\",\"reply_link_preview\":\"Keskusteluiden vastauslinkkien esikatselu\",\"reply_visibility_all\":\"Näytä kaikki vastaukset\",\"reply_visibility_following\":\"Näytä vain vastaukset minulle tai seuraamilleni käyttäjille\",\"reply_visibility_self\":\"Näytä vain vastaukset minulle\",\"saving_err\":\"Virhe tallentaessa asetuksia\",\"saving_ok\":\"Asetukset tallennettu\",\"security_tab\":\"Tietoturva\",\"scope_copy\":\"Kopioi näkyvyysrajaus vastatessa (Yksityisviestit aina kopioivat)\",\"set_new_avatar\":\"Aseta uusi profiilikuva\",\"set_new_profile_background\":\"Aseta uusi taustakuva\",\"set_new_profile_banner\":\"Aseta uusi juliste\",\"settings\":\"Asetukset\",\"subject_input_always_show\":\"Näytä aihe-kenttä\",\"subject_line_behavior\":\"Aihe-kentän kopiointi\",\"subject_line_email\":\"Kuten sähköposti: \\\"re: aihe\\\"\",\"subject_line_mastodon\":\"Kopioi sellaisenaan\",\"subject_line_noop\":\"Älä kopioi\",\"stop_gifs\":\"Toista giffit vain kohdistaessa\",\"streaming\":\"Näytä uudet viestit automaattisesti ollessasi ruudun huipulla\",\"text\":\"Teksti\",\"theme\":\"Teema\",\"theme_help\":\"Käytä heksadesimaalivärejä muokataksesi väriteemaasi.\",\"theme_help_v2_1\":\"Voit asettaa tiettyjen osien värin tai läpinäkyvyyden täyttämällä valintalaatikon, käytä \\\"Tyhjennä kaikki\\\"-nappia tyhjentääksesi kaiken.\",\"theme_help_v2_2\":\"Ikonit kenttien alla ovat kontrasti-indikaattoreita, lisätietoa kohdistamalla. Käyttäessä läpinäkyvyyttä ne näyttävät pahimman skenaarion.\",\"tooltipRadius\":\"Ohje- tai huomioviestit\",\"user_settings\":\"Käyttäjän asetukset\",\"values\":{\"false\":\"pois päältä\",\"true\":\"päällä\"}},\"timeline\":{\"collapse\":\"Sulje\",\"conversation\":\"Keskustelu\",\"error_fetching\":\"Virhe ladatessa viestejä\",\"load_older\":\"Lataa vanhempia viestejä\",\"no_retweet_hint\":\"Viesti ei ole julkinen, eikä sitä voi toistaa\",\"repeated\":\"toisti\",\"show_new\":\"Näytä uudet\",\"up_to_date\":\"Ajantasalla\",\"no_more_statuses\":\"Ei enempää viestejä\"},\"status\":{\"reply_to\":\"Vastaus\",\"replies_list\":\"Vastaukset:\"},\"user_card\":{\"approve\":\"Hyväksy\",\"block\":\"Estä\",\"blocked\":\"Estetty!\",\"deny\":\"Älä hyväksy\",\"follow\":\"Seuraa\",\"follow_sent\":\"Pyyntö lähetetty!\",\"follow_progress\":\"Pyydetään...\",\"follow_again\":\"Lähetä pyyntö uudestaan\",\"follow_unfollow\":\"Älä seuraa\",\"followees\":\"Seuraa\",\"followers\":\"Seuraajat\",\"following\":\"Seuraat!\",\"follows_you\":\"Seuraa sinua!\",\"its_you\":\"Sinun tili!\",\"mute\":\"Hiljennä\",\"muted\":\"Hiljennetty\",\"per_day\":\"päivässä\",\"remote_follow\":\"Seuraa muualta\",\"statuses\":\"Viestit\"},\"user_profile\":{\"timeline_title\":\"Käyttäjän aikajana\"},\"who_to_follow\":{\"more\":\"Lisää\",\"who_to_follow\":\"Seurausehdotukset\"},\"tool_tip\":{\"media_upload\":\"Lataa tiedosto\",\"repeat\":\"Toista\",\"reply\":\"Vastaa\",\"favorite\":\"Tykkää\",\"user_settings\":\"Käyttäjäasetukset\"},\"upload\":{\"error\":{\"base\":\"Lataus epäonnistui.\",\"file_too_big\":\"Tiedosto liian suuri [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"Yritä uudestaan myöhemmin\"},\"file_size_units\":{\"B\":\"tavua\",\"KiB\":\"kt\",\"MiB\":\"Mt\",\"GiB\":\"Gt\",\"TiB\":\"Tt\"}}}\n\n/***/ }),\n/* 442 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = {\"chat\":{\"title\":\"Chat\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Proxy média\",\"scope_options\":\"Options de visibilité\",\"text_limit\":\"Limite du texte\",\"title\":\"Caractéristiques\",\"who_to_follow\":\"Qui s'abonner\"},\"finder\":{\"error_fetching_user\":\"Erreur lors de la recherche de l'utilisateur\",\"find_user\":\"Chercher un utilisateur\"},\"general\":{\"apply\":\"Appliquer\",\"submit\":\"Envoyer\"},\"login\":{\"login\":\"Connexion\",\"description\":\"Connexion avec OAuth\",\"logout\":\"Déconnexion\",\"password\":\"Mot de passe\",\"placeholder\":\"p.e. lain\",\"register\":\"S'inscrire\",\"username\":\"Identifiant\"},\"nav\":{\"chat\":\"Chat local\",\"friend_requests\":\"Demandes d'ami\",\"dms\":\"Messages adressés\",\"mentions\":\"Notifications\",\"public_tl\":\"Statuts locaux\",\"timeline\":\"Journal\",\"twkn\":\"Le réseau connu\"},\"notifications\":{\"broken_favorite\":\"Chargement d'un message inconnu ...\",\"favorited_you\":\"a aimé votre statut\",\"followed_you\":\"a commencé à vous suivre\",\"load_older\":\"Charger les notifications précédentes\",\"notifications\":\"Notifications\",\"read\":\"Lu !\",\"repeated_you\":\"a partagé votre statut\"},\"post_status\":{\"account_not_locked_warning\":\"Votre compte n'est pas {0}. N'importe qui peut vous suivre pour voir vos billets en Abonné·e·s uniquement.\",\"account_not_locked_warning_link\":\"verrouillé\",\"attachments_sensitive\":\"Marquer le média comme sensible\",\"content_type\":{\"plain_text\":\"Texte brut\"},\"content_warning\":\"Sujet (optionnel)\",\"default\":\"Écrivez ici votre prochain statut.\",\"direct_warning\":\"Ce message sera visible à toutes les personnes mentionnées.\",\"posting\":\"Envoi en cours\",\"scope\":{\"direct\":\"Direct - N'envoyer qu'aux personnes mentionnées\",\"private\":\"Abonné·e·s uniquement - Seul·e·s vos abonné·e·s verront vos billets\",\"public\":\"Publique - Afficher dans les fils publics\",\"unlisted\":\"Non-Listé - Ne pas afficher dans les fils publics\"}},\"registration\":{\"bio\":\"Biographie\",\"email\":\"Adresse email\",\"fullname\":\"Pseudonyme\",\"password_confirm\":\"Confirmation du mot de passe\",\"registration\":\"Inscription\",\"token\":\"Jeton d'invitation\"},\"settings\":{\"attachmentRadius\":\"Pièces jointes\",\"attachments\":\"Pièces jointes\",\"autoload\":\"Charger la suite automatiquement une fois le bas de la page atteint\",\"avatar\":\"Avatar\",\"avatarAltRadius\":\"Avatars (Notifications)\",\"avatarRadius\":\"Avatars\",\"background\":\"Arrière-plan\",\"bio\":\"Biographie\",\"btnRadius\":\"Boutons\",\"cBlue\":\"Bleu (Répondre, suivre)\",\"cGreen\":\"Vert (Partager)\",\"cOrange\":\"Orange (Aimer)\",\"cRed\":\"Rouge (Annuler)\",\"change_password\":\"Changez votre mot de passe\",\"change_password_error\":\"Il y a eu un problème pour changer votre mot de passe.\",\"changed_password\":\"Mot de passe modifié avec succès !\",\"collapse_subject\":\"Réduire les messages avec des sujets\",\"confirm_new_password\":\"Confirmation du nouveau mot de passe\",\"current_avatar\":\"Avatar actuel\",\"current_password\":\"Mot de passe actuel\",\"current_profile_banner\":\"Bannière de profil actuelle\",\"data_import_export_tab\":\"Import / Export des Données\",\"default_vis\":\"Portée de visibilité par défaut\",\"delete_account\":\"Supprimer le compte\",\"delete_account_description\":\"Supprimer définitivement votre compte et tous vos statuts.\",\"delete_account_error\":\"Il y a eu un problème lors de la tentative de suppression de votre compte. Si le problème persiste, contactez l'administrateur de cette instance.\",\"delete_account_instructions\":\"Indiquez votre mot de passe ci-dessous pour confirmer la suppression de votre compte.\",\"export_theme\":\"Enregistrer le thème\",\"filtering\":\"Filtre\",\"filtering_explanation\":\"Tous les statuts contenant ces mots seront masqués. Un mot par ligne\",\"follow_export\":\"Exporter les abonnements\",\"follow_export_button\":\"Exporter les abonnements en csv\",\"follow_export_processing\":\"Exportation en cours…\",\"follow_import\":\"Importer des abonnements\",\"follow_import_error\":\"Erreur lors de l'importation des abonnements\",\"follows_imported\":\"Abonnements importés ! Le traitement peut prendre un moment.\",\"foreground\":\"Premier plan\",\"general\":\"Général\",\"hide_attachments_in_convo\":\"Masquer les pièces jointes dans les conversations\",\"hide_attachments_in_tl\":\"Masquer les pièces jointes dans le journal\",\"hide_post_stats\":\"Masquer les statistiques de publication (le nombre de favoris)\",\"hide_user_stats\":\"Masquer les statistiques de profil (le nombre d'amis)\",\"import_followers_from_a_csv_file\":\"Importer des abonnements depuis un fichier csv\",\"import_theme\":\"Charger le thème\",\"inputRadius\":\"Champs de texte\",\"instance_default\":\"(default: {value})\",\"instance_default_simple\":\"(default)\",\"interfaceLanguage\":\"Langue de l'interface\",\"invalid_theme_imported\":\"Le fichier sélectionné n'est pas un thème Pleroma pris en charge. Aucun changement n'a été apporté à votre thème.\",\"limited_availability\":\"Non disponible dans votre navigateur\",\"links\":\"Liens\",\"lock_account_description\":\"Limitez votre compte aux abonnés acceptés uniquement\",\"loop_video\":\"Vidéos en boucle\",\"loop_video_silent_only\":\"Boucle uniquement les vidéos sans le son (les «gifs» de Mastodon)\",\"name\":\"Nom\",\"name_bio\":\"Nom & Bio\",\"new_password\":\"Nouveau mot de passe\",\"no_rich_text_description\":\"Ne formatez pas le texte\",\"notification_visibility\":\"Types de notifications à afficher\",\"notification_visibility_follows\":\"Abonnements\",\"notification_visibility_likes\":\"J’aime\",\"notification_visibility_mentions\":\"Mentionnés\",\"notification_visibility_repeats\":\"Partages\",\"nsfw_clickthrough\":\"Masquer les images marquées comme contenu adulte ou sensible\",\"oauth_tokens\":\"Jetons OAuth\",\"token\":\"Jeton\",\"refresh_token\":\"Refresh Token\",\"valid_until\":\"Valable jusque\",\"revoke_token\":\"Révoquer\",\"panelRadius\":\"Fenêtres\",\"pause_on_unfocused\":\"Suspendre le streaming lorsque l'onglet n'est pas centré\",\"presets\":\"Thèmes prédéfinis\",\"profile_background\":\"Image de fond\",\"profile_banner\":\"Bannière de profil\",\"profile_tab\":\"Profil\",\"radii_help\":\"Vous pouvez ici choisir le niveau d'arrondi des angles de l'interface (en pixels)\",\"replies_in_timeline\":\"Réponses au journal\",\"reply_link_preview\":\"Afficher un aperçu lors du survol de liens vers une réponse\",\"reply_visibility_all\":\"Montrer toutes les réponses\",\"reply_visibility_following\":\"Afficher uniquement les réponses adressées à moi ou aux utilisateurs que je suis\",\"reply_visibility_self\":\"Afficher uniquement les réponses adressées à moi\",\"saving_err\":\"Erreur lors de l'enregistrement des paramètres\",\"saving_ok\":\"Paramètres enregistrés\",\"security_tab\":\"Sécurité\",\"set_new_avatar\":\"Changer d'avatar\",\"set_new_profile_background\":\"Changer d'image de fond\",\"set_new_profile_banner\":\"Changer de bannière\",\"settings\":\"Paramètres\",\"stop_gifs\":\"N'animer les GIFS que lors du survol du curseur de la souris\",\"streaming\":\"Charger automatiquement les nouveaux statuts lorsque vous êtes au haut de la page\",\"text\":\"Texte\",\"theme\":\"Thème\",\"theme_help\":\"Spécifiez des codes couleur hexadécimaux (#rrvvbb) pour personnaliser les couleurs du thème.\",\"tooltipRadius\":\"Info-bulles/alertes\",\"user_settings\":\"Paramètres utilisateur\",\"values\":{\"false\":\"non\",\"true\":\"oui\"}},\"timeline\":{\"collapse\":\"Fermer\",\"conversation\":\"Conversation\",\"error_fetching\":\"Erreur en cherchant les mises à jour\",\"load_older\":\"Afficher plus\",\"no_retweet_hint\":\"Le message est marqué en abonnés-seulement ou direct et ne peut pas être répété\",\"repeated\":\"a partagé\",\"show_new\":\"Afficher plus\",\"up_to_date\":\"À jour\"},\"user_card\":{\"approve\":\"Accepter\",\"block\":\"Bloquer\",\"blocked\":\"Bloqué !\",\"deny\":\"Rejeter\",\"follow\":\"Suivre\",\"followees\":\"Suivis\",\"followers\":\"Vous suivent\",\"following\":\"Suivi !\",\"follows_you\":\"Vous suit !\",\"mute\":\"Masquer\",\"muted\":\"Masqué\",\"per_day\":\"par jour\",\"remote_follow\":\"Suivre d'une autre instance\",\"statuses\":\"Statuts\"},\"user_profile\":{\"timeline_title\":\"Journal de l'utilisateur\"},\"who_to_follow\":{\"more\":\"Plus\",\"who_to_follow\":\"Qui s'abonner\"}}\n\n/***/ }),\n/* 443 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = {\"chat\":{\"title\":\"Comhrá\"},\"features_panel\":{\"chat\":\"Comhrá\",\"gopher\":\"Gófar\",\"media_proxy\":\"Seachfhreastalaí meáin\",\"scope_options\":\"Rogha scóip\",\"text_limit\":\"Teorainn Téacs\",\"title\":\"Gnéithe\",\"who_to_follow\":\"Daoine le leanúint\"},\"finder\":{\"error_fetching_user\":\"Earráid a aimsiú d'úsáideoir\",\"find_user\":\"Aimsigh úsáideoir\"},\"general\":{\"apply\":\"Feidhmigh\",\"submit\":\"Deimhnigh\"},\"login\":{\"login\":\"Logáil isteach\",\"logout\":\"Logáil amach\",\"password\":\"Pasfhocal\",\"placeholder\":\"m.sh. Daire\",\"register\":\"Clárú\",\"username\":\"Ainm Úsáideora\"},\"nav\":{\"chat\":\"Comhrá Áitiúil\",\"friend_requests\":\"Iarratas ar Cairdeas\",\"mentions\":\"Tagairt\",\"public_tl\":\"Amlíne Poiblí\",\"timeline\":\"Amlíne\",\"twkn\":\"An Líonra Iomlán\"},\"notifications\":{\"broken_favorite\":\"Post anaithnid. Cuardach dó...\",\"favorited_you\":\"toghadh le do phost\",\"followed_you\":\"lean tú\",\"load_older\":\"Luchtaigh fógraí aosta\",\"notifications\":\"Fógraí\",\"read\":\"Léigh!\",\"repeated_you\":\"athphostáil tú\"},\"post_status\":{\"account_not_locked_warning\":\"Níl do chuntas {0}. Is féidir le duine ar bith a leanúint leat chun do phoist leantacha amháin a fheiceáil.\",\"account_not_locked_warning_link\":\"faoi glas\",\"attachments_sensitive\":\"Marcáil ceangaltán mar íogair\",\"content_type\":{\"plain_text\":\"Gnáth-théacs\"},\"content_warning\":\"Teideal (roghnach)\",\"default\":\"Lá iontach anseo i nGaillimh\",\"direct_warning\":\"Ní bheidh an post seo le feiceáil ach amháin do na húsáideoirí atá luaite.\",\"posting\":\"Post nua\",\"scope\":{\"direct\":\"Díreach - Post chuig úsáideoirí luaite amháin\",\"private\":\"Leanúna amháin - Post chuig lucht leanúna amháin\",\"public\":\"Poiblí - Post chuig amlínte poiblí\",\"unlisted\":\"Neamhliostaithe - Ná cuir post chuig amlínte poiblí\"}},\"registration\":{\"bio\":\"Scéal saoil\",\"email\":\"Ríomhphost\",\"fullname\":\"Ainm taispeána'\",\"password_confirm\":\"Deimhnigh do pasfhocal\",\"registration\":\"Clárú\",\"token\":\"Cód cuireadh\"},\"settings\":{\"attachmentRadius\":\"Ceangaltáin\",\"attachments\":\"Ceangaltáin\",\"autoload\":\"Cumasaigh luchtú uathoibríoch nuair a scrollaítear go bun\",\"avatar\":\"Phictúir phrófíle\",\"avatarAltRadius\":\"Phictúirí phrófíle (Fograí)\",\"avatarRadius\":\"Phictúirí phrófíle\",\"background\":\"Cúlra\",\"bio\":\"Scéal saoil\",\"btnRadius\":\"Cnaipí\",\"cBlue\":\"Gorm (Freagra, lean)\",\"cGreen\":\"Glas (Athphóstail)\",\"cOrange\":\"Oráiste (Cosúil)\",\"cRed\":\"Dearg (Cealaigh)\",\"change_password\":\"Athraigh do pasfhocal\",\"change_password_error\":\"Bhí fadhb ann ag athrú do pasfhocail\",\"changed_password\":\"Athraigh an pasfhocal go rathúil!\",\"collapse_subject\":\"Poist a chosc le teidil\",\"confirm_new_password\":\"Deimhnigh do pasfhocal nua\",\"current_avatar\":\"Phictúir phrófíle\",\"current_password\":\"Pasfhocal reatha\",\"current_profile_banner\":\"Phictúir ceanntáisc\",\"data_import_export_tab\":\"Iompórtáil / Easpórtáil Sonraí\",\"default_vis\":\"Scóip infheicthe réamhshocraithe\",\"delete_account\":\"Scrios cuntas\",\"delete_account_description\":\"Do chuntas agus do chuid teachtaireachtaí go léir a scriosadh go buan.\",\"delete_account_error\":\"Bhí fadhb ann a scriosadh do chuntas. Má leanann sé seo, téigh i dteagmháil le do riarthóir.\",\"delete_account_instructions\":\"Scríobh do phasfhocal san ionchur thíos chun deimhniú a scriosadh.\",\"export_theme\":\"Sábháil Téama\",\"filtering\":\"Scagadh\",\"filtering_explanation\":\"Beidh gach post ina bhfuil na focail seo i bhfolach, ceann in aghaidh an líne\",\"follow_export\":\"Easpórtáil do leanann\",\"follow_export_button\":\"Easpórtáil do leanann chuig comhad csv\",\"follow_export_processing\":\"Próiseáil. Iarrtar ort go luath an comhad a íoslódáil.\",\"follow_import\":\"Iompórtáil do leanann\",\"follow_import_error\":\"Earráid agus do leanann a iompórtáil\",\"follows_imported\":\"Do leanann iompórtáil! Tógfaidh an próiseas iad le tamall.\",\"foreground\":\"Tulra\",\"general\":\"Ginearálta\",\"hide_attachments_in_convo\":\"Folaigh ceangaltáin i comhráite\",\"hide_attachments_in_tl\":\"Folaigh ceangaltáin sa amlíne\",\"hide_post_stats\":\"Folaigh staitisticí na bpost (m.sh. líon na n-athrá)\",\"hide_user_stats\":\"Folaigh na staitisticí úsáideora (m.sh. líon na leantóiri)\",\"import_followers_from_a_csv_file\":\"Iompórtáil leanann ó chomhad csv\",\"import_theme\":\"Luchtaigh Téama\",\"inputRadius\":\"Limistéar iontrála\",\"instance_default\":\"(Réamhshocrú: {value})\",\"interfaceLanguage\":\"Teanga comhéadain\",\"invalid_theme_imported\":\"Ní téama bailí é an comhad dícheangailte. Níor rinneadh aon athruithe.\",\"limited_availability\":\"Níl sé ar fáil i do bhrabhsálaí\",\"links\":\"Naisc\",\"lock_account_description\":\"Srian a chur ar do chuntas le lucht leanúna ceadaithe amháin\",\"loop_video\":\"Lúb físeáin\",\"loop_video_silent_only\":\"Lúb físeáin amháin gan fuaim (i.e. Mastodon's \\\"gifs\\\")\",\"name\":\"Ainm\",\"name_bio\":\"Ainm ⁊ Scéal\",\"new_password\":\"Pasfhocal nua'\",\"notification_visibility\":\"Cineálacha fógraí a thaispeáint\",\"notification_visibility_follows\":\"Leana\",\"notification_visibility_likes\":\"Thaithin\",\"notification_visibility_mentions\":\"Tagairt\",\"notification_visibility_repeats\":\"Atphostáil\",\"no_rich_text_description\":\"Bain formáidiú téacs saibhir ó gach post\",\"nsfw_clickthrough\":\"Cumasaigh an ceangaltán NSFW cliceáil ar an gcnaipe\",\"oauth_tokens\":\"Tocanna OAuth\",\"token\":\"Token\",\"refresh_token\":\"Athnuachan Comórtas\",\"valid_until\":\"Bailí Go dtí\",\"revoke_token\":\"Athghairm\",\"panelRadius\":\"Painéil\",\"pause_on_unfocused\":\"Sruthú ar sos nuair a bhíonn an fócas caillte\",\"presets\":\"Réamhshocruithe\",\"profile_background\":\"Cúlra Próifíl\",\"profile_banner\":\"Phictúir Ceanntáisc\",\"profile_tab\":\"Próifíl\",\"radii_help\":\"Cruinniú imeall comhéadan a chumrú (i bpicteilíní)\",\"replies_in_timeline\":\"Freagraí sa amlíne\",\"reply_link_preview\":\"Cumasaigh réamhamharc nasc freagartha ar chlár na luiche\",\"reply_visibility_all\":\"Taispeáin gach freagra\",\"reply_visibility_following\":\"Taispeáin freagraí amháin atá dírithe ar mise nó ar úsáideoirí atá mé ag leanúint\",\"reply_visibility_self\":\"Taispeáin freagraí amháin atá dírithe ar mise\",\"saving_err\":\"Earráid socruithe a shábháil\",\"saving_ok\":\"Socruithe sábháilte\",\"security_tab\":\"Slándáil\",\"set_new_avatar\":\"Athraigh do phictúir phrófíle\",\"set_new_profile_background\":\"Athraigh do cúlra próifíl\",\"set_new_profile_banner\":\"Athraigh do phictúir ceanntáisc\",\"settings\":\"Socruithe\",\"stop_gifs\":\"Seinn GIFs ar an scáileán\",\"streaming\":\"Cumasaigh post nua a shruthú uathoibríoch nuair a scrollaítear go barr an leathanaigh\",\"text\":\"Téacs\",\"theme\":\"Téama\",\"theme_help\":\"Úsáid cód daith hex (#rrggbb) chun do schéim a saincheapadh\",\"tooltipRadius\":\"Bileoga eolais\",\"user_settings\":\"Socruithe úsáideora\",\"values\":{\"false\":\"níl\",\"true\":\"tá\"}},\"timeline\":{\"collapse\":\"Folaigh\",\"conversation\":\"Cómhra\",\"error_fetching\":\"Earráid a thabhairt cothrom le dáta\",\"load_older\":\"Luchtaigh níos mó\",\"no_retweet_hint\":\"Tá an post seo marcáilte mar lucht leanúna amháin nó díreach agus ní féidir é a athphostáil\",\"repeated\":\"athphostáil\",\"show_new\":\"Taispeáin nua\",\"up_to_date\":\"Nuashonraithe\"},\"user_card\":{\"approve\":\"Údaraigh\",\"block\":\"Cosc\",\"blocked\":\"Cuireadh coisc!\",\"deny\":\"Diúltaigh\",\"follow\":\"Lean\",\"followees\":\"Leantóirí\",\"followers\":\"Á Leanúint\",\"following\":\"Á Leanúint\",\"follows_you\":\"Leanann tú\",\"mute\":\"Cuir i mód ciúin\",\"muted\":\"Mód ciúin\",\"per_day\":\"laethúil\",\"remote_follow\":\"Leaníunt iargúlta\",\"statuses\":\"Poist\"},\"user_profile\":{\"timeline_title\":\"Amlíne úsáideora\"},\"who_to_follow\":{\"more\":\"Feach uile\",\"who_to_follow\":\"Daoine le leanúint\"}}\n\n/***/ }),\n/* 444 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = {\"chat\":{\"title\":\"צ'אט\"},\"features_panel\":{\"chat\":\"צ'אט\",\"gopher\":\"גופר\",\"media_proxy\":\"מדיה פרוקסי\",\"scope_options\":\"אפשרויות טווח\",\"text_limit\":\"מגבלת טקסט\",\"title\":\"מאפיינים\",\"who_to_follow\":\"אחרי מי לעקוב\"},\"finder\":{\"error_fetching_user\":\"שגיאה במציאת משתמש\",\"find_user\":\"מציאת משתמש\"},\"general\":{\"apply\":\"החל\",\"submit\":\"שלח\"},\"login\":{\"login\":\"התחבר\",\"logout\":\"התנתק\",\"password\":\"סיסמה\",\"placeholder\":\"למשל lain\",\"register\":\"הירשם\",\"username\":\"שם המשתמש\"},\"nav\":{\"chat\":\"צ'אט מקומי\",\"friend_requests\":\"בקשות עקיבה\",\"mentions\":\"אזכורים\",\"public_tl\":\"ציר הזמן הציבורי\",\"timeline\":\"ציר הזמן\",\"twkn\":\"כל הרשת הידועה\"},\"notifications\":{\"broken_favorite\":\"סטאטוס לא ידוע, מחפש...\",\"favorited_you\":\"אהב את הסטטוס שלך\",\"followed_you\":\"עקב אחריך!\",\"load_older\":\"טען התראות ישנות\",\"notifications\":\"התראות\",\"read\":\"קרא!\",\"repeated_you\":\"חזר על הסטטוס שלך\"},\"post_status\":{\"account_not_locked_warning\":\"המשתמש שלך אינו {0}. כל אחד יכול לעקוב אחריך ולראות את ההודעות לעוקבים-בלבד שלך.\",\"account_not_locked_warning_link\":\"נעול\",\"attachments_sensitive\":\"סמן מסמכים מצורפים כלא בטוחים לצפייה\",\"content_type\":{\"plain_text\":\"טקסט פשוט\"},\"content_warning\":\"נושא (נתון לבחירה)\",\"default\":\"הרגע נחת ב-ל.א.\",\"direct_warning\":\"הודעה זו תהיה זמינה רק לאנשים המוזכרים.\",\"posting\":\"מפרסם\",\"scope\":{\"direct\":\"ישיר - שלח לאנשים המוזכרים בלבד\",\"private\":\"עוקבים-בלבד - שלח לעוקבים בלבד\",\"public\":\"ציבורי - שלח לציר הזמן הציבורי\",\"unlisted\":\"מחוץ לרשימה - אל תשלח לציר הזמן הציבורי\"}},\"registration\":{\"bio\":\"אודות\",\"email\":\"אימייל\",\"fullname\":\"שם תצוגה\",\"password_confirm\":\"אישור סיסמה\",\"registration\":\"הרשמה\",\"token\":\"טוקן הזמנה\"},\"settings\":{\"attachmentRadius\":\"צירופים\",\"attachments\":\"צירופים\",\"autoload\":\"החל טעינה אוטומטית בגלילה לתחתית הדף\",\"avatar\":\"תמונת פרופיל\",\"avatarAltRadius\":\"תמונות פרופיל (התראות)\",\"avatarRadius\":\"תמונות פרופיל\",\"background\":\"רקע\",\"bio\":\"אודות\",\"btnRadius\":\"כפתורים\",\"cBlue\":\"כחול (תגובה, עקיבה)\",\"cGreen\":\"ירוק (חזרה)\",\"cOrange\":\"כתום (לייק)\",\"cRed\":\"אדום (ביטול)\",\"change_password\":\"שנה סיסמה\",\"change_password_error\":\"הייתה בעיה בשינוי סיסמתך.\",\"changed_password\":\"סיסמה שונתה בהצלחה!\",\"collapse_subject\":\"מזער הודעות עם נושאים\",\"confirm_new_password\":\"אשר סיסמה\",\"current_avatar\":\"תמונת הפרופיל הנוכחית שלך\",\"current_password\":\"סיסמה נוכחית\",\"current_profile_banner\":\"כרזת הפרופיל הנוכחית שלך\",\"data_import_export_tab\":\"ייבוא או ייצוא מידע\",\"default_vis\":\"ברירת מחדל לטווח הנראות\",\"delete_account\":\"מחק משתמש\",\"delete_account_description\":\"מחק לצמיתות את המשתמש שלך ואת כל הודעותיך.\",\"delete_account_error\":\"הייתה בעיה במחיקת המשתמש. אם זה ממשיך, אנא עדכן את מנהל השרת שלך.\",\"delete_account_instructions\":\"הכנס את סיסמתך בקלט למטה על מנת לאשר מחיקת משתמש.\",\"export_theme\":\"שמור ערכים\",\"filtering\":\"סינון\",\"filtering_explanation\":\"כל הסטטוסים הכוללים את המילים הללו יושתקו, אחד לשורה\",\"follow_export\":\"יצוא עקיבות\",\"follow_export_button\":\"ייצא את הנעקבים שלך לקובץ csv\",\"follow_export_processing\":\"טוען. בקרוב תתבקש להוריד את הקובץ את הקובץ שלך\",\"follow_import\":\"יבוא עקיבות\",\"follow_import_error\":\"שגיאה בייבוא נעקבים.\",\"follows_imported\":\"נעקבים יובאו! ייקח זמן מה לעבד אותם.\",\"foreground\":\"חזית\",\"hide_attachments_in_convo\":\"החבא צירופים בשיחות\",\"hide_attachments_in_tl\":\"החבא צירופים בציר הזמן\",\"import_followers_from_a_csv_file\":\"ייבא את הנעקבים שלך מקובץ csv\",\"import_theme\":\"טען ערכים\",\"inputRadius\":\"שדות קלט\",\"interfaceLanguage\":\"שפת הממשק\",\"invalid_theme_imported\":\"הקובץ הנבחר אינו תמה הנתמכת ע\\\"י פלרומה. שום שינויים לא נעשו לתמה שלך.\",\"limited_availability\":\"לא זמין בדפדפן שלך\",\"links\":\"לינקים\",\"lock_account_description\":\"הגבל את המשתמש לעוקבים מאושרים בלבד\",\"loop_video\":\"נגן סרטונים ללא הפסקה\",\"loop_video_silent_only\":\"נגן רק סרטונים חסרי קול ללא הפסקה\",\"name\":\"שם\",\"name_bio\":\"שם ואודות\",\"new_password\":\"סיסמה חדשה\",\"notification_visibility\":\"סוג ההתראות שתרצו לראות\",\"notification_visibility_follows\":\"עקיבות\",\"notification_visibility_likes\":\"לייקים\",\"notification_visibility_mentions\":\"אזכורים\",\"notification_visibility_repeats\":\"חזרות\",\"nsfw_clickthrough\":\"החל החבאת צירופים לא בטוחים לצפיה בעת עבודה בעזרת לחיצת עכבר\",\"oauth_tokens\":\"אסימוני OAuth\",\"token\":\"אסימון\",\"refresh_token\":\"רענון האסימון\",\"valid_until\":\"בתוקף עד\",\"revoke_token\":\"בטל\",\"panelRadius\":\"פאנלים\",\"pause_on_unfocused\":\"השהה זרימת הודעות כשהחלון לא בפוקוס\",\"presets\":\"ערכים קבועים מראש\",\"profile_background\":\"רקע הפרופיל\",\"profile_banner\":\"כרזת הפרופיל\",\"profile_tab\":\"פרופיל\",\"radii_help\":\"קבע מראש עיגול פינות לממשק (בפיקסלים)\",\"replies_in_timeline\":\"תגובות בציר הזמן\",\"reply_link_preview\":\"החל תצוגה מקדימה של לינק-תגובה בעת ריחוף עם העכבר\",\"reply_visibility_all\":\"הראה את כל התגובות\",\"reply_visibility_following\":\"הראה תגובות שמופנות אליי או לעקובים שלי בלבד\",\"reply_visibility_self\":\"הראה תגובות שמופנות אליי בלבד\",\"security_tab\":\"ביטחון\",\"set_new_avatar\":\"קבע תמונת פרופיל חדשה\",\"set_new_profile_background\":\"קבע רקע פרופיל חדש\",\"set_new_profile_banner\":\"קבע כרזת פרופיל חדשה\",\"settings\":\"הגדרות\",\"stop_gifs\":\"נגן-בעת-ריחוף GIFs\",\"streaming\":\"החל זרימת הודעות אוטומטית בעת גלילה למעלה הדף\",\"text\":\"טקסט\",\"theme\":\"תמה\",\"theme_help\":\"השתמש בקודי צבע הקס (#אדום-אדום-ירוק-ירוק-כחול-כחול) על מנת להתאים אישית את תמת הצבע שלך.\",\"tooltipRadius\":\"טולטיפ \\\\ התראות\",\"user_settings\":\"הגדרות משתמש\"},\"timeline\":{\"collapse\":\"מוטט\",\"conversation\":\"שיחה\",\"error_fetching\":\"שגיאה בהבאת הודעות\",\"load_older\":\"טען סטטוסים חדשים\",\"no_retweet_hint\":\"ההודעה מסומנת כ\\\"לעוקבים-בלבד\\\" ולא ניתן לחזור עליה\",\"repeated\":\"חזר\",\"show_new\":\"הראה חדש\",\"up_to_date\":\"עדכני\"},\"user_card\":{\"approve\":\"אשר\",\"block\":\"חסימה\",\"blocked\":\"חסום!\",\"deny\":\"דחה\",\"follow\":\"עקוב\",\"followees\":\"נעקבים\",\"followers\":\"עוקבים\",\"following\":\"עוקב!\",\"follows_you\":\"עוקב אחריך!\",\"mute\":\"השתק\",\"muted\":\"מושתק\",\"per_day\":\"ליום\",\"remote_follow\":\"עקיבה מרחוק\",\"statuses\":\"סטטוסים\"},\"user_profile\":{\"timeline_title\":\"ציר זמן המשתמש\"},\"who_to_follow\":{\"more\":\"עוד\",\"who_to_follow\":\"אחרי מי לעקוב\"}}\n\n/***/ }),\n/* 445 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = {\"finder\":{\"error_fetching_user\":\"Hiba felhasználó beszerzésével\",\"find_user\":\"Felhasználó keresése\"},\"general\":{\"submit\":\"Elküld\"},\"login\":{\"login\":\"Bejelentkezés\",\"logout\":\"Kijelentkezés\",\"password\":\"Jelszó\",\"placeholder\":\"e.g. lain\",\"register\":\"Feliratkozás\",\"username\":\"Felhasználó név\"},\"nav\":{\"mentions\":\"Említéseim\",\"public_tl\":\"Publikus Idővonal\",\"timeline\":\"Idővonal\",\"twkn\":\"Az Egész Ismert Hálózat\"},\"notifications\":{\"followed_you\":\"követ téged\",\"notifications\":\"Értesítések\",\"read\":\"Olvasva!\"},\"post_status\":{\"default\":\"Most érkeztem L.A.-be\",\"posting\":\"Küldés folyamatban\"},\"registration\":{\"bio\":\"Bio\",\"email\":\"Email\",\"fullname\":\"Teljes név\",\"password_confirm\":\"Jelszó megerősítése\",\"registration\":\"Feliratkozás\"},\"settings\":{\"attachments\":\"Csatolmányok\",\"autoload\":\"Autoatikus betöltés engedélyezése lap aljára görgetéskor\",\"avatar\":\"Avatár\",\"bio\":\"Bio\",\"current_avatar\":\"Jelenlegi avatár\",\"current_profile_banner\":\"Jelenlegi profil banner\",\"filtering\":\"Szűrés\",\"filtering_explanation\":\"Minden tartalom mely ezen szavakat tartalmazza némítva lesz, soronként egy\",\"hide_attachments_in_convo\":\"Csatolmányok elrejtése a társalgásokban\",\"hide_attachments_in_tl\":\"Csatolmányok elrejtése az idővonalon\",\"name\":\"Név\",\"name_bio\":\"Név és Bio\",\"nsfw_clickthrough\":\"NSFW átkattintási tartalom elrejtésének engedélyezése\",\"profile_background\":\"Profil háttérkép\",\"profile_banner\":\"Profil Banner\",\"reply_link_preview\":\"Válasz-link előzetes mutatása egér rátételkor\",\"set_new_avatar\":\"Új avatár\",\"set_new_profile_background\":\"Új profil háttér beállítása\",\"set_new_profile_banner\":\"Új profil banner\",\"settings\":\"Beállítások\",\"theme\":\"Téma\",\"user_settings\":\"Felhasználói beállítások\"},\"timeline\":{\"conversation\":\"Társalgás\",\"error_fetching\":\"Hiba a frissítések beszerzésénél\",\"load_older\":\"Régebbi állapotok betöltése\",\"show_new\":\"Újak mutatása\",\"up_to_date\":\"Naprakész\"},\"user_card\":{\"block\":\"Letilt\",\"blocked\":\"Letiltva!\",\"follow\":\"Követ\",\"followees\":\"Követettek\",\"followers\":\"Követők\",\"following\":\"Követve!\",\"follows_you\":\"Követ téged!\",\"mute\":\"Némít\",\"muted\":\"Némított\",\"per_day\":\"naponta\",\"statuses\":\"Állapotok\"}}\n\n/***/ }),\n/* 446 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = {\"general\":{\"submit\":\"Invia\",\"apply\":\"Applica\"},\"nav\":{\"mentions\":\"Menzioni\",\"public_tl\":\"Sequenza temporale pubblica\",\"timeline\":\"Sequenza temporale\",\"twkn\":\"L'intera rete conosciuta\",\"chat\":\"Chat Locale\",\"friend_requests\":\"Richieste di Seguirti\"},\"notifications\":{\"followed_you\":\"ti segue\",\"notifications\":\"Notifiche\",\"read\":\"Leggi!\",\"broken_favorite\":\"Stato sconosciuto, lo sto cercando...\",\"favorited_you\":\"ha messo mi piace al tuo stato\",\"load_older\":\"Carica notifiche più vecchie\",\"repeated_you\":\"ha condiviso il tuo stato\"},\"settings\":{\"attachments\":\"Allegati\",\"autoload\":\"Abilita caricamento automatico quando si raggiunge fondo pagina\",\"avatar\":\"Avatar\",\"bio\":\"Introduzione\",\"current_avatar\":\"Il tuo avatar attuale\",\"current_profile_banner\":\"Il tuo banner attuale\",\"filtering\":\"Filtri\",\"filtering_explanation\":\"Tutti i post contenenti queste parole saranno silenziati, uno per linea\",\"hide_attachments_in_convo\":\"Nascondi gli allegati presenti nelle conversazioni\",\"hide_attachments_in_tl\":\"Nascondi gli allegati presenti nella sequenza temporale\",\"name\":\"Nome\",\"name_bio\":\"Nome & Introduzione\",\"nsfw_clickthrough\":\"Abilita il click per visualizzare gli allegati segnati come NSFW\",\"profile_background\":\"Sfondo della tua pagina\",\"profile_banner\":\"Banner del tuo profilo\",\"reply_link_preview\":\"Abilita il link per la risposta al passaggio del mouse\",\"set_new_avatar\":\"Scegli un nuovo avatar\",\"set_new_profile_background\":\"Scegli un nuovo sfondo per la tua pagina\",\"set_new_profile_banner\":\"Scegli un nuovo banner per il tuo profilo\",\"settings\":\"Impostazioni\",\"theme\":\"Tema\",\"user_settings\":\"Impostazioni Utente\",\"attachmentRadius\":\"Allegati\",\"avatarAltRadius\":\"Avatar (Notifiche)\",\"avatarRadius\":\"Avatar\",\"background\":\"Sfondo\",\"btnRadius\":\"Pulsanti\",\"cBlue\":\"Blu (Rispondere, seguire)\",\"cGreen\":\"Verde (Condividi)\",\"cOrange\":\"Arancio (Mi piace)\",\"cRed\":\"Rosso (Annulla)\",\"change_password\":\"Cambia Password\",\"change_password_error\":\"C'è stato un problema durante il cambiamento della password.\",\"changed_password\":\"Password cambiata correttamente!\",\"collapse_subject\":\"Riduci post che hanno un oggetto\",\"confirm_new_password\":\"Conferma la nuova password\",\"current_password\":\"Password attuale\",\"data_import_export_tab\":\"Importa / Esporta Dati\",\"default_vis\":\"Visibilità predefinita dei post\",\"delete_account\":\"Elimina Account\",\"delete_account_description\":\"Elimina definitivamente il tuo account e tutti i tuoi messaggi.\",\"delete_account_error\":\"C'è stato un problema durante l'eliminazione del tuo account. Se il problema persiste contatta l'amministratore della tua istanza.\",\"delete_account_instructions\":\"Digita la tua password nel campo sottostante per confermare l'eliminazione dell'account.\",\"export_theme\":\"Salva settaggi\",\"follow_export\":\"Esporta la lista di chi segui\",\"follow_export_button\":\"Esporta la lista di chi segui in un file csv\",\"follow_export_processing\":\"Sto elaborando, presto ti sarà chiesto di scaricare il tuo file\",\"follow_import\":\"Importa la lista di chi segui\",\"follow_import_error\":\"Errore nell'importazione della lista di chi segui\",\"follows_imported\":\"Importazione riuscita! L'elaborazione richiederà un po' di tempo.\",\"foreground\":\"In primo piano\",\"general\":\"Generale\",\"hide_post_stats\":\"Nascondi statistiche dei post (es. il numero di mi piace)\",\"hide_user_stats\":\"Nascondi statistiche dell'utente (es. il numero di chi ti segue)\",\"import_followers_from_a_csv_file\":\"Importa una lista di chi segui da un file csv\",\"import_theme\":\"Carica settaggi\",\"inputRadius\":\"Campi di testo\",\"instance_default\":\"(predefinito: {value})\",\"interfaceLanguage\":\"Linguaggio dell'interfaccia\",\"invalid_theme_imported\":\"Il file selezionato non è un file di tema per Pleroma supportato. Il tuo tema non è stato modificato.\",\"limited_availability\":\"Non disponibile nel tuo browser\",\"links\":\"Collegamenti\",\"lock_account_description\":\"Limita il tuo account solo per contatti approvati\",\"loop_video\":\"Riproduci video in ciclo continuo\",\"loop_video_silent_only\":\"Riproduci solo video senza audio in ciclo continuo (es. le gif di Mastodon)\",\"new_password\":\"Nuova password\",\"notification_visibility\":\"Tipi di notifiche da mostrare\",\"notification_visibility_follows\":\"Nuove persone ti seguono\",\"notification_visibility_likes\":\"Mi piace\",\"notification_visibility_mentions\":\"Menzioni\",\"notification_visibility_repeats\":\"Condivisioni\",\"no_rich_text_description\":\"Togli la formattazione del testo da tutti i post\",\"oauth_tokens\":\"Token OAuth\",\"token\":\"Token\",\"refresh_token\":\"Aggiorna token\",\"valid_until\":\"Valido fino a\",\"revoke_token\":\"Revocare\",\"panelRadius\":\"Pannelli\",\"pause_on_unfocused\":\"Metti in pausa l'aggiornamento continuo quando la scheda non è in primo piano\",\"presets\":\"Valori predefiniti\",\"profile_tab\":\"Profilo\",\"radii_help\":\"Imposta l'arrotondamento dei bordi (in pixel)\",\"replies_in_timeline\":\"Risposte nella sequenza temporale\",\"reply_visibility_all\":\"Mostra tutte le risposte\",\"reply_visibility_following\":\"Mostra solo le risposte dirette a me o agli utenti che seguo\",\"reply_visibility_self\":\"Mostra solo risposte dirette a me\",\"saving_err\":\"Errore nel salvataggio delle impostazioni\",\"saving_ok\":\"Impostazioni salvate\",\"security_tab\":\"Sicurezza\",\"stop_gifs\":\"Riproduci GIF al passaggio del cursore del mouse\",\"streaming\":\"Abilita aggiornamento automatico dei nuovi post quando si è in alto alla pagina\",\"text\":\"Testo\",\"theme_help\":\"Usa codici colore esadecimali (#rrggbb) per personalizzare il tuo schema di colori.\",\"tooltipRadius\":\"Descrizioni/avvisi\",\"values\":{\"false\":\"no\",\"true\":\"si\"}},\"timeline\":{\"error_fetching\":\"Errore nel prelievo aggiornamenti\",\"load_older\":\"Carica messaggi più vecchi\",\"show_new\":\"Mostra nuovi\",\"up_to_date\":\"Aggiornato\",\"collapse\":\"Riduci\",\"conversation\":\"Conversazione\",\"no_retweet_hint\":\"La visibilità del post è impostata solo per chi ti segue o messaggio diretto e non può essere condiviso\",\"repeated\":\"condiviso\"},\"user_card\":{\"follow\":\"Segui\",\"followees\":\"Chi stai seguendo\",\"followers\":\"Chi ti segue\",\"following\":\"Lo stai seguendo!\",\"follows_you\":\"Ti segue!\",\"mute\":\"Silenzia\",\"muted\":\"Silenziato\",\"per_day\":\"al giorno\",\"statuses\":\"Messaggi\",\"approve\":\"Approva\",\"block\":\"Blocca\",\"blocked\":\"Bloccato!\",\"deny\":\"Nega\",\"remote_follow\":\"Segui da remoto\"},\"chat\":{\"title\":\"Chat\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Media proxy\",\"scope_options\":\"Opzioni di visibilità\",\"text_limit\":\"Lunghezza limite\",\"title\":\"Caratteristiche\",\"who_to_follow\":\"Chi seguire\"},\"finder\":{\"error_fetching_user\":\"Errore nel recupero dell'utente\",\"find_user\":\"Trova utente\"},\"login\":{\"login\":\"Accedi\",\"logout\":\"Disconnettiti\",\"password\":\"Password\",\"placeholder\":\"es. lain\",\"register\":\"Registrati\",\"username\":\"Nome utente\"},\"post_status\":{\"account_not_locked_warning\":\"Il tuo account non è {0}. Chiunque può seguirti e vedere i tuoi post riservati a chi ti segue.\",\"account_not_locked_warning_link\":\"bloccato\",\"attachments_sensitive\":\"Segna allegati come sensibili\",\"content_type\":{\"plain_text\":\"Testo normale\"},\"content_warning\":\"Oggetto (facoltativo)\",\"default\":\"Appena atterrato in L.A.\",\"direct_warning\":\"Questo post sarà visibile solo dagli utenti menzionati.\",\"posting\":\"Pubblica\",\"scope\":{\"direct\":\"Diretto - Pubblicato solo per gli utenti menzionati\",\"private\":\"Solo per chi ti segue - Visibile solo da chi ti segue\",\"public\":\"Pubblico - Visibile sulla sequenza temporale pubblica\",\"unlisted\":\"Non elencato - Non visibile sulla sequenza temporale pubblica\"}},\"registration\":{\"bio\":\"Introduzione\",\"email\":\"Email\",\"fullname\":\"Nome visualizzato\",\"password_confirm\":\"Conferma password\",\"registration\":\"Registrazione\",\"token\":\"Codice d'invito\"},\"user_profile\":{\"timeline_title\":\"Sequenza Temporale dell'Utente\"},\"who_to_follow\":{\"more\":\"Più\",\"who_to_follow\":\"Chi seguire\"}}\n\n/***/ }),\n/* 447 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = {\"chat\":{\"title\":\"チャット\"},\"features_panel\":{\"chat\":\"チャット\",\"gopher\":\"Gopher\",\"media_proxy\":\"メディアプロクシ\",\"scope_options\":\"こうかいはんいせんたく\",\"text_limit\":\"もじのかず\",\"title\":\"ゆうこうなきのう\",\"who_to_follow\":\"おすすめユーザー\"},\"finder\":{\"error_fetching_user\":\"ユーザーけんさくがエラーになりました。\",\"find_user\":\"ユーザーをさがす\"},\"general\":{\"apply\":\"てきよう\",\"submit\":\"そうしん\",\"more\":\"つづき\",\"generic_error\":\"エラーになりました\"},\"login\":{\"login\":\"ログイン\",\"description\":\"OAuthでログイン\",\"logout\":\"ログアウト\",\"password\":\"パスワード\",\"placeholder\":\"れい: lain\",\"register\":\"はじめる\",\"username\":\"ユーザーめい\",\"hint\":\"はなしあいにくわわるには、ログインしてください\"},\"nav\":{\"about\":\"これはなに?\",\"back\":\"もどる\",\"chat\":\"ローカルチャット\",\"friend_requests\":\"フォローリクエスト\",\"mentions\":\"メンション\",\"dms\":\"ダイレクトメッセージ\",\"public_tl\":\"パブリックタイムライン\",\"timeline\":\"タイムライン\",\"twkn\":\"つながっているすべてのネットワーク\",\"user_search\":\"ユーザーをさがす\",\"who_to_follow\":\"おすすめユーザー\",\"preferences\":\"せってい\"},\"notifications\":{\"broken_favorite\":\"ステータスがみつかりません。さがしています...\",\"favorited_you\":\"あなたのステータスがおきにいりされました\",\"followed_you\":\"フォローされました\",\"load_older\":\"ふるいつうちをみる\",\"notifications\":\"つうち\",\"read\":\"よんだ!\",\"repeated_you\":\"あなたのステータスがリピートされました\",\"no_more_notifications\":\"つうちはありません\"},\"post_status\":{\"new_status\":\"とうこうする\",\"account_not_locked_warning\":\"あなたのアカウントは {0} ではありません。あなたをフォローすれば、だれでも、フォロワーげんていのステータスをよむことができます。\",\"account_not_locked_warning_link\":\"ロックされたアカウント\",\"attachments_sensitive\":\"ファイルをNSFWにする\",\"content_type\":{\"plain_text\":\"プレーンテキスト\"},\"content_warning\":\"せつめい (かかなくてもよい)\",\"default\":\"はねだくうこうに、つきました。\",\"direct_warning\":\"このステータスは、メンションされたユーザーだけが、よむことができます。\",\"posting\":\"とうこう\",\"scope\":{\"direct\":\"ダイレクト: メンションされたユーザーのみにとどきます。\",\"private\":\"フォロワーげんてい: フォロワーのみにとどきます。\",\"public\":\"パブリック: パブリックタイムラインにとどきます。\",\"unlisted\":\"アンリステッド: パブリックタイムラインにとどきません。\"}},\"registration\":{\"bio\":\"プロフィール\",\"email\":\"Eメール\",\"fullname\":\"スクリーンネーム\",\"password_confirm\":\"パスワードのかくにん\",\"registration\":\"はじめる\",\"token\":\"しょうたいトークン\",\"captcha\":\"CAPTCHA\",\"new_captcha\":\"もじがよめないときは、がぞうをクリックすると、あたらしいがぞうになります\",\"validations\":{\"username_required\":\"なにかかいてください\",\"fullname_required\":\"なにかかいてください\",\"email_required\":\"なにかかいてください\",\"password_required\":\"なにかかいてください\",\"password_confirmation_required\":\"なにかかいてください\",\"password_confirmation_match\":\"パスワードがちがいます\"}},\"settings\":{\"attachmentRadius\":\"ファイル\",\"attachments\":\"ファイル\",\"autoload\":\"したにスクロールしたとき、じどうてきによみこむ。\",\"avatar\":\"アバター\",\"avatarAltRadius\":\"つうちのアバター\",\"avatarRadius\":\"アバター\",\"background\":\"バックグラウンド\",\"bio\":\"プロフィール\",\"btnRadius\":\"ボタン\",\"cBlue\":\"リプライとフォロー\",\"cGreen\":\"リピート\",\"cOrange\":\"おきにいり\",\"cRed\":\"キャンセル\",\"change_password\":\"パスワードをかえる\",\"change_password_error\":\"パスワードをかえることが、できなかったかもしれません。\",\"changed_password\":\"パスワードが、かわりました!\",\"collapse_subject\":\"せつめいのあるとうこうをたたむ\",\"composing\":\"とうこう\",\"confirm_new_password\":\"あたらしいパスワードのかくにん\",\"current_avatar\":\"いまのアバター\",\"current_password\":\"いまのパスワード\",\"current_profile_banner\":\"いまのプロフィールバナー\",\"data_import_export_tab\":\"インポートとエクスポート\",\"default_vis\":\"デフォルトのこうかいはんい\",\"delete_account\":\"アカウントをけす\",\"delete_account_description\":\"あなたのアカウントとメッセージが、きえます。\",\"delete_account_error\":\"アカウントをけすことが、できなかったかもしれません。インスタンスのかんりしゃに、れんらくしてください。\",\"delete_account_instructions\":\"ほんとうにアカウントをけしてもいいなら、パスワードをかいてください。\",\"avatar_size_instruction\":\"アバターのおおきさは、150×150ピクセルか、それよりもおおきくするといいです。\",\"export_theme\":\"セーブ\",\"filtering\":\"フィルタリング\",\"filtering_explanation\":\"これらのことばをふくむすべてのものがミュートされます。1ぎょうに1つのことばをかいてください。\",\"follow_export\":\"フォローのエクスポート\",\"follow_export_button\":\"エクスポート\",\"follow_export_processing\":\"おまちください。まもなくファイルをダウンロードできます。\",\"follow_import\":\"フォローインポート\",\"follow_import_error\":\"フォローのインポートがエラーになりました。\",\"follows_imported\":\"フォローがインポートされました! すこしじかんがかかるかもしれません。\",\"foreground\":\"フォアグラウンド\",\"general\":\"ぜんぱん\",\"hide_attachments_in_convo\":\"スレッドのファイルをかくす\",\"hide_attachments_in_tl\":\"タイムラインのファイルをかくす\",\"hide_isp\":\"インスタンススペシフィックパネルをかくす\",\"preload_images\":\"がぞうをさきよみする\",\"use_one_click_nsfw\":\"NSFWなファイルを1クリックでひらく\",\"hide_post_stats\":\"とうこうのとうけいをかくす (れい: おきにいりのかず)\",\"hide_user_stats\":\"ユーザーのとうけいをかくす (れい: フォロワーのかず)\",\"hide_filtered_statuses\":\"フィルターされたとうこうをかくす\",\"import_followers_from_a_csv_file\":\"CSVファイルからフォローをインポートする\",\"import_theme\":\"ロード\",\"inputRadius\":\"インプットフィールド\",\"checkboxRadius\":\"チェックボックス\",\"instance_default\":\"(デフォルト: {value})\",\"instance_default_simple\":\"(デフォルト)\",\"interface\":\"インターフェース\",\"interfaceLanguage\":\"インターフェースのことば\",\"invalid_theme_imported\":\"このファイルはPleromaのテーマではありません。テーマはへんこうされませんでした。\",\"limited_availability\":\"あなたのブラウザではできません\",\"links\":\"リンク\",\"lock_account_description\":\"あなたがみとめたひとだけ、あなたのアカウントをフォローできる\",\"loop_video\":\"ビデオをくりかえす\",\"loop_video_silent_only\":\"おとのないビデオだけくりかえす\",\"play_videos_in_modal\":\"ビデオをメディアビューアーでみる\",\"use_contain_fit\":\"がぞうのサムネイルを、きりぬかない\",\"name\":\"なまえ\",\"name_bio\":\"なまえとプロフィール\",\"new_password\":\"あたらしいパスワード\",\"notification_visibility\":\"ひょうじするつうち\",\"notification_visibility_follows\":\"フォロー\",\"notification_visibility_likes\":\"おきにいり\",\"notification_visibility_mentions\":\"メンション\",\"notification_visibility_repeats\":\"リピート\",\"no_rich_text_description\":\"リッチテキストをつかわない\",\"hide_follows_description\":\"フォローしているひとをみせない\",\"hide_followers_description\":\"フォロワーをみせない\",\"show_admin_badge\":\"アドミンのしるしをみる\",\"show_moderator_badge\":\"モデレーターのしるしをみる\",\"nsfw_clickthrough\":\"NSFWなファイルをかくす\",\"oauth_tokens\":\"OAuthトークン\",\"token\":\"トークン\",\"refresh_token\":\"トークンを更新\",\"valid_until\":\"まで有効\",\"revoke_token\":\"取り消す\",\"panelRadius\":\"パネル\",\"pause_on_unfocused\":\"タブにフォーカスがないときストリーミングをとめる\",\"presets\":\"プリセット\",\"profile_background\":\"プロフィールのバックグラウンド\",\"profile_banner\":\"プロフィールバナー\",\"profile_tab\":\"プロフィール\",\"radii_help\":\"インターフェースのまるさをせっていする。\",\"replies_in_timeline\":\"タイムラインのリプライ\",\"reply_link_preview\":\"カーソルをかさねたとき、リプライのプレビューをみる\",\"reply_visibility_all\":\"すべてのリプライをみる\",\"reply_visibility_following\":\"わたしにあてられたリプライと、フォローしているひとからのリプライをみる\",\"reply_visibility_self\":\"わたしにあてられたリプライをみる\",\"saving_err\":\"せっていをセーブできませんでした\",\"saving_ok\":\"せっていをセーブしました\",\"security_tab\":\"セキュリティ\",\"scope_copy\":\"リプライするとき、こうかいはんいをコピーする (DMのこうかいはんいは、つねにコピーされます)\",\"set_new_avatar\":\"あたらしいアバターをせっていする\",\"set_new_profile_background\":\"あたらしいプロフィールのバックグラウンドをせっていする\",\"set_new_profile_banner\":\"あたらしいプロフィールバナーを設定する\",\"settings\":\"せってい\",\"subject_input_always_show\":\"サブジェクトフィールドをいつでもひょうじする\",\"subject_line_behavior\":\"リプライするときサブジェクトをコピーする\",\"subject_line_email\":\"メールふう: \\\"re: サブジェクト\\\"\",\"subject_line_mastodon\":\"マストドンふう: そのままコピー\",\"subject_line_noop\":\"コピーしない\",\"post_status_content_type\":\"とうこうのコンテントタイプ\",\"stop_gifs\":\"カーソルをかさねたとき、GIFをうごかす\",\"streaming\":\"うえまでスクロールしたとき、じどうてきにストリーミングする\",\"text\":\"もじ\",\"theme\":\"テーマ\",\"theme_help\":\"カラーテーマをカスタマイズできます\",\"theme_help_v2_1\":\"チェックボックスをONにすると、コンポーネントごとに、いろと、とうめいどを、オーバーライドできます。「すべてクリア」ボタンをおすと、すべてのオーバーライドを、やめます。\",\"theme_help_v2_2\":\"バックグラウンドとテキストのコントラストをあらわすアイコンがあります。マウスをホバーすると、くわしいせつめいがでます。とうめいないろをつかっているときは、もっともわるいばあいのコントラストがしめされます。\",\"tooltipRadius\":\"ツールチップとアラート\",\"user_settings\":\"ユーザーせってい\",\"values\":{\"false\":\"いいえ\",\"true\":\"はい\"},\"notifications\":\"つうち\",\"enable_web_push_notifications\":\"ウェブプッシュつうちをゆるす\",\"style\":{\"switcher\":{\"keep_color\":\"いろをのこす\",\"keep_shadows\":\"かげをのこす\",\"keep_opacity\":\"とうめいどをのこす\",\"keep_roundness\":\"まるさをのこす\",\"keep_fonts\":\"フォントをのこす\",\"save_load_hint\":\"「のこす」オプションをONにすると、テーマをえらんだときとロードしたとき、いまのせっていをのこします。また、テーマをエクスポートするとき、これらのオプションをストアします。すべてのチェックボックスをOFFにすると、テーマをエクスポートしたとき、すべてのせっていをセーブします。\",\"reset\":\"リセット\",\"clear_all\":\"すべてクリア\",\"clear_opacity\":\"とうめいどをクリア\"},\"common\":{\"color\":\"いろ\",\"opacity\":\"とうめいど\",\"contrast\":{\"hint\":\"コントラストは {ratio} です。{level}。({context})\",\"level\":{\"aa\":\"AAレベルガイドライン (ミニマル) をみたします\",\"aaa\":\"AAAレベルガイドライン (レコメンデッド) をみたします。\",\"bad\":\"ガイドラインをみたしません。\"},\"context\":{\"18pt\":\"おおきい (18ポイントいじょう) テキスト\",\"text\":\"テキスト\"}}},\"common_colors\":{\"_tab_label\":\"きょうつう\",\"main\":\"きょうつうのいろ\",\"foreground_hint\":\"「くわしく」タブで、もっとこまかくせっていできます\",\"rgbo\":\"アイコンとアクセントとバッジ\"},\"advanced_colors\":{\"_tab_label\":\"くわしく\",\"alert\":\"アラートのバックグラウンド\",\"alert_error\":\"エラー\",\"badge\":\"バッジのバックグラウンド\",\"badge_notification\":\"つうち\",\"panel_header\":\"パネルヘッダー\",\"top_bar\":\"トップバー\",\"borders\":\"さかいめ\",\"buttons\":\"ボタン\",\"inputs\":\"インプットフィールド\",\"faint_text\":\"うすいテキスト\"},\"radii\":{\"_tab_label\":\"まるさ\"},\"shadows\":{\"_tab_label\":\"ひかりとかげ\",\"component\":\"コンポーネント\",\"override\":\"オーバーライド\",\"shadow_id\":\"かげ #{value}\",\"blur\":\"ぼかし\",\"spread\":\"ひろがり\",\"inset\":\"うちがわ\",\"hint\":\"かげのせっていでは、いろのあたいとして --variable をつかうことができます。これはCSS3へんすうです。ただし、とうめいどのせっていは、きかなくなります。\",\"filter_hint\":{\"always_drop_shadow\":\"ブラウザーがサポートしていれば、つねに {0} がつかわれます。\",\"drop_shadow_syntax\":\"{0} は、{1} パラメーターと {2} キーワードをサポートしていません。\",\"avatar_inset\":\"うちがわのかげと、そとがわのかげを、いっしょにつかうと、とうめいなアバターが、へんなみためになります。\",\"spread_zero\":\"ひろがりが 0 よりもおおきなかげは、0 とおなじです。\",\"inset_classic\":\"うちがわのかげは {0} をつかいます。\"},\"components\":{\"panel\":\"パネル\",\"panelHeader\":\"パネルヘッダー\",\"topBar\":\"トップバー\",\"avatar\":\"ユーザーアバター (プロフィール)\",\"avatarStatus\":\"ユーザーアバター (とうこう)\",\"popup\":\"ポップアップとツールチップ\",\"button\":\"ボタン\",\"buttonHover\":\"ボタン (ホバー)\",\"buttonPressed\":\"ボタン (おされているとき)\",\"buttonPressedHover\":\"ボタン (ホバー、かつ、おされているとき)\",\"input\":\"インプットフィールド\"}},\"fonts\":{\"_tab_label\":\"フォント\",\"help\":\"「カスタム」をえらんだときは、システムにあるフォントのなまえを、ただしくにゅうりょくしてください。\",\"components\":{\"interface\":\"インターフェース\",\"input\":\"インプットフィールド\",\"post\":\"とうこう\",\"postCode\":\"モノスペース (とうこうがリッチテキストであるとき)\"},\"family\":\"フォントめい\",\"size\":\"おおきさ (px)\",\"weight\":\"ふとさ\",\"custom\":\"カスタム\"},\"preview\":{\"header\":\"プレビュー\",\"content\":\"ほんぶん\",\"error\":\"エラーのれい\",\"button\":\"ボタン\",\"text\":\"これは{0}と{1}のれいです。\",\"mono\":\"monospace\",\"input\":\"はねだくうこうに、つきました。\",\"faint_link\":\"とてもたすけになるマニュアル\",\"fine_print\":\"わたしたちの{0}を、よまないでください!\",\"header_faint\":\"エラーではありません\",\"checkbox\":\"りようきやくを、よみました\",\"link\":\"ハイパーリンク\"}}},\"timeline\":{\"collapse\":\"たたむ\",\"conversation\":\"スレッド\",\"error_fetching\":\"よみこみがエラーになりました\",\"load_older\":\"ふるいステータス\",\"no_retweet_hint\":\"とうこうを「フォロワーのみ」または「ダイレクト」にすると、リピートできなくなります\",\"repeated\":\"リピート\",\"show_new\":\"よみこみ\",\"up_to_date\":\"さいしん\",\"no_more_statuses\":\"これでおわりです\"},\"user_card\":{\"approve\":\"うけいれ\",\"block\":\"ブロック\",\"blocked\":\"ブロックしています!\",\"deny\":\"おことわり\",\"favorites\":\"おきにいり\",\"follow\":\"フォロー\",\"follow_sent\":\"リクエストを、おくりました!\",\"follow_progress\":\"リクエストしています…\",\"follow_again\":\"ふたたびリクエストをおくりますか?\",\"follow_unfollow\":\"フォローをやめる\",\"followees\":\"フォロー\",\"followers\":\"フォロワー\",\"following\":\"フォローしています!\",\"follows_you\":\"フォローされました!\",\"its_you\":\"これはあなたです!\",\"media\":\"メディア\",\"mute\":\"ミュート\",\"muted\":\"ミュートしています!\",\"per_day\":\"/日\",\"remote_follow\":\"リモートフォロー\",\"statuses\":\"ステータス\"},\"user_profile\":{\"timeline_title\":\"ユーザータイムライン\"},\"who_to_follow\":{\"more\":\"くわしく\",\"who_to_follow\":\"おすすめユーザー\"},\"tool_tip\":{\"media_upload\":\"メディアをアップロード\",\"repeat\":\"リピート\",\"reply\":\"リプライ\",\"favorite\":\"おきにいり\",\"user_settings\":\"ユーザーせってい\"},\"upload\":{\"error\":{\"base\":\"アップロードにしっぱいしました。\",\"file_too_big\":\"ファイルがおおきすぎます [{filesize} {filesizeunit} / {allowedsize} {allowedsizeunit}]\",\"default\":\"しばらくしてから、ためしてください\"},\"file_size_units\":{\"B\":\"B\",\"KiB\":\"KiB\",\"MiB\":\"MiB\",\"GiB\":\"GiB\",\"TiB\":\"TiB\"}}}\n\n/***/ }),\n/* 448 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = {\"chat\":{\"title\":\"챗\"},\"features_panel\":{\"chat\":\"챗\",\"gopher\":\"고퍼\",\"media_proxy\":\"미디어 프록시\",\"scope_options\":\"범위 옵션\",\"text_limit\":\"텍스트 제한\",\"title\":\"기능\",\"who_to_follow\":\"팔로우 추천\"},\"finder\":{\"error_fetching_user\":\"사용자 정보 불러오기 실패\",\"find_user\":\"사용자 찾기\"},\"general\":{\"apply\":\"적용\",\"submit\":\"보내기\"},\"login\":{\"login\":\"로그인\",\"description\":\"OAuth로 로그인\",\"logout\":\"로그아웃\",\"password\":\"암호\",\"placeholder\":\"예시: lain\",\"register\":\"가입\",\"username\":\"사용자 이름\"},\"nav\":{\"about\":\"About\",\"back\":\"뒤로\",\"chat\":\"로컬 챗\",\"friend_requests\":\"팔로우 요청\",\"mentions\":\"멘션\",\"dms\":\"다이렉트 메시지\",\"public_tl\":\"공개 타임라인\",\"timeline\":\"타임라인\",\"twkn\":\"모든 알려진 네트워크\",\"user_search\":\"사용자 검색\",\"preferences\":\"환경설정\"},\"notifications\":{\"broken_favorite\":\"알 수 없는 게시물입니다, 검색 합니다...\",\"favorited_you\":\"당신의 게시물을 즐겨찾기\",\"followed_you\":\"당신을 팔로우\",\"load_older\":\"오래 된 알림 불러오기\",\"notifications\":\"알림\",\"read\":\"읽음!\",\"repeated_you\":\"당신의 게시물을 리핏\"},\"post_status\":{\"new_status\":\"새 게시물 게시\",\"account_not_locked_warning\":\"당신의 계정은 {0} 상태가 아닙니다. 누구나 당신을 팔로우 하고 팔로워 전용 게시물을 볼 수 있습니다.\",\"account_not_locked_warning_link\":\"잠김\",\"attachments_sensitive\":\"첨부물을 민감함으로 설정\",\"content_type\":{\"plain_text\":\"평문\"},\"content_warning\":\"주제 (필수 아님)\",\"default\":\"LA에 도착!\",\"direct_warning\":\"이 게시물을 멘션 된 사용자들에게만 보여집니다\",\"posting\":\"게시\",\"scope\":{\"direct\":\"다이렉트 - 멘션 된 사용자들에게만\",\"private\":\"팔로워 전용 - 팔로워들에게만\",\"public\":\"공개 - 공개 타임라인으로\",\"unlisted\":\"비공개 - 공개 타임라인에 게시 안 함\"}},\"registration\":{\"bio\":\"소개\",\"email\":\"이메일\",\"fullname\":\"표시 되는 이름\",\"password_confirm\":\"암호 확인\",\"registration\":\"가입하기\",\"token\":\"초대 토큰\",\"captcha\":\"캡차\",\"new_captcha\":\"이미지를 클릭해서 새로운 캡차\",\"validations\":{\"username_required\":\"공백으로 둘 수 없습니다\",\"fullname_required\":\"공백으로 둘 수 없습니다\",\"email_required\":\"공백으로 둘 수 없습니다\",\"password_required\":\"공백으로 둘 수 없습니다\",\"password_confirmation_required\":\"공백으로 둘 수 없습니다\",\"password_confirmation_match\":\"패스워드와 일치해야 합니다\"}},\"settings\":{\"attachmentRadius\":\"첨부물\",\"attachments\":\"첨부물\",\"autoload\":\"최하단에 도착하면 자동으로 로드 활성화\",\"avatar\":\"아바타\",\"avatarAltRadius\":\"아바타 (알림)\",\"avatarRadius\":\"아바타\",\"background\":\"배경\",\"bio\":\"소개\",\"btnRadius\":\"버튼\",\"cBlue\":\"파랑 (답글, 팔로우)\",\"cGreen\":\"초록 (리트윗)\",\"cOrange\":\"주황 (즐겨찾기)\",\"cRed\":\"빨강 (취소)\",\"change_password\":\"암호 바꾸기\",\"change_password_error\":\"암호를 바꾸는 데 몇 가지 문제가 있습니다.\",\"changed_password\":\"암호를 바꾸었습니다!\",\"collapse_subject\":\"주제를 가진 게시물 접기\",\"composing\":\"작성\",\"confirm_new_password\":\"새 패스워드 확인\",\"current_avatar\":\"현재 아바타\",\"current_password\":\"현재 패스워드\",\"current_profile_banner\":\"현재 프로필 배너\",\"data_import_export_tab\":\"데이터 불러오기 / 내보내기\",\"default_vis\":\"기본 공개 범위\",\"delete_account\":\"계정 삭제\",\"delete_account_description\":\"계정과 메시지를 영구히 삭제.\",\"delete_account_error\":\"계정을 삭제하는데 문제가 있습니다. 계속 발생한다면 인스턴스 관리자에게 문의하세요.\",\"delete_account_instructions\":\"계정 삭제를 확인하기 위해 아래에 패스워드 입력.\",\"export_theme\":\"프리셋 저장\",\"filtering\":\"필터링\",\"filtering_explanation\":\"아래의 단어를 가진 게시물들은 뮤트 됩니다, 한 줄에 하나씩 적으세요\",\"follow_export\":\"팔로우 내보내기\",\"follow_export_button\":\"팔로우 목록을 csv로 내보내기\",\"follow_export_processing\":\"진행 중입니다, 곧 다운로드 가능해 질 것입니다\",\"follow_import\":\"팔로우 불러오기\",\"follow_import_error\":\"팔로우 불러오기 실패\",\"follows_imported\":\"팔로우 목록을 불러왔습니다! 처리에는 시간이 걸립니다.\",\"foreground\":\"전경\",\"general\":\"일반\",\"hide_attachments_in_convo\":\"대화의 첨부물 숨기기\",\"hide_attachments_in_tl\":\"타임라인의 첨부물 숨기기\",\"hide_isp\":\"인스턴스 전용 패널 숨기기\",\"preload_images\":\"이미지 미리 불러오기\",\"hide_post_stats\":\"게시물 통계 숨기기 (즐겨찾기 수 등)\",\"hide_user_stats\":\"사용자 통계 숨기기 (팔로워 수 등)\",\"import_followers_from_a_csv_file\":\"csv 파일에서 팔로우 목록 불러오기\",\"import_theme\":\"프리셋 불러오기\",\"inputRadius\":\"입력 칸\",\"checkboxRadius\":\"체크박스\",\"instance_default\":\"(기본: {value})\",\"instance_default_simple\":\"(기본)\",\"interface\":\"인터페이스\",\"interfaceLanguage\":\"인터페이스 언어\",\"invalid_theme_imported\":\"선택한 파일은 지원하는 플레로마 테마가 아닙니다. 아무런 변경도 일어나지 않았습니다.\",\"limited_availability\":\"이 브라우저에서 사용 불가\",\"links\":\"링크\",\"lock_account_description\":\"계정을 승인 된 팔로워들로 제한\",\"loop_video\":\"비디오 반복재생\",\"loop_video_silent_only\":\"소리가 없는 비디오만 반복 재생 (마스토돈의 \\\"gifs\\\" 같은 것들)\",\"name\":\"이름\",\"name_bio\":\"이름 & 소개\",\"new_password\":\"새 암호\",\"notification_visibility\":\"보여 줄 알림 종류\",\"notification_visibility_follows\":\"팔로우\",\"notification_visibility_likes\":\"좋아함\",\"notification_visibility_mentions\":\"멘션\",\"notification_visibility_repeats\":\"반복\",\"no_rich_text_description\":\"모든 게시물의 서식을 지우기\",\"hide_follows_description\":\"내가 팔로우하는 사람을 표시하지 않음\",\"hide_followers_description\":\"나를 따르는 사람을 보여주지 마라.\",\"nsfw_clickthrough\":\"NSFW 이미지 \\\"클릭해서 보이기\\\"를 활성화\",\"oauth_tokens\":\"OAuth 토큰\",\"token\":\"토큰\",\"refresh_token\":\"토큰 새로 고침\",\"valid_until\":\"까지 유효하다\",\"revoke_token\":\"취소\",\"panelRadius\":\"패널\",\"pause_on_unfocused\":\"탭이 활성 상태가 아닐 때 스트리밍 멈추기\",\"presets\":\"프리셋\",\"profile_background\":\"프로필 배경\",\"profile_banner\":\"프로필 배너\",\"profile_tab\":\"프로필\",\"radii_help\":\"인터페이스 모서리 둥글기 (픽셀 단위)\",\"replies_in_timeline\":\"답글을 타임라인에\",\"reply_link_preview\":\"마우스를 올려서 답글 링크 미리보기 활성화\",\"reply_visibility_all\":\"모든 답글 보기\",\"reply_visibility_following\":\"나에게 직접 오는 답글이나 내가 팔로우 중인 사람에게서 오는 답글만 표시\",\"reply_visibility_self\":\"나에게 직접 전송 된 답글만 보이기\",\"saving_err\":\"설정 저장 실패\",\"saving_ok\":\"설정 저장 됨\",\"security_tab\":\"보안\",\"scope_copy\":\"답글을 달 때 공개 범위 따라가리 (다이렉트 메시지는 언제나 따라감)\",\"set_new_avatar\":\"새 아바타 설정\",\"set_new_profile_background\":\"새 프로필 배경 설정\",\"set_new_profile_banner\":\"새 프로필 배너 설정\",\"settings\":\"설정\",\"subject_input_always_show\":\"항상 주제 칸 보이기\",\"subject_line_behavior\":\"답글을 달 때 주제 복사하기\",\"subject_line_email\":\"이메일처럼: \\\"re: 주제\\\"\",\"subject_line_mastodon\":\"마스토돈처럼: 그대로 복사\",\"subject_line_noop\":\"복사 안 함\",\"stop_gifs\":\"GIF파일에 마우스를 올려서 재생\",\"streaming\":\"최상단에 도달하면 자동으로 새 게시물 스트리밍\",\"text\":\"텍스트\",\"theme\":\"테마\",\"theme_help\":\"16진수 색상코드(#rrggbb)를 사용해 색상 테마를 커스터마이즈.\",\"theme_help_v2_1\":\"체크박스를 통해 몇몇 컴포넌트의 색상과 불투명도를 조절 가능, \\\"모두 지우기\\\" 버튼으로 덮어 씌운 것을 모두 취소.\",\"theme_help_v2_2\":\"몇몇 입력칸 밑의 아이콘은 전경/배경 대비 관련 표시등입니다, 마우스를 올려 자세한 정보를 볼 수 있습니다. 투명도 대비 표시등이 가장 최악의 경우를 나타낸다는 것을 유의하세요.\",\"tooltipRadius\":\"툴팁/경고\",\"user_settings\":\"사용자 설정\",\"values\":{\"false\":\"아니오\",\"true\":\"네\"},\"notifications\":\"알림\",\"enable_web_push_notifications\":\"웹 푸시 알림 활성화\",\"style\":{\"switcher\":{\"keep_color\":\"색상 유지\",\"keep_shadows\":\"그림자 유지\",\"keep_opacity\":\"불투명도 유지\",\"keep_roundness\":\"둥글기 유지\",\"keep_fonts\":\"글자체 유지\",\"save_load_hint\":\"\\\"유지\\\" 옵션들은 다른 테마를 고르거나 불러 올 때 현재 설정 된 옵션들을 건드리지 않게 합니다, 테마를 내보내기 할 때도 이 옵션에 따라 저장합니다. 아무 것도 체크 되지 않았다면 모든 설정을 내보냅니다.\",\"reset\":\"초기화\",\"clear_all\":\"모두 지우기\",\"clear_opacity\":\"불투명도 지우기\"},\"common\":{\"color\":\"색상\",\"opacity\":\"불투명도\",\"contrast\":{\"hint\":\"대비율이 {ratio}입니다, 이것은 {context} {level}\",\"level\":{\"aa\":\"AA등급 가이드라인에 부합합니다 (최소한도)\",\"aaa\":\"AAA등급 가이드라인에 부합합니다 (권장)\",\"bad\":\"아무런 가이드라인 등급에도 미치지 못합니다\"},\"context\":{\"18pt\":\"큰 (18pt 이상) 텍스트에 대해\",\"text\":\"텍스트에 대해\"}}},\"common_colors\":{\"_tab_label\":\"일반\",\"main\":\"일반 색상\",\"foreground_hint\":\"\\\"고급\\\" 탭에서 더 자세한 설정이 가능합니다\",\"rgbo\":\"아이콘, 강조, 배지\"},\"advanced_colors\":{\"_tab_label\":\"고급\",\"alert\":\"주의 배경\",\"alert_error\":\"에러\",\"badge\":\"배지 배경\",\"badge_notification\":\"알림\",\"panel_header\":\"패널 헤더\",\"top_bar\":\"상단 바\",\"borders\":\"테두리\",\"buttons\":\"버튼\",\"inputs\":\"입력칸\",\"faint_text\":\"흐려진 텍스트\"},\"radii\":{\"_tab_label\":\"둥글기\"},\"shadows\":{\"_tab_label\":\"그림자와 빛\",\"component\":\"컴포넌트\",\"override\":\"덮어쓰기\",\"shadow_id\":\"그림자 #{value}\",\"blur\":\"흐리기\",\"spread\":\"퍼지기\",\"inset\":\"안쪽으로\",\"hint\":\"그림자에는 CSS3 변수를 --variable을 통해 색상 값으로 사용할 수 있습니다. 불투명도에는 적용 되지 않습니다.\",\"filter_hint\":{\"always_drop_shadow\":\"경고, 이 그림자는 브라우저가 지원하는 경우 항상 {0}을 사용합니다.\",\"drop_shadow_syntax\":\"{0}는 {1} 파라미터와 {2} 키워드를 지원하지 않습니다.\",\"avatar_inset\":\"안쪽과 안쪽이 아닌 그림자를 모두 설정하는 경우 투명 아바타에서 예상치 못 한 결과가 나올 수 있다는 것에 주의해 주세요.\",\"spread_zero\":\"퍼지기가 0보다 큰 그림자는 0으로 설정한 것과 동일하게 보여집니다\",\"inset_classic\":\"안쪽 그림자는 {0}를 사용합니다\"},\"components\":{\"panel\":\"패널\",\"panelHeader\":\"패널 헤더\",\"topBar\":\"상단 바\",\"avatar\":\"사용자 아바타 (프로필 뷰에서)\",\"avatarStatus\":\"사용자 아바타 (게시물에서)\",\"popup\":\"팝업과 툴팁\",\"button\":\"버튼\",\"buttonHover\":\"버튼 (마우스 올렸을 때)\",\"buttonPressed\":\"버튼 (눌렸을 때)\",\"buttonPressedHover\":\"Button (마우스 올림 + 눌림)\",\"input\":\"입력칸\"}},\"fonts\":{\"_tab_label\":\"글자체\",\"help\":\"인터페이스의 요소에 사용 될 글자체를 고르세요. \\\"커스텀\\\"은 시스템에 있는 폰트 이름을 정확히 입력해야 합니다.\",\"components\":{\"interface\":\"인터페이스\",\"input\":\"입력칸\",\"post\":\"게시물 텍스트\",\"postCode\":\"게시물의 고정폭 텍스트 (서식 있는 텍스트)\"},\"family\":\"글자체 이름\",\"size\":\"크기 (px 단위)\",\"weight\":\"굵기\",\"custom\":\"커스텀\"},\"preview\":{\"header\":\"미리보기\",\"content\":\"내용\",\"error\":\"에러 예시\",\"button\":\"버튼\",\"text\":\"더 많은 {0} 그리고 {1}\",\"mono\":\"내용\",\"input\":\"LA에 막 도착!\",\"faint_link\":\"도움 되는 설명서\",\"fine_print\":\"우리의 {0} 를 읽고 도움 되지 않는 것들을 배우자!\",\"header_faint\":\"이건 괜찮아\",\"checkbox\":\"나는 약관을 대충 훑어보았습니다\",\"link\":\"작고 귀여운 링크\"}}},\"timeline\":{\"collapse\":\"접기\",\"conversation\":\"대화\",\"error_fetching\":\"업데이트 불러오기 실패\",\"load_older\":\"더 오래 된 게시물 불러오기\",\"no_retweet_hint\":\"팔로워 전용, 다이렉트 메시지는 반복할 수 없습니다\",\"repeated\":\"반복 됨\",\"show_new\":\"새로운 것 보기\",\"up_to_date\":\"최신 상태\"},\"user_card\":{\"approve\":\"승인\",\"block\":\"차단\",\"blocked\":\"차단 됨!\",\"deny\":\"거부\",\"follow\":\"팔로우\",\"follow_sent\":\"요청 보내짐!\",\"follow_progress\":\"요청 중…\",\"follow_again\":\"요청을 다시 보낼까요?\",\"follow_unfollow\":\"팔로우 중지\",\"followees\":\"팔로우 중\",\"followers\":\"팔로워\",\"following\":\"팔로우 중!\",\"follows_you\":\"당신을 팔로우 합니다!\",\"its_you\":\"당신입니다!\",\"mute\":\"침묵\",\"muted\":\"침묵 됨\",\"per_day\":\" / 하루\",\"remote_follow\":\"원격 팔로우\",\"statuses\":\"게시물\"},\"user_profile\":{\"timeline_title\":\"사용자 타임라인\"},\"who_to_follow\":{\"more\":\"더 보기\",\"who_to_follow\":\"팔로우 추천\"},\"tool_tip\":{\"media_upload\":\"미디어 업로드\",\"repeat\":\"반복\",\"reply\":\"답글\",\"favorite\":\"즐겨찾기\",\"user_settings\":\"사용자 설정\"},\"upload\":{\"error\":{\"base\":\"업로드 실패.\",\"file_too_big\":\"파일이 너무 커요 [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"잠시 후에 다시 시도해 보세요\"},\"file_size_units\":{\"B\":\"바이트\",\"KiB\":\"키비바이트\",\"MiB\":\"메비바이트\",\"GiB\":\"기비바이트\",\"TiB\":\"테비바이트\"}}}\n\n/***/ }),\n/* 449 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = {\"chat\":{\"title\":\"Nettprat\"},\"features_panel\":{\"chat\":\"Nettprat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Media proxy\",\"scope_options\":\"Velg mottakere\",\"text_limit\":\"Tekst-grense\",\"title\":\"Egenskaper\",\"who_to_follow\":\"Hvem å følge\"},\"finder\":{\"error_fetching_user\":\"Feil ved henting av bruker\",\"find_user\":\"Finn bruker\"},\"general\":{\"apply\":\"Bruk\",\"submit\":\"Send\"},\"login\":{\"login\":\"Logg inn\",\"logout\":\"Logg ut\",\"password\":\"Passord\",\"placeholder\":\"f. eks lain\",\"register\":\"Registrer\",\"username\":\"Brukernavn\"},\"nav\":{\"chat\":\"Lokal nettprat\",\"friend_requests\":\"Følgeforespørsler\",\"mentions\":\"Nevnt\",\"public_tl\":\"Offentlig Tidslinje\",\"timeline\":\"Tidslinje\",\"twkn\":\"Det hele kjente nettverket\"},\"notifications\":{\"broken_favorite\":\"Ukjent status, leter etter den...\",\"favorited_you\":\"likte din status\",\"followed_you\":\"fulgte deg\",\"load_older\":\"Last eldre varsler\",\"notifications\":\"Varslinger\",\"read\":\"Les!\",\"repeated_you\":\"Gjentok din status\"},\"post_status\":{\"account_not_locked_warning\":\"Kontoen din er ikke {0}. Hvem som helst kan følge deg for å se dine statuser til følgere\",\"account_not_locked_warning_link\":\"låst\",\"attachments_sensitive\":\"Merk vedlegg som sensitive\",\"content_type\":{\"plain_text\":\"Klar tekst\"},\"content_warning\":\"Tema (valgfritt)\",\"default\":\"Landet akkurat i L.A.\",\"direct_warning\":\"Denne statusen vil kun bli sett av nevnte brukere\",\"posting\":\"Publiserer\",\"scope\":{\"direct\":\"Direkte, publiser bare til nevnte brukere\",\"private\":\"Bare følgere, publiser bare til brukere som følger deg\",\"public\":\"Offentlig, publiser til offentlige tidslinjer\",\"unlisted\":\"Uoppført, ikke publiser til offentlige tidslinjer\"}},\"registration\":{\"bio\":\"Biografi\",\"email\":\"Epost-adresse\",\"fullname\":\"Visningsnavn\",\"password_confirm\":\"Bekreft passord\",\"registration\":\"Registrering\",\"token\":\"Invitasjons-bevis\"},\"settings\":{\"attachmentRadius\":\"Vedlegg\",\"attachments\":\"Vedlegg\",\"autoload\":\"Automatisk lasting når du blar ned til bunnen\",\"avatar\":\"Profilbilde\",\"avatarAltRadius\":\"Profilbilde (Varslinger)\",\"avatarRadius\":\"Profilbilde\",\"background\":\"Bakgrunn\",\"bio\":\"Biografi\",\"btnRadius\":\"Knapper\",\"cBlue\":\"Blå (Svar, følg)\",\"cGreen\":\"Grønn (Gjenta)\",\"cOrange\":\"Oransje (Lik)\",\"cRed\":\"Rød (Avbryt)\",\"change_password\":\"Endre passord\",\"change_password_error\":\"Feil ved endring av passord\",\"changed_password\":\"Passord endret\",\"collapse_subject\":\"Sammenfold statuser med tema\",\"confirm_new_password\":\"Bekreft nytt passord\",\"current_avatar\":\"Ditt nåværende profilbilde\",\"current_password\":\"Nåværende passord\",\"current_profile_banner\":\"Din nåværende profil-banner\",\"data_import_export_tab\":\"Data import / eksport\",\"default_vis\":\"Standard visnings-omfang\",\"delete_account\":\"Slett konto\",\"delete_account_description\":\"Slett din konto og alle dine statuser\",\"delete_account_error\":\"Det oppsto et problem ved sletting av kontoen din, hvis dette problemet forblir kontakt din administrator\",\"delete_account_instructions\":\"Skriv inn ditt passord i feltet nedenfor for å bekrefte sletting av konto\",\"export_theme\":\"Lagre tema\",\"filtering\":\"Filtrering\",\"filtering_explanation\":\"Alle statuser som inneholder disse ordene vil bli dempet, en kombinasjon av tegn per linje\",\"follow_export\":\"Eksporter følginger\",\"follow_export_button\":\"Eksporter følgingene dine til en .csv fil\",\"follow_export_processing\":\"Jobber, du vil snart bli spurt om å laste ned filen din.\",\"follow_import\":\"Importer følginger\",\"follow_import_error\":\"Feil ved importering av følginger.\",\"follows_imported\":\"Følginger importert! Behandling vil ta litt tid.\",\"foreground\":\"Forgrunn\",\"general\":\"Generell\",\"hide_attachments_in_convo\":\"Gjem vedlegg i samtaler\",\"hide_attachments_in_tl\":\"Gjem vedlegg på tidslinje\",\"import_followers_from_a_csv_file\":\"Importer følginger fra en csv fil\",\"import_theme\":\"Last tema\",\"inputRadius\":\"Input felt\",\"instance_default\":\"(standard: {value})\",\"interfaceLanguage\":\"Grensesnitt-språk\",\"invalid_theme_imported\":\"Den valgte filen er ikke ett støttet Pleroma-tema, ingen endringer til ditt tema ble gjort\",\"limited_availability\":\"Ikke tilgjengelig i din nettleser\",\"links\":\"Linker\",\"lock_account_description\":\"Begrens din konto til bare godkjente følgere\",\"loop_video\":\"Gjenta videoer\",\"loop_video_silent_only\":\"Gjenta bare videoer uten lyd, (for eksempel Mastodon sine \\\"gifs\\\")\",\"name\":\"Navn\",\"name_bio\":\"Navn & Biografi\",\"new_password\":\"Nytt passord\",\"notification_visibility\":\"Typer varsler som skal vises\",\"notification_visibility_follows\":\"Følginger\",\"notification_visibility_likes\":\"Likes\",\"notification_visibility_mentions\":\"Nevnt\",\"notification_visibility_repeats\":\"Gjentakelser\",\"no_rich_text_description\":\"Fjern all formatering fra statuser\",\"nsfw_clickthrough\":\"Krev trykk for å vise statuser som kan være upassende\",\"oauth_tokens\":\"OAuth Tokens\",\"token\":\"Pollett\",\"refresh_token\":\"Refresh Token\",\"valid_until\":\"Gyldig til\",\"revoke_token\":\"Tilbakekall\",\"panelRadius\":\"Panel\",\"pause_on_unfocused\":\"Stopp henting av poster når vinduet ikke er i fokus\",\"presets\":\"Forhåndsdefinerte tema\",\"profile_background\":\"Profil-bakgrunn\",\"profile_banner\":\"Profil-banner\",\"profile_tab\":\"Profil\",\"radii_help\":\"Bestem hvor runde hjørnene i brukergrensesnittet skal være (i piksler)\",\"replies_in_timeline\":\"Svar på tidslinje\",\"reply_link_preview\":\"Vis en forhåndsvisning når du holder musen over svar til en status\",\"reply_visibility_all\":\"Vis alle svar\",\"reply_visibility_following\":\"Vis bare svar som er til meg eller folk jeg følger\",\"reply_visibility_self\":\"Vis bare svar som er til meg\",\"saving_err\":\"Feil ved lagring av innstillinger\",\"saving_ok\":\"Innstillinger lagret\",\"security_tab\":\"Sikkerhet\",\"set_new_avatar\":\"Rediger profilbilde\",\"set_new_profile_background\":\"Rediger profil-bakgrunn\",\"set_new_profile_banner\":\"Sett ny profil-banner\",\"settings\":\"Innstillinger\",\"stop_gifs\":\"Spill av GIFs når du holder over dem\",\"streaming\":\"Automatisk strømming av nye statuser når du har bladd til toppen\",\"text\":\"Tekst\",\"theme\":\"Tema\",\"theme_help\":\"Bruk heksadesimale fargekoder (#rrggbb) til å endre farge-temaet ditt.\",\"tooltipRadius\":\"Verktøytips/advarsler\",\"user_settings\":\"Brukerinstillinger\",\"values\":{\"false\":\"nei\",\"true\":\"ja\"}},\"timeline\":{\"collapse\":\"Sammenfold\",\"conversation\":\"Samtale\",\"error_fetching\":\"Feil ved henting av oppdateringer\",\"load_older\":\"Last eldre statuser\",\"no_retweet_hint\":\"Status er markert som bare til følgere eller direkte og kan ikke gjentas\",\"repeated\":\"gjentok\",\"show_new\":\"Vis nye\",\"up_to_date\":\"Oppdatert\"},\"user_card\":{\"approve\":\"Godkjenn\",\"block\":\"Blokker\",\"blocked\":\"Blokkert!\",\"deny\":\"Avslå\",\"follow\":\"Følg\",\"followees\":\"Følger\",\"followers\":\"Følgere\",\"following\":\"Følger!\",\"follows_you\":\"Følger deg!\",\"mute\":\"Demp\",\"muted\":\"Dempet\",\"per_day\":\"per dag\",\"remote_follow\":\"Følg eksternt\",\"statuses\":\"Statuser\"},\"user_profile\":{\"timeline_title\":\"Bruker-tidslinje\"},\"who_to_follow\":{\"more\":\"Mer\",\"who_to_follow\":\"Hvem å følge\"}}\n\n/***/ }),\n/* 450 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = {\"chat\":{\"title\":\"Chat\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Media proxy\",\"scope_options\":\"Zichtbaarheidsopties\",\"text_limit\":\"Tekst limiet\",\"title\":\"Features\",\"who_to_follow\":\"Wie te volgen\"},\"finder\":{\"error_fetching_user\":\"Fout tijdens ophalen gebruiker\",\"find_user\":\"Gebruiker zoeken\"},\"general\":{\"apply\":\"toepassen\",\"submit\":\"Verzend\"},\"login\":{\"login\":\"Log in\",\"description\":\"Log in met OAuth\",\"logout\":\"Log uit\",\"password\":\"Wachtwoord\",\"placeholder\":\"bv. lain\",\"register\":\"Registreer\",\"username\":\"Gebruikersnaam\"},\"nav\":{\"about\":\"Over\",\"back\":\"Terug\",\"chat\":\"Locale Chat\",\"friend_requests\":\"Volgverzoek\",\"mentions\":\"Vermeldingen\",\"dms\":\"Directe Berichten\",\"public_tl\":\"Publieke Tijdlijn\",\"timeline\":\"Tijdlijn\",\"twkn\":\"Het Geheel Gekende Netwerk\",\"user_search\":\"Zoek Gebruiker\",\"who_to_follow\":\"Wie te volgen\",\"preferences\":\"Voorkeuren\"},\"notifications\":{\"broken_favorite\":\"Onbekende status, aan het zoeken...\",\"favorited_you\":\"vond je status leuk\",\"followed_you\":\"volgt jou\",\"load_older\":\"Laad oudere meldingen\",\"notifications\":\"Meldingen\",\"read\":\"Gelezen!\",\"repeated_you\":\"Herhaalde je status\"},\"post_status\":{\"new_status\":\"Post nieuwe status\",\"account_not_locked_warning\":\"Je account is niet {0}. Iedereen die je volgt kan enkel-volgers posts lezen.\",\"account_not_locked_warning_link\":\"gesloten\",\"attachments_sensitive\":\"Markeer bijlage als gevoelig\",\"content_type\":{\"plain_text\":\"Gewone tekst\"},\"content_warning\":\"Onderwerp (optioneel)\",\"default\":\"Tijd voor een pauze!\",\"direct_warning\":\"Deze post zal enkel zichtbaar zijn voor de personen die genoemd zijn.\",\"posting\":\"Plaatsen\",\"scope\":{\"direct\":\"Direct - Post enkel naar genoemde gebruikers\",\"private\":\"Enkel volgers - Post enkel naar volgers\",\"public\":\"Publiek - Post op publieke tijdlijnen\",\"unlisted\":\"Unlisted - Toon niet op publieke tijdlijnen\"}},\"registration\":{\"bio\":\"Bio\",\"email\":\"Email\",\"fullname\":\"Weergave naam\",\"password_confirm\":\"Wachtwoord bevestiging\",\"registration\":\"Registratie\",\"token\":\"Uitnodigingstoken\",\"captcha\":\"CAPTCHA\",\"new_captcha\":\"Klik op de afbeelding voor een nieuwe captcha\",\"validations\":{\"username_required\":\"moet ingevuld zijn\",\"fullname_required\":\"moet ingevuld zijn\",\"email_required\":\"moet ingevuld zijn\",\"password_required\":\"moet ingevuld zijn\",\"password_confirmation_required\":\"moet ingevuld zijn\",\"password_confirmation_match\":\"komt niet overeen met het wachtwoord\"}},\"settings\":{\"attachmentRadius\":\"Bijlages\",\"attachments\":\"Bijlages\",\"autoload\":\"Automatisch laden wanneer tot de bodem gescrold inschakelen\",\"avatar\":\"Avatar\",\"avatarAltRadius\":\"Avatars (Meldingen)\",\"avatarRadius\":\"Avatars\",\"background\":\"Achtergrond\",\"bio\":\"Bio\",\"btnRadius\":\"Knoppen\",\"cBlue\":\"Blauw (Antwoord, volgen)\",\"cGreen\":\"Groen (Herhaal)\",\"cOrange\":\"Oranje (Vind ik leuk)\",\"cRed\":\"Rood (Annuleer)\",\"change_password\":\"Verander Wachtwoord\",\"change_password_error\":\"Er was een probleem bij het aanpassen van je wachtwoord.\",\"changed_password\":\"Wachtwoord succesvol aangepast!\",\"collapse_subject\":\"Klap posts met onderwerp in\",\"composing\":\"Samenstellen\",\"confirm_new_password\":\"Bevestig nieuw wachtwoord\",\"current_avatar\":\"Je huidige avatar\",\"current_password\":\"Huidig wachtwoord\",\"current_profile_banner\":\"Je huidige profiel banner\",\"data_import_export_tab\":\"Data Import / Export\",\"default_vis\":\"Standaard zichtbaarheidsscope\",\"delete_account\":\"Verwijder Account\",\"delete_account_description\":\"Verwijder je account en berichten permanent.\",\"delete_account_error\":\"Er was een probleem bij het verwijderen van je account. Indien dit probleem blijft, gelieve de administratie van deze instantie te verwittigen.\",\"delete_account_instructions\":\"Typ je wachtwoord in de input hieronder om het verwijderen van je account te bevestigen.\",\"export_theme\":\"Sla preset op\",\"filtering\":\"Filtering\",\"filtering_explanation\":\"Alle statussen die deze woorden bevatten worden genegeerd, één filter per lijn.\",\"follow_export\":\"Volgers export\",\"follow_export_button\":\"Exporteer je volgers naar een csv file\",\"follow_export_processing\":\"Aan het verwerken, binnen enkele ogenblikken wordt je gevraagd je bestand te downloaden\",\"follow_import\":\"Volgers import\",\"follow_import_error\":\"Fout bij importeren volgers\",\"follows_imported\":\"Volgers geïmporteerd! Het kan even duren om ze allemaal te verwerken.\",\"foreground\":\"Voorgrond\",\"general\":\"Algemeen\",\"hide_attachments_in_convo\":\"Verberg bijlages in conversaties\",\"hide_attachments_in_tl\":\"Verberg bijlages in de tijdlijn\",\"hide_isp\":\"Verberg instantie-specifiek paneel\",\"preload_images\":\"Afbeeldingen voorladen\",\"hide_post_stats\":\"Verberg post statistieken (bv. het aantal vind-ik-leuks)\",\"hide_user_stats\":\"Verberg post statistieken (bv. het aantal volgers)\",\"import_followers_from_a_csv_file\":\"Importeer volgers uit een csv file\",\"import_theme\":\"Laad preset\",\"inputRadius\":\"Invoer velden\",\"checkboxRadius\":\"Checkboxen\",\"instance_default\":\"(standaard: {value})\",\"instance_default_simple\":\"(standaard)\",\"interface\":\"Interface\",\"interfaceLanguage\":\"Interface taal\",\"invalid_theme_imported\":\"Het geselecteerde thema is geen door Pleroma ondersteund thema. Er zijn geen aanpassingen gedaan.\",\"limited_availability\":\"Onbeschikbaar in je browser\",\"links\":\"Links\",\"lock_account_description\":\"Laat volgers enkel toe na expliciete toestemming\",\"loop_video\":\"Speel videos af in een lus\",\"loop_video_silent_only\":\"Speel enkel videos zonder geluid af in een lus (bv. Mastodon's \\\"gifs\\\")\",\"name\":\"Naam\",\"name_bio\":\"Naam & Bio\",\"new_password\":\"Nieuw wachtwoord\",\"notification_visibility\":\"Type meldingen die getoond worden\",\"notification_visibility_follows\":\"Volgers\",\"notification_visibility_likes\":\"Vind-ik-leuks\",\"notification_visibility_mentions\":\"Vermeldingen\",\"notification_visibility_repeats\":\"Herhalingen\",\"no_rich_text_description\":\"Strip rich text formattering van alle posts\",\"hide_network_description\":\"Toon niet wie mij volgt en wie ik volg.\",\"nsfw_clickthrough\":\"Schakel doorklikbaar verbergen van NSFW bijlages in\",\"oauth_tokens\":\"OAuth-tokens\",\"token\":\"Token\",\"refresh_token\":\"Token vernieuwen\",\"valid_until\":\"Geldig tot\",\"revoke_token\":\"Intrekken\",\"panelRadius\":\"Panelen\",\"pause_on_unfocused\":\"Pauzeer streamen wanneer de tab niet gefocused is\",\"presets\":\"Presets\",\"profile_background\":\"Profiel Achtergrond\",\"profile_banner\":\"Profiel Banner\",\"profile_tab\":\"Profiel\",\"radii_help\":\"Stel afronding van hoeken in de interface in (in pixels)\",\"replies_in_timeline\":\"Antwoorden in tijdlijn\",\"reply_link_preview\":\"Schakel antwoordlink preview in bij over zweven met muisaanwijzer\",\"reply_visibility_all\":\"Toon alle antwoorden\",\"reply_visibility_following\":\"Toon enkel antwoorden naar mij of andere gebruikers gericht\",\"reply_visibility_self\":\"Toon enkel antwoorden naar mij gericht\",\"saving_err\":\"Fout tijdens opslaan van instellingen\",\"saving_ok\":\"Instellingen opgeslagen\",\"security_tab\":\"Veiligheid\",\"scope_copy\":\"Neem scope over bij antwoorden (Directe Berichten blijven altijd Direct)\",\"set_new_avatar\":\"Zet nieuwe avatar\",\"set_new_profile_background\":\"Zet nieuwe profiel achtergrond\",\"set_new_profile_banner\":\"Zet nieuwe profiel banner\",\"settings\":\"Instellingen\",\"subject_input_always_show\":\"Maak onderwerpveld altijd zichtbaar\",\"subject_line_behavior\":\"Kopieer onderwerp bij antwoorden\",\"subject_line_email\":\"Zoals email: \\\"re: onderwerp\\\"\",\"subject_line_mastodon\":\"Zoals Mastodon: kopieer zoals het is\",\"subject_line_noop\":\"Kopieer niet\",\"stop_gifs\":\"Speel GIFs af bij zweven\",\"streaming\":\"Schakel automatisch streamen van posts in wanneer tot boven gescrold.\",\"text\":\"Tekst\",\"theme\":\"Thema\",\"theme_help\":\"Gebruik hex color codes (#rrggbb) om je kleurschema te wijzigen.\",\"theme_help_v2_1\":\"Je kan ook de kleur en transparantie van bepaalde componenten overschrijven door de checkbox aan te vinken, gebruik de \\\"Wis alles\\\" knop om alle overschrijvingen te annuleren.\",\"theme_help_v2_2\":\"Iconen onder sommige items zijn achtergrond/tekst contrast indicators, zweef er over voor gedetailleerde info. Hou er rekening mee dat bij doorzichtigheid de ergst mogelijke situatie wordt weer gegeven.\",\"tooltipRadius\":\"Gereedschapstips/alarmen\",\"user_settings\":\"Gebruikers Instellingen\",\"values\":{\"false\":\"nee\",\"true\":\"ja\"},\"notifications\":\"Meldingen\",\"enable_web_push_notifications\":\"Schakel web push meldingen in\",\"style\":{\"switcher\":{\"keep_color\":\"Behoud kleuren\",\"keep_shadows\":\"Behoud schaduwen\",\"keep_opacity\":\"Behoud transparantie\",\"keep_roundness\":\"Behoud afrondingen\",\"keep_fonts\":\"Behoud lettertypes\",\"save_load_hint\":\"\\\"Behoud\\\" opties behouden de momenteel ingestelde opties bij het selecteren of laden van thema's, maar slaan ook de genoemde opties op bij het exporteren van een thema. Wanneer alle selectievakjes zijn uitgeschakeld, zal het exporteren van thema's alles opslaan.\",\"reset\":\"Reset\",\"clear_all\":\"Wis alles\",\"clear_opacity\":\"Wis transparantie\"},\"common\":{\"color\":\"Kleur\",\"opacity\":\"Transparantie\",\"contrast\":{\"hint\":\"Contrast ratio is {ratio}, {level} {context}\",\"level\":{\"aa\":\"voldoet aan de richtlijn van niveau AA (minimum)\",\"aaa\":\"voldoet aan de richtlijn van niveau AAA (aangeraden)\",\"bad\":\"voldoet aan geen enkele toegankelijkheidsrichtlijn\"},\"context\":{\"18pt\":\"voor grote (18pt+) tekst\",\"text\":\"voor tekst\"}}},\"common_colors\":{\"_tab_label\":\"Gemeenschappelijk\",\"main\":\"Gemeenschappelijke kleuren\",\"foreground_hint\":\"Zie \\\"Geavanceerd\\\" tab voor meer gedetailleerde controle\",\"rgbo\":\"Iconen, accenten, badges\"},\"advanced_colors\":{\"_tab_label\":\"Geavanceerd\",\"alert\":\"Alarm achtergrond\",\"alert_error\":\"Fout\",\"badge\":\"Badge achtergrond\",\"badge_notification\":\"Meldingen\",\"panel_header\":\"Paneel hoofding\",\"top_bar\":\"Top bar\",\"borders\":\"Randen\",\"buttons\":\"Knoppen\",\"inputs\":\"Invoervelden\",\"faint_text\":\"Vervaagde tekst\"},\"radii\":{\"_tab_label\":\"Rondheid\"},\"shadows\":{\"_tab_label\":\"Schaduw en belichting\",\"component\":\"Component\",\"override\":\"Overschrijven\",\"shadow_id\":\"Schaduw #{value}\",\"blur\":\"Vervagen\",\"spread\":\"Spreid\",\"inset\":\"Inzet\",\"hint\":\"Voor schaduw kan je ook --variable gebruiken als een kleur waarde om CSS3 variabelen te gebruiken. Houd er rekening mee dat het instellen van opaciteit in dit geval niet werkt.\",\"filter_hint\":{\"always_drop_shadow\":\"Waarschuwing, deze schaduw gebruikt altijd {0} als de browser dit ondersteund.\",\"drop_shadow_syntax\":\"{0} ondersteund niet de {1} parameter en {2} sleutelwoord.\",\"avatar_inset\":\"Houd er rekening mee dat het combineren van zowel inzet and niet-inzet schaduwen op transparante avatars onverwachte resultaten kan opleveren.\",\"spread_zero\":\"Schaduw met spreiding > 0 worden weergegeven alsof ze op nul staan\",\"inset_classic\":\"Inzet schaduw zal {0} gebruiken\"},\"components\":{\"panel\":\"Paneel\",\"panelHeader\":\"Paneel hoofding\",\"topBar\":\"Top bar\",\"avatar\":\"Gebruiker avatar (in profiel weergave)\",\"avatarStatus\":\"Gebruiker avatar (in post weergave)\",\"popup\":\"Popups en gereedschapstips\",\"button\":\"Knop\",\"buttonHover\":\"Knop (zweven)\",\"buttonPressed\":\"Knop (ingedrukt)\",\"buttonPressedHover\":\"Knop (ingedrukt+zweven)\",\"input\":\"Invoerveld\"}},\"fonts\":{\"_tab_label\":\"Lettertypes\",\"help\":\"Selecteer het lettertype om te gebruiken voor elementen van de UI.Voor \\\"aangepast\\\" moet je de exacte naam van het lettertype invoeren zoals die in het systeem wordt weergegeven.\",\"components\":{\"interface\":\"Interface\",\"input\":\"Invoervelden\",\"post\":\"Post tekst\",\"postCode\":\"Monospaced tekst in een post (rich text)\"},\"family\":\"Naam lettertype\",\"size\":\"Grootte (in px)\",\"weight\":\"Gewicht (vetheid)\",\"custom\":\"Aangepast\"},\"preview\":{\"header\":\"Voorvertoning\",\"content\":\"Inhoud\",\"error\":\"Voorbeeld fout\",\"button\":\"Knop\",\"text\":\"Nog een boel andere {0} en {1}\",\"mono\":\"inhoud\",\"input\":\"Tijd voor een pauze!\",\"faint_link\":\"handige gebruikershandleiding\",\"fine_print\":\"Lees onze {0} om niets nuttig te leren!\",\"header_faint\":\"Alles komt goed\",\"checkbox\":\"Ik heb de gebruikersvoorwaarden eens van ver bekeken\",\"link\":\"een link\"}}},\"timeline\":{\"collapse\":\"Inklappen\",\"conversation\":\"Conversatie\",\"error_fetching\":\"Fout bij ophalen van updates\",\"load_older\":\"Laad oudere Statussen\",\"no_retweet_hint\":\"Post is gemarkeerd als enkel volgers of direct en kan niet worden herhaald\",\"repeated\":\"herhaalde\",\"show_new\":\"Toon nieuwe\",\"up_to_date\":\"Up-to-date\"},\"user_card\":{\"approve\":\"Goedkeuren\",\"block\":\"Blokkeren\",\"blocked\":\"Geblokkeerd!\",\"deny\":\"Ontzeggen\",\"favorites\":\"Vind-ik-leuks\",\"follow\":\"Volgen\",\"follow_sent\":\"Aanvraag verzonden!\",\"follow_progress\":\"Aanvragen…\",\"follow_again\":\"Aanvraag opnieuw zenden?\",\"follow_unfollow\":\"Stop volgen\",\"followees\":\"Aan het volgen\",\"followers\":\"Volgers\",\"following\":\"Aan het volgen!\",\"follows_you\":\"Volgt jou!\",\"its_you\":\"'t is jij!\",\"mute\":\"Dempen\",\"muted\":\"Gedempt\",\"per_day\":\"per dag\",\"remote_follow\":\"Volg vanop afstand\",\"statuses\":\"Statussen\"},\"user_profile\":{\"timeline_title\":\"Gebruikers Tijdlijn\"},\"who_to_follow\":{\"more\":\"Meer\",\"who_to_follow\":\"Wie te volgen\"},\"tool_tip\":{\"media_upload\":\"Upload Media\",\"repeat\":\"Herhaal\",\"reply\":\"Antwoord\",\"favorite\":\"Vind-ik-leuk\",\"user_settings\":\"Gebruikers Instellingen\"},\"upload\":{\"error\":{\"base\":\"Upload gefaald.\",\"file_too_big\":\"Bestand is te groot [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"Probeer later opnieuw\"},\"file_size_units\":{\"B\":\"B\",\"KiB\":\"KiB\",\"MiB\":\"MiB\",\"GiB\":\"GiB\",\"TiB\":\"TiB\"}}}\n\n/***/ }),\n/* 451 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = {\"chat\":{\"title\":\"Messatjariá\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Servidor mandatari mèdia\",\"scope_options\":\"Nivèls de confidencialitat\",\"text_limit\":\"Limita de tèxte\",\"title\":\"Foncionalitats\",\"who_to_follow\":\"Qual seguir\"},\"finder\":{\"error_fetching_user\":\"Error pendent la cèrca d’un utilizaire\",\"find_user\":\"Cercar un utilizaire\"},\"general\":{\"apply\":\"Aplicar\",\"submit\":\"Mandar\",\"more\":\"Mai\",\"generic_error\":\"Una error s’es producha\",\"optional\":\"opcional\"},\"image_cropper\":{\"crop_picture\":\"Talhar l’imatge\",\"save\":\"Salvar\",\"cancel\":\"Anullar\"},\"login\":{\"login\":\"Connexion\",\"description\":\"Connexion via OAuth\",\"logout\":\"Desconnexion\",\"password\":\"Senhal\",\"placeholder\":\"e.g. lain\",\"register\":\"Se marcar\",\"username\":\"Nom d’utilizaire\",\"hint\":\"Connectatz-vos per participar a la discutida\"},\"media_modal\":{\"previous\":\"Precedent\",\"next\":\"Seguent\"},\"nav\":{\"about\":\"A prepaus\",\"back\":\"Tornar\",\"chat\":\"Chat local\",\"friend_requests\":\"Demandas de seguiment\",\"mentions\":\"Notificacions\",\"dms\":\"Messatges privats\",\"public_tl\":\"Estatuts locals\",\"timeline\":\"Flux d’actualitat\",\"twkn\":\"Lo malhum conegut\",\"user_search\":\"Cèrca d’utilizaires\",\"who_to_follow\":\"Qual seguir\",\"preferences\":\"Preferéncias\"},\"notifications\":{\"broken_favorite\":\"Estatut desconegut, sèm a lo cercar...\",\"favorited_you\":\"a aimat vòstre estatut\",\"followed_you\":\"vos a seguit\",\"load_older\":\"Cargar las notificaciones mai ancianas\",\"notifications\":\"Notficacions\",\"read\":\"Legit !\",\"repeated_you\":\"a repetit vòstre estatut\",\"no_more_notifications\":\"Pas mai de notificacions\"},\"post_status\":{\"new_status\":\"Publicar d’estatuts novèls\",\"account_not_locked_warning\":\"Vòstre compte es pas {0}. Qual que siá pòt vos seguir per veire vòstras publicacions destinadas pas qu'a vòstres seguidors.\",\"account_not_locked_warning_link\":\"clavat\",\"attachments_sensitive\":\"Marcar las pèças juntas coma sensiblas\",\"content_type\":{\"plain_text\":\"Tèxte brut\"},\"content_warning\":\"Avís de contengut (opcional)\",\"default\":\"Escrivètz aquí vòstre estatut.\",\"direct_warning\":\"Aquesta publicacion serà pas que visibla pels utilizaires mencionats.\",\"posting\":\"Mandadís\",\"scope\":{\"direct\":\"Dirècte - Publicar pels utilizaires mencionats solament\",\"private\":\"Seguidors solament - Publicar pels sols seguidors\",\"public\":\"Public - Publicar pel flux d’actualitat public\",\"unlisted\":\"Pas listat - Publicar pas pel flux public\"}},\"registration\":{\"bio\":\"Biografia\",\"email\":\"Adreça de corrièl\",\"fullname\":\"Nom complèt\",\"password_confirm\":\"Confirmar lo senhal\",\"registration\":\"Inscripcion\",\"token\":\"Geton de convidat\",\"captcha\":\"CAPTCHA\",\"new_captcha\":\"Clicatz l’imatge per obténer una nòva captcha\",\"username_placeholder\":\"e.g. lain\",\"fullname_placeholder\":\"e.g. Lain Iwakura\",\"bio_placeholder\":\"e.g.\\nHi, Soi lo Lain\\nSoi afocada d’animes e vivi al Japan. Benlèu que me coneissètz de the Wired.\",\"validations\":{\"username_required\":\"pòt pas èsser void\",\"fullname_required\":\"pòt pas èsser void\",\"email_required\":\"pòt pas èsser void\",\"password_required\":\"pòt pas èsser void\",\"password_confirmation_required\":\"pòt pas èsser void\",\"password_confirmation_match\":\"deu èsser lo meteis senhal\"}},\"settings\":{\"app_name\":\"Nom de l’aplicacion\",\"attachmentRadius\":\"Pèças juntas\",\"attachments\":\"Pèças juntas\",\"autoload\":\"Activar lo cargament automatic un còp arribat al cap de la pagina\",\"avatar\":\"Avatar\",\"avatarAltRadius\":\"Avatars (Notificacions)\",\"avatarRadius\":\"Avatars\",\"background\":\"Rèire plan\",\"bio\":\"Biografia\",\"blocks_tab\":\"Blocatges\",\"btnRadius\":\"Botons\",\"cBlue\":\"Blau (Respondre, seguir)\",\"cGreen\":\"Verd (Repartajar)\",\"cOrange\":\"Irange (Aimar)\",\"cRed\":\"Roge (Anullar)\",\"change_password\":\"Cambiar lo senhal\",\"change_password_error\":\"Una error s’es producha en cambiant lo senhal.\",\"changed_password\":\"Senhal corrèctament cambiat !\",\"collapse_subject\":\"Replegar las publicacions amb de subjèctes\",\"composing\":\"Escritura\",\"confirm_new_password\":\"Confirmatz lo nòu senhal\",\"current_avatar\":\"Vòstre avatar actual\",\"current_password\":\"Senhal actual\",\"current_profile_banner\":\"Bandièra actuala del perfil\",\"data_import_export_tab\":\"Importar / Exportar las donadas\",\"default_vis\":\"Nivèl de visibilitat per defaut\",\"delete_account\":\"Suprimir lo compte\",\"delete_account_description\":\"Suprimir vòstre compte e los messatges per sempre.\",\"delete_account_error\":\"Una error s’es producha en suprimir lo compte. S’aquò ten d’arribar mercés de contactar vòstre administrador d’instància.\",\"delete_account_instructions\":\"Picatz vòstre senhal dins lo camp tèxte çai-jos per confirmar la supression del compte.\",\"avatar_size_instruction\":\"La talha minimum recomandada pels imatges d’avatar es 150x150 pixèls.\",\"export_theme\":\"Enregistrar la preconfiguracion\",\"filtering\":\"Filtratge\",\"filtering_explanation\":\"Totes los estatuts amb aqueles mots seràn en silenci, un mot per linha\",\"follow_export\":\"Exportar los abonaments\",\"follow_export_button\":\"Exportar vòstres abonaments dins un fichièr csv\",\"follow_export_processing\":\"Tractament, vos demandarem lèu de telecargar lo fichièr\",\"follow_import\":\"Importar los abonaments\",\"follow_import_error\":\"Error en important los seguidors\",\"follows_imported\":\"Seguidors importats. Lo tractament pòt trigar una estona.\",\"foreground\":\"Endavant\",\"general\":\"General\",\"hide_attachments_in_convo\":\"Rescondre las pèças juntas dins las conversacions\",\"hide_attachments_in_tl\":\"Rescondre las pèças juntas\",\"max_thumbnails\":\"Nombre maximum de vinhetas per publicacion\",\"hide_isp\":\"Amagar lo panèl especial instància\",\"preload_images\":\"Precargar los imatges\",\"use_one_click_nsfw\":\"Dobrir las pèças juntas NSFW amb un clic\",\"hide_post_stats\":\"Amagar los estatistics de publicacion (ex. lo ombre de favorits)\",\"hide_user_stats\":\"Amagar las estatisticas de l’utilizaire (ex. lo nombre de seguidors)\",\"hide_filtered_statuses\":\"Amagar los estatuts filtrats\",\"import_followers_from_a_csv_file\":\"Importar los seguidors d’un fichièr csv\",\"import_theme\":\"Cargar un tèma\",\"inputRadius\":\"Camps tèxte\",\"checkboxRadius\":\"Casas de marcar\",\"instance_default\":\"(defaut : {value})\",\"instance_default_simple\":\"(defaut)\",\"interface\":\"Interfàcia\",\"interfaceLanguage\":\"Lenga de l’interfàcia\",\"invalid_theme_imported\":\"Lo fichièr seleccionat es pas un tèma Pleroma valid. Cap de cambiament es estat fach a vòstre tèma.\",\"limited_availability\":\"Pas disponible per vòstre navigador\",\"links\":\"Ligams\",\"lock_account_description\":\"Limitar vòstre compte als seguidors acceptats solament\",\"loop_video\":\"Bocla vidèo\",\"loop_video_silent_only\":\"Legir en bocla solament las vidèos sens son (coma los « Gifs » de Mastodon)\",\"mutes_tab\":\"Agamats\",\"play_videos_in_modal\":\"Legir las vidèoas dirèctament dins la visualizaira mèdia\",\"use_contain_fit\":\"Talhar pas las pèças juntas per las vinhetas\",\"name\":\"Nom\",\"name_bio\":\"Nom & Bio\",\"new_password\":\"Nòu senhal\",\"notification_visibility_follows\":\"Abonaments\",\"notification_visibility_likes\":\"Aimar\",\"notification_visibility_mentions\":\"Mencions\",\"notification_visibility_repeats\":\"Repeticions\",\"notification_visibility\":\"Tipes de notificacion de mostrar\",\"no_rich_text_description\":\"Netejar lo format tèxte de totas las publicacions\",\"no_blocks\":\"Cap de blocatge\",\"no_mutes\":\"Cap d’amagat\",\"hide_follows_description\":\"Mostrar pas qual seguissi\",\"hide_followers_description\":\"Mostrar pas qual me seguisson\",\"show_admin_badge\":\"Mostrar lo badge Admin badge al perfil meu\",\"show_moderator_badge\":\"Mostrar lo badge Moderator al perfil meu\",\"nsfw_clickthrough\":\"Activar lo clic per mostrar los imatges marcats coma pels adults o sensibles\",\"oauth_tokens\":\"Listats OAuth\",\"token\":\"Geton\",\"refresh_token\":\"Actualizar lo geton\",\"valid_until\":\"Valid fins a\",\"revoke_token\":\"Revocar\",\"panelRadius\":\"Panèls\",\"pause_on_unfocused\":\"Pausar la difusion quand l’onglet es pas seleccionat\",\"presets\":\"Pre-enregistrats\",\"profile_background\":\"Imatge de fons\",\"profile_banner\":\"Bandièra del perfil\",\"profile_tab\":\"Perfil\",\"radii_help\":\"Configurar los caires arredondits de l’interfàcia (en pixèls)\",\"replies_in_timeline\":\"Responsas del flux\",\"reply_link_preview\":\"Activar l’apercebut en passar la mirga\",\"reply_visibility_all\":\"Mostrar totas las responsas\",\"reply_visibility_following\":\"Mostrar pas que las responsas que me son destinada a ieu o un utilizaire que seguissi\",\"reply_visibility_self\":\"Mostrar pas que las responsas que me son destinadas\",\"saving_err\":\"Error en enregistrant los paramètres\",\"saving_ok\":\"Paramètres enregistrats\",\"scope_copy\":\"Copiar lo nivèl de confidencialitat per las responsas (Totjorn aissí pels Messatges Dirèctes)\",\"security_tab\":\"Seguretat\",\"set_new_avatar\":\"Definir un nòu avatar\",\"set_new_profile_background\":\"Definir un nòu fons de perfil\",\"set_new_profile_banner\":\"Definir una nòva bandièra de perfil\",\"settings\":\"Paramètres\",\"subject_input_always_show\":\"Totjorn mostrar lo camp de subjècte\",\"subject_line_behavior\":\"Copiar lo subjècte per las responsas\",\"subject_line_email\":\"Coma los corrièls : \\\"re: subjècte\\\"\",\"subject_line_mastodon\":\"Coma mastodon : copiar tal coma es\",\"subject_line_noop\":\"Copiar pas\",\"post_status_content_type\":\"Publicar lo tipe de contengut dels estatuts\",\"stop_gifs\":\"Lançar los GIFs al subrevòl\",\"streaming\":\"Activar lo cargament automatic dels novèls estatus en anar amont\",\"text\":\"Tèxt\",\"theme\":\"Tèma\",\"theme_help_v2_1\":\"You can also override certain component's colors and opacity by toggling the checkbox, use \\\"Clear all\\\" button to clear all overrides.\",\"theme_help_v2_2\":\"Icons underneath some entries are background/text contrast indicators, hover over for detailed info. Please keep in mind that when using transparency contrast indicators show the worst possible case.\",\"theme_help\":\"Emplegatz los còdis de color hex (#rrggbb) per personalizar vòstre tèma de color.\",\"tooltipRadius\":\"Astúcias/alèrtas\",\"upload_a_photo\":\"Enviar una fotografia\",\"user_settings\":\"Paramètres utilizaire\",\"values\":{\"false\":\"non\",\"true\":\"òc\"}},\"timeline\":{\"collapse\":\"Tampar\",\"conversation\":\"Conversacion\",\"error_fetching\":\"Error en cercant de mesas a jorn\",\"load_older\":\"Ne veire mai\",\"repeated\":\"repetit\",\"show_new\":\"Ne veire mai\",\"up_to_date\":\"A jorn\",\"no_retweet_hint\":\"La publicacion marcada coma pels seguidors solament o dirècte pòt pas èsser repetida\"},\"status\":{\"reply_to\":\"Respondre à\",\"replies_list\":\"Responsas :\"},\"user_card\":{\"approve\":\"Validar\",\"block\":\"Blocar\",\"blocked\":\"Blocat !\",\"deny\":\"Refusar\",\"favorites\":\"Favorits\",\"follow\":\"Seguir\",\"follow_sent\":\"Demanda enviada !\",\"follow_progress\":\"Demanda…\",\"follow_again\":\"Tornar enviar la demanda ?\",\"follow_unfollow\":\"Quitar de seguir\",\"followees\":\"Abonaments\",\"followers\":\"Seguidors\",\"following\":\"Seguit !\",\"follows_you\":\"Vos sèc !\",\"its_you\":\"Sètz vos !\",\"media\":\"Mèdia\",\"mute\":\"Amagar\",\"muted\":\"Amagat\",\"per_day\":\"per jorn\",\"remote_follow\":\"Seguir a distància\",\"statuses\":\"Estatuts\",\"unblock\":\"Desblocar\",\"unblock_progress\":\"Desblocatge...\",\"block_progress\":\"Blocatge...\",\"unmute\":\"Tornar mostrar\",\"unmute_progress\":\"Afichatge...\",\"mute_progress\":\"A amagar...\"},\"user_profile\":{\"timeline_title\":\"Flux utilizaire\",\"profile_does_not_exist\":\"Aqueste perfil existís pas.\",\"profile_loading_error\":\"Una error s’es producha en cargant aqueste perfil.\"},\"who_to_follow\":{\"more\":\"Mai\",\"who_to_follow\":\"Qual seguir\"},\"tool_tip\":{\"media_upload\":\"Enviar un mèdia\",\"repeat\":\"Repetir\",\"reply\":\"Respondre\",\"favorite\":\"aimar\",\"user_settings\":\"Paramètres utilizaire\"},\"upload\":{\"error\":{\"base\":\"Mandadís fracassat.\",\"file_too_big\":\"Fichièr tròp grand [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"Tornatz ensajar mai tard\"},\"file_size_units\":{\"B\":\"o\",\"KiB\":\"Kio\",\"MiB\":\"Mio\",\"GiB\":\"Gio\",\"TiB\":\"Tio\"}}}\n\n/***/ }),\n/* 452 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = {\"chat\":{\"title\":\"Czat\"},\"finder\":{\"error_fetching_user\":\"Błąd przy pobieraniu profilu\",\"find_user\":\"Znajdź użytkownika\"},\"general\":{\"apply\":\"Zastosuj\",\"submit\":\"Wyślij\"},\"login\":{\"login\":\"Zaloguj\",\"logout\":\"Wyloguj\",\"password\":\"Hasło\",\"placeholder\":\"n.p. lain\",\"register\":\"Zarejestruj\",\"username\":\"Użytkownik\"},\"nav\":{\"chat\":\"Lokalny czat\",\"mentions\":\"Wzmianki\",\"public_tl\":\"Publiczna oś czasu\",\"timeline\":\"Oś czasu\",\"twkn\":\"Cała znana sieć\"},\"notifications\":{\"favorited_you\":\"dodał twój status do ulubionych\",\"followed_you\":\"obserwuje cię\",\"notifications\":\"Powiadomienia\",\"read\":\"Przeczytane!\",\"repeated_you\":\"powtórzył twój status\"},\"post_status\":{\"default\":\"Właśnie wróciłem z kościoła\",\"posting\":\"Wysyłanie\"},\"registration\":{\"bio\":\"Bio\",\"email\":\"Email\",\"fullname\":\"Wyświetlana nazwa profilu\",\"password_confirm\":\"Potwierdzenie hasła\",\"registration\":\"Rejestracja\"},\"settings\":{\"attachmentRadius\":\"Załączniki\",\"attachments\":\"Załączniki\",\"autoload\":\"Włącz automatyczne ładowanie po przewinięciu do końca strony\",\"avatar\":\"Awatar\",\"avatarAltRadius\":\"Awatary (powiadomienia)\",\"avatarRadius\":\"Awatary\",\"background\":\"Tło\",\"bio\":\"Bio\",\"btnRadius\":\"Przyciski\",\"cBlue\":\"Niebieski (odpowiedz, obserwuj)\",\"cGreen\":\"Zielony (powtórzenia)\",\"cOrange\":\"Pomarańczowy (ulubione)\",\"cRed\":\"Czerwony (anuluj)\",\"change_password\":\"Zmień hasło\",\"change_password_error\":\"Podczas zmiany hasła wystąpił problem.\",\"changed_password\":\"Hasło zmienione poprawnie!\",\"confirm_new_password\":\"Potwierdź nowe hasło\",\"current_avatar\":\"Twój obecny awatar\",\"current_password\":\"Obecne hasło\",\"current_profile_banner\":\"Twój obecny banner profilu\",\"delete_account\":\"Usuń konto\",\"delete_account_description\":\"Trwale usuń konto i wszystkie posty.\",\"delete_account_error\":\"Wystąpił problem z usuwaniem twojego konta. Jeżeli problem powtarza się, poinformuj administratora swojej instancji.\",\"delete_account_instructions\":\"Wprowadź swoje hasło w poniższe pole aby potwierdzić usunięcie konta.\",\"filtering\":\"Filtrowanie\",\"filtering_explanation\":\"Wszystkie statusy zawierające te słowa będą wyciszone. Jedno słowo na linijkę.\",\"follow_export\":\"Eksport obserwowanych\",\"follow_export_button\":\"Eksportuj swoją listę obserwowanych do pliku CSV\",\"follow_export_processing\":\"Przetwarzanie, wkrótce twój plik zacznie się ściągać.\",\"follow_import\":\"Import obserwowanych\",\"follow_import_error\":\"Błąd przy importowaniu obserwowanych\",\"follows_imported\":\"Obserwowani zaimportowani! Przetwarzanie może trochę potrwać.\",\"foreground\":\"Pierwszy plan\",\"hide_attachments_in_convo\":\"Ukryj załączniki w rozmowach\",\"hide_attachments_in_tl\":\"Ukryj załączniki w osi czasu\",\"import_followers_from_a_csv_file\":\"Importuj obserwowanych z pliku CSV\",\"inputRadius\":\"Pola tekstowe\",\"links\":\"Łącza\",\"name\":\"Imię\",\"name_bio\":\"Imię i bio\",\"new_password\":\"Nowe hasło\",\"nsfw_clickthrough\":\"Włącz domyślne ukrywanie załączników o treści nieprzyzwoitej (NSFW)\",\"oauth_tokens\":\"Tokeny OAuth\",\"token\":\"Token\",\"refresh_token\":\"Odśwież token\",\"valid_until\":\"Ważne do\",\"revoke_token\":\"Odwołać\",\"panelRadius\":\"Panele\",\"presets\":\"Gotowe motywy\",\"profile_background\":\"Tło profilu\",\"profile_banner\":\"Banner profilu\",\"radii_help\":\"Ustaw zaokrąglenie krawędzi interfejsu (w pikselach)\",\"reply_link_preview\":\"Włącz dymek z podglądem postu po najechaniu na znak odpowiedzi\",\"set_new_avatar\":\"Ustaw nowy awatar\",\"set_new_profile_background\":\"Ustaw nowe tło profilu\",\"set_new_profile_banner\":\"Ustaw nowy banner profilu\",\"settings\":\"Ustawienia\",\"stop_gifs\":\"Odtwarzaj GIFy po najechaniu kursorem\",\"streaming\":\"Włącz automatycznie strumieniowanie nowych postów gdy na początku strony\",\"text\":\"Tekst\",\"theme\":\"Motyw\",\"theme_help\":\"Użyj kolorów w notacji szesnastkowej (#rrggbb), by stworzyć swój motyw.\",\"tooltipRadius\":\"Etykiety/alerty\",\"user_settings\":\"Ustawienia użytkownika\"},\"timeline\":{\"collapse\":\"Zwiń\",\"conversation\":\"Rozmowa\",\"error_fetching\":\"Błąd pobierania\",\"load_older\":\"Załaduj starsze statusy\",\"repeated\":\"powtórzono\",\"show_new\":\"Pokaż nowe\",\"up_to_date\":\"Na bieżąco\"},\"user_card\":{\"block\":\"Zablokuj\",\"blocked\":\"Zablokowany!\",\"follow\":\"Obserwuj\",\"followees\":\"Obserwowani\",\"followers\":\"Obserwujący\",\"following\":\"Obserwowany!\",\"follows_you\":\"Obserwuje cię!\",\"mute\":\"Wycisz\",\"muted\":\"Wyciszony\",\"per_day\":\"dziennie\",\"remote_follow\":\"Zdalna obserwacja\",\"statuses\":\"Statusy\"},\"user_profile\":{\"timeline_title\":\"Oś czasu użytkownika\"}}\n\n/***/ }),\n/* 453 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = {\"chat\":{\"title\":\"Chat\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Proxy de mídia\",\"scope_options\":\"Opções de privacidade\",\"text_limit\":\"Limite de caracteres\",\"title\":\"Funções\",\"who_to_follow\":\"Quem seguir\"},\"finder\":{\"error_fetching_user\":\"Erro ao procurar usuário\",\"find_user\":\"Buscar usuário\"},\"general\":{\"apply\":\"Aplicar\",\"submit\":\"Enviar\",\"more\":\"Mais\",\"generic_error\":\"Houve um erro\",\"optional\":\"opcional\"},\"image_cropper\":{\"crop_picture\":\"Cortar imagem\",\"save\":\"Salvar\",\"cancel\":\"Cancelar\"},\"login\":{\"login\":\"Entrar\",\"description\":\"Entrar com OAuth\",\"logout\":\"Sair\",\"password\":\"Senha\",\"placeholder\":\"p.e. lain\",\"register\":\"Registrar\",\"username\":\"Usuário\",\"hint\":\"Entre para participar da discussão\"},\"media_modal\":{\"previous\":\"Anterior\",\"next\":\"Próximo\"},\"nav\":{\"about\":\"Sobre\",\"back\":\"Voltar\",\"chat\":\"Chat local\",\"friend_requests\":\"Solicitações de seguidores\",\"mentions\":\"Menções\",\"dms\":\"Mensagens diretas\",\"public_tl\":\"Linha do tempo pública\",\"timeline\":\"Linha do tempo\",\"twkn\":\"Toda a rede conhecida\",\"user_search\":\"Busca de usuário\",\"who_to_follow\":\"Quem seguir\",\"preferences\":\"Preferências\"},\"notifications\":{\"broken_favorite\":\"Status desconhecido, buscando...\",\"favorited_you\":\"favoritou sua postagem\",\"followed_you\":\"seguiu você\",\"load_older\":\"Carregar notificações antigas\",\"notifications\":\"Notificações\",\"read\":\"Lido!\",\"repeated_you\":\"repetiu sua postagem\",\"no_more_notifications\":\"Mais nenhuma notificação\"},\"post_status\":{\"new_status\":\"Postar novo status\",\"account_not_locked_warning\":\"Sua conta não está {0}. Qualquer pessoa pode te seguir para ver seus posts restritos.\",\"account_not_locked_warning_link\":\"fechada\",\"attachments_sensitive\":\"Marcar anexos como sensíveis\",\"content_type\":{\"plain_text\":\"Texto puro\"},\"content_warning\":\"Assunto (opcional)\",\"default\":\"Acabei de chegar no Rio!\",\"direct_warning\":\"Este post será visível apenas para os usuários mencionados.\",\"posting\":\"Publicando\",\"scope\":{\"direct\":\"Direto - Enviar somente aos usuários mencionados\",\"private\":\"Apenas para seguidores - Enviar apenas para seguidores\",\"public\":\"Público - Enviar a linhas do tempo públicas\",\"unlisted\":\"Não listado - Não enviar a linhas do tempo públicas\"}},\"registration\":{\"bio\":\"Biografia\",\"email\":\"Correio eletrônico\",\"fullname\":\"Nome para exibição\",\"password_confirm\":\"Confirmação de senha\",\"registration\":\"Registro\",\"token\":\"Código do convite\",\"captcha\":\"CAPTCHA\",\"new_captcha\":\"Clique na imagem para carregar um novo captcha\",\"username_placeholder\":\"p. ex. lain\",\"fullname_placeholder\":\"p. ex. Lain Iwakura\",\"bio_placeholder\":\"e.g.\\nOi, sou Lain\\nSou uma garota que vive no subúrbio do Japão. Você deve me conhecer da Rede.\",\"validations\":{\"username_required\":\"não pode ser deixado em branco\",\"fullname_required\":\"não pode ser deixado em branco\",\"email_required\":\"não pode ser deixado em branco\",\"password_required\":\"não pode ser deixado em branco\",\"password_confirmation_required\":\"não pode ser deixado em branco\",\"password_confirmation_match\":\"deve ser idêntica à senha\"}},\"settings\":{\"app_name\":\"Nome do aplicativo\",\"attachmentRadius\":\"Anexos\",\"attachments\":\"Anexos\",\"autoload\":\"Habilitar carregamento automático quando a rolagem chegar ao fim.\",\"avatar\":\"Avatar\",\"avatarAltRadius\":\"Avatares (Notificações)\",\"avatarRadius\":\"Avatares\",\"background\":\"Pano de Fundo\",\"bio\":\"Biografia\",\"blocks_tab\":\"Blocos\",\"btnRadius\":\"Botões\",\"cBlue\":\"Azul (Responder, seguir)\",\"cGreen\":\"Verde (Repetir)\",\"cOrange\":\"Laranja (Favoritar)\",\"cRed\":\"Vermelho (Cancelar)\",\"change_password\":\"Mudar senha\",\"change_password_error\":\"Houve um erro ao modificar sua senha.\",\"changed_password\":\"Senha modificada com sucesso!\",\"collapse_subject\":\"Esconder posts com assunto\",\"composing\":\"Escrevendo\",\"confirm_new_password\":\"Confirmar nova senha\",\"current_avatar\":\"Seu avatar atual\",\"current_password\":\"Sua senha atual\",\"current_profile_banner\":\"Sua capa de perfil atual\",\"data_import_export_tab\":\"Importação/exportação de dados\",\"default_vis\":\"Opção de privacidade padrão\",\"delete_account\":\"Deletar conta\",\"delete_account_description\":\"Deletar sua conta e mensagens permanentemente.\",\"delete_account_error\":\"Houve um problema ao deletar sua conta. Se ele persistir, por favor entre em contato com o/a administrador/a da instância.\",\"delete_account_instructions\":\"Digite sua senha no campo abaixo para confirmar a exclusão da conta.\",\"avatar_size_instruction\":\"O tamanho mínimo recomendado para imagens de avatar é 150x150 pixels.\",\"export_theme\":\"Salvar predefinições\",\"filtering\":\"Filtragem\",\"filtering_explanation\":\"Todas as postagens contendo estas palavras serão silenciadas, uma por linha.\",\"follow_export\":\"Exportar quem você segue\",\"follow_export_button\":\"Exportar quem você segue para um arquivo CSV\",\"follow_export_processing\":\"Processando. Em breve você receberá a solicitação de download do arquivo\",\"follow_import\":\"Importar quem você segue\",\"follow_import_error\":\"Erro ao importar seguidores\",\"follows_imported\":\"Seguidores importados! O processamento pode demorar um pouco.\",\"foreground\":\"Primeiro Plano\",\"general\":\"Geral\",\"hide_attachments_in_convo\":\"Ocultar anexos em conversas\",\"hide_attachments_in_tl\":\"Ocultar anexos na linha do tempo.\",\"max_thumbnails\":\"Número máximo de miniaturas por post\",\"hide_isp\":\"Esconder painel específico da instância\",\"preload_images\":\"Pré-carregar imagens\",\"use_one_click_nsfw\":\"Abrir anexos sensíveis com um clique\",\"hide_post_stats\":\"Esconder estatísticas de posts (p. ex. número de favoritos)\",\"hide_user_stats\":\"Esconder estatísticas do usuário (p. ex. número de seguidores)\",\"hide_filtered_statuses\":\"Esconder posts filtrados\",\"import_followers_from_a_csv_file\":\"Importe seguidores a partir de um arquivo CSV\",\"import_theme\":\"Carregar pré-definição\",\"inputRadius\":\"Campos de entrada\",\"checkboxRadius\":\"Checkboxes\",\"instance_default\":\"(padrão: {value})\",\"instance_default_simple\":\"(padrão)\",\"interface\":\"Interface\",\"interfaceLanguage\":\"Idioma da interface\",\"invalid_theme_imported\":\"O arquivo selecionado não é um tema compatível com o Pleroma. Nenhuma mudança no tema foi feita.\",\"limited_availability\":\"Indisponível para seu navegador\",\"links\":\"Links\",\"lock_account_description\":\"Restringir sua conta a seguidores aprovados\",\"loop_video\":\"Repetir vídeos\",\"loop_video_silent_only\":\"Repetir apenas vídeos sem som (como os \\\"gifs\\\" do Mastodon)\",\"mutes_tab\":\"Silenciados\",\"play_videos_in_modal\":\"Tocar vídeos diretamente no visualizador de mídia\",\"use_contain_fit\":\"Não cortar o anexo na miniatura\",\"name\":\"Nome\",\"name_bio\":\"Nome & Biografia\",\"new_password\":\"Nova senha\",\"notification_visibility\":\"Tipos de notificação para mostrar\",\"notification_visibility_follows\":\"Seguidos\",\"notification_visibility_likes\":\"Favoritos\",\"notification_visibility_mentions\":\"Menções\",\"notification_visibility_repeats\":\"Repetições\",\"no_rich_text_description\":\"Remover formatação de todos os posts\",\"no_blocks\":\"Sem bloqueios\",\"no_mutes\":\"Sem silenciados\",\"hide_follows_description\":\"Não mostrar quem estou seguindo\",\"hide_followers_description\":\"Não mostrar quem me segue\",\"show_admin_badge\":\"Mostrar distintivo de Administrador em meu perfil\",\"show_moderator_badge\":\"Mostrar título de Moderador em meu perfil\",\"nsfw_clickthrough\":\"Habilitar clique para ocultar anexos sensíveis\",\"oauth_tokens\":\"Token OAuth\",\"token\":\"Token\",\"refresh_token\":\"Atualizar Token\",\"valid_until\":\"Válido até\",\"revoke_token\":\"Revogar\",\"panelRadius\":\"Paineis\",\"pause_on_unfocused\":\"Parar transmissão quando a aba não estiver em primeiro plano\",\"presets\":\"Predefinições\",\"profile_background\":\"Pano de fundo de perfil\",\"profile_banner\":\"Capa de perfil\",\"profile_tab\":\"Perfil\",\"radii_help\":\"Arredondar arestas da interface (em píxeis)\",\"replies_in_timeline\":\"Respostas na linha do tempo\",\"reply_link_preview\":\"Habilitar a pré-visualização de link de respostas ao passar o mouse.\",\"reply_visibility_all\":\"Mostrar todas as respostas\",\"reply_visibility_following\":\"Só mostrar respostas direcionadas a mim ou a usuários que sigo\",\"reply_visibility_self\":\"Só mostrar respostas direcionadas a mim\",\"saving_err\":\"Erro ao salvar configurações\",\"saving_ok\":\"Configurações salvas\",\"security_tab\":\"Segurança\",\"scope_copy\":\"Copiar opções de privacidade ao responder (Mensagens diretas sempre copiam)\",\"set_new_avatar\":\"Alterar avatar\",\"set_new_profile_background\":\"Alterar o plano de fundo de perfil\",\"set_new_profile_banner\":\"Alterar capa de perfil\",\"settings\":\"Configurações\",\"subject_input_always_show\":\"Sempre mostrar campo de assunto\",\"subject_line_behavior\":\"Copiar assunto ao responder\",\"subject_line_email\":\"Como em email: \\\"re: assunto\\\"\",\"subject_line_mastodon\":\"Como o Mastodon: copiar como está\",\"subject_line_noop\":\"Não copiar\",\"post_status_content_type\":\"Postar tipo de conteúdo do status\",\"stop_gifs\":\"Reproduzir GIFs ao passar o cursor em cima\",\"streaming\":\"Habilitar o fluxo automático de postagens quando ao topo da página\",\"text\":\"Texto\",\"theme\":\"Tema\",\"theme_help\":\"Use cores em código hexadecimal (#rrggbb) para personalizar seu esquema de cores.\",\"theme_help_v2_1\":\"Você também pode sobrescrever as cores e opacidade de alguns componentes ao modificar o checkbox, use \\\"Limpar todos\\\" para limpar todas as modificações.\",\"theme_help_v2_2\":\"Alguns ícones sob registros são indicadores de fundo/contraste de textos, passe por cima para informações detalhadas. Tenha ciência de que os indicadores de contraste não funcionam muito bem com transparência.\",\"tooltipRadius\":\"Dicas/alertas\",\"upload_a_photo\":\"Enviar uma foto\",\"user_settings\":\"Configurações de Usuário\",\"values\":{\"false\":\"não\",\"true\":\"sim\"},\"notifications\":\"Notifications\",\"enable_web_push_notifications\":\"Habilitar notificações web push\",\"style\":{\"switcher\":{\"keep_color\":\"Manter cores\",\"keep_shadows\":\"Manter sombras\",\"keep_opacity\":\"Manter opacidade\",\"keep_roundness\":\"Manter arredondado\",\"keep_fonts\":\"Manter fontes\",\"save_load_hint\":\"Manter as opções preserva as opções atuais ao selecionar ou carregar temas; também salva as opções ao exportar um tempo. Quanto todos os campos estiverem desmarcados, tudo será salvo ao exportar o tema.\",\"reset\":\"Voltar ao padrão\",\"clear_all\":\"Limpar tudo\",\"clear_opacity\":\"Limpar opacidade\"},\"common\":{\"color\":\"Cor\",\"opacity\":\"Opacidade\",\"contrast\":{\"hint\":\"A taxa de contraste é {ratio}, {level} {context}\",\"level\":{\"aa\":\"padrão Nível AA (mínimo)\",\"aaa\":\"padrão Nível AAA (recomendado)\",\"bad\":\"nenhum padrão de acessibilidade\"},\"context\":{\"18pt\":\"para textos longos (18pt+)\",\"text\":\"para texto\"}}},\"common_colors\":{\"_tab_label\":\"Comum\",\"main\":\"Cores Comuns\",\"foreground_hint\":\"Configurações mais detalhadas na aba\\\"Avançado\\\"\",\"rgbo\":\"Ícones, acentuação, distintivos\"},\"advanced_colors\":{\"_tab_label\":\"Avançado\",\"alert\":\"Fundo de alerta\",\"alert_error\":\"Erro\",\"badge\":\"Fundo do distintivo\",\"badge_notification\":\"Notificação\",\"panel_header\":\"Topo do painel\",\"top_bar\":\"Barra do topo\",\"borders\":\"Bordas\",\"buttons\":\"Botões\",\"inputs\":\"Caixas de entrada\",\"faint_text\":\"Texto esmaecido\"},\"radii\":{\"_tab_label\":\"Arredondado\"},\"shadows\":{\"_tab_label\":\"Luz e sombra\",\"component\":\"Componente\",\"override\":\"Sobrescrever\",\"shadow_id\":\"Sombra #{value}\",\"blur\":\"Borrado\",\"spread\":\"Difusão\",\"inset\":\"Inserção\",\"hint\":\"Para as sombras você também pode usar --variável como valor de cor para utilizar variáveis do CSS3. Tenha em mente que configurar a opacidade não será possível neste caso.\",\"filter_hint\":{\"always_drop_shadow\":\"Atenção, esta sombra sempre utiliza {0} quando compatível com o navegador.\",\"drop_shadow_syntax\":\"{0} não é compatível com o parâmetro {1} e a palavra-chave {2}.\",\"avatar_inset\":\"Tenha em mente que combinar as sombras de inserção e a não-inserção em avatares pode causar resultados inesperados em avatares transparentes.\",\"spread_zero\":\"Sombras com uma difusão > 0 aparecerão como se fossem definidas como 0.\",\"inset_classic\":\"Sombras de inserção utilizarão {0}\"},\"components\":{\"panel\":\"Painel\",\"panelHeader\":\"Topo do painel\",\"topBar\":\"Barra do topo\",\"avatar\":\"Avatar do usuário (na visualização do perfil)\",\"avatarStatus\":\"Avatar do usuário (na exibição de posts)\",\"popup\":\"Dicas e notificações\",\"button\":\"Botão\",\"buttonHover\":\"Botão (em cima)\",\"buttonPressed\":\"Botão (pressionado)\",\"buttonPressedHover\":\"Botão (pressionado+em cima)\",\"input\":\"Campo de entrada\"}},\"fonts\":{\"_tab_label\":\"Fontes\",\"help\":\"Selecionar fonte dos elementos da interface. Para fonte \\\"personalizada\\\" você deve entrar exatamente o nome da fonte no sistema.\",\"components\":{\"interface\":\"Interface\",\"input\":\"Campo de entrada\",\"post\":\"Postar texto\",\"postCode\":\"Texto monoespaçado em post (formatação rica)\"},\"family\":\"Nome da fonte\",\"size\":\"Tamanho (em px)\",\"weight\":\"Peso\",\"custom\":\"Personalizada\"},\"preview\":{\"header\":\"Pré-visualizar\",\"content\":\"Conteúdo\",\"error\":\"Erro de exemplo\",\"button\":\"Botão\",\"text\":\"Vários {0} e {1}\",\"mono\":\"conteúdo\",\"input\":\"Acabei de chegar no Rio!\",\"faint_link\":\"manual útil\",\"fine_print\":\"Leia nosso {0} para não aprender nada!\",\"header_faint\":\"Está ok!\",\"checkbox\":\"Li os termos e condições\",\"link\":\"um belo link\"}}},\"timeline\":{\"collapse\":\"Esconder\",\"conversation\":\"Conversa\",\"error_fetching\":\"Erro ao buscar atualizações\",\"load_older\":\"Carregar postagens antigas\",\"no_retweet_hint\":\"Posts apenas para seguidores ou diretos não podem ser repetidos\",\"repeated\":\"Repetido\",\"show_new\":\"Mostrar novas\",\"up_to_date\":\"Atualizado\",\"no_more_statuses\":\"Sem mais posts\",\"no_statuses\":\"Sem posts\"},\"status\":{\"reply_to\":\"Responder a\",\"replies_list\":\"Respostas:\"},\"user_card\":{\"approve\":\"Aprovar\",\"block\":\"Bloquear\",\"blocked\":\"Bloqueado!\",\"deny\":\"Negar\",\"favorites\":\"Favoritos\",\"follow\":\"Seguir\",\"follow_sent\":\"Pedido enviado!\",\"follow_progress\":\"Enviando…\",\"follow_again\":\"Enviar solicitação novamente?\",\"follow_unfollow\":\"Deixar de seguir\",\"followees\":\"Seguindo\",\"followers\":\"Seguidores\",\"following\":\"Seguindo!\",\"follows_you\":\"Segue você!\",\"its_you\":\"É você!\",\"media\":\"Mídia\",\"mute\":\"Silenciar\",\"muted\":\"Silenciado\",\"per_day\":\"por dia\",\"remote_follow\":\"Seguidor Remoto\",\"statuses\":\"Postagens\",\"unblock\":\"Desbloquear\",\"unblock_progress\":\"Desbloqueando...\",\"block_progress\":\"Bloqueando...\",\"unmute\":\"Retirar silêncio\",\"unmute_progress\":\"Retirando silêncio...\",\"mute_progress\":\"Silenciando...\"},\"user_profile\":{\"timeline_title\":\"Linha do tempo do usuário\",\"profile_does_not_exist\":\"Desculpe, este perfil não existe.\",\"profile_loading_error\":\"Desculpe, houve um erro ao carregar este perfil.\"},\"who_to_follow\":{\"more\":\"Mais\",\"who_to_follow\":\"Quem seguir\"},\"tool_tip\":{\"media_upload\":\"Envio de mídia\",\"repeat\":\"Repetir\",\"reply\":\"Responder\",\"favorite\":\"Favoritar\",\"user_settings\":\"Configurações do usuário\"},\"upload\":{\"error\":{\"base\":\"Falha no envio.\",\"file_too_big\":\"Arquivo grande demais [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"Tente novamente mais tarde\"},\"file_size_units\":{\"B\":\"B\",\"KiB\":\"KiB\",\"MiB\":\"MiB\",\"GiB\":\"GiB\",\"TiB\":\"TiB\"}}}\n\n/***/ }),\n/* 454 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = {\"finder\":{\"error_fetching_user\":\"Eroare la preluarea utilizatorului\",\"find_user\":\"Găsește utilizator\"},\"general\":{\"submit\":\"trimite\"},\"login\":{\"login\":\"Loghează\",\"logout\":\"Deloghează\",\"password\":\"Parolă\",\"placeholder\":\"d.e. lain\",\"register\":\"Înregistrare\",\"username\":\"Nume utilizator\"},\"nav\":{\"mentions\":\"Menționări\",\"public_tl\":\"Cronologie Publică\",\"timeline\":\"Cronologie\",\"twkn\":\"Toată Reșeaua Cunoscută\"},\"notifications\":{\"followed_you\":\"te-a urmărit\",\"notifications\":\"Notificări\",\"read\":\"Citit!\"},\"post_status\":{\"default\":\"Nu de mult am aterizat în L.A.\",\"posting\":\"Postează\"},\"registration\":{\"bio\":\"Bio\",\"email\":\"Email\",\"fullname\":\"Numele întreg\",\"password_confirm\":\"Cofirmă parola\",\"registration\":\"Îregistrare\"},\"settings\":{\"attachments\":\"Atașamente\",\"autoload\":\"Permite încărcarea automată când scrolat la capăt\",\"avatar\":\"Avatar\",\"bio\":\"Bio\",\"current_avatar\":\"Avatarul curent\",\"current_profile_banner\":\"Bannerul curent al profilului\",\"filtering\":\"Filtru\",\"filtering_explanation\":\"Toate stările care conțin aceste cuvinte vor fi puse pe mut, una pe linie\",\"hide_attachments_in_convo\":\"Ascunde atașamentele în conversații\",\"hide_attachments_in_tl\":\"Ascunde atașamentele în cronologie\",\"name\":\"Nume\",\"name_bio\":\"Nume și Bio\",\"nsfw_clickthrough\":\"Permite ascunderea al atașamentelor NSFW\",\"profile_background\":\"Fundalul de profil\",\"profile_banner\":\"Banner de profil\",\"reply_link_preview\":\"Permite previzualizarea linkului de răspuns la planarea de mouse\",\"set_new_avatar\":\"Setează avatar nou\",\"set_new_profile_background\":\"Setează fundal nou\",\"set_new_profile_banner\":\"Setează banner nou la profil\",\"settings\":\"Setări\",\"theme\":\"Temă\",\"user_settings\":\"Setările utilizatorului\"},\"timeline\":{\"conversation\":\"Conversație\",\"error_fetching\":\"Erare la preluarea actualizărilor\",\"load_older\":\"Încarcă stări mai vechi\",\"show_new\":\"Arată cele noi\",\"up_to_date\":\"La zi\"},\"user_card\":{\"block\":\"Blochează\",\"blocked\":\"Blocat!\",\"follow\":\"Urmărește\",\"followees\":\"Urmărește\",\"followers\":\"Următori\",\"following\":\"Urmărit!\",\"follows_you\":\"Te urmărește!\",\"mute\":\"Pune pe mut\",\"muted\":\"Pus pe mut\",\"per_day\":\"pe zi\",\"statuses\":\"Stări\"}}\n\n/***/ }),\n/* 455 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = {\"chat\":{\"title\":\"Чат\"},\"finder\":{\"error_fetching_user\":\"Пользователь не найден\",\"find_user\":\"Найти пользователя\"},\"general\":{\"apply\":\"Применить\",\"submit\":\"Отправить\"},\"login\":{\"login\":\"Войти\",\"logout\":\"Выйти\",\"password\":\"Пароль\",\"placeholder\":\"e.c. lain\",\"register\":\"Зарегистрироваться\",\"username\":\"Имя пользователя\"},\"nav\":{\"back\":\"Назад\",\"chat\":\"Локальный чат\",\"mentions\":\"Упоминания\",\"public_tl\":\"Публичная лента\",\"timeline\":\"Лента\",\"twkn\":\"Федеративная лента\"},\"notifications\":{\"broken_favorite\":\"Неизвестный статус, ищем...\",\"favorited_you\":\"нравится ваш статус\",\"followed_you\":\"начал(а) читать вас\",\"load_older\":\"Загрузить старые уведомления\",\"notifications\":\"Уведомления\",\"read\":\"Прочесть\",\"repeated_you\":\"повторил(а) ваш статус\"},\"post_status\":{\"account_not_locked_warning\":\"Ваш аккаунт не {0}. Кто угодно может зафоловить вас чтобы прочитать посты только для подписчиков\",\"account_not_locked_warning_link\":\"залочен\",\"attachments_sensitive\":\"Вложения содержат чувствительный контент\",\"content_warning\":\"Тема (не обязательно)\",\"default\":\"Что нового?\",\"direct_warning\":\"Этот пост будет видет только упомянутым пользователям\",\"posting\":\"Отправляется\",\"scope\":{\"direct\":\"Личное - этот пост видят только те кто в нём упомянут\",\"private\":\"Для подписчиков - этот пост видят только подписчики\",\"public\":\"Публичный - этот пост виден всем\",\"unlisted\":\"Непубличный - этот пост не виден на публичных лентах\"}},\"registration\":{\"bio\":\"Описание\",\"email\":\"Email\",\"fullname\":\"Отображаемое имя\",\"password_confirm\":\"Подтверждение пароля\",\"registration\":\"Регистрация\",\"token\":\"Код приглашения\",\"validations\":{\"username_required\":\"не должно быть пустым\",\"fullname_required\":\"не должно быть пустым\",\"email_required\":\"не должен быть пустым\",\"password_required\":\"не должен быть пустым\",\"password_confirmation_required\":\"не должно быть пустым\",\"password_confirmation_match\":\"должно совпадать с паролем\"}},\"settings\":{\"attachmentRadius\":\"Прикреплённые файлы\",\"attachments\":\"Вложения\",\"autoload\":\"Включить автоматическую загрузку при прокрутке вниз\",\"avatar\":\"Аватар\",\"avatarAltRadius\":\"Аватары в уведомлениях\",\"avatarRadius\":\"Аватары\",\"background\":\"Фон\",\"bio\":\"Описание\",\"btnRadius\":\"Кнопки\",\"cBlue\":\"Ответить, читать\",\"cGreen\":\"Повторить\",\"cOrange\":\"Нравится\",\"cRed\":\"Отменить\",\"change_password\":\"Сменить пароль\",\"change_password_error\":\"Произошла ошибка при попытке изменить пароль.\",\"changed_password\":\"Пароль изменён успешно.\",\"collapse_subject\":\"Сворачивать посты с темой\",\"confirm_new_password\":\"Подтверждение нового пароля\",\"current_avatar\":\"Текущий аватар\",\"current_password\":\"Текущий пароль\",\"current_profile_banner\":\"Текущий баннер профиля\",\"data_import_export_tab\":\"Импорт / Экспорт данных\",\"delete_account\":\"Удалить аккаунт\",\"delete_account_description\":\"Удалить ваш аккаунт и все ваши сообщения.\",\"delete_account_error\":\"Возникла ошибка в процессе удаления вашего аккаунта. Если это повторяется, свяжитесь с администратором вашего сервера.\",\"delete_account_instructions\":\"Введите ваш пароль в поле ниже для подтверждения удаления.\",\"export_theme\":\"Сохранить Тему\",\"filtering\":\"Фильтрация\",\"filtering_explanation\":\"Все статусы, содержащие данные слова, будут игнорироваться, по одному в строке\",\"follow_export\":\"Экспортировать читаемых\",\"follow_export_button\":\"Экспортировать читаемых в файл .csv\",\"follow_export_processing\":\"Ведётся обработка, скоро вам будет предложено загрузить файл\",\"follow_import\":\"Импортировать читаемых\",\"follow_import_error\":\"Ошибка при импортировании читаемых.\",\"follows_imported\":\"Список читаемых импортирован. Обработка займёт некоторое время..\",\"foreground\":\"Передний план\",\"general\":\"Общие\",\"hide_attachments_in_convo\":\"Прятать вложения в разговорах\",\"hide_attachments_in_tl\":\"Прятать вложения в ленте\",\"hide_isp\":\"Скрыть серверную панель\",\"import_followers_from_a_csv_file\":\"Импортировать читаемых из файла .csv\",\"import_theme\":\"Загрузить Тему\",\"inputRadius\":\"Поля ввода\",\"checkboxRadius\":\"Чекбоксы\",\"interface\":\"Интерфейс\",\"interfaceLanguage\":\"Язык интерфейса\",\"limited_availability\":\"Не доступно в вашем браузере\",\"links\":\"Ссылки\",\"lock_account_description\":\"Аккаунт доступен только подтверждённым подписчикам\",\"loop_video\":\"Зациливать видео\",\"loop_video_silent_only\":\"Зацикливать только беззвучные видео (т.е. \\\"гифки\\\" с Mastodon)\",\"name\":\"Имя\",\"name_bio\":\"Имя и описание\",\"new_password\":\"Новый пароль\",\"notification_visibility\":\"Показывать уведомления\",\"notification_visibility_follows\":\"Подписки\",\"notification_visibility_likes\":\"Лайки\",\"notification_visibility_mentions\":\"Упоминания\",\"notification_visibility_repeats\":\"Повторы\",\"no_rich_text_description\":\"Убрать форматирование из всех постов\",\"hide_follows_description\":\"Не показывать кого я читаю\",\"hide_followers_description\":\"Не показывать кто читает меня\",\"show_admin_badge\":\"Показывать значок администратора в моем профиле\",\"show_moderator_badge\":\"Показывать значок модератора в моем профиле\",\"nsfw_clickthrough\":\"Включить скрытие NSFW вложений\",\"oauth_tokens\":\"OAuth токены\",\"token\":\"Токен\",\"refresh_token\":\"Рефреш токен\",\"valid_until\":\"Годен до\",\"revoke_token\":\"Удалить\",\"panelRadius\":\"Панели\",\"pause_on_unfocused\":\"Приостановить загрузку когда вкладка не в фокусе\",\"presets\":\"Пресеты\",\"profile_background\":\"Фон профиля\",\"profile_banner\":\"Баннер профиля\",\"profile_tab\":\"Профиль\",\"radii_help\":\"Скругление углов элементов интерфейса (в пикселях)\",\"replies_in_timeline\":\"Ответы в ленте\",\"reply_link_preview\":\"Включить предварительный просмотр ответа при наведении мыши\",\"reply_visibility_all\":\"Показывать все ответы\",\"reply_visibility_following\":\"Показывать только ответы мне и тех на кого я подписан\",\"reply_visibility_self\":\"Показывать только ответы мне\",\"security_tab\":\"Безопасность\",\"set_new_avatar\":\"Загрузить новый аватар\",\"set_new_profile_background\":\"Загрузить новый фон профиля\",\"set_new_profile_banner\":\"Загрузить новый баннер профиля\",\"settings\":\"Настройки\",\"subject_input_always_show\":\"Всегда показывать поле ввода темы\",\"stop_gifs\":\"Проигрывать GIF анимации только при наведении\",\"streaming\":\"Включить автоматическую загрузку новых сообщений при прокрутке вверх\",\"text\":\"Текст\",\"theme\":\"Тема\",\"theme_help\":\"Используйте шестнадцатеричные коды цветов (#rrggbb) для настройки темы.\",\"theme_help_v2_1\":\"Вы так же можете перепоределить цвета определенных компонентов нажав соотв. галочку. Используйте кнопку \\\"Очистить всё\\\" чтобы снять все переопределения\",\"theme_help_v2_2\":\"Под некоторыми полями ввода это идикаторы контрастности, наведите на них мышью чтобы узнать больше. Приспользовании прозрачности контраст расчитывается для наихудшего варианта.\",\"tooltipRadius\":\"Всплывающие подсказки/уведомления\",\"user_settings\":\"Настройки пользователя\",\"style\":{\"switcher\":{\"keep_color\":\"Оставить цвета\",\"keep_shadows\":\"Оставить тени\",\"keep_opacity\":\"Оставить прозрачность\",\"keep_roundness\":\"Оставить скругление\",\"keep_fonts\":\"Оставить шрифты\",\"save_load_hint\":\"Опции \\\"оставить...\\\" позволяют сохранить текущие настройки при выборе другой темы или импорта её из файла. Так же они влияют на то какие компоненты будут сохранены при экспорте темы. Когда все галочки сняты все компоненты будут экспортированы.\",\"reset\":\"Сбросить\",\"clear_all\":\"Очистить всё\",\"clear_opacity\":\"Очистить прозрачность\"},\"common\":{\"color\":\"Цвет\",\"opacity\":\"Прозрачность\",\"contrast\":{\"hint\":\"Уровень контраста: {ratio}, что {level} {context}\",\"level\":{\"aa\":\"соответствует гайдлайну Level AA (минимальный)\",\"aaa\":\"соответствует гайдлайну Level AAA (рекомендуемый)\",\"bad\":\"не соответствует каким либо гайдлайнам\"},\"context\":{\"18pt\":\"для крупного (18pt+) текста\",\"text\":\"для текста\"}}},\"common_colors\":{\"_tab_label\":\"Общие\",\"main\":\"Общие цвета\",\"foreground_hint\":\"См. вкладку \\\"Дополнительно\\\" для более детального контроля\",\"rgbo\":\"Иконки, акценты, ярылки\"},\"advanced_colors\":{\"_tab_label\":\"Дополнительно\",\"alert\":\"Фон уведомлений\",\"alert_error\":\"Ошибки\",\"badge\":\"Фон значков\",\"badge_notification\":\"Уведомления\",\"panel_header\":\"Заголовок панели\",\"top_bar\":\"Верняя полоска\",\"borders\":\"Границы\",\"buttons\":\"Кнопки\",\"inputs\":\"Поля ввода\",\"faint_text\":\"Маловажный текст\"},\"radii\":{\"_tab_label\":\"Скругление\"},\"shadows\":{\"_tab_label\":\"Светотень\",\"component\":\"Компонент\",\"override\":\"Переопределить\",\"shadow_id\":\"Тень №{value}\",\"blur\":\"Размытие\",\"spread\":\"Разброс\",\"inset\":\"Внутренняя\",\"hint\":\"Для теней вы так же можете использовать --variable в качестве цвета чтобы использовать CSS3-переменные. В таком случае прозрачность работать не будет.\",\"filter_hint\":{\"always_drop_shadow\":\"Внимание, эта тень всегда использует {0} когда браузер поддерживает это\",\"drop_shadow_syntax\":\"{0} не поддерживает параметр {1} и ключевое слово {2}\",\"avatar_inset\":\"Одновременное использование внутренних и внешних теней на (прозрачных) аватарках может дать не те результаты что вы ожидаете\",\"spread_zero\":\"Тени с разбросом > 0 будут выглядеть как если бы разброс установлен в 0\",\"inset_classic\":\"Внутренние тени будут использовать {0}\"},\"components\":{\"panel\":\"Панель\",\"panelHeader\":\"Заголовок панели\",\"topBar\":\"Верхняя полоска\",\"avatar\":\"Аватарка (профиль)\",\"avatarStatus\":\"Аватарка (в ленте)\",\"popup\":\"Всплывающие подсказки\",\"button\":\"Кнопки\",\"buttonHover\":\"Кнопки (наведен курсор)\",\"buttonPressed\":\"Кнопки (нажата)\",\"buttonPressedHover\":\"Кнопки (нажата+наведен курсор)\",\"input\":\"Поля ввода\"}},\"fonts\":{\"_tab_label\":\"Шрифты\",\"help\":\"Выберите тип шрифта для использования в интерфейсе. При выборе варианта \\\"другой\\\" надо ввести название шрифта в точности как он называется в системе.\",\"components\":{\"interface\":\"Интерфейс\",\"input\":\"Поля ввода\",\"post\":\"Текст постов\",\"postCode\":\"Моноширинный текст в посте (форматирование)\"},\"family\":\"Шрифт\",\"size\":\"Размер (в пикселях)\",\"weight\":\"Ширина\",\"custom\":\"Другой\"},\"preview\":{\"header\":\"Пример\",\"content\":\"Контент\",\"error\":\"Ошибка стоп 000\",\"button\":\"Кнопка\",\"text\":\"Еще немного {0} и масенькая {1}\",\"mono\":\"контента\",\"input\":\"Что нового?\",\"faint_link\":\"Его придется убрать\",\"fine_print\":\"Если проблемы остались — ваш гуртовщик мыши плохо стоит. {0}.\",\"header_faint\":\"Все идет по плану\",\"checkbox\":\"Я подтверждаю что не было ни единого разрыва\",\"link\":\"ссылка\"}}},\"timeline\":{\"collapse\":\"Свернуть\",\"conversation\":\"Разговор\",\"error_fetching\":\"Ошибка при обновлении\",\"load_older\":\"Загрузить старые статусы\",\"no_retweet_hint\":\"Пост помечен как \\\"только для подписчиков\\\" или \\\"личное\\\" и поэтому не может быть повторён\",\"repeated\":\"повторил(а)\",\"show_new\":\"Показать новые\",\"up_to_date\":\"Обновлено\"},\"user_card\":{\"block\":\"Заблокировать\",\"blocked\":\"Заблокирован\",\"favorites\":\"Понравившиеся\",\"follow\":\"Читать\",\"follow_sent\":\"Запрос отправлен!\",\"follow_progress\":\"Запрашиваем…\",\"follow_again\":\"Запросить еще заново?\",\"follow_unfollow\":\"Перестать читать\",\"followees\":\"Читаемые\",\"followers\":\"Читатели\",\"following\":\"Читаю\",\"follows_you\":\"Читает вас\",\"mute\":\"Игнорировать\",\"muted\":\"Игнорирую\",\"per_day\":\"в день\",\"remote_follow\":\"Читать удалённо\",\"statuses\":\"Статусы\"},\"user_profile\":{\"timeline_title\":\"Лента пользователя\"}}\n\n/***/ }),\n/* 456 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = {\"chat\":{\"title\":\"聊天\"},\"features_panel\":{\"chat\":\"聊天\",\"gopher\":\"Gopher\",\"media_proxy\":\"媒体代理\",\"scope_options\":\"可见范围设置\",\"text_limit\":\"文本长度限制\",\"title\":\"功能\",\"who_to_follow\":\"推荐关注\"},\"finder\":{\"error_fetching_user\":\"获取用户时发生错误\",\"find_user\":\"寻找用户\"},\"general\":{\"apply\":\"应用\",\"submit\":\"提交\"},\"login\":{\"login\":\"登录\",\"logout\":\"登出\",\"password\":\"密码\",\"placeholder\":\"例如:lain\",\"register\":\"注册\",\"username\":\"用户名\"},\"nav\":{\"chat\":\"本地聊天\",\"friend_requests\":\"关注请求\",\"mentions\":\"提及\",\"public_tl\":\"公共时间线\",\"timeline\":\"时间线\",\"twkn\":\"所有已知网络\"},\"notifications\":{\"broken_favorite\":\"未知的状态,正在搜索中...\",\"favorited_you\":\"收藏了你的状态\",\"followed_you\":\"关注了你\",\"load_older\":\"加载更早的通知\",\"notifications\":\"通知\",\"read\":\"阅读!\",\"repeated_you\":\"转发了你的状态\"},\"post_status\":{\"account_not_locked_warning\":\"你的帐号没有 {0}。任何人都可以关注你并浏览你的上锁内容。\",\"account_not_locked_warning_link\":\"上锁\",\"attachments_sensitive\":\"标记附件为敏感内容\",\"content_type\":{\"plain_text\":\"纯文本\"},\"content_warning\":\"主题(可选)\",\"default\":\"刚刚抵达上海\",\"direct_warning\":\"本条内容只有被提及的用户能够看到。\",\"posting\":\"发送\",\"scope\":{\"direct\":\"私信 - 只发送给被提及的用户\",\"private\":\"仅关注者 - 只有关注了你的人能看到\",\"public\":\"公共 - 发送到公共时间轴\",\"unlisted\":\"不公开 - 所有人可见,但不会发送到公共时间轴\"}},\"registration\":{\"bio\":\"简介\",\"email\":\"电子邮箱\",\"fullname\":\"全名\",\"password_confirm\":\"确认密码\",\"registration\":\"注册\",\"token\":\"邀请码\"},\"settings\":{\"attachmentRadius\":\"附件\",\"attachments\":\"附件\",\"autoload\":\"启用滚动到底部时的自动加载\",\"avatar\":\"头像\",\"avatarAltRadius\":\"头像(通知)\",\"avatarRadius\":\"头像\",\"background\":\"背景\",\"bio\":\"简介\",\"btnRadius\":\"按钮\",\"cBlue\":\"蓝色(回复,关注)\",\"cGreen\":\"绿色(转发)\",\"cOrange\":\"橙色(收藏)\",\"cRed\":\"红色(取消)\",\"change_password\":\"修改密码\",\"change_password_error\":\"修改密码的时候出了点问题。\",\"changed_password\":\"成功修改了密码!\",\"collapse_subject\":\"折叠带主题的内容\",\"confirm_new_password\":\"确认新密码\",\"current_avatar\":\"当前头像\",\"current_password\":\"当前密码\",\"current_profile_banner\":\"您当前的横幅图片\",\"data_import_export_tab\":\"数据导入/导出\",\"default_vis\":\"默认可见范围\",\"delete_account\":\"删除账户\",\"delete_account_description\":\"永久删除你的帐号和所有消息。\",\"delete_account_error\":\"删除账户时发生错误,如果一直删除不了,请联系实例管理员。\",\"delete_account_instructions\":\"在下面输入你的密码来确认删除账户\",\"export_theme\":\"导出预置主题\",\"filtering\":\"过滤器\",\"filtering_explanation\":\"所有包含以下词汇的内容都会被隐藏,一行一个\",\"follow_export\":\"导出关注\",\"follow_export_button\":\"将关注导出成 csv 文件\",\"follow_export_processing\":\"正在处理,过一会儿就可以下载你的文件了\",\"follow_import\":\"导入关注\",\"follow_import_error\":\"导入关注时错误\",\"follows_imported\":\"关注已导入!尚需要一些时间来处理。\",\"foreground\":\"前景\",\"general\":\"通用\",\"hide_attachments_in_convo\":\"在对话中隐藏附件\",\"hide_attachments_in_tl\":\"在时间线上隐藏附件\",\"hide_post_stats\":\"隐藏推文相关的统计数据(例如:收藏的次数)\",\"hide_user_stats\":\"隐藏用户的统计数据(例如:关注者的数量)\",\"import_followers_from_a_csv_file\":\"从 csv 文件中导入关注\",\"import_theme\":\"导入预置主题\",\"inputRadius\":\"输入框\",\"instance_default\":\"(默认:{value})\",\"interfaceLanguage\":\"界面语言\",\"invalid_theme_imported\":\"您所选择的主题文件不被 Pleroma 支持,因此主题未被修改。\",\"limited_availability\":\"在您的浏览器中无法使用\",\"links\":\"链接\",\"lock_account_description\":\"你需要手动审核关注请求\",\"loop_video\":\"循环视频\",\"loop_video_silent_only\":\"只循环没有声音的视频(例如:Mastodon 里的“GIF”)\",\"name\":\"名字\",\"name_bio\":\"名字及简介\",\"new_password\":\"新密码\",\"notification_visibility\":\"要显示的通知类型\",\"notification_visibility_follows\":\"关注\",\"notification_visibility_likes\":\"点赞\",\"notification_visibility_mentions\":\"提及\",\"notification_visibility_repeats\":\"转发\",\"no_rich_text_description\":\"不显示富文本格式\",\"nsfw_clickthrough\":\"将不和谐附件隐藏,点击才能打开\",\"oauth_tokens\":\"OAuth令牌\",\"token\":\"代币\",\"refresh_token\":\"刷新令牌\",\"valid_until\":\"有效期至\",\"revoke_token\":\"撤消\",\"panelRadius\":\"面板\",\"pause_on_unfocused\":\"在离开页面时暂停时间线推送\",\"presets\":\"预置\",\"profile_background\":\"个人资料背景图\",\"profile_banner\":\"横幅图片\",\"profile_tab\":\"个人资料\",\"radii_help\":\"设置界面边缘的圆角 (单位:像素)\",\"replies_in_timeline\":\"时间线中的回复\",\"reply_link_preview\":\"启用鼠标悬停时预览回复链接\",\"reply_visibility_all\":\"显示所有回复\",\"reply_visibility_following\":\"只显示发送给我的回复/发送给我关注的用户的回复\",\"reply_visibility_self\":\"只显示发送给我的回复\",\"saving_err\":\"保存设置时发生错误\",\"saving_ok\":\"设置已保存\",\"security_tab\":\"安全\",\"set_new_avatar\":\"设置新头像\",\"set_new_profile_background\":\"设置新的个人资料背景\",\"set_new_profile_banner\":\"设置新的横幅图片\",\"settings\":\"设置\",\"stop_gifs\":\"鼠标悬停时播放GIF\",\"streaming\":\"开启滚动到顶部时的自动推送\",\"text\":\"文本\",\"theme\":\"主题\",\"theme_help\":\"使用十六进制代码(#rrggbb)来设置主题颜色。\",\"tooltipRadius\":\"提醒\",\"user_settings\":\"用户设置\",\"values\":{\"false\":\"否\",\"true\":\"是\"}},\"timeline\":{\"collapse\":\"折叠\",\"conversation\":\"对话\",\"error_fetching\":\"获取更新时发生错误\",\"load_older\":\"加载更早的状态\",\"no_retweet_hint\":\"这条内容仅关注者可见,或者是私信,因此不能转发。\",\"repeated\":\"已转发\",\"show_new\":\"显示新内容\",\"up_to_date\":\"已是最新\"},\"user_card\":{\"approve\":\"允许\",\"block\":\"屏蔽\",\"blocked\":\"已屏蔽!\",\"deny\":\"拒绝\",\"follow\":\"关注\",\"followees\":\"正在关注\",\"followers\":\"关注者\",\"following\":\"正在关注!\",\"follows_you\":\"关注了你!\",\"mute\":\"隐藏\",\"muted\":\"已隐藏\",\"per_day\":\"每天\",\"remote_follow\":\"跨站关注\",\"statuses\":\"状态\"},\"user_profile\":{\"timeline_title\":\"用户时间线\"},\"who_to_follow\":{\"more\":\"更多\",\"who_to_follow\":\"推荐关注\"}}\n\n/***/ }),\n/* 457 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = [\"teď\",[\"%s s\",\"%s s\"],[\"%s min\",\"%s min\"],[\"%s h\",\"%s h\"],[\"%s d\",\"%s d\"],[\"%s týd\",\"%s týd\"],[\"%s měs\",\"%s měs\"],[\"%s r\",\"%s l\"]]\n\n/***/ }),\n/* 458 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = [\"now\",[\"%ss\",\"%ss\"],[\"%smin\",\"%smin\"],[\"%sh\",\"%sh\"],[\"%sd\",\"%sd\"],[\"%sw\",\"%sw\"],[\"%smo\",\"%smo\"],[\"%sy\",\"%sy\"]]\n\n/***/ }),\n/* 459 */\n/***/ (function(module, exports) {\n\n\tmodule.exports = [\"たった今\",\"%s 秒前\",\"%s 分前\",\"%s 時間前\",\"%s 日前\",\"%s 週間前\",\"%s ヶ月前\",\"%s 年前\"]\n\n/***/ }),\n/* 460 */,\n/* 461 */,\n/* 462 */,\n/* 463 */,\n/* 464 */,\n/* 465 */,\n/* 466 */,\n/* 467 */,\n/* 468 */,\n/* 469 */,\n/* 470 */,\n/* 471 */,\n/* 472 */,\n/* 473 */,\n/* 474 */,\n/* 475 */,\n/* 476 */,\n/* 477 */,\n/* 478 */,\n/* 479 */,\n/* 480 */,\n/* 481 */,\n/* 482 */,\n/* 483 */,\n/* 484 */,\n/* 485 */,\n/* 486 */,\n/* 487 */,\n/* 488 */,\n/* 489 */,\n/* 490 */,\n/* 491 */,\n/* 492 */,\n/* 493 */,\n/* 494 */,\n/* 495 */,\n/* 496 */,\n/* 497 */,\n/* 498 */,\n/* 499 */,\n/* 500 */,\n/* 501 */,\n/* 502 */,\n/* 503 */,\n/* 504 */,\n/* 505 */,\n/* 506 */,\n/* 507 */,\n/* 508 */,\n/* 509 */,\n/* 510 */,\n/* 511 */,\n/* 512 */,\n/* 513 */,\n/* 514 */,\n/* 515 */,\n/* 516 */,\n/* 517 */,\n/* 518 */,\n/* 519 */,\n/* 520 */,\n/* 521 */,\n/* 522 */,\n/* 523 */,\n/* 524 */,\n/* 525 */,\n/* 526 */,\n/* 527 */,\n/* 528 */,\n/* 529 */,\n/* 530 */,\n/* 531 */,\n/* 532 */,\n/* 533 */,\n/* 534 */,\n/* 535 */,\n/* 536 */,\n/* 537 */,\n/* 538 */,\n/* 539 */,\n/* 540 */,\n/* 541 */,\n/* 542 */,\n/* 543 */,\n/* 544 */,\n/* 545 */,\n/* 546 */,\n/* 547 */,\n/* 548 */,\n/* 549 */,\n/* 550 */,\n/* 551 */,\n/* 552 */,\n/* 553 */,\n/* 554 */,\n/* 555 */,\n/* 556 */,\n/* 557 */,\n/* 558 */,\n/* 559 */,\n/* 560 */,\n/* 561 */,\n/* 562 */,\n/* 563 */,\n/* 564 */,\n/* 565 */,\n/* 566 */,\n/* 567 */,\n/* 568 */,\n/* 569 */,\n/* 570 */,\n/* 571 */,\n/* 572 */,\n/* 573 */,\n/* 574 */,\n/* 575 */,\n/* 576 */,\n/* 577 */,\n/* 578 */,\n/* 579 */,\n/* 580 */,\n/* 581 */,\n/* 582 */,\n/* 583 */,\n/* 584 */,\n/* 585 */,\n/* 586 */,\n/* 587 */,\n/* 588 */,\n/* 589 */,\n/* 590 */,\n/* 591 */,\n/* 592 */,\n/* 593 */,\n/* 594 */,\n/* 595 */,\n/* 596 */,\n/* 597 */,\n/* 598 */,\n/* 599 */,\n/* 600 */,\n/* 601 */,\n/* 602 */,\n/* 603 */,\n/* 604 */,\n/* 605 */,\n/* 606 */,\n/* 607 */,\n/* 608 */,\n/* 609 */,\n/* 610 */,\n/* 611 */,\n/* 612 */,\n/* 613 */,\n/* 614 */,\n/* 615 */,\n/* 616 */,\n/* 617 */,\n/* 618 */,\n/* 619 */,\n/* 620 */,\n/* 621 */,\n/* 622 */,\n/* 623 */,\n/* 624 */,\n/* 625 */,\n/* 626 */,\n/* 627 */,\n/* 628 */,\n/* 629 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\tmodule.exports = __webpack_require__.p + \"static/img/nsfw.74818f9.png\";\n\n/***/ }),\n/* 630 */,\n/* 631 */,\n/* 632 */,\n/* 633 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(407)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(252),\n\t /* template */\n\t __webpack_require__(705),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 634 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(408)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(253),\n\t /* template */\n\t __webpack_require__(707),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 635 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(409)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(256),\n\t /* template */\n\t __webpack_require__(709),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 636 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(395)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(247),\n\t /* template */\n\t __webpack_require__(688),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 637 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(258),\n\t /* template */\n\t __webpack_require__(720),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 638 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(423)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(260),\n\t /* template */\n\t __webpack_require__(729),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 639 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(261),\n\t /* template */\n\t __webpack_require__(712),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 640 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(430)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(248),\n\t /* template */\n\t __webpack_require__(737),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 641 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(425)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(262),\n\t /* template */\n\t __webpack_require__(732),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 642 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(398)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(265),\n\t /* template */\n\t __webpack_require__(694),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 643 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(266),\n\t /* template */\n\t __webpack_require__(680),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 644 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(406)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(267),\n\t /* template */\n\t __webpack_require__(704),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 645 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(268),\n\t /* template */\n\t __webpack_require__(727),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 646 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(428)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(269),\n\t /* template */\n\t __webpack_require__(735),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 647 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(421)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(270),\n\t /* template */\n\t __webpack_require__(726),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 648 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(249),\n\t /* template */\n\t __webpack_require__(695),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 649 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(417)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(272),\n\t /* template */\n\t __webpack_require__(722),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 650 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(411)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(274),\n\t /* template */\n\t __webpack_require__(711),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 651 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(410)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(275),\n\t /* template */\n\t __webpack_require__(710),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 652 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(276),\n\t /* template */\n\t __webpack_require__(691),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 653 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(388)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(277),\n\t /* template */\n\t __webpack_require__(678),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 654 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(278),\n\t /* template */\n\t __webpack_require__(690),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 655 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(427)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(279),\n\t /* template */\n\t __webpack_require__(734),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 656 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(280),\n\t /* template */\n\t __webpack_require__(717),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 657 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(282),\n\t /* template */\n\t __webpack_require__(697),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 658 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(284),\n\t /* template */\n\t __webpack_require__(692),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 659 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(285),\n\t /* template */\n\t __webpack_require__(714),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 660 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(251),\n\t /* template */\n\t __webpack_require__(715),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 661 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(402)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(286),\n\t /* template */\n\t __webpack_require__(700),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 662 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(393)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(287),\n\t /* template */\n\t __webpack_require__(686),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 663 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(426)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(288),\n\t /* template */\n\t __webpack_require__(733),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 664 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(415)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(289),\n\t /* template */\n\t __webpack_require__(719),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 665 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(414)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(290),\n\t /* template */\n\t __webpack_require__(718),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 666 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(400)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(292),\n\t /* template */\n\t __webpack_require__(698),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 667 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t null,\n\t /* template */\n\t __webpack_require__(731),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 668 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(295),\n\t /* template */\n\t __webpack_require__(684),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 669 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(394)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(296),\n\t /* template */\n\t __webpack_require__(687),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 670 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(399)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(300),\n\t /* template */\n\t __webpack_require__(696),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 671 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(301),\n\t /* template */\n\t __webpack_require__(738),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 672 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(404)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(302),\n\t /* template */\n\t __webpack_require__(702),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 673 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(412)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(303),\n\t /* template */\n\t __webpack_require__(713),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 674 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(422)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(304),\n\t /* template */\n\t __webpack_require__(728),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 675 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(392)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(306),\n\t /* template */\n\t __webpack_require__(685),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 676 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t\n\t/* styles */\n\t__webpack_require__(429)\n\t\n\tvar Component = __webpack_require__(1)(\n\t /* script */\n\t __webpack_require__(307),\n\t /* template */\n\t __webpack_require__(736),\n\t /* scopeId */\n\t null,\n\t /* cssModules */\n\t null\n\t)\n\t\n\tmodule.exports = Component.exports\n\n\n/***/ }),\n/* 677 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"notifications\"\n\t }, [_c('div', {\n\t staticClass: \"panel panel-default\"\n\t }, [_c('div', {\n\t staticClass: \"panel-heading\"\n\t }, [_c('div', {\n\t staticClass: \"title\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('notifications.notifications')) + \"\\n \"), (_vm.unseenCount) ? _c('span', {\n\t staticClass: \"badge badge-notification unseen-count\"\n\t }, [_vm._v(_vm._s(_vm.unseenCount))]) : _vm._e()]), _vm._v(\" \"), (_vm.error) ? _c('div', {\n\t staticClass: \"loadmore-error alert error\",\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t }\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('timeline.error_fetching')) + \"\\n \")]) : _vm._e(), _vm._v(\" \"), (_vm.unseenCount) ? _c('button', {\n\t staticClass: \"read-button\",\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t return _vm.markAsSeen($event)\n\t }\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('notifications.read')))]) : _vm._e()]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"panel-body\"\n\t }, _vm._l((_vm.visibleNotifications), function(notification) {\n\t return _c('div', {\n\t key: notification.action.id,\n\t staticClass: \"notification\",\n\t class: {\n\t \"unseen\": !notification.seen\n\t }\n\t }, [_c('div', {\n\t staticClass: \"notification-overlay\"\n\t }), _vm._v(\" \"), _c('notification', {\n\t attrs: {\n\t \"notification\": notification\n\t }\n\t })], 1)\n\t }), 0), _vm._v(\" \"), _c('div', {\n\t staticClass: \"panel-footer\"\n\t }, [(_vm.bottomedOut) ? _c('div', {\n\t staticClass: \"new-status-notification text-center panel-footer faint\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('notifications.no_more_notifications')) + \"\\n \")]) : (!_vm.loading) ? _c('a', {\n\t attrs: {\n\t \"href\": \"#\"\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t _vm.fetchOlderNotifications()\n\t }\n\t }\n\t }, [_c('div', {\n\t staticClass: \"new-status-notification text-center panel-footer\"\n\t }, [_vm._v(_vm._s(_vm.$t('notifications.load_older')))])]) : _c('div', {\n\t staticClass: \"new-status-notification text-center panel-footer\"\n\t }, [_c('i', {\n\t staticClass: \"icon-spin3 animate-spin\"\n\t })])])])])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 678 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return (_vm.currentUser) ? _c('div', [_c('div', {\n\t directives: [{\n\t name: \"show\",\n\t rawName: \"v-show\",\n\t value: (_vm.postFormOpen),\n\t expression: \"postFormOpen\"\n\t }],\n\t staticClass: \"post-form-modal-view modal-view\",\n\t on: {\n\t \"click\": _vm.closePostForm\n\t }\n\t }, [_c('div', {\n\t staticClass: \"post-form-modal-panel panel\",\n\t on: {\n\t \"click\": function($event) {\n\t $event.stopPropagation();\n\t }\n\t }\n\t }, [_c('div', {\n\t staticClass: \"panel-heading\"\n\t }, [_vm._v(_vm._s(_vm.$t('post_status.new_status')))]), _vm._v(\" \"), _c('PostStatusForm', {\n\t staticClass: \"panel-body\",\n\t on: {\n\t \"posted\": _vm.closePostForm\n\t }\n\t })], 1)]), _vm._v(\" \"), _c('button', {\n\t staticClass: \"new-status-button\",\n\t class: {\n\t 'hidden': _vm.isHidden\n\t },\n\t on: {\n\t \"click\": _vm.openPostForm\n\t }\n\t }, [_c('i', {\n\t staticClass: \"icon-edit\"\n\t })])]) : _vm._e()\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 679 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t class: _vm.classes.root\n\t }, [_c('div', {\n\t class: _vm.classes.header\n\t }, [_c('div', {\n\t staticClass: \"title\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.title) + \"\\n \")]), _vm._v(\" \"), (_vm.timelineError) ? _c('div', {\n\t staticClass: \"loadmore-error alert error\",\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t }\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('timeline.error_fetching')) + \"\\n \")]) : _vm._e(), _vm._v(\" \"), (_vm.timeline.newStatusCount > 0 && !_vm.timelineError) ? _c('button', {\n\t staticClass: \"loadmore-button\",\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t return _vm.showNewStatuses($event)\n\t }\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('timeline.show_new')) + _vm._s(_vm.newStatusCountStr) + \"\\n \")]) : _vm._e(), _vm._v(\" \"), (!_vm.timeline.newStatusCount > 0 && !_vm.timelineError) ? _c('div', {\n\t staticClass: \"loadmore-text faint\",\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t }\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('timeline.up_to_date')) + \"\\n \")]) : _vm._e()]), _vm._v(\" \"), _c('div', {\n\t class: _vm.classes.body\n\t }, [_c('div', {\n\t staticClass: \"timeline\"\n\t }, _vm._l((_vm.timeline.visibleStatuses), function(status) {\n\t return _c('status-or-conversation', {\n\t key: status.id,\n\t staticClass: \"status-fadein\",\n\t attrs: {\n\t \"statusoid\": status\n\t }\n\t })\n\t }), 1)]), _vm._v(\" \"), _c('div', {\n\t class: _vm.classes.footer\n\t }, [(_vm.count === 0) ? _c('div', {\n\t staticClass: \"new-status-notification text-center panel-footer faint\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('timeline.no_statuses')) + \"\\n \")]) : (_vm.bottomedOut) ? _c('div', {\n\t staticClass: \"new-status-notification text-center panel-footer faint\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('timeline.no_more_statuses')) + \"\\n \")]) : (!_vm.timeline.loading) ? _c('a', {\n\t attrs: {\n\t \"href\": \"#\"\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t _vm.fetchOlderStatuses()\n\t }\n\t }\n\t }, [_c('div', {\n\t staticClass: \"new-status-notification text-center panel-footer\"\n\t }, [_vm._v(_vm._s(_vm.$t('timeline.load_older')))])]) : _c('div', {\n\t staticClass: \"new-status-notification text-center panel-footer\"\n\t }, [_c('i', {\n\t staticClass: \"icon-spin3 animate-spin\"\n\t })])])])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 680 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"settings panel panel-default\"\n\t }, [_c('div', {\n\t staticClass: \"panel-heading\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('nav.friend_requests')) + \"\\n \")]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"panel-body\"\n\t }, _vm._l((_vm.requests), function(request) {\n\t return _c('FollowRequestCard', {\n\t key: request.id,\n\t attrs: {\n\t \"user\": request\n\t }\n\t })\n\t }), 1)])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 681 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('StillImage', {\n\t staticClass: \"avatar\",\n\t class: {\n\t 'avatar-compact': _vm.compact, 'better-shadow': _vm.betterShadow\n\t },\n\t attrs: {\n\t \"src\": _vm.imgSrc,\n\t \"imageLoadError\": _vm.imageLoadError\n\t }\n\t })\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 682 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"post-status-form\"\n\t }, [_c('form', {\n\t on: {\n\t \"submit\": function($event) {\n\t $event.preventDefault();\n\t _vm.postStatus(_vm.newStatus)\n\t }\n\t }\n\t }, [_c('div', {\n\t staticClass: \"form-group\"\n\t }, [(!this.$store.state.users.currentUser.locked && this.newStatus.visibility == 'private') ? _c('i18n', {\n\t staticClass: \"visibility-notice\",\n\t attrs: {\n\t \"path\": \"post_status.account_not_locked_warning\",\n\t \"tag\": \"p\"\n\t }\n\t }, [_c('router-link', {\n\t attrs: {\n\t \"to\": {\n\t name: 'user-settings'\n\t }\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('post_status.account_not_locked_warning_link')))])], 1) : _vm._e(), _vm._v(\" \"), (this.newStatus.visibility == 'direct') ? _c('p', {\n\t staticClass: \"visibility-notice\"\n\t }, [_vm._v(_vm._s(_vm.$t('post_status.direct_warning')))]) : _vm._e(), _vm._v(\" \"), (_vm.newStatus.spoilerText || _vm.alwaysShowSubject) ? _c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.newStatus.spoilerText),\n\t expression: \"newStatus.spoilerText\"\n\t }],\n\t staticClass: \"form-cw\",\n\t attrs: {\n\t \"type\": \"text\",\n\t \"placeholder\": _vm.$t('post_status.content_warning')\n\t },\n\t domProps: {\n\t \"value\": (_vm.newStatus.spoilerText)\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.$set(_vm.newStatus, \"spoilerText\", $event.target.value)\n\t }\n\t }\n\t }) : _vm._e(), _vm._v(\" \"), _c('textarea', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.newStatus.status),\n\t expression: \"newStatus.status\"\n\t }],\n\t ref: \"textarea\",\n\t staticClass: \"form-control\",\n\t attrs: {\n\t \"placeholder\": _vm.$t('post_status.default'),\n\t \"rows\": \"1\",\n\t \"disabled\": _vm.posting\n\t },\n\t domProps: {\n\t \"value\": (_vm.newStatus.status)\n\t },\n\t on: {\n\t \"click\": _vm.setCaret,\n\t \"keyup\": [_vm.setCaret, function($event) {\n\t if (!('button' in $event) && _vm._k($event.keyCode, \"enter\", 13, $event.key, \"Enter\")) { return null; }\n\t if (!$event.ctrlKey) { return null; }\n\t _vm.postStatus(_vm.newStatus)\n\t }],\n\t \"keydown\": [_vm.onKeydown, function($event) {\n\t if (!('button' in $event) && _vm._k($event.keyCode, \"down\", 40, $event.key, [\"Down\", \"ArrowDown\"])) { return null; }\n\t return _vm.cycleForward($event)\n\t }, function($event) {\n\t if (!('button' in $event) && _vm._k($event.keyCode, \"up\", 38, $event.key, [\"Up\", \"ArrowUp\"])) { return null; }\n\t return _vm.cycleBackward($event)\n\t }, function($event) {\n\t if (!('button' in $event) && _vm._k($event.keyCode, \"tab\", 9, $event.key, \"Tab\")) { return null; }\n\t if (!$event.shiftKey) { return null; }\n\t return _vm.cycleBackward($event)\n\t }, function($event) {\n\t if (!('button' in $event) && _vm._k($event.keyCode, \"tab\", 9, $event.key, \"Tab\")) { return null; }\n\t return _vm.cycleForward($event)\n\t }, function($event) {\n\t if (!('button' in $event) && _vm._k($event.keyCode, \"enter\", 13, $event.key, \"Enter\")) { return null; }\n\t return _vm.replaceCandidate($event)\n\t }, function($event) {\n\t if (!('button' in $event) && _vm._k($event.keyCode, \"enter\", 13, $event.key, \"Enter\")) { return null; }\n\t if (!$event.metaKey) { return null; }\n\t _vm.postStatus(_vm.newStatus)\n\t }],\n\t \"drop\": _vm.fileDrop,\n\t \"dragover\": function($event) {\n\t $event.preventDefault();\n\t return _vm.fileDrag($event)\n\t },\n\t \"input\": [function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.$set(_vm.newStatus, \"status\", $event.target.value)\n\t }, _vm.resize],\n\t \"paste\": _vm.paste\n\t }\n\t }), _vm._v(\" \"), _c('div', {\n\t staticClass: \"visibility-tray\"\n\t }, [(_vm.formattingOptionsEnabled) ? _c('span', {\n\t staticClass: \"text-format\"\n\t }, [_c('label', {\n\t staticClass: \"select\",\n\t attrs: {\n\t \"for\": \"post-content-type\"\n\t }\n\t }, [_c('select', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.newStatus.contentType),\n\t expression: \"newStatus.contentType\"\n\t }],\n\t staticClass: \"form-control\",\n\t attrs: {\n\t \"id\": \"post-content-type\"\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n\t return o.selected\n\t }).map(function(o) {\n\t var val = \"_value\" in o ? o._value : o.value;\n\t return val\n\t });\n\t _vm.$set(_vm.newStatus, \"contentType\", $event.target.multiple ? $$selectedVal : $$selectedVal[0])\n\t }\n\t }\n\t }, _vm._l((_vm.postFormats), function(postFormat) {\n\t return _c('option', {\n\t key: postFormat,\n\t domProps: {\n\t \"value\": postFormat\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t((\"post_status.content_type[\\\"\" + postFormat + \"\\\"]\"))) + \"\\n \")])\n\t }), 0), _vm._v(\" \"), _c('i', {\n\t staticClass: \"icon-down-open\"\n\t })])]) : _vm._e(), _vm._v(\" \"), (_vm.scopeOptionsEnabled) ? _c('div', [_c('i', {\n\t staticClass: \"icon-mail-alt\",\n\t class: _vm.vis.direct,\n\t attrs: {\n\t \"title\": _vm.$t('post_status.scope.direct')\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t _vm.changeVis('direct')\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('i', {\n\t staticClass: \"icon-lock\",\n\t class: _vm.vis.private,\n\t attrs: {\n\t \"title\": _vm.$t('post_status.scope.private')\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t _vm.changeVis('private')\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('i', {\n\t staticClass: \"icon-lock-open-alt\",\n\t class: _vm.vis.unlisted,\n\t attrs: {\n\t \"title\": _vm.$t('post_status.scope.unlisted')\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t _vm.changeVis('unlisted')\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('i', {\n\t staticClass: \"icon-globe\",\n\t class: _vm.vis.public,\n\t attrs: {\n\t \"title\": _vm.$t('post_status.scope.public')\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t _vm.changeVis('public')\n\t }\n\t }\n\t })]) : _vm._e()])], 1), _vm._v(\" \"), (_vm.candidates) ? _c('div', {\n\t staticStyle: {\n\t \"position\": \"relative\"\n\t }\n\t }, [_c('div', {\n\t staticClass: \"autocomplete-panel\"\n\t }, _vm._l((_vm.candidates), function(candidate) {\n\t return _c('div', {\n\t on: {\n\t \"click\": function($event) {\n\t _vm.replace(candidate.utf || (candidate.screen_name + ' '))\n\t }\n\t }\n\t }, [_c('div', {\n\t staticClass: \"autocomplete\",\n\t class: {\n\t highlighted: candidate.highlighted\n\t }\n\t }, [(candidate.img) ? _c('span', [_c('img', {\n\t attrs: {\n\t \"src\": candidate.img\n\t }\n\t })]) : _c('span', [_vm._v(_vm._s(candidate.utf))]), _vm._v(\" \"), _c('span', [_vm._v(_vm._s(candidate.screen_name)), _c('small', [_vm._v(_vm._s(candidate.name))])])])])\n\t }), 0)]) : _vm._e(), _vm._v(\" \"), _c('div', {\n\t staticClass: \"form-bottom\"\n\t }, [_c('media-upload', {\n\t ref: \"mediaUpload\",\n\t attrs: {\n\t \"drop-files\": _vm.dropFiles\n\t },\n\t on: {\n\t \"uploading\": _vm.disableSubmit,\n\t \"uploaded\": _vm.addMediaFile,\n\t \"upload-failed\": _vm.uploadFailed\n\t }\n\t }), _vm._v(\" \"), (_vm.isOverLengthLimit) ? _c('p', {\n\t staticClass: \"error\"\n\t }, [_vm._v(_vm._s(_vm.charactersLeft))]) : (_vm.hasStatusLengthLimit) ? _c('p', {\n\t staticClass: \"faint\"\n\t }, [_vm._v(_vm._s(_vm.charactersLeft))]) : _vm._e(), _vm._v(\" \"), (_vm.posting) ? _c('button', {\n\t staticClass: \"btn btn-default\",\n\t attrs: {\n\t \"disabled\": \"\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('post_status.posting')))]) : (_vm.isOverLengthLimit) ? _c('button', {\n\t staticClass: \"btn btn-default\",\n\t attrs: {\n\t \"disabled\": \"\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('general.submit')))]) : _c('button', {\n\t staticClass: \"btn btn-default\",\n\t attrs: {\n\t \"disabled\": _vm.submitDisabled,\n\t \"type\": \"submit\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('general.submit')))])], 1), _vm._v(\" \"), (_vm.error) ? _c('div', {\n\t staticClass: \"alert error\"\n\t }, [_vm._v(\"\\n Error: \" + _vm._s(_vm.error) + \"\\n \"), _c('i', {\n\t staticClass: \"button-icon icon-cancel\",\n\t on: {\n\t \"click\": _vm.clearError\n\t }\n\t })]) : _vm._e(), _vm._v(\" \"), _c('div', {\n\t staticClass: \"attachments\"\n\t }, _vm._l((_vm.newStatus.files), function(file) {\n\t return _c('div', {\n\t staticClass: \"media-upload-wrapper\"\n\t }, [_c('i', {\n\t staticClass: \"fa button-icon icon-cancel\",\n\t on: {\n\t \"click\": function($event) {\n\t _vm.removeMediaFile(file)\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('div', {\n\t staticClass: \"media-upload-container attachment\"\n\t }, [(_vm.type(file) === 'image') ? _c('img', {\n\t staticClass: \"thumbnail media-upload\",\n\t attrs: {\n\t \"src\": file.image\n\t }\n\t }) : _vm._e(), _vm._v(\" \"), (_vm.type(file) === 'video') ? _c('video', {\n\t attrs: {\n\t \"src\": file.image,\n\t \"controls\": \"\"\n\t }\n\t }) : _vm._e(), _vm._v(\" \"), (_vm.type(file) === 'audio') ? _c('audio', {\n\t attrs: {\n\t \"src\": file.image,\n\t \"controls\": \"\"\n\t }\n\t }) : _vm._e(), _vm._v(\" \"), (_vm.type(file) === 'unknown') ? _c('a', {\n\t attrs: {\n\t \"href\": file.image\n\t }\n\t }, [_vm._v(_vm._s(file.url))]) : _vm._e()])])\n\t }), 0), _vm._v(\" \"), (_vm.newStatus.files.length > 0) ? _c('div', {\n\t staticClass: \"upload_settings\"\n\t }, [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.newStatus.nsfw),\n\t expression: \"newStatus.nsfw\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"filesSensitive\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.newStatus.nsfw) ? _vm._i(_vm.newStatus.nsfw, null) > -1 : (_vm.newStatus.nsfw)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.newStatus.nsfw,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.$set(_vm.newStatus, \"nsfw\", $$a.concat([$$v])))\n\t } else {\n\t $$i > -1 && (_vm.$set(_vm.newStatus, \"nsfw\", $$a.slice(0, $$i).concat($$a.slice($$i + 1))))\n\t }\n\t } else {\n\t _vm.$set(_vm.newStatus, \"nsfw\", $$c)\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"filesSensitive\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('post_status.attachments_sensitive')))])]) : _vm._e()])])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 683 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"timeline panel panel-default\"\n\t }, [_c('div', {\n\t staticClass: \"panel-heading conversation-heading\"\n\t }, [_c('span', {\n\t staticClass: \"title\"\n\t }, [_vm._v(\" \" + _vm._s(_vm.$t('timeline.conversation')) + \" \")]), _vm._v(\" \"), (_vm.collapsable) ? _c('span', [_c('a', {\n\t attrs: {\n\t \"href\": \"#\"\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t _vm.$emit('toggleExpanded')\n\t }\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('timeline.collapse')))])]) : _vm._e()]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"panel-body\"\n\t }, [_c('div', {\n\t staticClass: \"timeline\"\n\t }, _vm._l((_vm.conversation), function(status) {\n\t return _c('status', {\n\t key: status.id,\n\t staticClass: \"status-fadein\",\n\t attrs: {\n\t \"inlineExpanded\": _vm.collapsable,\n\t \"statusoid\": status,\n\t \"expandable\": false,\n\t \"focused\": _vm.focused(status.id),\n\t \"inConversation\": true,\n\t \"highlight\": _vm.highlight,\n\t \"replies\": _vm.getReplies(status.id)\n\t },\n\t on: {\n\t \"goto\": _vm.setHighlight\n\t }\n\t })\n\t }), 1)])])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 684 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('Timeline', {\n\t attrs: {\n\t \"title\": _vm.tag,\n\t \"timeline\": _vm.timeline,\n\t \"timeline-name\": 'tag',\n\t \"tag\": _vm.tag\n\t }\n\t })\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 685 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"panel panel-default\"\n\t }, [_c('div', {\n\t staticClass: \"panel-heading\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('who_to_follow.who_to_follow')) + \"\\n \")]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"panel-body\"\n\t }, _vm._l((_vm.users), function(user) {\n\t return _c('FollowCard', {\n\t key: user.id,\n\t attrs: {\n\t \"user\": user\n\t }\n\t })\n\t }), 1)])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 686 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return (_vm.loggedIn) ? _c('div', [(_vm.visibility !== 'private' && _vm.visibility !== 'direct') ? [_c('i', {\n\t staticClass: \"button-icon retweet-button icon-retweet rt-active\",\n\t class: _vm.classes,\n\t attrs: {\n\t \"title\": _vm.$t('tool_tip.repeat')\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t _vm.retweet()\n\t }\n\t }\n\t }), _vm._v(\" \"), (!_vm.hidePostStatsLocal && _vm.status.repeat_num > 0) ? _c('span', [_vm._v(_vm._s(_vm.status.repeat_num))]) : _vm._e()] : [_c('i', {\n\t staticClass: \"button-icon icon-lock\",\n\t class: _vm.classes,\n\t attrs: {\n\t \"title\": _vm.$t('timeline.no_retweet_hint')\n\t }\n\t })]], 2) : (!_vm.loggedIn) ? _c('div', [_c('i', {\n\t staticClass: \"button-icon icon-retweet\",\n\t class: _vm.classes,\n\t attrs: {\n\t \"title\": _vm.$t('tool_tip.repeat')\n\t }\n\t }), _vm._v(\" \"), (!_vm.hidePostStatsLocal && _vm.status.repeat_num > 0) ? _c('span', [_vm._v(_vm._s(_vm.status.repeat_num))]) : _vm._e()]) : _vm._e()\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 687 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', [_c('div', {\n\t staticClass: \"panel panel-default\"\n\t }, [_c('div', {\n\t staticClass: \"panel-body\"\n\t }, [_c('div', {\n\t staticClass: \"tos-content\",\n\t domProps: {\n\t \"innerHTML\": _vm._s(_vm.content)\n\t }\n\t })])])])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 688 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return (_vm.contrast) ? _c('span', {\n\t staticClass: \"contrast-ratio\"\n\t }, [_c('span', {\n\t staticClass: \"rating\",\n\t attrs: {\n\t \"title\": _vm.hint\n\t }\n\t }, [(_vm.contrast.aaa) ? _c('span', [_c('i', {\n\t staticClass: \"icon-thumbs-up-alt\"\n\t })]) : _vm._e(), _vm._v(\" \"), (!_vm.contrast.aaa && _vm.contrast.aa) ? _c('span', [_c('i', {\n\t staticClass: \"icon-adjust\"\n\t })]) : _vm._e(), _vm._v(\" \"), (!_vm.contrast.aaa && !_vm.contrast.aa) ? _c('span', [_c('i', {\n\t staticClass: \"icon-attention\"\n\t })]) : _vm._e()]), _vm._v(\" \"), (_vm.contrast && _vm.large) ? _c('span', {\n\t staticClass: \"rating\",\n\t attrs: {\n\t \"title\": _vm.hint_18pt\n\t }\n\t }, [(_vm.contrast.laaa) ? _c('span', [_c('i', {\n\t staticClass: \"icon-thumbs-up-alt\"\n\t })]) : _vm._e(), _vm._v(\" \"), (!_vm.contrast.laaa && _vm.contrast.laa) ? _c('span', [_c('i', {\n\t staticClass: \"icon-adjust\"\n\t })]) : _vm._e(), _vm._v(\" \"), (!_vm.contrast.laaa && !_vm.contrast.laa) ? _c('span', [_c('i', {\n\t staticClass: \"icon-attention\"\n\t })]) : _vm._e()]) : _vm._e()]) : _vm._e()\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 689 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('basic-user-card', {\n\t attrs: {\n\t \"user\": _vm.user\n\t }\n\t }, [_c('div', {\n\t staticClass: \"follow-card-content-container\"\n\t }, [(!_vm.noFollowsYou && _vm.user.follows_you) ? _c('span', {\n\t staticClass: \"faint\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.isMe ? _vm.$t('user_card.its_you') : _vm.$t('user_card.follows_you')) + \"\\n \")]) : _vm._e(), _vm._v(\" \"), (_vm.showFollow) ? _c('button', {\n\t staticClass: \"btn btn-default\",\n\t attrs: {\n\t \"disabled\": _vm.inProgress,\n\t \"title\": _vm.requestSent ? _vm.$t('user_card.follow_again') : ''\n\t },\n\t on: {\n\t \"click\": _vm.followUser\n\t }\n\t }, [(_vm.inProgress) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follow_progress')) + \"\\n \")] : (_vm.requestSent) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follow_sent')) + \"\\n \")] : [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follow')) + \"\\n \")]], 2) : _vm._e(), _vm._v(\" \"), (_vm.following) ? _c('button', {\n\t staticClass: \"btn btn-default pressed\",\n\t attrs: {\n\t \"disabled\": _vm.inProgress\n\t },\n\t on: {\n\t \"click\": _vm.unfollowUser\n\t }\n\t }, [(_vm.inProgress) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follow_progress')) + \"\\n \")] : [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follow_unfollow')) + \"\\n \")]], 2) : _vm._e()])])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 690 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('basic-user-card', {\n\t attrs: {\n\t \"user\": _vm.user\n\t }\n\t }, [_c('template', {\n\t slot: \"secondary-area\"\n\t }, [(_vm.muted) ? _c('button', {\n\t staticClass: \"btn btn-default\",\n\t attrs: {\n\t \"disabled\": _vm.progress\n\t },\n\t on: {\n\t \"click\": _vm.unmuteUser\n\t }\n\t }, [(_vm.progress) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.unmute_progress')) + \"\\n \")] : [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.unmute')) + \"\\n \")]], 2) : _c('button', {\n\t staticClass: \"btn btn-default\",\n\t attrs: {\n\t \"disabled\": _vm.progress\n\t },\n\t on: {\n\t \"click\": _vm.muteUser\n\t }\n\t }, [(_vm.progress) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.mute_progress')) + \"\\n \")] : [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.mute')) + \"\\n \")]], 2)])], 2)\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 691 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('Timeline', {\n\t attrs: {\n\t \"title\": _vm.$t('nav.mentions'),\n\t \"timeline\": _vm.timeline,\n\t \"timeline-name\": 'mentions'\n\t }\n\t })\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 692 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('Timeline', {\n\t attrs: {\n\t \"title\": _vm.$t('nav.twkn'),\n\t \"timeline\": _vm.timeline,\n\t \"timeline-name\": 'publicAndExternal'\n\t }\n\t })\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 693 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return (!this.collapsed || !this.floating) ? _c('div', {\n\t staticClass: \"chat-panel\"\n\t }, [_c('div', {\n\t staticClass: \"panel panel-default\"\n\t }, [_c('div', {\n\t staticClass: \"panel-heading timeline-heading\",\n\t class: {\n\t 'chat-heading': _vm.floating\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.stopPropagation();\n\t $event.preventDefault();\n\t return _vm.togglePanel($event)\n\t }\n\t }\n\t }, [_c('div', {\n\t staticClass: \"title\"\n\t }, [_c('span', [_vm._v(_vm._s(_vm.$t('chat.title')))]), _vm._v(\" \"), (_vm.floating) ? _c('i', {\n\t staticClass: \"icon-cancel\"\n\t }) : _vm._e()])]), _vm._v(\" \"), _c('div', {\n\t directives: [{\n\t name: \"chat-scroll\",\n\t rawName: \"v-chat-scroll\"\n\t }],\n\t staticClass: \"chat-window\"\n\t }, _vm._l((_vm.messages), function(message) {\n\t return _c('div', {\n\t key: message.id,\n\t staticClass: \"chat-message\"\n\t }, [_c('span', {\n\t staticClass: \"chat-avatar\"\n\t }, [_c('img', {\n\t attrs: {\n\t \"src\": message.author.avatar\n\t }\n\t })]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"chat-content\"\n\t }, [_c('router-link', {\n\t staticClass: \"chat-name\",\n\t attrs: {\n\t \"to\": _vm.userProfileLink(message.author)\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(message.author.username) + \"\\n \")]), _vm._v(\" \"), _c('br'), _vm._v(\" \"), _c('span', {\n\t staticClass: \"chat-text\"\n\t }, [_vm._v(\"\\n \" + _vm._s(message.text) + \"\\n \")])], 1)])\n\t }), 0), _vm._v(\" \"), _c('div', {\n\t staticClass: \"chat-input\"\n\t }, [_c('textarea', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.currentMessage),\n\t expression: \"currentMessage\"\n\t }],\n\t staticClass: \"chat-input-textarea\",\n\t attrs: {\n\t \"rows\": \"1\"\n\t },\n\t domProps: {\n\t \"value\": (_vm.currentMessage)\n\t },\n\t on: {\n\t \"keyup\": function($event) {\n\t if (!('button' in $event) && _vm._k($event.keyCode, \"enter\", 13, $event.key, \"Enter\")) { return null; }\n\t _vm.submit(_vm.currentMessage)\n\t },\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.currentMessage = $event.target.value\n\t }\n\t }\n\t })])])]) : _c('div', {\n\t staticClass: \"chat-panel\"\n\t }, [_c('div', {\n\t staticClass: \"panel panel-default\"\n\t }, [_c('div', {\n\t staticClass: \"panel-heading stub timeline-heading chat-heading\",\n\t on: {\n\t \"click\": function($event) {\n\t $event.stopPropagation();\n\t $event.preventDefault();\n\t return _vm.togglePanel($event)\n\t }\n\t }\n\t }, [_c('div', {\n\t staticClass: \"title\"\n\t }, [_c('i', {\n\t staticClass: \"icon-comment-empty\"\n\t }), _vm._v(\"\\n \" + _vm._s(_vm.$t('chat.title')) + \"\\n \")])])])])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 694 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('basic-user-card', {\n\t attrs: {\n\t \"user\": _vm.user\n\t }\n\t }, [_c('div', {\n\t staticClass: \"follow-request-card-content-container\"\n\t }, [_c('button', {\n\t staticClass: \"btn btn-default\",\n\t on: {\n\t \"click\": _vm.approveUser\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('user_card.approve')))]), _vm._v(\" \"), _c('button', {\n\t staticClass: \"btn btn-default\",\n\t on: {\n\t \"click\": _vm.denyUser\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('user_card.deny')))])])])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 695 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', [_c('label', {\n\t attrs: {\n\t \"for\": \"interface-language-switcher\"\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.interfaceLanguage')) + \"\\n \")]), _vm._v(\" \"), _c('label', {\n\t staticClass: \"select\",\n\t attrs: {\n\t \"for\": \"interface-language-switcher\"\n\t }\n\t }, [_c('select', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.language),\n\t expression: \"language\"\n\t }],\n\t attrs: {\n\t \"id\": \"interface-language-switcher\"\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n\t return o.selected\n\t }).map(function(o) {\n\t var val = \"_value\" in o ? o._value : o.value;\n\t return val\n\t });\n\t _vm.language = $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n\t }\n\t }\n\t }, _vm._l((_vm.languageCodes), function(langCode, i) {\n\t return _c('option', {\n\t domProps: {\n\t \"value\": langCode\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.languageNames[i]) + \"\\n \")])\n\t }), 0), _vm._v(\" \"), _c('i', {\n\t staticClass: \"icon-down-open\"\n\t })])])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 696 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', [_c('div', {\n\t staticClass: \"user-finder-container\"\n\t }, [(_vm.loading) ? _c('i', {\n\t staticClass: \"icon-spin4 user-finder-icon animate-spin-slow\"\n\t }) : _vm._e(), _vm._v(\" \"), (_vm.hidden) ? _c('a', {\n\t attrs: {\n\t \"href\": \"#\",\n\t \"title\": _vm.$t('finder.find_user')\n\t }\n\t }, [_c('i', {\n\t staticClass: \"icon-user-plus user-finder-icon\",\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t $event.stopPropagation();\n\t return _vm.toggleHidden($event)\n\t }\n\t }\n\t })]) : [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.username),\n\t expression: \"username\"\n\t }],\n\t ref: \"userSearchInput\",\n\t staticClass: \"user-finder-input\",\n\t attrs: {\n\t \"placeholder\": _vm.$t('finder.find_user'),\n\t \"id\": \"user-finder-input\",\n\t \"type\": \"text\"\n\t },\n\t domProps: {\n\t \"value\": (_vm.username)\n\t },\n\t on: {\n\t \"keyup\": function($event) {\n\t if (!('button' in $event) && _vm._k($event.keyCode, \"enter\", 13, $event.key, \"Enter\")) { return null; }\n\t _vm.findUser(_vm.username)\n\t },\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.username = $event.target.value\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('button', {\n\t staticClass: \"btn search-button\",\n\t on: {\n\t \"click\": function($event) {\n\t _vm.findUser(_vm.username)\n\t }\n\t }\n\t }, [_c('i', {\n\t staticClass: \"icon-search\"\n\t })]), _vm._v(\" \"), _c('i', {\n\t staticClass: \"button-icon icon-cancel user-finder-icon\",\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t $event.stopPropagation();\n\t return _vm.toggleHidden($event)\n\t }\n\t }\n\t })]], 2)])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 697 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('h1', [_vm._v(\"...\")])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 698 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', [(_vm.expanded) ? _c('conversation', {\n\t attrs: {\n\t \"collapsable\": true,\n\t \"statusoid\": _vm.statusoid\n\t },\n\t on: {\n\t \"toggleExpanded\": _vm.toggleExpanded\n\t }\n\t }) : _vm._e(), _vm._v(\" \"), (!_vm.expanded) ? _c('status', {\n\t attrs: {\n\t \"expandable\": true,\n\t \"inConversation\": false,\n\t \"focused\": false,\n\t \"statusoid\": _vm.statusoid\n\t },\n\t on: {\n\t \"toggleExpanded\": _vm.toggleExpanded\n\t }\n\t }) : _vm._e()], 1)\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 699 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"login panel panel-default\"\n\t }, [_c('div', {\n\t staticClass: \"panel-heading\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('login.login')) + \"\\n \")]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"panel-body\"\n\t }, [(_vm.loginMethod == 'password') ? _c('form', {\n\t staticClass: \"login-form\",\n\t on: {\n\t \"submit\": function($event) {\n\t $event.preventDefault();\n\t _vm.submit(_vm.user)\n\t }\n\t }\n\t }, [_c('div', {\n\t staticClass: \"form-group\"\n\t }, [_c('label', {\n\t attrs: {\n\t \"for\": \"username\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('login.username')))]), _vm._v(\" \"), _c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.user.username),\n\t expression: \"user.username\"\n\t }],\n\t staticClass: \"form-control\",\n\t attrs: {\n\t \"disabled\": _vm.loggingIn,\n\t \"id\": \"username\",\n\t \"placeholder\": _vm.$t('login.placeholder')\n\t },\n\t domProps: {\n\t \"value\": (_vm.user.username)\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.$set(_vm.user, \"username\", $event.target.value)\n\t }\n\t }\n\t })]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"form-group\"\n\t }, [_c('label', {\n\t attrs: {\n\t \"for\": \"password\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('login.password')))]), _vm._v(\" \"), _c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.user.password),\n\t expression: \"user.password\"\n\t }],\n\t staticClass: \"form-control\",\n\t attrs: {\n\t \"disabled\": _vm.loggingIn,\n\t \"id\": \"password\",\n\t \"type\": \"password\"\n\t },\n\t domProps: {\n\t \"value\": (_vm.user.password)\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.$set(_vm.user, \"password\", $event.target.value)\n\t }\n\t }\n\t })]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"form-group\"\n\t }, [_c('div', {\n\t staticClass: \"login-bottom\"\n\t }, [_c('div', [(_vm.registrationOpen) ? _c('router-link', {\n\t staticClass: \"register\",\n\t attrs: {\n\t \"to\": {\n\t name: 'registration'\n\t }\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('login.register')))]) : _vm._e()], 1), _vm._v(\" \"), _c('button', {\n\t staticClass: \"btn btn-default\",\n\t attrs: {\n\t \"disabled\": _vm.loggingIn,\n\t \"type\": \"submit\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('login.login')))])])])]) : _vm._e(), _vm._v(\" \"), (_vm.loginMethod == 'token') ? _c('form', {\n\t staticClass: \"login-form\",\n\t on: {\n\t \"submit\": function($event) {\n\t $event.preventDefault();\n\t return _vm.oAuthLogin($event)\n\t }\n\t }\n\t }, [_c('div', {\n\t staticClass: \"form-group\"\n\t }, [_c('p', [_vm._v(_vm._s(_vm.$t('login.description')))])]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"form-group\"\n\t }, [_c('div', {\n\t staticClass: \"login-bottom\"\n\t }, [_c('div', [(_vm.registrationOpen) ? _c('router-link', {\n\t staticClass: \"register\",\n\t attrs: {\n\t \"to\": {\n\t name: 'registration'\n\t }\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('login.register')))]) : _vm._e()], 1), _vm._v(\" \"), _c('button', {\n\t staticClass: \"btn btn-default\",\n\t attrs: {\n\t \"disabled\": _vm.loggingIn,\n\t \"type\": \"submit\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('login.login')))])])])]) : _vm._e(), _vm._v(\" \"), (_vm.authError) ? _c('div', {\n\t staticClass: \"form-group\"\n\t }, [_c('div', {\n\t staticClass: \"alert error\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.authError) + \"\\n \"), _c('i', {\n\t staticClass: \"button-icon icon-cancel\",\n\t on: {\n\t \"click\": _vm.clearError\n\t }\n\t })])]) : _vm._e()])])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 700 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"settings panel panel-default\"\n\t }, [_c('div', {\n\t staticClass: \"panel-heading\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('registration.registration')) + \"\\n \")]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"panel-body\"\n\t }, [_c('form', {\n\t staticClass: \"registration-form\",\n\t on: {\n\t \"submit\": function($event) {\n\t $event.preventDefault();\n\t _vm.submit(_vm.user)\n\t }\n\t }\n\t }, [_c('div', {\n\t staticClass: \"container\"\n\t }, [_c('div', {\n\t staticClass: \"text-fields\"\n\t }, [_c('div', {\n\t staticClass: \"form-group\",\n\t class: {\n\t 'form-group--error': _vm.$v.user.username.$error\n\t }\n\t }, [_c('label', {\n\t staticClass: \"form--label\",\n\t attrs: {\n\t \"for\": \"sign-up-username\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('login.username')))]), _vm._v(\" \"), _c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model.trim\",\n\t value: (_vm.$v.user.username.$model),\n\t expression: \"$v.user.username.$model\",\n\t modifiers: {\n\t \"trim\": true\n\t }\n\t }],\n\t staticClass: \"form-control\",\n\t attrs: {\n\t \"disabled\": _vm.isPending,\n\t \"id\": \"sign-up-username\",\n\t \"placeholder\": _vm.$t('registration.username_placeholder')\n\t },\n\t domProps: {\n\t \"value\": (_vm.$v.user.username.$model)\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.$set(_vm.$v.user.username, \"$model\", $event.target.value.trim())\n\t },\n\t \"blur\": function($event) {\n\t _vm.$forceUpdate()\n\t }\n\t }\n\t })]), _vm._v(\" \"), (_vm.$v.user.username.$dirty) ? _c('div', {\n\t staticClass: \"form-error\"\n\t }, [_c('ul', [(!_vm.$v.user.username.required) ? _c('li', [_c('span', [_vm._v(_vm._s(_vm.$t('registration.validations.username_required')))])]) : _vm._e()])]) : _vm._e(), _vm._v(\" \"), _c('div', {\n\t staticClass: \"form-group\",\n\t class: {\n\t 'form-group--error': _vm.$v.user.fullname.$error\n\t }\n\t }, [_c('label', {\n\t staticClass: \"form--label\",\n\t attrs: {\n\t \"for\": \"sign-up-fullname\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('registration.fullname')))]), _vm._v(\" \"), _c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model.trim\",\n\t value: (_vm.$v.user.fullname.$model),\n\t expression: \"$v.user.fullname.$model\",\n\t modifiers: {\n\t \"trim\": true\n\t }\n\t }],\n\t staticClass: \"form-control\",\n\t attrs: {\n\t \"disabled\": _vm.isPending,\n\t \"id\": \"sign-up-fullname\",\n\t \"placeholder\": _vm.$t('registration.fullname_placeholder')\n\t },\n\t domProps: {\n\t \"value\": (_vm.$v.user.fullname.$model)\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.$set(_vm.$v.user.fullname, \"$model\", $event.target.value.trim())\n\t },\n\t \"blur\": function($event) {\n\t _vm.$forceUpdate()\n\t }\n\t }\n\t })]), _vm._v(\" \"), (_vm.$v.user.fullname.$dirty) ? _c('div', {\n\t staticClass: \"form-error\"\n\t }, [_c('ul', [(!_vm.$v.user.fullname.required) ? _c('li', [_c('span', [_vm._v(_vm._s(_vm.$t('registration.validations.fullname_required')))])]) : _vm._e()])]) : _vm._e(), _vm._v(\" \"), _c('div', {\n\t staticClass: \"form-group\",\n\t class: {\n\t 'form-group--error': _vm.$v.user.email.$error\n\t }\n\t }, [_c('label', {\n\t staticClass: \"form--label\",\n\t attrs: {\n\t \"for\": \"email\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('registration.email')))]), _vm._v(\" \"), _c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.$v.user.email.$model),\n\t expression: \"$v.user.email.$model\"\n\t }],\n\t staticClass: \"form-control\",\n\t attrs: {\n\t \"disabled\": _vm.isPending,\n\t \"id\": \"email\",\n\t \"type\": \"email\"\n\t },\n\t domProps: {\n\t \"value\": (_vm.$v.user.email.$model)\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.$set(_vm.$v.user.email, \"$model\", $event.target.value)\n\t }\n\t }\n\t })]), _vm._v(\" \"), (_vm.$v.user.email.$dirty) ? _c('div', {\n\t staticClass: \"form-error\"\n\t }, [_c('ul', [(!_vm.$v.user.email.required) ? _c('li', [_c('span', [_vm._v(_vm._s(_vm.$t('registration.validations.email_required')))])]) : _vm._e()])]) : _vm._e(), _vm._v(\" \"), _c('div', {\n\t staticClass: \"form-group\"\n\t }, [_c('label', {\n\t staticClass: \"form--label\",\n\t attrs: {\n\t \"for\": \"bio\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('registration.bio')) + \" (\" + _vm._s(_vm.$t('general.optional')) + \")\")]), _vm._v(\" \"), _c('textarea', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.user.bio),\n\t expression: \"user.bio\"\n\t }],\n\t staticClass: \"form-control\",\n\t attrs: {\n\t \"disabled\": _vm.isPending,\n\t \"id\": \"bio\",\n\t \"placeholder\": _vm.$t('registration.bio_placeholder')\n\t },\n\t domProps: {\n\t \"value\": (_vm.user.bio)\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.$set(_vm.user, \"bio\", $event.target.value)\n\t }\n\t }\n\t })]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"form-group\",\n\t class: {\n\t 'form-group--error': _vm.$v.user.password.$error\n\t }\n\t }, [_c('label', {\n\t staticClass: \"form--label\",\n\t attrs: {\n\t \"for\": \"sign-up-password\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('login.password')))]), _vm._v(\" \"), _c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.user.password),\n\t expression: \"user.password\"\n\t }],\n\t staticClass: \"form-control\",\n\t attrs: {\n\t \"disabled\": _vm.isPending,\n\t \"id\": \"sign-up-password\",\n\t \"type\": \"password\"\n\t },\n\t domProps: {\n\t \"value\": (_vm.user.password)\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.$set(_vm.user, \"password\", $event.target.value)\n\t }\n\t }\n\t })]), _vm._v(\" \"), (_vm.$v.user.password.$dirty) ? _c('div', {\n\t staticClass: \"form-error\"\n\t }, [_c('ul', [(!_vm.$v.user.password.required) ? _c('li', [_c('span', [_vm._v(_vm._s(_vm.$t('registration.validations.password_required')))])]) : _vm._e()])]) : _vm._e(), _vm._v(\" \"), _c('div', {\n\t staticClass: \"form-group\",\n\t class: {\n\t 'form-group--error': _vm.$v.user.confirm.$error\n\t }\n\t }, [_c('label', {\n\t staticClass: \"form--label\",\n\t attrs: {\n\t \"for\": \"sign-up-password-confirmation\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('registration.password_confirm')))]), _vm._v(\" \"), _c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.user.confirm),\n\t expression: \"user.confirm\"\n\t }],\n\t staticClass: \"form-control\",\n\t attrs: {\n\t \"disabled\": _vm.isPending,\n\t \"id\": \"sign-up-password-confirmation\",\n\t \"type\": \"password\"\n\t },\n\t domProps: {\n\t \"value\": (_vm.user.confirm)\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.$set(_vm.user, \"confirm\", $event.target.value)\n\t }\n\t }\n\t })]), _vm._v(\" \"), (_vm.$v.user.confirm.$dirty) ? _c('div', {\n\t staticClass: \"form-error\"\n\t }, [_c('ul', [(!_vm.$v.user.confirm.required) ? _c('li', [_c('span', [_vm._v(_vm._s(_vm.$t('registration.validations.password_confirmation_required')))])]) : _vm._e(), _vm._v(\" \"), (!_vm.$v.user.confirm.sameAsPassword) ? _c('li', [_c('span', [_vm._v(_vm._s(_vm.$t('registration.validations.password_confirmation_match')))])]) : _vm._e()])]) : _vm._e(), _vm._v(\" \"), (_vm.captcha.type != 'none') ? _c('div', {\n\t staticClass: \"form-group\",\n\t attrs: {\n\t \"id\": \"captcha-group\"\n\t }\n\t }, [_c('label', {\n\t staticClass: \"form--label\",\n\t attrs: {\n\t \"for\": \"captcha-label\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('captcha')))]), _vm._v(\" \"), (_vm.captcha.type == 'kocaptcha') ? [_c('img', {\n\t attrs: {\n\t \"src\": _vm.captcha.url\n\t },\n\t on: {\n\t \"click\": _vm.setCaptcha\n\t }\n\t }), _vm._v(\" \"), _c('sub', [_vm._v(_vm._s(_vm.$t('registration.new_captcha')))]), _vm._v(\" \"), _c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.captcha.solution),\n\t expression: \"captcha.solution\"\n\t }],\n\t staticClass: \"form-control\",\n\t attrs: {\n\t \"disabled\": _vm.isPending,\n\t \"id\": \"captcha-answer\",\n\t \"type\": \"text\",\n\t \"autocomplete\": \"off\"\n\t },\n\t domProps: {\n\t \"value\": (_vm.captcha.solution)\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.$set(_vm.captcha, \"solution\", $event.target.value)\n\t }\n\t }\n\t })] : _vm._e()], 2) : _vm._e(), _vm._v(\" \"), (_vm.token) ? _c('div', {\n\t staticClass: \"form-group\"\n\t }, [_c('label', {\n\t attrs: {\n\t \"for\": \"token\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('registration.token')))]), _vm._v(\" \"), _c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.token),\n\t expression: \"token\"\n\t }],\n\t staticClass: \"form-control\",\n\t attrs: {\n\t \"disabled\": \"true\",\n\t \"id\": \"token\",\n\t \"type\": \"text\"\n\t },\n\t domProps: {\n\t \"value\": (_vm.token)\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.token = $event.target.value\n\t }\n\t }\n\t })]) : _vm._e(), _vm._v(\" \"), _c('div', {\n\t staticClass: \"form-group\"\n\t }, [_c('button', {\n\t staticClass: \"btn btn-default\",\n\t attrs: {\n\t \"disabled\": _vm.isPending,\n\t \"type\": \"submit\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('general.submit')))])])]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"terms-of-service\",\n\t domProps: {\n\t \"innerHTML\": _vm._s(_vm.termsOfService)\n\t }\n\t })]), _vm._v(\" \"), (_vm.serverValidationErrors.length) ? _c('div', {\n\t staticClass: \"form-group\"\n\t }, [_c('div', {\n\t staticClass: \"alert error\"\n\t }, _vm._l((_vm.serverValidationErrors), function(error) {\n\t return _c('span', [_vm._v(_vm._s(error))])\n\t }), 0)]) : _vm._e()])])])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 701 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"features-panel\"\n\t }, [_c('div', {\n\t staticClass: \"panel panel-default base01-background\"\n\t }, [_c('div', {\n\t staticClass: \"panel-heading timeline-heading base02-background base04\"\n\t }, [_c('div', {\n\t staticClass: \"title\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('features_panel.title')) + \"\\n \")])]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"panel-body features-panel\"\n\t }, [_c('ul', [(_vm.chat) ? _c('li', [_vm._v(_vm._s(_vm.$t('features_panel.chat')))]) : _vm._e(), _vm._v(\" \"), (_vm.gopher) ? _c('li', [_vm._v(_vm._s(_vm.$t('features_panel.gopher')))]) : _vm._e(), _vm._v(\" \"), (_vm.whoToFollow) ? _c('li', [_vm._v(_vm._s(_vm.$t('features_panel.who_to_follow')))]) : _vm._e(), _vm._v(\" \"), (_vm.mediaProxy) ? _c('li', [_vm._v(_vm._s(_vm.$t('features_panel.media_proxy')))]) : _vm._e(), _vm._v(\" \"), (_vm.scopeOptions) ? _c('li', [_vm._v(_vm._s(_vm.$t('features_panel.scope_options')))]) : _vm._e(), _vm._v(\" \"), _c('li', [_vm._v(_vm._s(_vm.$t('features_panel.text_limit')) + \" = \" + _vm._s(_vm.textlimit))])])])])])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 702 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', [(_vm.user.id) ? _c('div', {\n\t staticClass: \"user-profile panel panel-default\"\n\t }, [_c('UserCard', {\n\t attrs: {\n\t \"user\": _vm.user,\n\t \"switcher\": true,\n\t \"selected\": _vm.timeline.viewing,\n\t \"rounded\": \"top\"\n\t }\n\t }), _vm._v(\" \"), _c('tab-switcher', {\n\t ref: \"tabSwitcher\",\n\t attrs: {\n\t \"renderOnlyFocused\": true\n\t }\n\t }, [_c('Timeline', {\n\t attrs: {\n\t \"label\": _vm.$t('user_card.statuses'),\n\t \"disabled\": !_vm.user.statuses_count,\n\t \"count\": _vm.user.statuses_count,\n\t \"embedded\": true,\n\t \"title\": _vm.$t('user_profile.timeline_title'),\n\t \"timeline\": _vm.timeline,\n\t \"timeline-name\": 'user',\n\t \"user-id\": _vm.fetchBy\n\t }\n\t }), _vm._v(\" \"), (_vm.followsTabVisible) ? _c('div', {\n\t attrs: {\n\t \"label\": _vm.$t('user_card.followees'),\n\t \"disabled\": !_vm.user.friends_count\n\t }\n\t }, [_c('FriendList', {\n\t attrs: {\n\t \"userId\": _vm.userId\n\t }\n\t })], 1) : _vm._e(), _vm._v(\" \"), (_vm.followersTabVisible) ? _c('div', {\n\t attrs: {\n\t \"label\": _vm.$t('user_card.followers'),\n\t \"disabled\": !_vm.user.followers_count\n\t }\n\t }, [_c('FollowerList', {\n\t attrs: {\n\t \"userId\": _vm.userId,\n\t \"entryProps\": {\n\t noFollowsYou: _vm.isUs\n\t }\n\t }\n\t })], 1) : _vm._e(), _vm._v(\" \"), _c('Timeline', {\n\t attrs: {\n\t \"label\": _vm.$t('user_card.media'),\n\t \"disabled\": !_vm.media.visibleStatuses.length,\n\t \"embedded\": true,\n\t \"title\": _vm.$t('user_card.media'),\n\t \"timeline-name\": \"media\",\n\t \"timeline\": _vm.media,\n\t \"user-id\": _vm.fetchBy\n\t }\n\t }), _vm._v(\" \"), (_vm.isUs) ? _c('Timeline', {\n\t attrs: {\n\t \"label\": _vm.$t('user_card.favorites'),\n\t \"disabled\": !_vm.favorites.visibleStatuses.length,\n\t \"embedded\": true,\n\t \"title\": _vm.$t('user_card.favorites'),\n\t \"timeline-name\": \"favorites\",\n\t \"timeline\": _vm.favorites\n\t }\n\t }) : _vm._e()], 1)], 1) : _c('div', {\n\t staticClass: \"panel user-profile-placeholder\"\n\t }, [_c('div', {\n\t staticClass: \"panel-heading\"\n\t }, [_c('div', {\n\t staticClass: \"title\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.profile_tab')) + \"\\n \")])]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"panel-body\"\n\t }, [(_vm.error) ? _c('span', [_vm._v(_vm._s(_vm.error))]) : _c('i', {\n\t staticClass: \"icon-spin3 animate-spin\"\n\t })])])])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 703 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return (_vm.usePlaceHolder) ? _c('div', {\n\t on: {\n\t \"click\": _vm.openModal\n\t }\n\t }, [(_vm.type !== 'html') ? _c('a', {\n\t staticClass: \"placeholder\",\n\t attrs: {\n\t \"target\": \"_blank\",\n\t \"href\": _vm.attachment.url\n\t }\n\t }, [_vm._v(\"\\n [\" + _vm._s(_vm.nsfw ? \"NSFW/\" : \"\") + _vm._s(_vm.type.toUpperCase()) + \"]\\n \")]) : _vm._e()]) : _c('div', {\n\t directives: [{\n\t name: \"show\",\n\t rawName: \"v-show\",\n\t value: (!_vm.isEmpty),\n\t expression: \"!isEmpty\"\n\t }],\n\t staticClass: \"attachment\",\n\t class: ( _obj = {\n\t loading: _vm.loading,\n\t 'fullwidth': _vm.fullwidth,\n\t 'nsfw-placeholder': _vm.hidden\n\t }, _obj[_vm.type] = true, _obj )\n\t }, [(_vm.hidden) ? _c('a', {\n\t staticClass: \"image-attachment\",\n\t attrs: {\n\t \"href\": _vm.attachment.url\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t return _vm.toggleHidden($event)\n\t }\n\t }\n\t }, [_c('img', {\n\t key: _vm.nsfwImage,\n\t staticClass: \"nsfw\",\n\t class: {\n\t 'small': _vm.isSmall\n\t },\n\t attrs: {\n\t \"src\": _vm.nsfwImage\n\t }\n\t }), _vm._v(\" \"), (_vm.type === 'video') ? _c('i', {\n\t staticClass: \"play-icon icon-play-circled\"\n\t }) : _vm._e()]) : _vm._e(), _vm._v(\" \"), (_vm.nsfw && _vm.hideNsfwLocal && !_vm.hidden) ? _c('div', {\n\t staticClass: \"hider\"\n\t }, [_c('a', {\n\t attrs: {\n\t \"href\": \"#\"\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t return _vm.toggleHidden($event)\n\t }\n\t }\n\t }, [_vm._v(\"Hide\")])]) : _vm._e(), _vm._v(\" \"), (_vm.type === 'image' && (!_vm.hidden || _vm.preloadImage)) ? _c('a', {\n\t staticClass: \"image-attachment\",\n\t class: {\n\t 'hidden': _vm.hidden && _vm.preloadImage\n\t },\n\t attrs: {\n\t \"href\": _vm.attachment.url,\n\t \"target\": \"_blank\",\n\t \"title\": _vm.attachment.description\n\t },\n\t on: {\n\t \"click\": _vm.openModal\n\t }\n\t }, [_c('StillImage', {\n\t attrs: {\n\t \"referrerpolicy\": _vm.referrerpolicy,\n\t \"mimetype\": _vm.attachment.mimetype,\n\t \"src\": _vm.attachment.large_thumb_url || _vm.attachment.url\n\t }\n\t })], 1) : _vm._e(), _vm._v(\" \"), (_vm.type === 'video' && !_vm.hidden) ? _c('a', {\n\t staticClass: \"video-container\",\n\t class: {\n\t 'small': _vm.isSmall\n\t },\n\t attrs: {\n\t \"href\": _vm.allowPlay ? undefined : _vm.attachment.url\n\t },\n\t on: {\n\t \"click\": _vm.openModal\n\t }\n\t }, [_c('VideoAttachment', {\n\t staticClass: \"video\",\n\t attrs: {\n\t \"attachment\": _vm.attachment,\n\t \"controls\": _vm.allowPlay\n\t }\n\t }), _vm._v(\" \"), (!_vm.allowPlay) ? _c('i', {\n\t staticClass: \"play-icon icon-play-circled\"\n\t }) : _vm._e()], 1) : _vm._e(), _vm._v(\" \"), (_vm.type === 'audio') ? _c('audio', {\n\t attrs: {\n\t \"src\": _vm.attachment.url,\n\t \"controls\": \"\"\n\t }\n\t }) : _vm._e(), _vm._v(\" \"), (_vm.type === 'html' && _vm.attachment.oembed) ? _c('div', {\n\t staticClass: \"oembed\",\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t return _vm.linkClicked($event)\n\t }\n\t }\n\t }, [(_vm.attachment.thumb_url) ? _c('div', {\n\t staticClass: \"image\"\n\t }, [_c('img', {\n\t attrs: {\n\t \"src\": _vm.attachment.thumb_url\n\t }\n\t })]) : _vm._e(), _vm._v(\" \"), _c('div', {\n\t staticClass: \"text\"\n\t }, [_c('h1', [_c('a', {\n\t attrs: {\n\t \"href\": _vm.attachment.url\n\t }\n\t }, [_vm._v(_vm._s(_vm.attachment.oembed.title))])]), _vm._v(\" \"), _c('div', {\n\t domProps: {\n\t \"innerHTML\": _vm._s(_vm.attachment.oembed.oembedHTML)\n\t }\n\t })])]) : _vm._e()])\n\t var _obj;\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 704 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"font-control style-control\",\n\t class: {\n\t custom: _vm.isCustom\n\t }\n\t }, [_c('label', {\n\t staticClass: \"label\",\n\t attrs: {\n\t \"for\": _vm.preset === 'custom' ? _vm.name : _vm.name + '-font-switcher'\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.label) + \"\\n \")]), _vm._v(\" \"), (typeof _vm.fallback !== 'undefined') ? _c('input', {\n\t staticClass: \"opt exlcude-disabled\",\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": _vm.name + '-o'\n\t },\n\t domProps: {\n\t \"checked\": _vm.present\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t _vm.$emit('input', typeof _vm.value === 'undefined' ? _vm.fallback : undefined)\n\t }\n\t }\n\t }) : _vm._e(), _vm._v(\" \"), (typeof _vm.fallback !== 'undefined') ? _c('label', {\n\t staticClass: \"opt-l\",\n\t attrs: {\n\t \"for\": _vm.name + '-o'\n\t }\n\t }) : _vm._e(), _vm._v(\" \"), _c('label', {\n\t staticClass: \"select\",\n\t attrs: {\n\t \"for\": _vm.name + '-font-switcher',\n\t \"disabled\": !_vm.present\n\t }\n\t }, [_c('select', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.preset),\n\t expression: \"preset\"\n\t }],\n\t staticClass: \"font-switcher\",\n\t attrs: {\n\t \"disabled\": !_vm.present,\n\t \"id\": _vm.name + '-font-switcher'\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n\t return o.selected\n\t }).map(function(o) {\n\t var val = \"_value\" in o ? o._value : o.value;\n\t return val\n\t });\n\t _vm.preset = $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n\t }\n\t }\n\t }, _vm._l((_vm.availableOptions), function(option) {\n\t return _c('option', {\n\t domProps: {\n\t \"value\": option\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(option === 'custom' ? _vm.$t('settings.style.fonts.custom') : option) + \"\\n \")])\n\t }), 0), _vm._v(\" \"), _c('i', {\n\t staticClass: \"icon-down-open\"\n\t })]), _vm._v(\" \"), (_vm.isCustom) ? _c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.family),\n\t expression: \"family\"\n\t }],\n\t staticClass: \"custom-font\",\n\t attrs: {\n\t \"type\": \"text\",\n\t \"id\": _vm.name\n\t },\n\t domProps: {\n\t \"value\": (_vm.family)\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.family = $event.target.value\n\t }\n\t }\n\t }) : _vm._e()])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 705 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t style: (_vm.bgAppStyle),\n\t attrs: {\n\t \"id\": \"app\"\n\t }\n\t }, [_c('div', {\n\t staticClass: \"app-bg-wrapper\",\n\t style: (_vm.bgStyle)\n\t }), _vm._v(\" \"), _c('nav', {\n\t staticClass: \"nav-bar container\",\n\t attrs: {\n\t \"id\": \"nav\"\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t _vm.scrollToTop()\n\t }\n\t }\n\t }, [_c('div', {\n\t staticClass: \"logo\",\n\t style: (_vm.logoBgStyle)\n\t }, [_c('div', {\n\t staticClass: \"mask\",\n\t style: (_vm.logoMaskStyle)\n\t }), _vm._v(\" \"), _c('img', {\n\t style: (_vm.logoStyle),\n\t attrs: {\n\t \"src\": _vm.logo\n\t }\n\t })]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"inner-nav\"\n\t }, [_c('div', {\n\t staticClass: \"item\"\n\t }, [_c('a', {\n\t staticClass: \"menu-button\",\n\t attrs: {\n\t \"href\": \"#\"\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.stopPropagation();\n\t $event.preventDefault();\n\t _vm.toggleMobileSidebar()\n\t }\n\t }\n\t }, [_c('i', {\n\t staticClass: \"button-icon icon-menu\"\n\t }), _vm._v(\" \"), (_vm.unseenNotificationsCount) ? _c('div', {\n\t staticClass: \"alert-dot\"\n\t }) : _vm._e()]), _vm._v(\" \"), _c('router-link', {\n\t staticClass: \"site-name\",\n\t attrs: {\n\t \"to\": {\n\t name: 'root'\n\t },\n\t \"active-class\": \"home\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.sitename))])], 1), _vm._v(\" \"), _c('div', {\n\t staticClass: \"item right\"\n\t }, [_c('user-finder', {\n\t staticClass: \"button-icon nav-icon mobile-hidden\",\n\t on: {\n\t \"toggled\": _vm.onFinderToggled\n\t }\n\t }), _vm._v(\" \"), _c('router-link', {\n\t staticClass: \"mobile-hidden\",\n\t attrs: {\n\t \"to\": {\n\t name: 'settings'\n\t }\n\t }\n\t }, [_c('i', {\n\t staticClass: \"button-icon icon-cog nav-icon\",\n\t attrs: {\n\t \"title\": _vm.$t('nav.preferences')\n\t }\n\t })]), _vm._v(\" \"), (_vm.currentUser) ? _c('a', {\n\t staticClass: \"mobile-hidden\",\n\t attrs: {\n\t \"href\": \"#\"\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t return _vm.logout($event)\n\t }\n\t }\n\t }, [_c('i', {\n\t staticClass: \"button-icon icon-logout nav-icon\",\n\t attrs: {\n\t \"title\": _vm.$t('login.logout')\n\t }\n\t })]) : _vm._e()], 1)])]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"container\",\n\t attrs: {\n\t \"id\": \"content\"\n\t }\n\t }, [_c('side-drawer', {\n\t ref: \"sideDrawer\",\n\t attrs: {\n\t \"logout\": _vm.logout\n\t }\n\t }), _vm._v(\" \"), _c('div', {\n\t staticClass: \"sidebar-flexer mobile-hidden\"\n\t }, [_c('div', {\n\t staticClass: \"sidebar-bounds\"\n\t }, [_c('div', {\n\t staticClass: \"sidebar-scroller\"\n\t }, [_c('div', {\n\t staticClass: \"sidebar\"\n\t }, [_c('user-panel'), _vm._v(\" \"), _c('nav-panel'), _vm._v(\" \"), (_vm.showInstanceSpecificPanel) ? _c('instance-specific-panel') : _vm._e(), _vm._v(\" \"), (!_vm.currentUser && _vm.showFeaturesPanel) ? _c('features-panel') : _vm._e(), _vm._v(\" \"), (_vm.currentUser && _vm.suggestionsEnabled) ? _c('who-to-follow-panel') : _vm._e(), _vm._v(\" \"), (_vm.currentUser) ? _c('notifications') : _vm._e()], 1)])])]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"main\"\n\t }, [(!_vm.currentUser) ? _c('div', {\n\t staticClass: \"login-hint panel panel-default\"\n\t }, [_c('router-link', {\n\t staticClass: \"panel-body\",\n\t attrs: {\n\t \"to\": {\n\t name: 'login'\n\t }\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"login.hint\")) + \"\\n \")])], 1) : _vm._e(), _vm._v(\" \"), _c('transition', {\n\t attrs: {\n\t \"name\": \"fade\"\n\t }\n\t }, [_c('router-view')], 1)], 1), _vm._v(\" \"), _c('media-modal')], 1), _vm._v(\" \"), (_vm.currentUser && _vm.chat) ? _c('chat-panel', {\n\t staticClass: \"floating-chat mobile-hidden\",\n\t attrs: {\n\t \"floating\": true\n\t }\n\t }) : _vm._e(), _vm._v(\" \"), _c('MobilePostStatusModal')], 1)\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 706 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"opacity-control style-control\",\n\t class: {\n\t disabled: !_vm.present || _vm.disabled\n\t }\n\t }, [_c('label', {\n\t staticClass: \"label\",\n\t attrs: {\n\t \"for\": _vm.name\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.common.opacity')) + \"\\n \")]), _vm._v(\" \"), (typeof _vm.fallback !== 'undefined') ? _c('input', {\n\t staticClass: \"opt exclude-disabled\",\n\t attrs: {\n\t \"id\": _vm.name + '-o',\n\t \"type\": \"checkbox\"\n\t },\n\t domProps: {\n\t \"checked\": _vm.present\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t _vm.$emit('input', !_vm.present ? _vm.fallback : undefined)\n\t }\n\t }\n\t }) : _vm._e(), _vm._v(\" \"), (typeof _vm.fallback !== 'undefined') ? _c('label', {\n\t staticClass: \"opt-l\",\n\t attrs: {\n\t \"for\": _vm.name + '-o'\n\t }\n\t }) : _vm._e(), _vm._v(\" \"), _c('input', {\n\t staticClass: \"input-number\",\n\t attrs: {\n\t \"id\": _vm.name,\n\t \"type\": \"number\",\n\t \"disabled\": !_vm.present || _vm.disabled,\n\t \"max\": \"1\",\n\t \"min\": \"0\",\n\t \"step\": \".05\"\n\t },\n\t domProps: {\n\t \"value\": _vm.value || _vm.fallback\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t _vm.$emit('input', $event.target.value)\n\t }\n\t }\n\t })])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 707 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"sidebar\"\n\t }, [_c('instance-specific-panel'), _vm._v(\" \"), (_vm.showFeaturesPanel) ? _c('features-panel') : _vm._e(), _vm._v(\" \"), _c('terms-of-service-panel')], 1)\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 708 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('video', {\n\t staticClass: \"video\",\n\t attrs: {\n\t \"src\": _vm.attachment.url,\n\t \"loop\": _vm.loopVideo,\n\t \"controls\": _vm.controls,\n\t \"playsinline\": \"\"\n\t },\n\t on: {\n\t \"loadeddata\": _vm.onVideoDataLoad\n\t }\n\t })\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 709 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('basic-user-card', {\n\t attrs: {\n\t \"user\": _vm.user\n\t }\n\t }, [_c('div', {\n\t staticClass: \"block-card-content-container\"\n\t }, [(_vm.blocked) ? _c('button', {\n\t staticClass: \"btn btn-default\",\n\t attrs: {\n\t \"disabled\": _vm.progress\n\t },\n\t on: {\n\t \"click\": _vm.unblockUser\n\t }\n\t }, [(_vm.progress) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.unblock_progress')) + \"\\n \")] : [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.unblock')) + \"\\n \")]], 2) : _c('button', {\n\t staticClass: \"btn btn-default\",\n\t attrs: {\n\t \"disabled\": _vm.progress\n\t },\n\t on: {\n\t \"click\": _vm.blockUser\n\t }\n\t }, [(_vm.progress) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.block_progress')) + \"\\n \")] : [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.block')) + \"\\n \")]], 2)])])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 710 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"media-upload\",\n\t on: {\n\t \"drop\": [function($event) {\n\t $event.preventDefault();\n\t }, _vm.fileDrop],\n\t \"dragover\": function($event) {\n\t $event.preventDefault();\n\t return _vm.fileDrag($event)\n\t }\n\t }\n\t }, [_c('label', {\n\t staticClass: \"btn btn-default\",\n\t attrs: {\n\t \"title\": _vm.$t('tool_tip.media_upload')\n\t }\n\t }, [(_vm.uploading) ? _c('i', {\n\t staticClass: \"icon-spin4 animate-spin\"\n\t }) : _vm._e(), _vm._v(\" \"), (!_vm.uploading) ? _c('i', {\n\t staticClass: \"icon-upload\"\n\t }) : _vm._e(), _vm._v(\" \"), (_vm.uploadReady) ? _c('input', {\n\t staticStyle: {\n\t \"position\": \"fixed\",\n\t \"top\": \"-100em\"\n\t },\n\t attrs: {\n\t \"type\": \"file\",\n\t \"multiple\": \"true\"\n\t },\n\t on: {\n\t \"change\": _vm.change\n\t }\n\t }) : _vm._e()])])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 711 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return (_vm.showing) ? _c('div', {\n\t staticClass: \"modal-view media-modal-view\",\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t return _vm.hide($event)\n\t }\n\t }\n\t }, [(_vm.type === 'image') ? _c('img', {\n\t staticClass: \"modal-image\",\n\t attrs: {\n\t \"src\": _vm.currentMedia.url\n\t }\n\t }) : _vm._e(), _vm._v(\" \"), (_vm.type === 'video') ? _c('VideoAttachment', {\n\t staticClass: \"modal-image\",\n\t attrs: {\n\t \"attachment\": _vm.currentMedia,\n\t \"controls\": true\n\t },\n\t nativeOn: {\n\t \"click\": function($event) {\n\t $event.stopPropagation();\n\t }\n\t }\n\t }) : _vm._e(), _vm._v(\" \"), (_vm.canNavigate) ? _c('button', {\n\t staticClass: \"modal-view-button-arrow modal-view-button-arrow--prev\",\n\t attrs: {\n\t \"title\": _vm.$t('media_modal.previous')\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.stopPropagation();\n\t $event.preventDefault();\n\t return _vm.goPrev($event)\n\t }\n\t }\n\t }, [_c('i', {\n\t staticClass: \"icon-left-open arrow-icon\"\n\t })]) : _vm._e(), _vm._v(\" \"), (_vm.canNavigate) ? _c('button', {\n\t staticClass: \"modal-view-button-arrow modal-view-button-arrow--next\",\n\t attrs: {\n\t \"title\": _vm.$t('media_modal.next')\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.stopPropagation();\n\t $event.preventDefault();\n\t return _vm.goNext($event)\n\t }\n\t }\n\t }, [_c('i', {\n\t staticClass: \"icon-right-open arrow-icon\"\n\t })]) : _vm._e()], 1) : _vm._e()\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 712 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('Timeline', {\n\t attrs: {\n\t \"title\": _vm.$t('nav.dms'),\n\t \"timeline\": _vm.timeline,\n\t \"timeline-name\": 'dms'\n\t }\n\t })\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 713 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"user-search panel panel-default\"\n\t }, [_c('div', {\n\t staticClass: \"panel-heading\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('nav.user_search')) + \"\\n \")]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"user-search-input-container\"\n\t }, [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.username),\n\t expression: \"username\"\n\t }],\n\t ref: \"userSearchInput\",\n\t staticClass: \"user-finder-input\",\n\t attrs: {\n\t \"placeholder\": _vm.$t('finder.find_user')\n\t },\n\t domProps: {\n\t \"value\": (_vm.username)\n\t },\n\t on: {\n\t \"keyup\": function($event) {\n\t if (!('button' in $event) && _vm._k($event.keyCode, \"enter\", 13, $event.key, \"Enter\")) { return null; }\n\t _vm.newQuery(_vm.username)\n\t },\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.username = $event.target.value\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('button', {\n\t staticClass: \"btn search-button\",\n\t on: {\n\t \"click\": function($event) {\n\t _vm.newQuery(_vm.username)\n\t }\n\t }\n\t }, [_c('i', {\n\t staticClass: \"icon-search\"\n\t })])]), _vm._v(\" \"), (_vm.loading) ? _c('div', {\n\t staticClass: \"text-center loading-icon\"\n\t }, [_c('i', {\n\t staticClass: \"icon-spin3 animate-spin\"\n\t })]) : _c('div', {\n\t staticClass: \"panel-body\"\n\t }, _vm._l((_vm.users), function(user) {\n\t return _c('FollowCard', {\n\t key: user.id,\n\t attrs: {\n\t \"user\": user\n\t }\n\t })\n\t }), 1)])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 714 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('Timeline', {\n\t attrs: {\n\t \"title\": _vm.$t('nav.public_tl'),\n\t \"timeline\": _vm.timeline,\n\t \"timeline-name\": 'public'\n\t }\n\t })\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 715 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"range-control style-control\",\n\t class: {\n\t disabled: !_vm.present || _vm.disabled\n\t }\n\t }, [_c('label', {\n\t staticClass: \"label\",\n\t attrs: {\n\t \"for\": _vm.name\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.label) + \"\\n \")]), _vm._v(\" \"), (typeof _vm.fallback !== 'undefined') ? _c('input', {\n\t staticClass: \"opt exclude-disabled\",\n\t attrs: {\n\t \"id\": _vm.name + '-o',\n\t \"type\": \"checkbox\"\n\t },\n\t domProps: {\n\t \"checked\": _vm.present\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t _vm.$emit('input', !_vm.present ? _vm.fallback : undefined)\n\t }\n\t }\n\t }) : _vm._e(), _vm._v(\" \"), (typeof _vm.fallback !== 'undefined') ? _c('label', {\n\t staticClass: \"opt-l\",\n\t attrs: {\n\t \"for\": _vm.name + '-o'\n\t }\n\t }) : _vm._e(), _vm._v(\" \"), _c('input', {\n\t staticClass: \"input-number\",\n\t attrs: {\n\t \"id\": _vm.name,\n\t \"type\": \"range\",\n\t \"disabled\": !_vm.present || _vm.disabled,\n\t \"max\": _vm.max || _vm.hardMax || 100,\n\t \"min\": _vm.min || _vm.hardMin || 0,\n\t \"step\": _vm.step || 1\n\t },\n\t domProps: {\n\t \"value\": _vm.value || _vm.fallback\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t _vm.$emit('input', $event.target.value)\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('input', {\n\t staticClass: \"input-number\",\n\t attrs: {\n\t \"id\": _vm.name,\n\t \"type\": \"number\",\n\t \"disabled\": !_vm.present || _vm.disabled,\n\t \"max\": _vm.hardMax,\n\t \"min\": _vm.hardMin,\n\t \"step\": _vm.step || 1\n\t },\n\t domProps: {\n\t \"value\": _vm.value || _vm.fallback\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t _vm.$emit('input', $event.target.value)\n\t }\n\t }\n\t })])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 716 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"basic-user-card\"\n\t }, [_c('router-link', {\n\t attrs: {\n\t \"to\": _vm.userProfileLink(_vm.user)\n\t }\n\t }, [_c('UserAvatar', {\n\t staticClass: \"avatar\",\n\t attrs: {\n\t \"src\": _vm.user.profile_image_url\n\t },\n\t nativeOn: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t return _vm.toggleUserExpanded($event)\n\t }\n\t }\n\t })], 1), _vm._v(\" \"), (_vm.userExpanded) ? _c('div', {\n\t staticClass: \"basic-user-card-expanded-content\"\n\t }, [_c('UserCard', {\n\t attrs: {\n\t \"user\": _vm.user,\n\t \"rounded\": true,\n\t \"bordered\": true\n\t }\n\t })], 1) : _c('div', {\n\t staticClass: \"basic-user-card-collapsed-content\"\n\t }, [_c('div', {\n\t staticClass: \"basic-user-card-user-name\",\n\t attrs: {\n\t \"title\": _vm.user.name\n\t }\n\t }, [(_vm.user.name_html) ? _c('span', {\n\t domProps: {\n\t \"innerHTML\": _vm._s(_vm.user.name_html)\n\t }\n\t }) : _c('span', [_vm._v(_vm._s(_vm.user.name))])]), _vm._v(\" \"), _c('div', [_c('router-link', {\n\t staticClass: \"basic-user-card-screen-name\",\n\t attrs: {\n\t \"to\": _vm.userProfileLink(_vm.user)\n\t }\n\t }, [_vm._v(\"\\n @\" + _vm._s(_vm.user.screen_name) + \"\\n \")])], 1), _vm._v(\" \"), _vm._t(\"default\")], 2)], 1)\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 717 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return (_vm.notification.type === 'mention') ? _c('status', {\n\t attrs: {\n\t \"compact\": true,\n\t \"statusoid\": _vm.notification.status\n\t }\n\t }) : _c('div', {\n\t staticClass: \"non-mention\",\n\t class: [_vm.userClass, {\n\t highlighted: _vm.userStyle\n\t }],\n\t style: ([_vm.userStyle])\n\t }, [_c('a', {\n\t staticClass: \"avatar-container\",\n\t attrs: {\n\t \"href\": _vm.notification.action.user.statusnet_profile_url\n\t },\n\t on: {\n\t \"!click\": function($event) {\n\t $event.stopPropagation();\n\t $event.preventDefault();\n\t return _vm.toggleUserExpanded($event)\n\t }\n\t }\n\t }, [_c('UserAvatar', {\n\t attrs: {\n\t \"compact\": true,\n\t \"betterShadow\": _vm.betterShadow,\n\t \"src\": _vm.notification.action.user.profile_image_url_original\n\t }\n\t })], 1), _vm._v(\" \"), _c('div', {\n\t staticClass: \"notification-right\"\n\t }, [(_vm.userExpanded) ? _c('UserCard', {\n\t attrs: {\n\t \"user\": _vm.notification.action.user,\n\t \"rounded\": true,\n\t \"bordered\": true\n\t }\n\t }) : _vm._e(), _vm._v(\" \"), _c('span', {\n\t staticClass: \"notification-details\"\n\t }, [_c('div', {\n\t staticClass: \"name-and-action\"\n\t }, [(!!_vm.notification.action.user.name_html) ? _c('span', {\n\t staticClass: \"username\",\n\t attrs: {\n\t \"title\": '@' + _vm.notification.action.user.screen_name\n\t },\n\t domProps: {\n\t \"innerHTML\": _vm._s(_vm.notification.action.user.name_html)\n\t }\n\t }) : _c('span', {\n\t staticClass: \"username\",\n\t attrs: {\n\t \"title\": '@' + _vm.notification.action.user.screen_name\n\t }\n\t }, [_vm._v(_vm._s(_vm.notification.action.user.name))]), _vm._v(\" \"), (_vm.notification.type === 'like') ? _c('span', [_c('i', {\n\t staticClass: \"fa icon-star lit\"\n\t }), _vm._v(\" \"), _c('small', [_vm._v(_vm._s(_vm.$t('notifications.favorited_you')))])]) : _vm._e(), _vm._v(\" \"), (_vm.notification.type === 'repeat') ? _c('span', [_c('i', {\n\t staticClass: \"fa icon-retweet lit\",\n\t attrs: {\n\t \"title\": _vm.$t('tool_tip.repeat')\n\t }\n\t }), _vm._v(\" \"), _c('small', [_vm._v(_vm._s(_vm.$t('notifications.repeated_you')))])]) : _vm._e(), _vm._v(\" \"), (_vm.notification.type === 'follow') ? _c('span', [_c('i', {\n\t staticClass: \"fa icon-user-plus lit\"\n\t }), _vm._v(\" \"), _c('small', [_vm._v(_vm._s(_vm.$t('notifications.followed_you')))])]) : _vm._e()]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"timeago\"\n\t }, [(_vm.notification.status) ? _c('router-link', {\n\t staticClass: \"faint-link\",\n\t attrs: {\n\t \"to\": {\n\t name: 'conversation',\n\t params: {\n\t id: _vm.notification.status.id\n\t }\n\t }\n\t }\n\t }, [_c('timeago', {\n\t attrs: {\n\t \"since\": _vm.notification.action.created_at,\n\t \"auto-update\": 240\n\t }\n\t })], 1) : _vm._e()], 1)]), _vm._v(\" \"), (_vm.notification.type === 'follow') ? _c('div', {\n\t staticClass: \"follow-text\"\n\t }, [_c('router-link', {\n\t attrs: {\n\t \"to\": _vm.userProfileLink(_vm.notification.action.user)\n\t }\n\t }, [_vm._v(\"\\n @\" + _vm._s(_vm.notification.action.user.screen_name) + \"\\n \")])], 1) : [_c('status', {\n\t staticClass: \"faint\",\n\t attrs: {\n\t \"compact\": true,\n\t \"statusoid\": _vm.notification.status,\n\t \"noHeading\": true\n\t }\n\t })]], 2)])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 718 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"side-drawer-container\",\n\t class: {\n\t 'side-drawer-container-closed': _vm.closed, 'side-drawer-container-open': !_vm.closed\n\t }\n\t }, [_c('div', {\n\t staticClass: \"side-drawer\",\n\t class: {\n\t 'side-drawer-closed': _vm.closed\n\t },\n\t on: {\n\t \"touchstart\": _vm.touchStart,\n\t \"touchmove\": _vm.touchMove\n\t }\n\t }, [_c('div', {\n\t staticClass: \"side-drawer-heading\",\n\t on: {\n\t \"click\": _vm.toggleDrawer\n\t }\n\t }, [(_vm.currentUser) ? _c('UserCard', {\n\t attrs: {\n\t \"user\": _vm.currentUser,\n\t \"hideBio\": true\n\t }\n\t }) : _c('div', {\n\t staticClass: \"side-drawer-logo-wrapper\"\n\t }, [_c('img', {\n\t attrs: {\n\t \"src\": _vm.logo\n\t }\n\t }), _vm._v(\" \"), _c('span', [_vm._v(_vm._s(_vm.sitename))])])], 1), _vm._v(\" \"), _c('ul', [(!_vm.currentUser) ? _c('li', {\n\t on: {\n\t \"click\": _vm.toggleDrawer\n\t }\n\t }, [_c('router-link', {\n\t attrs: {\n\t \"to\": {\n\t name: 'login'\n\t }\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"login.login\")) + \"\\n \")])], 1) : _vm._e(), _vm._v(\" \"), (_vm.currentUser) ? _c('li', {\n\t on: {\n\t \"click\": _vm.toggleDrawer\n\t }\n\t }, [_c('router-link', {\n\t attrs: {\n\t \"to\": {\n\t name: 'notifications',\n\t params: {\n\t username: _vm.currentUser.screen_name\n\t }\n\t }\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"notifications.notifications\")) + \" \" + _vm._s(_vm.unseenNotificationsCount > 0 ? (\"(\" + _vm.unseenNotificationsCount + \")\") : '') + \"\\n \")])], 1) : _vm._e(), _vm._v(\" \"), (_vm.currentUser) ? _c('li', {\n\t on: {\n\t \"click\": _vm.toggleDrawer\n\t }\n\t }, [_c('router-link', {\n\t attrs: {\n\t \"to\": {\n\t name: 'dms',\n\t params: {\n\t username: _vm.currentUser.screen_name\n\t }\n\t }\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.dms\")) + \"\\n \")])], 1) : _vm._e()]), _vm._v(\" \"), _c('ul', [(_vm.currentUser) ? _c('li', {\n\t on: {\n\t \"click\": _vm.toggleDrawer\n\t }\n\t }, [_c('router-link', {\n\t attrs: {\n\t \"to\": {\n\t name: 'friends'\n\t }\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.timeline\")) + \"\\n \")])], 1) : _vm._e(), _vm._v(\" \"), (_vm.currentUser && _vm.currentUser.locked) ? _c('li', {\n\t on: {\n\t \"click\": _vm.toggleDrawer\n\t }\n\t }, [_c('router-link', {\n\t attrs: {\n\t \"to\": \"/friend-requests\"\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.friend_requests\")) + \"\\n \"), (_vm.followRequestCount > 0) ? _c('span', {\n\t staticClass: \"badge follow-request-count\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.followRequestCount) + \"\\n \")]) : _vm._e()])], 1) : _vm._e(), _vm._v(\" \"), _c('li', {\n\t on: {\n\t \"click\": _vm.toggleDrawer\n\t }\n\t }, [_c('router-link', {\n\t attrs: {\n\t \"to\": \"/main/public\"\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.public_tl\")) + \"\\n \")])], 1), _vm._v(\" \"), _c('li', {\n\t on: {\n\t \"click\": _vm.toggleDrawer\n\t }\n\t }, [_c('router-link', {\n\t attrs: {\n\t \"to\": \"/main/all\"\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.twkn\")) + \"\\n \")])], 1), _vm._v(\" \"), (_vm.currentUser && _vm.chat) ? _c('li', {\n\t on: {\n\t \"click\": _vm.toggleDrawer\n\t }\n\t }, [_c('router-link', {\n\t attrs: {\n\t \"to\": {\n\t name: 'chat'\n\t }\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.chat\")) + \"\\n \")])], 1) : _vm._e()]), _vm._v(\" \"), _c('ul', [_c('li', {\n\t on: {\n\t \"click\": _vm.toggleDrawer\n\t }\n\t }, [_c('router-link', {\n\t attrs: {\n\t \"to\": {\n\t name: 'user-search'\n\t }\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.user_search\")) + \"\\n \")])], 1), _vm._v(\" \"), (_vm.currentUser && _vm.suggestionsEnabled) ? _c('li', {\n\t on: {\n\t \"click\": _vm.toggleDrawer\n\t }\n\t }, [_c('router-link', {\n\t attrs: {\n\t \"to\": {\n\t name: 'who-to-follow'\n\t }\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.who_to_follow\")) + \"\\n \")])], 1) : _vm._e(), _vm._v(\" \"), _c('li', {\n\t on: {\n\t \"click\": _vm.toggleDrawer\n\t }\n\t }, [_c('router-link', {\n\t attrs: {\n\t \"to\": {\n\t name: 'settings'\n\t }\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"settings.settings\")) + \"\\n \")])], 1), _vm._v(\" \"), _c('li', {\n\t on: {\n\t \"click\": _vm.toggleDrawer\n\t }\n\t }, [_c('router-link', {\n\t attrs: {\n\t \"to\": {\n\t name: 'about'\n\t }\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.about\")) + \"\\n \")])], 1), _vm._v(\" \"), (_vm.currentUser) ? _c('li', {\n\t on: {\n\t \"click\": _vm.toggleDrawer\n\t }\n\t }, [_c('a', {\n\t attrs: {\n\t \"href\": \"#\"\n\t },\n\t on: {\n\t \"click\": _vm.doLogout\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"login.logout\")) + \"\\n \")])]) : _vm._e()])]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"side-drawer-click-outside\",\n\t class: {\n\t 'side-drawer-click-outside-closed': _vm.closed\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.stopPropagation();\n\t $event.preventDefault();\n\t return _vm.toggleDrawer($event)\n\t }\n\t }\n\t })])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 719 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"shadow-control\",\n\t class: {\n\t disabled: !_vm.present\n\t }\n\t }, [_c('div', {\n\t staticClass: \"shadow-preview-container\"\n\t }, [_c('div', {\n\t staticClass: \"y-shift-control\",\n\t attrs: {\n\t \"disabled\": !_vm.present\n\t }\n\t }, [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.selected.y),\n\t expression: \"selected.y\"\n\t }],\n\t staticClass: \"input-number\",\n\t attrs: {\n\t \"disabled\": !_vm.present,\n\t \"type\": \"number\"\n\t },\n\t domProps: {\n\t \"value\": (_vm.selected.y)\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.$set(_vm.selected, \"y\", $event.target.value)\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('div', {\n\t staticClass: \"wrap\"\n\t }, [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.selected.y),\n\t expression: \"selected.y\"\n\t }],\n\t staticClass: \"input-range\",\n\t attrs: {\n\t \"disabled\": !_vm.present,\n\t \"type\": \"range\",\n\t \"max\": \"20\",\n\t \"min\": \"-20\"\n\t },\n\t domProps: {\n\t \"value\": (_vm.selected.y)\n\t },\n\t on: {\n\t \"__r\": function($event) {\n\t _vm.$set(_vm.selected, \"y\", $event.target.value)\n\t }\n\t }\n\t })])]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"preview-window\"\n\t }, [_c('div', {\n\t staticClass: \"preview-block\",\n\t style: (_vm.style)\n\t })]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"x-shift-control\",\n\t attrs: {\n\t \"disabled\": !_vm.present\n\t }\n\t }, [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.selected.x),\n\t expression: \"selected.x\"\n\t }],\n\t staticClass: \"input-number\",\n\t attrs: {\n\t \"disabled\": !_vm.present,\n\t \"type\": \"number\"\n\t },\n\t domProps: {\n\t \"value\": (_vm.selected.x)\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.$set(_vm.selected, \"x\", $event.target.value)\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('div', {\n\t staticClass: \"wrap\"\n\t }, [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.selected.x),\n\t expression: \"selected.x\"\n\t }],\n\t staticClass: \"input-range\",\n\t attrs: {\n\t \"disabled\": !_vm.present,\n\t \"type\": \"range\",\n\t \"max\": \"20\",\n\t \"min\": \"-20\"\n\t },\n\t domProps: {\n\t \"value\": (_vm.selected.x)\n\t },\n\t on: {\n\t \"__r\": function($event) {\n\t _vm.$set(_vm.selected, \"x\", $event.target.value)\n\t }\n\t }\n\t })])])]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"shadow-tweak\"\n\t }, [_c('div', {\n\t staticClass: \"id-control style-control\",\n\t attrs: {\n\t \"disabled\": _vm.usingFallback\n\t }\n\t }, [_c('label', {\n\t staticClass: \"select\",\n\t attrs: {\n\t \"for\": \"shadow-switcher\",\n\t \"disabled\": !_vm.ready || _vm.usingFallback\n\t }\n\t }, [_c('select', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.selectedId),\n\t expression: \"selectedId\"\n\t }],\n\t staticClass: \"shadow-switcher\",\n\t attrs: {\n\t \"disabled\": !_vm.ready || _vm.usingFallback,\n\t \"id\": \"shadow-switcher\"\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n\t return o.selected\n\t }).map(function(o) {\n\t var val = \"_value\" in o ? o._value : o.value;\n\t return val\n\t });\n\t _vm.selectedId = $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n\t }\n\t }\n\t }, _vm._l((_vm.cValue), function(shadow, index) {\n\t return _c('option', {\n\t domProps: {\n\t \"value\": index\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.shadows.shadow_id', {\n\t value: index\n\t })) + \"\\n \")])\n\t }), 0), _vm._v(\" \"), _c('i', {\n\t staticClass: \"icon-down-open\"\n\t })]), _vm._v(\" \"), _c('button', {\n\t staticClass: \"btn btn-default\",\n\t attrs: {\n\t \"disabled\": !_vm.ready || !_vm.present\n\t },\n\t on: {\n\t \"click\": _vm.del\n\t }\n\t }, [_c('i', {\n\t staticClass: \"icon-cancel\"\n\t })]), _vm._v(\" \"), _c('button', {\n\t staticClass: \"btn btn-default\",\n\t attrs: {\n\t \"disabled\": !_vm.moveUpValid\n\t },\n\t on: {\n\t \"click\": _vm.moveUp\n\t }\n\t }, [_c('i', {\n\t staticClass: \"icon-up-open\"\n\t })]), _vm._v(\" \"), _c('button', {\n\t staticClass: \"btn btn-default\",\n\t attrs: {\n\t \"disabled\": !_vm.moveDnValid\n\t },\n\t on: {\n\t \"click\": _vm.moveDn\n\t }\n\t }, [_c('i', {\n\t staticClass: \"icon-down-open\"\n\t })]), _vm._v(\" \"), _c('button', {\n\t staticClass: \"btn btn-default\",\n\t attrs: {\n\t \"disabled\": _vm.usingFallback\n\t },\n\t on: {\n\t \"click\": _vm.add\n\t }\n\t }, [_c('i', {\n\t staticClass: \"icon-plus\"\n\t })])]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"inset-control style-control\",\n\t attrs: {\n\t \"disabled\": !_vm.present\n\t }\n\t }, [_c('label', {\n\t staticClass: \"label\",\n\t attrs: {\n\t \"for\": \"inset\"\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.shadows.inset')) + \"\\n \")]), _vm._v(\" \"), _c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.selected.inset),\n\t expression: \"selected.inset\"\n\t }],\n\t staticClass: \"input-inset\",\n\t attrs: {\n\t \"disabled\": !_vm.present,\n\t \"name\": \"inset\",\n\t \"id\": \"inset\",\n\t \"type\": \"checkbox\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.selected.inset) ? _vm._i(_vm.selected.inset, null) > -1 : (_vm.selected.inset)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.selected.inset,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.$set(_vm.selected, \"inset\", $$a.concat([$$v])))\n\t } else {\n\t $$i > -1 && (_vm.$set(_vm.selected, \"inset\", $$a.slice(0, $$i).concat($$a.slice($$i + 1))))\n\t }\n\t } else {\n\t _vm.$set(_vm.selected, \"inset\", $$c)\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t staticClass: \"checkbox-label\",\n\t attrs: {\n\t \"for\": \"inset\"\n\t }\n\t })]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"blur-control style-control\",\n\t attrs: {\n\t \"disabled\": !_vm.present\n\t }\n\t }, [_c('label', {\n\t staticClass: \"label\",\n\t attrs: {\n\t \"for\": \"spread\"\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.shadows.blur')) + \"\\n \")]), _vm._v(\" \"), _c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.selected.blur),\n\t expression: \"selected.blur\"\n\t }],\n\t staticClass: \"input-range\",\n\t attrs: {\n\t \"disabled\": !_vm.present,\n\t \"name\": \"blur\",\n\t \"id\": \"blur\",\n\t \"type\": \"range\",\n\t \"max\": \"20\",\n\t \"min\": \"0\"\n\t },\n\t domProps: {\n\t \"value\": (_vm.selected.blur)\n\t },\n\t on: {\n\t \"__r\": function($event) {\n\t _vm.$set(_vm.selected, \"blur\", $event.target.value)\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.selected.blur),\n\t expression: \"selected.blur\"\n\t }],\n\t staticClass: \"input-number\",\n\t attrs: {\n\t \"disabled\": !_vm.present,\n\t \"type\": \"number\",\n\t \"min\": \"0\"\n\t },\n\t domProps: {\n\t \"value\": (_vm.selected.blur)\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.$set(_vm.selected, \"blur\", $event.target.value)\n\t }\n\t }\n\t })]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"spread-control style-control\",\n\t attrs: {\n\t \"disabled\": !_vm.present\n\t }\n\t }, [_c('label', {\n\t staticClass: \"label\",\n\t attrs: {\n\t \"for\": \"spread\"\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.shadows.spread')) + \"\\n \")]), _vm._v(\" \"), _c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.selected.spread),\n\t expression: \"selected.spread\"\n\t }],\n\t staticClass: \"input-range\",\n\t attrs: {\n\t \"disabled\": !_vm.present,\n\t \"name\": \"spread\",\n\t \"id\": \"spread\",\n\t \"type\": \"range\",\n\t \"max\": \"20\",\n\t \"min\": \"-20\"\n\t },\n\t domProps: {\n\t \"value\": (_vm.selected.spread)\n\t },\n\t on: {\n\t \"__r\": function($event) {\n\t _vm.$set(_vm.selected, \"spread\", $event.target.value)\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.selected.spread),\n\t expression: \"selected.spread\"\n\t }],\n\t staticClass: \"input-number\",\n\t attrs: {\n\t \"disabled\": !_vm.present,\n\t \"type\": \"number\"\n\t },\n\t domProps: {\n\t \"value\": (_vm.selected.spread)\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.$set(_vm.selected, \"spread\", $event.target.value)\n\t }\n\t }\n\t })]), _vm._v(\" \"), _c('ColorInput', {\n\t attrs: {\n\t \"disabled\": !_vm.present,\n\t \"label\": _vm.$t('settings.style.common.color'),\n\t \"name\": \"shadow\"\n\t },\n\t model: {\n\t value: (_vm.selected.color),\n\t callback: function($$v) {\n\t _vm.$set(_vm.selected, \"color\", $$v)\n\t },\n\t expression: \"selected.color\"\n\t }\n\t }), _vm._v(\" \"), _c('OpacityInput', {\n\t attrs: {\n\t \"disabled\": !_vm.present\n\t },\n\t model: {\n\t value: (_vm.selected.alpha),\n\t callback: function($$v) {\n\t _vm.$set(_vm.selected, \"alpha\", $$v)\n\t },\n\t expression: \"selected.alpha\"\n\t }\n\t }), _vm._v(\" \"), _c('p', [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.shadows.hint')) + \"\\n \")])], 1)])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 720 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('conversation', {\n\t attrs: {\n\t \"collapsable\": false,\n\t \"statusoid\": _vm.statusoid\n\t }\n\t })\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 721 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"still-image\",\n\t class: {\n\t animated: _vm.animated\n\t }\n\t }, [(_vm.animated) ? _c('canvas', {\n\t ref: \"canvas\"\n\t }) : _vm._e(), _vm._v(\" \"), _c('img', {\n\t ref: \"src\",\n\t attrs: {\n\t \"src\": _vm.src,\n\t \"referrerpolicy\": _vm.referrerpolicy\n\t },\n\t on: {\n\t \"load\": _vm.onLoad,\n\t \"error\": _vm.onError\n\t }\n\t })])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 722 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', [_c('a', {\n\t staticClass: \"link-preview-card\",\n\t attrs: {\n\t \"href\": _vm.card.url,\n\t \"target\": \"_blank\",\n\t \"rel\": \"noopener\"\n\t }\n\t }, [(_vm.useImage) ? _c('div', {\n\t staticClass: \"card-image\",\n\t class: {\n\t 'small-image': _vm.size === 'small'\n\t }\n\t }, [_c('img', {\n\t attrs: {\n\t \"src\": _vm.card.image\n\t }\n\t })]) : _vm._e(), _vm._v(\" \"), _c('div', {\n\t staticClass: \"card-content\"\n\t }, [_c('span', {\n\t staticClass: \"card-host faint\"\n\t }, [_vm._v(_vm._s(_vm.card.provider_name))]), _vm._v(\" \"), _c('h4', {\n\t staticClass: \"card-title\"\n\t }, [_vm._v(_vm._s(_vm.card.title))]), _vm._v(\" \"), (_vm.useDescription) ? _c('p', {\n\t staticClass: \"card-description\"\n\t }, [_vm._v(_vm._s(_vm.card.description))]) : _vm._e()])])])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 723 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"color-control style-control\",\n\t class: {\n\t disabled: !_vm.present || _vm.disabled\n\t }\n\t }, [_c('label', {\n\t staticClass: \"label\",\n\t attrs: {\n\t \"for\": _vm.name\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.label) + \"\\n \")]), _vm._v(\" \"), (typeof _vm.fallback !== 'undefined') ? _c('input', {\n\t staticClass: \"opt exlcude-disabled\",\n\t attrs: {\n\t \"id\": _vm.name + '-o',\n\t \"type\": \"checkbox\"\n\t },\n\t domProps: {\n\t \"checked\": _vm.present\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t _vm.$emit('input', typeof _vm.value === 'undefined' ? _vm.fallback : undefined)\n\t }\n\t }\n\t }) : _vm._e(), _vm._v(\" \"), (typeof _vm.fallback !== 'undefined') ? _c('label', {\n\t staticClass: \"opt-l\",\n\t attrs: {\n\t \"for\": _vm.name + '-o'\n\t }\n\t }) : _vm._e(), _vm._v(\" \"), _c('input', {\n\t staticClass: \"color-input\",\n\t attrs: {\n\t \"id\": _vm.name,\n\t \"type\": \"color\",\n\t \"disabled\": !_vm.present || _vm.disabled\n\t },\n\t domProps: {\n\t \"value\": _vm.value || _vm.fallback\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t _vm.$emit('input', $event.target.value)\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('input', {\n\t staticClass: \"text-input\",\n\t attrs: {\n\t \"id\": _vm.name + '-t',\n\t \"type\": \"text\",\n\t \"disabled\": !_vm.present || _vm.disabled\n\t },\n\t domProps: {\n\t \"value\": _vm.value || _vm.fallback\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t _vm.$emit('input', $event.target.value)\n\t }\n\t }\n\t })])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 724 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return (!_vm.hideStatus) ? _c('div', {\n\t staticClass: \"status-el\",\n\t class: [{\n\t 'status-el_focused': _vm.isFocused\n\t }, {\n\t 'status-conversation': _vm.inlineExpanded\n\t }]\n\t }, [(_vm.muted && !_vm.isPreview) ? [_c('div', {\n\t staticClass: \"media status container muted\"\n\t }, [_c('small', [_c('router-link', {\n\t attrs: {\n\t \"to\": _vm.userProfileLink\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.status.user.screen_name) + \"\\n \")])], 1), _vm._v(\" \"), _c('small', {\n\t staticClass: \"muteWords\"\n\t }, [_vm._v(_vm._s(_vm.muteWordHits.join(', ')))]), _vm._v(\" \"), _c('a', {\n\t staticClass: \"unmute\",\n\t attrs: {\n\t \"href\": \"#\"\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t return _vm.toggleMute($event)\n\t }\n\t }\n\t }, [_c('i', {\n\t staticClass: \"button-icon icon-eye-off\"\n\t })])])] : [(_vm.retweet && !_vm.noHeading) ? _c('div', {\n\t staticClass: \"media container retweet-info\",\n\t class: [_vm.repeaterClass, {\n\t highlighted: _vm.repeaterStyle\n\t }],\n\t style: ([_vm.repeaterStyle])\n\t }, [(_vm.retweet) ? _c('UserAvatar', {\n\t staticClass: \"media-left\",\n\t attrs: {\n\t \"betterShadow\": _vm.betterShadow,\n\t \"src\": _vm.statusoid.user.profile_image_url_original\n\t }\n\t }) : _vm._e(), _vm._v(\" \"), _c('div', {\n\t staticClass: \"media-body faint\"\n\t }, [_c('span', {\n\t staticClass: \"user-name\"\n\t }, [(_vm.retweeterHtml) ? _c('router-link', {\n\t attrs: {\n\t \"to\": _vm.retweeterProfileLink\n\t },\n\t domProps: {\n\t \"innerHTML\": _vm._s(_vm.retweeterHtml)\n\t }\n\t }) : _c('router-link', {\n\t attrs: {\n\t \"to\": _vm.retweeterProfileLink\n\t }\n\t }, [_vm._v(_vm._s(_vm.retweeter))])], 1), _vm._v(\" \"), _c('i', {\n\t staticClass: \"fa icon-retweet retweeted\",\n\t attrs: {\n\t \"title\": _vm.$t('tool_tip.repeat')\n\t }\n\t }), _vm._v(\"\\n \" + _vm._s(_vm.$t('timeline.repeated')) + \"\\n \")])], 1) : _vm._e(), _vm._v(\" \"), _c('div', {\n\t staticClass: \"media status\",\n\t class: [_vm.userClass, {\n\t highlighted: _vm.userStyle,\n\t 'is-retweet': _vm.retweet\n\t }],\n\t style: ([_vm.userStyle])\n\t }, [(!_vm.noHeading) ? _c('div', {\n\t staticClass: \"media-left\"\n\t }, [_c('router-link', {\n\t attrs: {\n\t \"to\": _vm.userProfileLink\n\t },\n\t nativeOn: {\n\t \"!click\": function($event) {\n\t $event.stopPropagation();\n\t $event.preventDefault();\n\t return _vm.toggleUserExpanded($event)\n\t }\n\t }\n\t }, [_c('UserAvatar', {\n\t attrs: {\n\t \"compact\": _vm.compact,\n\t \"betterShadow\": _vm.betterShadow,\n\t \"src\": _vm.status.user.profile_image_url_original\n\t }\n\t })], 1)], 1) : _vm._e(), _vm._v(\" \"), _c('div', {\n\t staticClass: \"status-body\"\n\t }, [(_vm.userExpanded) ? _c('UserCard', {\n\t staticClass: \"status-usercard\",\n\t attrs: {\n\t \"user\": _vm.status.user,\n\t \"rounded\": true,\n\t \"bordered\": true\n\t }\n\t }) : _vm._e(), _vm._v(\" \"), (!_vm.noHeading) ? _c('div', {\n\t staticClass: \"media-heading\"\n\t }, [_c('div', {\n\t staticClass: \"heading-name-row\"\n\t }, [_c('div', {\n\t staticClass: \"name-and-account-name\"\n\t }, [(_vm.status.user.name_html) ? _c('h4', {\n\t staticClass: \"user-name\",\n\t domProps: {\n\t \"innerHTML\": _vm._s(_vm.status.user.name_html)\n\t }\n\t }) : _c('h4', {\n\t staticClass: \"user-name\"\n\t }, [_vm._v(_vm._s(_vm.status.user.name))]), _vm._v(\" \"), _c('router-link', {\n\t staticClass: \"account-name\",\n\t attrs: {\n\t \"to\": _vm.userProfileLink\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.status.user.screen_name) + \"\\n \")])], 1), _vm._v(\" \"), _c('span', {\n\t staticClass: \"heading-right\"\n\t }, [_c('router-link', {\n\t staticClass: \"timeago faint-link\",\n\t attrs: {\n\t \"to\": {\n\t name: 'conversation',\n\t params: {\n\t id: _vm.status.id\n\t }\n\t }\n\t }\n\t }, [_c('timeago', {\n\t attrs: {\n\t \"since\": _vm.status.created_at,\n\t \"auto-update\": 60\n\t }\n\t })], 1), _vm._v(\" \"), (_vm.status.visibility) ? _c('div', {\n\t staticClass: \"button-icon visibility-icon\"\n\t }, [_c('i', {\n\t class: _vm.visibilityIcon(_vm.status.visibility),\n\t attrs: {\n\t \"title\": _vm._f(\"capitalize\")(_vm.status.visibility)\n\t }\n\t })]) : _vm._e(), _vm._v(\" \"), (!_vm.status.is_local && !_vm.isPreview) ? _c('a', {\n\t staticClass: \"source_url\",\n\t attrs: {\n\t \"href\": _vm.status.external_url,\n\t \"target\": \"_blank\",\n\t \"title\": \"Source\"\n\t }\n\t }, [_c('i', {\n\t staticClass: \"button-icon icon-link-ext-alt\"\n\t })]) : _vm._e(), _vm._v(\" \"), (_vm.expandable && !_vm.isPreview) ? [_c('a', {\n\t attrs: {\n\t \"href\": \"#\",\n\t \"title\": \"Expand\"\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t return _vm.toggleExpanded($event)\n\t }\n\t }\n\t }, [_c('i', {\n\t staticClass: \"button-icon icon-plus-squared\"\n\t })])] : _vm._e(), _vm._v(\" \"), (_vm.unmuted) ? _c('a', {\n\t attrs: {\n\t \"href\": \"#\"\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t return _vm.toggleMute($event)\n\t }\n\t }\n\t }, [_c('i', {\n\t staticClass: \"button-icon icon-eye-off\"\n\t })]) : _vm._e()], 2)]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"heading-reply-row\"\n\t }, [(_vm.isReply) ? _c('div', {\n\t staticClass: \"reply-to-and-accountname\"\n\t }, [_c('a', {\n\t staticClass: \"reply-to\",\n\t attrs: {\n\t \"href\": \"#\",\n\t \"aria-label\": _vm.$t('tool_tip.reply')\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t _vm.gotoOriginal(_vm.status.in_reply_to_status_id)\n\t },\n\t \"mouseenter\": function($event) {\n\t $event.preventDefault();\n\t $event.stopPropagation();\n\t _vm.replyEnter(_vm.status.in_reply_to_status_id, $event)\n\t },\n\t \"mouseleave\": function($event) {\n\t $event.preventDefault();\n\t $event.stopPropagation();\n\t _vm.replyLeave()\n\t }\n\t }\n\t }, [(!_vm.isPreview) ? _c('i', {\n\t staticClass: \"button-icon icon-reply\"\n\t }) : _vm._e(), _vm._v(\" \"), _c('span', {\n\t staticClass: \"faint-link reply-to-text\"\n\t }, [_vm._v(_vm._s(_vm.$t('status.reply_to')))])]), _vm._v(\" \"), _c('router-link', {\n\t attrs: {\n\t \"to\": _vm.replyProfileLink\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.replyToName) + \"\\n \")]), _vm._v(\" \"), (_vm.replies && _vm.replies.length) ? _c('span', {\n\t staticClass: \"faint replies-separator\"\n\t }, [_vm._v(\"\\n -\\n \")]) : _vm._e()], 1) : _vm._e(), _vm._v(\" \"), (_vm.inConversation && !_vm.isPreview) ? _c('div', {\n\t staticClass: \"replies\"\n\t }, [(_vm.replies && _vm.replies.length) ? _c('span', {\n\t staticClass: \"faint\"\n\t }, [_vm._v(_vm._s(_vm.$t('status.replies_list')))]) : _vm._e(), _vm._v(\" \"), _vm._l((_vm.replies), function(reply) {\n\t return (_vm.replies) ? _c('span', {\n\t staticClass: \"reply-link faint\"\n\t }, [_c('a', {\n\t attrs: {\n\t \"href\": \"#\"\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t _vm.gotoOriginal(reply.id)\n\t },\n\t \"mouseenter\": function($event) {\n\t _vm.replyEnter(reply.id, $event)\n\t },\n\t \"mouseout\": function($event) {\n\t _vm.replyLeave()\n\t }\n\t }\n\t }, [_vm._v(_vm._s(reply.name))])]) : _vm._e()\n\t })], 2) : _vm._e()])]) : _vm._e(), _vm._v(\" \"), (_vm.showPreview) ? _c('div', {\n\t staticClass: \"status-preview-container\"\n\t }, [(_vm.preview) ? _c('status', {\n\t staticClass: \"status-preview\",\n\t attrs: {\n\t \"isPreview\": true,\n\t \"statusoid\": _vm.preview,\n\t \"compact\": true\n\t }\n\t }) : _c('div', {\n\t staticClass: \"status-preview status-preview-loading\"\n\t }, [_c('i', {\n\t staticClass: \"icon-spin4 animate-spin\"\n\t })])], 1) : _vm._e(), _vm._v(\" \"), (_vm.longSubject) ? _c('div', {\n\t staticClass: \"status-content-wrapper\",\n\t class: {\n\t 'tall-status': !_vm.showingLongSubject\n\t }\n\t }, [(!_vm.showingLongSubject) ? _c('a', {\n\t staticClass: \"tall-status-hider\",\n\t class: {\n\t 'tall-status-hider_focused': _vm.isFocused\n\t },\n\t attrs: {\n\t \"href\": \"#\"\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t _vm.showingLongSubject = true\n\t }\n\t }\n\t }, [_vm._v(\"Show more\")]) : _vm._e(), _vm._v(\" \"), _c('div', {\n\t staticClass: \"status-content media-body\",\n\t domProps: {\n\t \"innerHTML\": _vm._s(_vm.status.statusnet_html)\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t return _vm.linkClicked($event)\n\t }\n\t }\n\t }), _vm._v(\" \"), (_vm.showingLongSubject) ? _c('a', {\n\t staticClass: \"status-unhider\",\n\t attrs: {\n\t \"href\": \"#\"\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t _vm.showingLongSubject = false\n\t }\n\t }\n\t }, [_vm._v(\"Show less\")]) : _vm._e()]) : _c('div', {\n\t staticClass: \"status-content-wrapper\",\n\t class: {\n\t 'tall-status': _vm.hideTallStatus\n\t }\n\t }, [(_vm.hideTallStatus) ? _c('a', {\n\t staticClass: \"tall-status-hider\",\n\t class: {\n\t 'tall-status-hider_focused': _vm.isFocused\n\t },\n\t attrs: {\n\t \"href\": \"#\"\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t return _vm.toggleShowMore($event)\n\t }\n\t }\n\t }, [_vm._v(\"Show more\")]) : _vm._e(), _vm._v(\" \"), (!_vm.hideSubjectStatus) ? _c('div', {\n\t staticClass: \"status-content media-body\",\n\t domProps: {\n\t \"innerHTML\": _vm._s(_vm.status.statusnet_html)\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t return _vm.linkClicked($event)\n\t }\n\t }\n\t }) : _c('div', {\n\t staticClass: \"status-content media-body\",\n\t domProps: {\n\t \"innerHTML\": _vm._s(_vm.status.summary_html)\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t return _vm.linkClicked($event)\n\t }\n\t }\n\t }), _vm._v(\" \"), (_vm.hideSubjectStatus) ? _c('a', {\n\t staticClass: \"cw-status-hider\",\n\t attrs: {\n\t \"href\": \"#\"\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t return _vm.toggleShowMore($event)\n\t }\n\t }\n\t }, [_vm._v(\"Show more\")]) : _vm._e(), _vm._v(\" \"), (_vm.showingMore) ? _c('a', {\n\t staticClass: \"status-unhider\",\n\t attrs: {\n\t \"href\": \"#\"\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t return _vm.toggleShowMore($event)\n\t }\n\t }\n\t }, [_vm._v(\"Show less\")]) : _vm._e()]), _vm._v(\" \"), (_vm.status.attachments && (!_vm.hideSubjectStatus || _vm.showingLongSubject)) ? _c('div', {\n\t staticClass: \"attachments media-body\"\n\t }, [_vm._l((_vm.nonGalleryAttachments), function(attachment) {\n\t return _c('attachment', {\n\t key: attachment.id,\n\t staticClass: \"non-gallery\",\n\t attrs: {\n\t \"size\": _vm.attachmentSize,\n\t \"nsfw\": _vm.nsfwClickthrough,\n\t \"attachment\": attachment,\n\t \"allowPlay\": true,\n\t \"setMedia\": _vm.setMedia()\n\t }\n\t })\n\t }), _vm._v(\" \"), (_vm.galleryAttachments.length > 0) ? _c('gallery', {\n\t attrs: {\n\t \"nsfw\": _vm.nsfwClickthrough,\n\t \"attachments\": _vm.galleryAttachments,\n\t \"setMedia\": _vm.setMedia()\n\t }\n\t }) : _vm._e()], 2) : _vm._e(), _vm._v(\" \"), (_vm.status.card && !_vm.hideSubjectStatus && !_vm.noHeading) ? _c('div', {\n\t staticClass: \"link-preview media-body\"\n\t }, [_c('link-preview', {\n\t attrs: {\n\t \"card\": _vm.status.card,\n\t \"size\": _vm.attachmentSize,\n\t \"nsfw\": _vm.nsfwClickthrough\n\t }\n\t })], 1) : _vm._e(), _vm._v(\" \"), (!_vm.noHeading && !_vm.isPreview) ? _c('div', {\n\t staticClass: \"status-actions media-body\"\n\t }, [(_vm.loggedIn) ? _c('div', [_c('a', {\n\t attrs: {\n\t \"href\": \"#\",\n\t \"title\": _vm.$t('tool_tip.reply')\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t return _vm.toggleReplying($event)\n\t }\n\t }\n\t }, [_c('i', {\n\t staticClass: \"button-icon icon-reply\",\n\t class: {\n\t 'icon-reply-active': _vm.replying\n\t }\n\t })])]) : _vm._e(), _vm._v(\" \"), _c('retweet-button', {\n\t attrs: {\n\t \"visibility\": _vm.status.visibility,\n\t \"loggedIn\": _vm.loggedIn,\n\t \"status\": _vm.status\n\t }\n\t }), _vm._v(\" \"), _c('favorite-button', {\n\t attrs: {\n\t \"loggedIn\": _vm.loggedIn,\n\t \"status\": _vm.status\n\t }\n\t }), _vm._v(\" \"), _c('delete-button', {\n\t attrs: {\n\t \"status\": _vm.status\n\t }\n\t })], 1) : _vm._e()], 1)]), _vm._v(\" \"), (_vm.replying) ? _c('div', {\n\t staticClass: \"container\"\n\t }, [_c('div', {\n\t staticClass: \"reply-left\"\n\t }), _vm._v(\" \"), _c('post-status-form', {\n\t staticClass: \"reply-body\",\n\t attrs: {\n\t \"reply-to\": _vm.status.id,\n\t \"attentions\": _vm.status.attentions,\n\t \"repliedUser\": _vm.status.user,\n\t \"copy-message-scope\": _vm.status.visibility,\n\t \"subject\": _vm.replySubject\n\t },\n\t on: {\n\t \"posted\": _vm.toggleReplying\n\t }\n\t })], 1) : _vm._e()]], 2) : _vm._e()\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 725 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return (_vm.show) ? _c('div', {\n\t staticClass: \"instance-specific-panel\"\n\t }, [_c('div', {\n\t staticClass: \"panel panel-default\"\n\t }, [_c('div', {\n\t staticClass: \"panel-body\"\n\t }, [_c('div', {\n\t domProps: {\n\t \"innerHTML\": _vm._s(_vm.instanceSpecificPanelContent)\n\t }\n\t })])])]) : _vm._e()\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 726 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"image-cropper\"\n\t }, [(_vm.dataUrl) ? _c('div', [_c('div', {\n\t staticClass: \"image-cropper-image-container\"\n\t }, [_c('img', {\n\t ref: \"img\",\n\t attrs: {\n\t \"src\": _vm.dataUrl,\n\t \"alt\": \"\"\n\t },\n\t on: {\n\t \"load\": function($event) {\n\t $event.stopPropagation();\n\t return _vm.createCropper($event)\n\t }\n\t }\n\t })]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"image-cropper-buttons-wrapper\"\n\t }, [_c('button', {\n\t staticClass: \"btn\",\n\t attrs: {\n\t \"type\": \"button\",\n\t \"disabled\": _vm.submitting\n\t },\n\t domProps: {\n\t \"textContent\": _vm._s(_vm.saveText)\n\t },\n\t on: {\n\t \"click\": _vm.submit\n\t }\n\t }), _vm._v(\" \"), _c('button', {\n\t staticClass: \"btn\",\n\t attrs: {\n\t \"type\": \"button\",\n\t \"disabled\": _vm.submitting\n\t },\n\t domProps: {\n\t \"textContent\": _vm._s(_vm.cancelText)\n\t },\n\t on: {\n\t \"click\": _vm.destroy\n\t }\n\t }), _vm._v(\" \"), (_vm.submitting) ? _c('i', {\n\t staticClass: \"icon-spin4 animate-spin\"\n\t }) : _vm._e()]), _vm._v(\" \"), (_vm.submitError) ? _c('div', {\n\t staticClass: \"alert error\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.submitErrorMsg) + \"\\n \"), _c('i', {\n\t staticClass: \"button-icon icon-cancel\",\n\t on: {\n\t \"click\": _vm.clearError\n\t }\n\t })]) : _vm._e()]) : _vm._e(), _vm._v(\" \"), _c('input', {\n\t ref: \"input\",\n\t staticClass: \"image-cropper-img-input\",\n\t attrs: {\n\t \"type\": \"file\",\n\t \"accept\": _vm.mimes\n\t }\n\t })])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 727 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('Timeline', {\n\t attrs: {\n\t \"title\": _vm.$t('nav.timeline'),\n\t \"timeline\": _vm.timeline,\n\t \"timeline-name\": 'friends'\n\t }\n\t })\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 728 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"settings panel panel-default\"\n\t }, [_c('div', {\n\t staticClass: \"panel-heading\"\n\t }, [_c('div', {\n\t staticClass: \"title\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.user_settings')) + \"\\n \")]), _vm._v(\" \"), _c('transition', {\n\t attrs: {\n\t \"name\": \"fade\"\n\t }\n\t }, [(_vm.currentSaveStateNotice) ? [(_vm.currentSaveStateNotice.error) ? _c('div', {\n\t staticClass: \"alert error\",\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t }\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.saving_err')) + \"\\n \")]) : _vm._e(), _vm._v(\" \"), (!_vm.currentSaveStateNotice.error) ? _c('div', {\n\t staticClass: \"alert transparent\",\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t }\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.saving_ok')) + \"\\n \")]) : _vm._e()] : _vm._e()], 2)], 1), _vm._v(\" \"), _c('div', {\n\t staticClass: \"panel-body profile-edit\"\n\t }, [_c('tab-switcher', [_c('div', {\n\t attrs: {\n\t \"label\": _vm.$t('settings.profile_tab')\n\t }\n\t }, [_c('div', {\n\t staticClass: \"setting-item\"\n\t }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.name_bio')))]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.name')))]), _vm._v(\" \"), _c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.newName),\n\t expression: \"newName\"\n\t }],\n\t staticClass: \"name-changer\",\n\t attrs: {\n\t \"id\": \"username\"\n\t },\n\t domProps: {\n\t \"value\": (_vm.newName)\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.newName = $event.target.value\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.bio')))]), _vm._v(\" \"), _c('textarea', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.newBio),\n\t expression: \"newBio\"\n\t }],\n\t staticClass: \"bio\",\n\t domProps: {\n\t \"value\": (_vm.newBio)\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.newBio = $event.target.value\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('p', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.newLocked),\n\t expression: \"newLocked\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"account-locked\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.newLocked) ? _vm._i(_vm.newLocked, null) > -1 : (_vm.newLocked)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.newLocked,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.newLocked = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.newLocked = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.newLocked = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"account-locked\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.lock_account_description')))])]), _vm._v(\" \"), (_vm.scopeOptionsEnabled) ? _c('div', [_c('label', {\n\t attrs: {\n\t \"for\": \"default-vis\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.default_vis')))]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"visibility-tray\",\n\t attrs: {\n\t \"id\": \"default-vis\"\n\t }\n\t }, [_c('i', {\n\t staticClass: \"icon-mail-alt\",\n\t class: _vm.vis.direct,\n\t attrs: {\n\t \"title\": _vm.$t('post_status.scope.direct')\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t _vm.changeVis('direct')\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('i', {\n\t staticClass: \"icon-lock\",\n\t class: _vm.vis.private,\n\t attrs: {\n\t \"title\": _vm.$t('post_status.scope.private')\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t _vm.changeVis('private')\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('i', {\n\t staticClass: \"icon-lock-open-alt\",\n\t class: _vm.vis.unlisted,\n\t attrs: {\n\t \"title\": _vm.$t('post_status.scope.unlisted')\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t _vm.changeVis('unlisted')\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('i', {\n\t staticClass: \"icon-globe\",\n\t class: _vm.vis.public,\n\t attrs: {\n\t \"title\": _vm.$t('post_status.scope.public')\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t _vm.changeVis('public')\n\t }\n\t }\n\t })])]) : _vm._e(), _vm._v(\" \"), _c('p', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.newNoRichText),\n\t expression: \"newNoRichText\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"account-no-rich-text\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.newNoRichText) ? _vm._i(_vm.newNoRichText, null) > -1 : (_vm.newNoRichText)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.newNoRichText,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.newNoRichText = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.newNoRichText = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.newNoRichText = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"account-no-rich-text\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.no_rich_text_description')))])]), _vm._v(\" \"), _c('p', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.hideFollows),\n\t expression: \"hideFollows\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"account-hide-follows\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.hideFollows) ? _vm._i(_vm.hideFollows, null) > -1 : (_vm.hideFollows)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.hideFollows,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.hideFollows = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.hideFollows = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.hideFollows = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"account-hide-follows\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.hide_follows_description')))])]), _vm._v(\" \"), _c('p', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.hideFollowers),\n\t expression: \"hideFollowers\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"account-hide-followers\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.hideFollowers) ? _vm._i(_vm.hideFollowers, null) > -1 : (_vm.hideFollowers)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.hideFollowers,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.hideFollowers = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.hideFollowers = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.hideFollowers = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"account-hide-followers\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.hide_followers_description')))])]), _vm._v(\" \"), _c('p', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.showRole),\n\t expression: \"showRole\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"account-show-role\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.showRole) ? _vm._i(_vm.showRole, null) > -1 : (_vm.showRole)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.showRole,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.showRole = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.showRole = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.showRole = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), (_vm.role === 'admin') ? _c('label', {\n\t attrs: {\n\t \"for\": \"account-show-role\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.show_admin_badge')))]) : _vm._e(), _vm._v(\" \"), (_vm.role === 'moderator') ? _c('label', {\n\t attrs: {\n\t \"for\": \"account-show-role\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.show_moderator_badge')))]) : _vm._e()]), _vm._v(\" \"), _c('button', {\n\t staticClass: \"btn btn-default\",\n\t attrs: {\n\t \"disabled\": _vm.newName && _vm.newName.length === 0\n\t },\n\t on: {\n\t \"click\": _vm.updateProfile\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('general.submit')))])]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"setting-item\"\n\t }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.avatar')))]), _vm._v(\" \"), _c('p', {\n\t staticClass: \"visibility-notice\"\n\t }, [_vm._v(_vm._s(_vm.$t('settings.avatar_size_instruction')))]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.current_avatar')))]), _vm._v(\" \"), _c('img', {\n\t staticClass: \"current-avatar\",\n\t attrs: {\n\t \"src\": _vm.user.profile_image_url_original\n\t }\n\t }), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.set_new_avatar')))]), _vm._v(\" \"), _c('button', {\n\t directives: [{\n\t name: \"show\",\n\t rawName: \"v-show\",\n\t value: (_vm.pickAvatarBtnVisible),\n\t expression: \"pickAvatarBtnVisible\"\n\t }],\n\t staticClass: \"btn\",\n\t attrs: {\n\t \"type\": \"button\",\n\t \"id\": \"pick-avatar\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.upload_a_photo')))]), _vm._v(\" \"), _c('image-cropper', {\n\t attrs: {\n\t \"trigger\": \"#pick-avatar\",\n\t \"submitHandler\": _vm.submitAvatar\n\t },\n\t on: {\n\t \"open\": function($event) {\n\t _vm.pickAvatarBtnVisible = false\n\t },\n\t \"close\": function($event) {\n\t _vm.pickAvatarBtnVisible = true\n\t }\n\t }\n\t })], 1), _vm._v(\" \"), _c('div', {\n\t staticClass: \"setting-item\"\n\t }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.profile_banner')))]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.current_profile_banner')))]), _vm._v(\" \"), _c('img', {\n\t staticClass: \"banner\",\n\t attrs: {\n\t \"src\": _vm.user.cover_photo\n\t }\n\t }), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.set_new_profile_banner')))]), _vm._v(\" \"), (_vm.bannerPreview) ? _c('img', {\n\t staticClass: \"banner\",\n\t attrs: {\n\t \"src\": _vm.bannerPreview\n\t }\n\t }) : _vm._e(), _vm._v(\" \"), _c('div', [_c('input', {\n\t attrs: {\n\t \"type\": \"file\"\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t _vm.uploadFile('banner', $event)\n\t }\n\t }\n\t })]), _vm._v(\" \"), (_vm.bannerUploading) ? _c('i', {\n\t staticClass: \" icon-spin4 animate-spin uploading\"\n\t }) : (_vm.bannerPreview) ? _c('button', {\n\t staticClass: \"btn btn-default\",\n\t on: {\n\t \"click\": _vm.submitBanner\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('general.submit')))]) : _vm._e(), _vm._v(\" \"), (_vm.bannerUploadError) ? _c('div', {\n\t staticClass: \"alert error\"\n\t }, [_vm._v(\"\\n Error: \" + _vm._s(_vm.bannerUploadError) + \"\\n \"), _c('i', {\n\t staticClass: \"button-icon icon-cancel\",\n\t on: {\n\t \"click\": function($event) {\n\t _vm.clearUploadError('banner')\n\t }\n\t }\n\t })]) : _vm._e()]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"setting-item\"\n\t }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.profile_background')))]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.set_new_profile_background')))]), _vm._v(\" \"), (_vm.backgroundPreview) ? _c('img', {\n\t staticClass: \"bg\",\n\t attrs: {\n\t \"src\": _vm.backgroundPreview\n\t }\n\t }) : _vm._e(), _vm._v(\" \"), _c('div', [_c('input', {\n\t attrs: {\n\t \"type\": \"file\"\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t _vm.uploadFile('background', $event)\n\t }\n\t }\n\t })]), _vm._v(\" \"), (_vm.backgroundUploading) ? _c('i', {\n\t staticClass: \" icon-spin4 animate-spin uploading\"\n\t }) : (_vm.backgroundPreview) ? _c('button', {\n\t staticClass: \"btn btn-default\",\n\t on: {\n\t \"click\": _vm.submitBg\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('general.submit')))]) : _vm._e(), _vm._v(\" \"), (_vm.backgroundUploadError) ? _c('div', {\n\t staticClass: \"alert error\"\n\t }, [_vm._v(\"\\n Error: \" + _vm._s(_vm.backgroundUploadError) + \"\\n \"), _c('i', {\n\t staticClass: \"button-icon icon-cancel\",\n\t on: {\n\t \"click\": function($event) {\n\t _vm.clearUploadError('background')\n\t }\n\t }\n\t })]) : _vm._e()])]), _vm._v(\" \"), _c('div', {\n\t attrs: {\n\t \"label\": _vm.$t('settings.security_tab')\n\t }\n\t }, [_c('div', {\n\t staticClass: \"setting-item\"\n\t }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.change_password')))]), _vm._v(\" \"), _c('div', [_c('p', [_vm._v(_vm._s(_vm.$t('settings.current_password')))]), _vm._v(\" \"), _c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.changePasswordInputs[0]),\n\t expression: \"changePasswordInputs[0]\"\n\t }],\n\t attrs: {\n\t \"type\": \"password\"\n\t },\n\t domProps: {\n\t \"value\": (_vm.changePasswordInputs[0])\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.$set(_vm.changePasswordInputs, 0, $event.target.value)\n\t }\n\t }\n\t })]), _vm._v(\" \"), _c('div', [_c('p', [_vm._v(_vm._s(_vm.$t('settings.new_password')))]), _vm._v(\" \"), _c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.changePasswordInputs[1]),\n\t expression: \"changePasswordInputs[1]\"\n\t }],\n\t attrs: {\n\t \"type\": \"password\"\n\t },\n\t domProps: {\n\t \"value\": (_vm.changePasswordInputs[1])\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.$set(_vm.changePasswordInputs, 1, $event.target.value)\n\t }\n\t }\n\t })]), _vm._v(\" \"), _c('div', [_c('p', [_vm._v(_vm._s(_vm.$t('settings.confirm_new_password')))]), _vm._v(\" \"), _c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.changePasswordInputs[2]),\n\t expression: \"changePasswordInputs[2]\"\n\t }],\n\t attrs: {\n\t \"type\": \"password\"\n\t },\n\t domProps: {\n\t \"value\": (_vm.changePasswordInputs[2])\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.$set(_vm.changePasswordInputs, 2, $event.target.value)\n\t }\n\t }\n\t })]), _vm._v(\" \"), _c('button', {\n\t staticClass: \"btn btn-default\",\n\t on: {\n\t \"click\": _vm.changePassword\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('general.submit')))]), _vm._v(\" \"), (_vm.changedPassword) ? _c('p', [_vm._v(_vm._s(_vm.$t('settings.changed_password')))]) : (_vm.changePasswordError !== false) ? _c('p', [_vm._v(_vm._s(_vm.$t('settings.change_password_error')))]) : _vm._e(), _vm._v(\" \"), (_vm.changePasswordError) ? _c('p', [_vm._v(_vm._s(_vm.changePasswordError))]) : _vm._e()]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"setting-item\"\n\t }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.oauth_tokens')))]), _vm._v(\" \"), _c('table', {\n\t staticClass: \"oauth-tokens\"\n\t }, [_c('thead', [_c('tr', [_c('th', [_vm._v(_vm._s(_vm.$t('settings.app_name')))]), _vm._v(\" \"), _c('th', [_vm._v(_vm._s(_vm.$t('settings.valid_until')))]), _vm._v(\" \"), _c('th')])]), _vm._v(\" \"), _c('tbody', _vm._l((_vm.oauthTokens), function(oauthToken) {\n\t return _c('tr', {\n\t key: oauthToken.id\n\t }, [_c('td', [_vm._v(_vm._s(oauthToken.appName))]), _vm._v(\" \"), _c('td', [_vm._v(_vm._s(oauthToken.validUntil))]), _vm._v(\" \"), _c('td', {\n\t staticClass: \"actions\"\n\t }, [_c('button', {\n\t staticClass: \"btn btn-default\",\n\t on: {\n\t \"click\": function($event) {\n\t _vm.revokeToken(oauthToken.id)\n\t }\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.revoke_token')) + \"\\n \")])])])\n\t }), 0)])]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"setting-item\"\n\t }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.delete_account')))]), _vm._v(\" \"), (!_vm.deletingAccount) ? _c('p', [_vm._v(_vm._s(_vm.$t('settings.delete_account_description')))]) : _vm._e(), _vm._v(\" \"), (_vm.deletingAccount) ? _c('div', [_c('p', [_vm._v(_vm._s(_vm.$t('settings.delete_account_instructions')))]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('login.password')))]), _vm._v(\" \"), _c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.deleteAccountConfirmPasswordInput),\n\t expression: \"deleteAccountConfirmPasswordInput\"\n\t }],\n\t attrs: {\n\t \"type\": \"password\"\n\t },\n\t domProps: {\n\t \"value\": (_vm.deleteAccountConfirmPasswordInput)\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.deleteAccountConfirmPasswordInput = $event.target.value\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('button', {\n\t staticClass: \"btn btn-default\",\n\t on: {\n\t \"click\": _vm.deleteAccount\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.delete_account')))])]) : _vm._e(), _vm._v(\" \"), (_vm.deleteAccountError !== false) ? _c('p', [_vm._v(_vm._s(_vm.$t('settings.delete_account_error')))]) : _vm._e(), _vm._v(\" \"), (_vm.deleteAccountError) ? _c('p', [_vm._v(_vm._s(_vm.deleteAccountError))]) : _vm._e(), _vm._v(\" \"), (!_vm.deletingAccount) ? _c('button', {\n\t staticClass: \"btn btn-default\",\n\t on: {\n\t \"click\": _vm.confirmDelete\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('general.submit')))]) : _vm._e()])]), _vm._v(\" \"), (_vm.pleromaBackend) ? _c('div', {\n\t attrs: {\n\t \"label\": _vm.$t('settings.data_import_export_tab')\n\t }\n\t }, [_c('div', {\n\t staticClass: \"setting-item\"\n\t }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.follow_import')))]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.import_followers_from_a_csv_file')))]), _vm._v(\" \"), _c('form', [_c('input', {\n\t ref: \"followlist\",\n\t attrs: {\n\t \"type\": \"file\"\n\t },\n\t on: {\n\t \"change\": _vm.followListChange\n\t }\n\t })]), _vm._v(\" \"), (_vm.followListUploading) ? _c('i', {\n\t staticClass: \" icon-spin4 animate-spin uploading\"\n\t }) : _c('button', {\n\t staticClass: \"btn btn-default\",\n\t on: {\n\t \"click\": _vm.importFollows\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('general.submit')))]), _vm._v(\" \"), (_vm.followsImported) ? _c('div', [_c('i', {\n\t staticClass: \"icon-cross\",\n\t on: {\n\t \"click\": _vm.dismissImported\n\t }\n\t }), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.follows_imported')))])]) : (_vm.followImportError) ? _c('div', [_c('i', {\n\t staticClass: \"icon-cross\",\n\t on: {\n\t \"click\": _vm.dismissImported\n\t }\n\t }), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.follow_import_error')))])]) : _vm._e()]), _vm._v(\" \"), (_vm.enableFollowsExport) ? _c('div', {\n\t staticClass: \"setting-item\"\n\t }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.follow_export')))]), _vm._v(\" \"), _c('button', {\n\t staticClass: \"btn btn-default\",\n\t on: {\n\t \"click\": _vm.exportFollows\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.follow_export_button')))])]) : _c('div', {\n\t staticClass: \"setting-item\"\n\t }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.follow_export_processing')))])])]) : _vm._e(), _vm._v(\" \"), _c('div', {\n\t attrs: {\n\t \"label\": _vm.$t('settings.blocks_tab')\n\t }\n\t }, [_c('block-list', {\n\t attrs: {\n\t \"refresh\": true\n\t }\n\t }, [_c('template', {\n\t slot: \"empty\"\n\t }, [_vm._v(_vm._s(_vm.$t('settings.no_blocks')))])], 2)], 1)])], 1)])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 729 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return (_vm.canDelete) ? _c('div', [_c('a', {\n\t attrs: {\n\t \"href\": \"#\"\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t _vm.deleteStatus()\n\t }\n\t }\n\t }, [_c('i', {\n\t staticClass: \"button-icon icon-cancel delete-status\"\n\t })])]) : _vm._e()\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 730 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"style-switcher\"\n\t }, [_c('div', {\n\t staticClass: \"presets-container\"\n\t }, [_c('div', {\n\t staticClass: \"save-load\"\n\t }, [_c('export-import', {\n\t attrs: {\n\t \"exportObject\": _vm.exportedTheme,\n\t \"exportLabel\": _vm.$t(\"settings.export_theme\"),\n\t \"importLabel\": _vm.$t(\"settings.import_theme\"),\n\t \"importFailedText\": _vm.$t(\"settings.invalid_theme_imported\"),\n\t \"onImport\": _vm.onImport,\n\t \"validator\": _vm.importValidator\n\t }\n\t }, [_c('template', {\n\t slot: \"before\"\n\t }, [_c('div', {\n\t staticClass: \"presets\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.presets')) + \"\\n \"), _c('label', {\n\t staticClass: \"select\",\n\t attrs: {\n\t \"for\": \"preset-switcher\"\n\t }\n\t }, [_c('select', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.selected),\n\t expression: \"selected\"\n\t }],\n\t staticClass: \"preset-switcher\",\n\t attrs: {\n\t \"id\": \"preset-switcher\"\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n\t return o.selected\n\t }).map(function(o) {\n\t var val = \"_value\" in o ? o._value : o.value;\n\t return val\n\t });\n\t _vm.selected = $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n\t }\n\t }\n\t }, _vm._l((_vm.availableStyles), function(style) {\n\t return _c('option', {\n\t style: ({\n\t backgroundColor: style[1] || style.theme.colors.bg,\n\t color: style[3] || style.theme.colors.text\n\t }),\n\t domProps: {\n\t \"value\": style\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(style[0] || style.name) + \"\\n \")])\n\t }), 0), _vm._v(\" \"), _c('i', {\n\t staticClass: \"icon-down-open\"\n\t })])])])], 2)], 1), _vm._v(\" \"), _c('div', {\n\t staticClass: \"save-load-options\"\n\t }, [_c('span', {\n\t staticClass: \"keep-option\"\n\t }, [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.keepColor),\n\t expression: \"keepColor\"\n\t }],\n\t attrs: {\n\t \"id\": \"keep-color\",\n\t \"type\": \"checkbox\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.keepColor) ? _vm._i(_vm.keepColor, null) > -1 : (_vm.keepColor)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.keepColor,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.keepColor = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.keepColor = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.keepColor = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"keep-color\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.keep_color')))])]), _vm._v(\" \"), _c('span', {\n\t staticClass: \"keep-option\"\n\t }, [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.keepShadows),\n\t expression: \"keepShadows\"\n\t }],\n\t attrs: {\n\t \"id\": \"keep-shadows\",\n\t \"type\": \"checkbox\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.keepShadows) ? _vm._i(_vm.keepShadows, null) > -1 : (_vm.keepShadows)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.keepShadows,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.keepShadows = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.keepShadows = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.keepShadows = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"keep-shadows\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.keep_shadows')))])]), _vm._v(\" \"), _c('span', {\n\t staticClass: \"keep-option\"\n\t }, [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.keepOpacity),\n\t expression: \"keepOpacity\"\n\t }],\n\t attrs: {\n\t \"id\": \"keep-opacity\",\n\t \"type\": \"checkbox\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.keepOpacity) ? _vm._i(_vm.keepOpacity, null) > -1 : (_vm.keepOpacity)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.keepOpacity,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.keepOpacity = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.keepOpacity = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.keepOpacity = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"keep-opacity\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.keep_opacity')))])]), _vm._v(\" \"), _c('span', {\n\t staticClass: \"keep-option\"\n\t }, [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.keepRoundness),\n\t expression: \"keepRoundness\"\n\t }],\n\t attrs: {\n\t \"id\": \"keep-roundness\",\n\t \"type\": \"checkbox\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.keepRoundness) ? _vm._i(_vm.keepRoundness, null) > -1 : (_vm.keepRoundness)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.keepRoundness,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.keepRoundness = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.keepRoundness = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.keepRoundness = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"keep-roundness\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.keep_roundness')))])]), _vm._v(\" \"), _c('span', {\n\t staticClass: \"keep-option\"\n\t }, [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.keepFonts),\n\t expression: \"keepFonts\"\n\t }],\n\t attrs: {\n\t \"id\": \"keep-fonts\",\n\t \"type\": \"checkbox\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.keepFonts) ? _vm._i(_vm.keepFonts, null) > -1 : (_vm.keepFonts)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.keepFonts,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.keepFonts = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.keepFonts = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.keepFonts = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"keep-fonts\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.keep_fonts')))])]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.style.switcher.save_load_hint')))])])]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"preview-container\"\n\t }, [_c('preview', {\n\t style: (_vm.previewRules)\n\t })], 1), _vm._v(\" \"), _c('keep-alive', [_c('tab-switcher', {\n\t key: \"style-tweak\"\n\t }, [_c('div', {\n\t staticClass: \"color-container\",\n\t attrs: {\n\t \"label\": _vm.$t('settings.style.common_colors._tab_label')\n\t }\n\t }, [_c('div', {\n\t staticClass: \"tab-header\"\n\t }, [_c('p', [_vm._v(_vm._s(_vm.$t('settings.theme_help')))]), _vm._v(\" \"), _c('button', {\n\t staticClass: \"btn\",\n\t on: {\n\t \"click\": _vm.clearOpacity\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.clear_opacity')))]), _vm._v(\" \"), _c('button', {\n\t staticClass: \"btn\",\n\t on: {\n\t \"click\": _vm.clearV1\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.clear_all')))])]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.theme_help_v2_1')))]), _vm._v(\" \"), _c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.common_colors.main')))]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"color-item\"\n\t }, [_c('ColorInput', {\n\t attrs: {\n\t \"name\": \"bgColor\",\n\t \"label\": _vm.$t('settings.background')\n\t },\n\t model: {\n\t value: (_vm.bgColorLocal),\n\t callback: function($$v) {\n\t _vm.bgColorLocal = $$v\n\t },\n\t expression: \"bgColorLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('OpacityInput', {\n\t attrs: {\n\t \"name\": \"bgOpacity\",\n\t \"fallback\": _vm.previewTheme.opacity.bg || 1\n\t },\n\t model: {\n\t value: (_vm.bgOpacityLocal),\n\t callback: function($$v) {\n\t _vm.bgOpacityLocal = $$v\n\t },\n\t expression: \"bgOpacityLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('ColorInput', {\n\t attrs: {\n\t \"name\": \"textColor\",\n\t \"label\": _vm.$t('settings.text')\n\t },\n\t model: {\n\t value: (_vm.textColorLocal),\n\t callback: function($$v) {\n\t _vm.textColorLocal = $$v\n\t },\n\t expression: \"textColorLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('ContrastRatio', {\n\t attrs: {\n\t \"contrast\": _vm.previewContrast.bgText\n\t }\n\t }), _vm._v(\" \"), _c('ColorInput', {\n\t attrs: {\n\t \"name\": \"linkColor\",\n\t \"label\": _vm.$t('settings.links')\n\t },\n\t model: {\n\t value: (_vm.linkColorLocal),\n\t callback: function($$v) {\n\t _vm.linkColorLocal = $$v\n\t },\n\t expression: \"linkColorLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('ContrastRatio', {\n\t attrs: {\n\t \"contrast\": _vm.previewContrast.bgLink\n\t }\n\t })], 1), _vm._v(\" \"), _c('div', {\n\t staticClass: \"color-item\"\n\t }, [_c('ColorInput', {\n\t attrs: {\n\t \"name\": \"fgColor\",\n\t \"label\": _vm.$t('settings.foreground')\n\t },\n\t model: {\n\t value: (_vm.fgColorLocal),\n\t callback: function($$v) {\n\t _vm.fgColorLocal = $$v\n\t },\n\t expression: \"fgColorLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('ColorInput', {\n\t attrs: {\n\t \"name\": \"fgTextColor\",\n\t \"label\": _vm.$t('settings.text'),\n\t \"fallback\": _vm.previewTheme.colors.fgText\n\t },\n\t model: {\n\t value: (_vm.fgTextColorLocal),\n\t callback: function($$v) {\n\t _vm.fgTextColorLocal = $$v\n\t },\n\t expression: \"fgTextColorLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('ColorInput', {\n\t attrs: {\n\t \"name\": \"fgLinkColor\",\n\t \"label\": _vm.$t('settings.links'),\n\t \"fallback\": _vm.previewTheme.colors.fgLink\n\t },\n\t model: {\n\t value: (_vm.fgLinkColorLocal),\n\t callback: function($$v) {\n\t _vm.fgLinkColorLocal = $$v\n\t },\n\t expression: \"fgLinkColorLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.style.common_colors.foreground_hint')))])], 1), _vm._v(\" \"), _c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.common_colors.rgbo')))]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"color-item\"\n\t }, [_c('ColorInput', {\n\t attrs: {\n\t \"name\": \"cRedColor\",\n\t \"label\": _vm.$t('settings.cRed')\n\t },\n\t model: {\n\t value: (_vm.cRedColorLocal),\n\t callback: function($$v) {\n\t _vm.cRedColorLocal = $$v\n\t },\n\t expression: \"cRedColorLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('ContrastRatio', {\n\t attrs: {\n\t \"contrast\": _vm.previewContrast.bgRed\n\t }\n\t }), _vm._v(\" \"), _c('ColorInput', {\n\t attrs: {\n\t \"name\": \"cBlueColor\",\n\t \"label\": _vm.$t('settings.cBlue')\n\t },\n\t model: {\n\t value: (_vm.cBlueColorLocal),\n\t callback: function($$v) {\n\t _vm.cBlueColorLocal = $$v\n\t },\n\t expression: \"cBlueColorLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('ContrastRatio', {\n\t attrs: {\n\t \"contrast\": _vm.previewContrast.bgBlue\n\t }\n\t })], 1), _vm._v(\" \"), _c('div', {\n\t staticClass: \"color-item\"\n\t }, [_c('ColorInput', {\n\t attrs: {\n\t \"name\": \"cGreenColor\",\n\t \"label\": _vm.$t('settings.cGreen')\n\t },\n\t model: {\n\t value: (_vm.cGreenColorLocal),\n\t callback: function($$v) {\n\t _vm.cGreenColorLocal = $$v\n\t },\n\t expression: \"cGreenColorLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('ContrastRatio', {\n\t attrs: {\n\t \"contrast\": _vm.previewContrast.bgGreen\n\t }\n\t }), _vm._v(\" \"), _c('ColorInput', {\n\t attrs: {\n\t \"name\": \"cOrangeColor\",\n\t \"label\": _vm.$t('settings.cOrange')\n\t },\n\t model: {\n\t value: (_vm.cOrangeColorLocal),\n\t callback: function($$v) {\n\t _vm.cOrangeColorLocal = $$v\n\t },\n\t expression: \"cOrangeColorLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('ContrastRatio', {\n\t attrs: {\n\t \"contrast\": _vm.previewContrast.bgOrange\n\t }\n\t })], 1), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.theme_help_v2_2')))])]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"color-container\",\n\t attrs: {\n\t \"label\": _vm.$t('settings.style.advanced_colors._tab_label')\n\t }\n\t }, [_c('div', {\n\t staticClass: \"tab-header\"\n\t }, [_c('p', [_vm._v(_vm._s(_vm.$t('settings.theme_help')))]), _vm._v(\" \"), _c('button', {\n\t staticClass: \"btn\",\n\t on: {\n\t \"click\": _vm.clearOpacity\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.clear_opacity')))]), _vm._v(\" \"), _c('button', {\n\t staticClass: \"btn\",\n\t on: {\n\t \"click\": _vm.clearV1\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.clear_all')))])]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"color-item\"\n\t }, [_c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.advanced_colors.alert')))]), _vm._v(\" \"), _c('ColorInput', {\n\t attrs: {\n\t \"name\": \"alertError\",\n\t \"label\": _vm.$t('settings.style.advanced_colors.alert_error'),\n\t \"fallback\": _vm.previewTheme.colors.alertError\n\t },\n\t model: {\n\t value: (_vm.alertErrorColorLocal),\n\t callback: function($$v) {\n\t _vm.alertErrorColorLocal = $$v\n\t },\n\t expression: \"alertErrorColorLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('ContrastRatio', {\n\t attrs: {\n\t \"contrast\": _vm.previewContrast.alertError\n\t }\n\t })], 1), _vm._v(\" \"), _c('div', {\n\t staticClass: \"color-item\"\n\t }, [_c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.advanced_colors.badge')))]), _vm._v(\" \"), _c('ColorInput', {\n\t attrs: {\n\t \"name\": \"badgeNotification\",\n\t \"label\": _vm.$t('settings.style.advanced_colors.badge_notification'),\n\t \"fallback\": _vm.previewTheme.colors.badgeNotification\n\t },\n\t model: {\n\t value: (_vm.badgeNotificationColorLocal),\n\t callback: function($$v) {\n\t _vm.badgeNotificationColorLocal = $$v\n\t },\n\t expression: \"badgeNotificationColorLocal\"\n\t }\n\t })], 1), _vm._v(\" \"), _c('div', {\n\t staticClass: \"color-item\"\n\t }, [_c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.advanced_colors.panel_header')))]), _vm._v(\" \"), _c('ColorInput', {\n\t attrs: {\n\t \"name\": \"panelColor\",\n\t \"fallback\": _vm.fgColorLocal,\n\t \"label\": _vm.$t('settings.background')\n\t },\n\t model: {\n\t value: (_vm.panelColorLocal),\n\t callback: function($$v) {\n\t _vm.panelColorLocal = $$v\n\t },\n\t expression: \"panelColorLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('OpacityInput', {\n\t attrs: {\n\t \"name\": \"panelOpacity\",\n\t \"fallback\": _vm.previewTheme.opacity.panel || 1\n\t },\n\t model: {\n\t value: (_vm.panelOpacityLocal),\n\t callback: function($$v) {\n\t _vm.panelOpacityLocal = $$v\n\t },\n\t expression: \"panelOpacityLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('ColorInput', {\n\t attrs: {\n\t \"name\": \"panelTextColor\",\n\t \"fallback\": _vm.previewTheme.colors.panelText,\n\t \"label\": _vm.$t('settings.text')\n\t },\n\t model: {\n\t value: (_vm.panelTextColorLocal),\n\t callback: function($$v) {\n\t _vm.panelTextColorLocal = $$v\n\t },\n\t expression: \"panelTextColorLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('ContrastRatio', {\n\t attrs: {\n\t \"contrast\": _vm.previewContrast.panelText,\n\t \"large\": \"1\"\n\t }\n\t }), _vm._v(\" \"), _c('ColorInput', {\n\t attrs: {\n\t \"name\": \"panelLinkColor\",\n\t \"fallback\": _vm.previewTheme.colors.panelLink,\n\t \"label\": _vm.$t('settings.links')\n\t },\n\t model: {\n\t value: (_vm.panelLinkColorLocal),\n\t callback: function($$v) {\n\t _vm.panelLinkColorLocal = $$v\n\t },\n\t expression: \"panelLinkColorLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('ContrastRatio', {\n\t attrs: {\n\t \"contrast\": _vm.previewContrast.panelLink,\n\t \"large\": \"1\"\n\t }\n\t })], 1), _vm._v(\" \"), _c('div', {\n\t staticClass: \"color-item\"\n\t }, [_c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.advanced_colors.top_bar')))]), _vm._v(\" \"), _c('ColorInput', {\n\t attrs: {\n\t \"name\": \"topBarColor\",\n\t \"fallback\": _vm.fgColorLocal,\n\t \"label\": _vm.$t('settings.background')\n\t },\n\t model: {\n\t value: (_vm.topBarColorLocal),\n\t callback: function($$v) {\n\t _vm.topBarColorLocal = $$v\n\t },\n\t expression: \"topBarColorLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('ColorInput', {\n\t attrs: {\n\t \"name\": \"topBarTextColor\",\n\t \"fallback\": _vm.previewTheme.colors.topBarText,\n\t \"label\": _vm.$t('settings.text')\n\t },\n\t model: {\n\t value: (_vm.topBarTextColorLocal),\n\t callback: function($$v) {\n\t _vm.topBarTextColorLocal = $$v\n\t },\n\t expression: \"topBarTextColorLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('ContrastRatio', {\n\t attrs: {\n\t \"contrast\": _vm.previewContrast.topBarText\n\t }\n\t }), _vm._v(\" \"), _c('ColorInput', {\n\t attrs: {\n\t \"name\": \"topBarLinkColor\",\n\t \"fallback\": _vm.previewTheme.colors.topBarLink,\n\t \"label\": _vm.$t('settings.links')\n\t },\n\t model: {\n\t value: (_vm.topBarLinkColorLocal),\n\t callback: function($$v) {\n\t _vm.topBarLinkColorLocal = $$v\n\t },\n\t expression: \"topBarLinkColorLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('ContrastRatio', {\n\t attrs: {\n\t \"contrast\": _vm.previewContrast.topBarLink\n\t }\n\t })], 1), _vm._v(\" \"), _c('div', {\n\t staticClass: \"color-item\"\n\t }, [_c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.advanced_colors.inputs')))]), _vm._v(\" \"), _c('ColorInput', {\n\t attrs: {\n\t \"name\": \"inputColor\",\n\t \"fallback\": _vm.fgColorLocal,\n\t \"label\": _vm.$t('settings.background')\n\t },\n\t model: {\n\t value: (_vm.inputColorLocal),\n\t callback: function($$v) {\n\t _vm.inputColorLocal = $$v\n\t },\n\t expression: \"inputColorLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('OpacityInput', {\n\t attrs: {\n\t \"name\": \"inputOpacity\",\n\t \"fallback\": _vm.previewTheme.opacity.input || 1\n\t },\n\t model: {\n\t value: (_vm.inputOpacityLocal),\n\t callback: function($$v) {\n\t _vm.inputOpacityLocal = $$v\n\t },\n\t expression: \"inputOpacityLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('ColorInput', {\n\t attrs: {\n\t \"name\": \"inputTextColor\",\n\t \"fallback\": _vm.previewTheme.colors.inputText,\n\t \"label\": _vm.$t('settings.text')\n\t },\n\t model: {\n\t value: (_vm.inputTextColorLocal),\n\t callback: function($$v) {\n\t _vm.inputTextColorLocal = $$v\n\t },\n\t expression: \"inputTextColorLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('ContrastRatio', {\n\t attrs: {\n\t \"contrast\": _vm.previewContrast.inputText\n\t }\n\t })], 1), _vm._v(\" \"), _c('div', {\n\t staticClass: \"color-item\"\n\t }, [_c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.advanced_colors.buttons')))]), _vm._v(\" \"), _c('ColorInput', {\n\t attrs: {\n\t \"name\": \"btnColor\",\n\t \"fallback\": _vm.fgColorLocal,\n\t \"label\": _vm.$t('settings.background')\n\t },\n\t model: {\n\t value: (_vm.btnColorLocal),\n\t callback: function($$v) {\n\t _vm.btnColorLocal = $$v\n\t },\n\t expression: \"btnColorLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('OpacityInput', {\n\t attrs: {\n\t \"name\": \"btnOpacity\",\n\t \"fallback\": _vm.previewTheme.opacity.btn || 1\n\t },\n\t model: {\n\t value: (_vm.btnOpacityLocal),\n\t callback: function($$v) {\n\t _vm.btnOpacityLocal = $$v\n\t },\n\t expression: \"btnOpacityLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('ColorInput', {\n\t attrs: {\n\t \"name\": \"btnTextColor\",\n\t \"fallback\": _vm.previewTheme.colors.btnText,\n\t \"label\": _vm.$t('settings.text')\n\t },\n\t model: {\n\t value: (_vm.btnTextColorLocal),\n\t callback: function($$v) {\n\t _vm.btnTextColorLocal = $$v\n\t },\n\t expression: \"btnTextColorLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('ContrastRatio', {\n\t attrs: {\n\t \"contrast\": _vm.previewContrast.btnText\n\t }\n\t })], 1), _vm._v(\" \"), _c('div', {\n\t staticClass: \"color-item\"\n\t }, [_c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.advanced_colors.borders')))]), _vm._v(\" \"), _c('ColorInput', {\n\t attrs: {\n\t \"name\": \"borderColor\",\n\t \"fallback\": _vm.previewTheme.colors.border,\n\t \"label\": _vm.$t('settings.style.common.color')\n\t },\n\t model: {\n\t value: (_vm.borderColorLocal),\n\t callback: function($$v) {\n\t _vm.borderColorLocal = $$v\n\t },\n\t expression: \"borderColorLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('OpacityInput', {\n\t attrs: {\n\t \"name\": \"borderOpacity\",\n\t \"fallback\": _vm.previewTheme.opacity.border || 1\n\t },\n\t model: {\n\t value: (_vm.borderOpacityLocal),\n\t callback: function($$v) {\n\t _vm.borderOpacityLocal = $$v\n\t },\n\t expression: \"borderOpacityLocal\"\n\t }\n\t })], 1), _vm._v(\" \"), _c('div', {\n\t staticClass: \"color-item\"\n\t }, [_c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.advanced_colors.faint_text')))]), _vm._v(\" \"), _c('ColorInput', {\n\t attrs: {\n\t \"name\": \"faintColor\",\n\t \"fallback\": _vm.previewTheme.colors.faint || 1,\n\t \"label\": _vm.$t('settings.text')\n\t },\n\t model: {\n\t value: (_vm.faintColorLocal),\n\t callback: function($$v) {\n\t _vm.faintColorLocal = $$v\n\t },\n\t expression: \"faintColorLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('ColorInput', {\n\t attrs: {\n\t \"name\": \"faintLinkColor\",\n\t \"fallback\": _vm.previewTheme.colors.faintLink,\n\t \"label\": _vm.$t('settings.links')\n\t },\n\t model: {\n\t value: (_vm.faintLinkColorLocal),\n\t callback: function($$v) {\n\t _vm.faintLinkColorLocal = $$v\n\t },\n\t expression: \"faintLinkColorLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('ColorInput', {\n\t attrs: {\n\t \"name\": \"panelFaintColor\",\n\t \"fallback\": _vm.previewTheme.colors.panelFaint,\n\t \"label\": _vm.$t('settings.style.advanced_colors.panel_header')\n\t },\n\t model: {\n\t value: (_vm.panelFaintColorLocal),\n\t callback: function($$v) {\n\t _vm.panelFaintColorLocal = $$v\n\t },\n\t expression: \"panelFaintColorLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('OpacityInput', {\n\t attrs: {\n\t \"name\": \"faintOpacity\",\n\t \"fallback\": _vm.previewTheme.opacity.faint || 0.5\n\t },\n\t model: {\n\t value: (_vm.faintOpacityLocal),\n\t callback: function($$v) {\n\t _vm.faintOpacityLocal = $$v\n\t },\n\t expression: \"faintOpacityLocal\"\n\t }\n\t })], 1)]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"radius-container\",\n\t attrs: {\n\t \"label\": _vm.$t('settings.style.radii._tab_label')\n\t }\n\t }, [_c('div', {\n\t staticClass: \"tab-header\"\n\t }, [_c('p', [_vm._v(_vm._s(_vm.$t('settings.radii_help')))]), _vm._v(\" \"), _c('button', {\n\t staticClass: \"btn\",\n\t on: {\n\t \"click\": _vm.clearRoundness\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.clear_all')))])]), _vm._v(\" \"), _c('RangeInput', {\n\t attrs: {\n\t \"name\": \"btnRadius\",\n\t \"label\": _vm.$t('settings.btnRadius'),\n\t \"fallback\": _vm.previewTheme.radii.btn,\n\t \"max\": \"16\",\n\t \"hardMin\": \"0\"\n\t },\n\t model: {\n\t value: (_vm.btnRadiusLocal),\n\t callback: function($$v) {\n\t _vm.btnRadiusLocal = $$v\n\t },\n\t expression: \"btnRadiusLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('RangeInput', {\n\t attrs: {\n\t \"name\": \"inputRadius\",\n\t \"label\": _vm.$t('settings.inputRadius'),\n\t \"fallback\": _vm.previewTheme.radii.input,\n\t \"max\": \"9\",\n\t \"hardMin\": \"0\"\n\t },\n\t model: {\n\t value: (_vm.inputRadiusLocal),\n\t callback: function($$v) {\n\t _vm.inputRadiusLocal = $$v\n\t },\n\t expression: \"inputRadiusLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('RangeInput', {\n\t attrs: {\n\t \"name\": \"checkboxRadius\",\n\t \"label\": _vm.$t('settings.checkboxRadius'),\n\t \"fallback\": _vm.previewTheme.radii.checkbox,\n\t \"max\": \"16\",\n\t \"hardMin\": \"0\"\n\t },\n\t model: {\n\t value: (_vm.checkboxRadiusLocal),\n\t callback: function($$v) {\n\t _vm.checkboxRadiusLocal = $$v\n\t },\n\t expression: \"checkboxRadiusLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('RangeInput', {\n\t attrs: {\n\t \"name\": \"panelRadius\",\n\t \"label\": _vm.$t('settings.panelRadius'),\n\t \"fallback\": _vm.previewTheme.radii.panel,\n\t \"max\": \"50\",\n\t \"hardMin\": \"0\"\n\t },\n\t model: {\n\t value: (_vm.panelRadiusLocal),\n\t callback: function($$v) {\n\t _vm.panelRadiusLocal = $$v\n\t },\n\t expression: \"panelRadiusLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('RangeInput', {\n\t attrs: {\n\t \"name\": \"avatarRadius\",\n\t \"label\": _vm.$t('settings.avatarRadius'),\n\t \"fallback\": _vm.previewTheme.radii.avatar,\n\t \"max\": \"28\",\n\t \"hardMin\": \"0\"\n\t },\n\t model: {\n\t value: (_vm.avatarRadiusLocal),\n\t callback: function($$v) {\n\t _vm.avatarRadiusLocal = $$v\n\t },\n\t expression: \"avatarRadiusLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('RangeInput', {\n\t attrs: {\n\t \"name\": \"avatarAltRadius\",\n\t \"label\": _vm.$t('settings.avatarAltRadius'),\n\t \"fallback\": _vm.previewTheme.radii.avatarAlt,\n\t \"max\": \"28\",\n\t \"hardMin\": \"0\"\n\t },\n\t model: {\n\t value: (_vm.avatarAltRadiusLocal),\n\t callback: function($$v) {\n\t _vm.avatarAltRadiusLocal = $$v\n\t },\n\t expression: \"avatarAltRadiusLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('RangeInput', {\n\t attrs: {\n\t \"name\": \"attachmentRadius\",\n\t \"label\": _vm.$t('settings.attachmentRadius'),\n\t \"fallback\": _vm.previewTheme.radii.attachment,\n\t \"max\": \"50\",\n\t \"hardMin\": \"0\"\n\t },\n\t model: {\n\t value: (_vm.attachmentRadiusLocal),\n\t callback: function($$v) {\n\t _vm.attachmentRadiusLocal = $$v\n\t },\n\t expression: \"attachmentRadiusLocal\"\n\t }\n\t }), _vm._v(\" \"), _c('RangeInput', {\n\t attrs: {\n\t \"name\": \"tooltipRadius\",\n\t \"label\": _vm.$t('settings.tooltipRadius'),\n\t \"fallback\": _vm.previewTheme.radii.tooltip,\n\t \"max\": \"50\",\n\t \"hardMin\": \"0\"\n\t },\n\t model: {\n\t value: (_vm.tooltipRadiusLocal),\n\t callback: function($$v) {\n\t _vm.tooltipRadiusLocal = $$v\n\t },\n\t expression: \"tooltipRadiusLocal\"\n\t }\n\t })], 1), _vm._v(\" \"), _c('div', {\n\t staticClass: \"shadow-container\",\n\t attrs: {\n\t \"label\": _vm.$t('settings.style.shadows._tab_label')\n\t }\n\t }, [_c('div', {\n\t staticClass: \"tab-header shadow-selector\"\n\t }, [_c('div', {\n\t staticClass: \"select-container\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.shadows.component')) + \"\\n \"), _c('label', {\n\t staticClass: \"select\",\n\t attrs: {\n\t \"for\": \"shadow-switcher\"\n\t }\n\t }, [_c('select', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.shadowSelected),\n\t expression: \"shadowSelected\"\n\t }],\n\t staticClass: \"shadow-switcher\",\n\t attrs: {\n\t \"id\": \"shadow-switcher\"\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n\t return o.selected\n\t }).map(function(o) {\n\t var val = \"_value\" in o ? o._value : o.value;\n\t return val\n\t });\n\t _vm.shadowSelected = $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n\t }\n\t }\n\t }, _vm._l((_vm.shadowsAvailable), function(shadow) {\n\t return _c('option', {\n\t domProps: {\n\t \"value\": shadow\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.shadows.components.' + shadow)) + \"\\n \")])\n\t }), 0), _vm._v(\" \"), _c('i', {\n\t staticClass: \"icon-down-open\"\n\t })])]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"override\"\n\t }, [_c('label', {\n\t staticClass: \"label\",\n\t attrs: {\n\t \"for\": \"override\"\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.shadows.override')) + \"\\n \")]), _vm._v(\" \"), _c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.currentShadowOverriden),\n\t expression: \"currentShadowOverriden\"\n\t }],\n\t staticClass: \"input-override\",\n\t attrs: {\n\t \"name\": \"override\",\n\t \"id\": \"override\",\n\t \"type\": \"checkbox\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.currentShadowOverriden) ? _vm._i(_vm.currentShadowOverriden, null) > -1 : (_vm.currentShadowOverriden)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.currentShadowOverriden,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.currentShadowOverriden = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.currentShadowOverriden = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.currentShadowOverriden = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t staticClass: \"checkbox-label\",\n\t attrs: {\n\t \"for\": \"override\"\n\t }\n\t })]), _vm._v(\" \"), _c('button', {\n\t staticClass: \"btn\",\n\t on: {\n\t \"click\": _vm.clearShadows\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.clear_all')))])]), _vm._v(\" \"), _c('shadow-control', {\n\t attrs: {\n\t \"ready\": !!_vm.currentShadowFallback,\n\t \"fallback\": _vm.currentShadowFallback\n\t },\n\t model: {\n\t value: (_vm.currentShadow),\n\t callback: function($$v) {\n\t _vm.currentShadow = $$v\n\t },\n\t expression: \"currentShadow\"\n\t }\n\t }), _vm._v(\" \"), (_vm.shadowSelected === 'avatar' || _vm.shadowSelected === 'avatarStatus') ? _c('div', [_c('i18n', {\n\t attrs: {\n\t \"path\": \"settings.style.shadows.filter_hint.always_drop_shadow\",\n\t \"tag\": \"p\"\n\t }\n\t }, [_c('code', [_vm._v(\"filter: drop-shadow()\")])]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.style.shadows.filter_hint.avatar_inset')))]), _vm._v(\" \"), _c('i18n', {\n\t attrs: {\n\t \"path\": \"settings.style.shadows.filter_hint.drop_shadow_syntax\",\n\t \"tag\": \"p\"\n\t }\n\t }, [_c('code', [_vm._v(\"drop-shadow\")]), _vm._v(\" \"), _c('code', [_vm._v(\"spread-radius\")]), _vm._v(\" \"), _c('code', [_vm._v(\"inset\")])]), _vm._v(\" \"), _c('i18n', {\n\t attrs: {\n\t \"path\": \"settings.style.shadows.filter_hint.inset_classic\",\n\t \"tag\": \"p\"\n\t }\n\t }, [_c('code', [_vm._v(\"box-shadow\")])]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.style.shadows.filter_hint.spread_zero')))])], 1) : _vm._e()], 1), _vm._v(\" \"), _c('div', {\n\t staticClass: \"fonts-container\",\n\t attrs: {\n\t \"label\": _vm.$t('settings.style.fonts._tab_label')\n\t }\n\t }, [_c('div', {\n\t staticClass: \"tab-header\"\n\t }, [_c('p', [_vm._v(_vm._s(_vm.$t('settings.style.fonts.help')))]), _vm._v(\" \"), _c('button', {\n\t staticClass: \"btn\",\n\t on: {\n\t \"click\": _vm.clearFonts\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.clear_all')))])]), _vm._v(\" \"), _c('FontControl', {\n\t attrs: {\n\t \"name\": \"ui\",\n\t \"label\": _vm.$t('settings.style.fonts.components.interface'),\n\t \"fallback\": _vm.previewTheme.fonts.interface,\n\t \"no-inherit\": \"1\"\n\t },\n\t model: {\n\t value: (_vm.fontsLocal.interface),\n\t callback: function($$v) {\n\t _vm.$set(_vm.fontsLocal, \"interface\", $$v)\n\t },\n\t expression: \"fontsLocal.interface\"\n\t }\n\t }), _vm._v(\" \"), _c('FontControl', {\n\t attrs: {\n\t \"name\": \"input\",\n\t \"label\": _vm.$t('settings.style.fonts.components.input'),\n\t \"fallback\": _vm.previewTheme.fonts.input\n\t },\n\t model: {\n\t value: (_vm.fontsLocal.input),\n\t callback: function($$v) {\n\t _vm.$set(_vm.fontsLocal, \"input\", $$v)\n\t },\n\t expression: \"fontsLocal.input\"\n\t }\n\t }), _vm._v(\" \"), _c('FontControl', {\n\t attrs: {\n\t \"name\": \"post\",\n\t \"label\": _vm.$t('settings.style.fonts.components.post'),\n\t \"fallback\": _vm.previewTheme.fonts.post\n\t },\n\t model: {\n\t value: (_vm.fontsLocal.post),\n\t callback: function($$v) {\n\t _vm.$set(_vm.fontsLocal, \"post\", $$v)\n\t },\n\t expression: \"fontsLocal.post\"\n\t }\n\t }), _vm._v(\" \"), _c('FontControl', {\n\t attrs: {\n\t \"name\": \"postCode\",\n\t \"label\": _vm.$t('settings.style.fonts.components.postCode'),\n\t \"fallback\": _vm.previewTheme.fonts.postCode\n\t },\n\t model: {\n\t value: (_vm.fontsLocal.postCode),\n\t callback: function($$v) {\n\t _vm.$set(_vm.fontsLocal, \"postCode\", $$v)\n\t },\n\t expression: \"fontsLocal.postCode\"\n\t }\n\t })], 1)])], 1), _vm._v(\" \"), _c('div', {\n\t staticClass: \"apply-container\"\n\t }, [_c('button', {\n\t staticClass: \"btn submit\",\n\t attrs: {\n\t \"disabled\": !_vm.themeValid\n\t },\n\t on: {\n\t \"click\": _vm.setCustomTheme\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('general.apply')))]), _vm._v(\" \"), _c('button', {\n\t staticClass: \"btn\",\n\t on: {\n\t \"click\": _vm.clearAll\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.reset')))])])], 1)\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 731 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"panel dummy\"\n\t }, [_c('div', {\n\t staticClass: \"panel-heading\"\n\t }, [_c('div', {\n\t staticClass: \"title\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.header')) + \"\\n \"), _c('span', {\n\t staticClass: \"badge badge-notification\"\n\t }, [_vm._v(\"\\n 99\\n \")])]), _vm._v(\" \"), _c('span', {\n\t staticClass: \"faint\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.header_faint')) + \"\\n \")]), _vm._v(\" \"), _c('span', {\n\t staticClass: \"alert error\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.error')) + \"\\n \")]), _vm._v(\" \"), _c('button', {\n\t staticClass: \"btn\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.button')) + \"\\n \")])]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"panel-body theme-preview-content\"\n\t }, [_c('div', {\n\t staticClass: \"post\"\n\t }, [_c('div', {\n\t staticClass: \"avatar\"\n\t }, [_vm._v(\"\\n ( ͡° ͜ʖ ͡°)\\n \")]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"content\"\n\t }, [_c('h4', [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.content')) + \"\\n \")]), _vm._v(\" \"), _c('i18n', {\n\t attrs: {\n\t \"path\": \"settings.style.preview.text\"\n\t }\n\t }, [_c('code', {\n\t staticStyle: {\n\t \"font-family\": \"var(--postCodeFont)\"\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.mono')) + \"\\n \")]), _vm._v(\" \"), _c('a', {\n\t staticStyle: {\n\t \"color\": \"var(--link)\"\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.link')) + \"\\n \")])]), _vm._v(\" \"), _vm._m(0)], 1)]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"after-post\"\n\t }, [_c('div', {\n\t staticClass: \"avatar-alt\"\n\t }, [_vm._v(\"\\n :^)\\n \")]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"content\"\n\t }, [_c('i18n', {\n\t staticClass: \"faint\",\n\t attrs: {\n\t \"path\": \"settings.style.preview.fine_print\",\n\t \"tag\": \"span\"\n\t }\n\t }, [_c('a', {\n\t staticStyle: {\n\t \"color\": \"var(--faintLink)\"\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.faint_link')) + \"\\n \")])])], 1)]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"separator\"\n\t }), _vm._v(\" \"), _c('span', {\n\t staticClass: \"alert error\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.error')) + \"\\n \")]), _vm._v(\" \"), _c('input', {\n\t attrs: {\n\t \"type\": \"text\"\n\t },\n\t domProps: {\n\t \"value\": _vm.$t('settings.style.preview.input')\n\t }\n\t }), _vm._v(\" \"), _c('div', {\n\t staticClass: \"actions\"\n\t }, [_c('span', {\n\t staticClass: \"checkbox\"\n\t }, [_c('input', {\n\t attrs: {\n\t \"checked\": \"very yes\",\n\t \"type\": \"checkbox\",\n\t \"id\": \"preview_checkbox\"\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"preview_checkbox\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.style.preview.checkbox')))])]), _vm._v(\" \"), _c('button', {\n\t staticClass: \"btn\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.button')) + \"\\n \")])])])])\n\t},staticRenderFns: [function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"icons\"\n\t }, [_c('i', {\n\t staticClass: \"button-icon icon-reply\",\n\t staticStyle: {\n\t \"color\": \"var(--cBlue)\"\n\t }\n\t }), _vm._v(\" \"), _c('i', {\n\t staticClass: \"button-icon icon-retweet\",\n\t staticStyle: {\n\t \"color\": \"var(--cGreen)\"\n\t }\n\t }), _vm._v(\" \"), _c('i', {\n\t staticClass: \"button-icon icon-star\",\n\t staticStyle: {\n\t \"color\": \"var(--cOrange)\"\n\t }\n\t }), _vm._v(\" \"), _c('i', {\n\t staticClass: \"button-icon icon-cancel\",\n\t staticStyle: {\n\t \"color\": \"var(--cRed)\"\n\t }\n\t })])\n\t}]}\n\n/***/ }),\n/* 732 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return (_vm.loggedIn) ? _c('div', [_c('i', {\n\t staticClass: \"button-icon favorite-button fav-active\",\n\t class: _vm.classes,\n\t attrs: {\n\t \"title\": _vm.$t('tool_tip.favorite')\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t _vm.favorite()\n\t }\n\t }\n\t }), _vm._v(\" \"), (!_vm.hidePostStatsLocal && _vm.status.fave_num > 0) ? _c('span', [_vm._v(_vm._s(_vm.status.fave_num))]) : _vm._e()]) : _c('div', [_c('i', {\n\t staticClass: \"button-icon favorite-button\",\n\t class: _vm.classes,\n\t attrs: {\n\t \"title\": _vm.$t('tool_tip.favorite')\n\t }\n\t }), _vm._v(\" \"), (!_vm.hidePostStatsLocal && _vm.status.fave_num > 0) ? _c('span', [_vm._v(_vm._s(_vm.status.fave_num))]) : _vm._e()])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 733 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"settings panel panel-default\"\n\t }, [_c('div', {\n\t staticClass: \"panel-heading\"\n\t }, [_c('div', {\n\t staticClass: \"title\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.settings')) + \"\\n \")]), _vm._v(\" \"), _c('transition', {\n\t attrs: {\n\t \"name\": \"fade\"\n\t }\n\t }, [(_vm.currentSaveStateNotice) ? [(_vm.currentSaveStateNotice.error) ? _c('div', {\n\t staticClass: \"alert error\",\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t }\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.saving_err')) + \"\\n \")]) : _vm._e(), _vm._v(\" \"), (!_vm.currentSaveStateNotice.error) ? _c('div', {\n\t staticClass: \"alert transparent\",\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t }\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.saving_ok')) + \"\\n \")]) : _vm._e()] : _vm._e()], 2)], 1), _vm._v(\" \"), _c('div', {\n\t staticClass: \"panel-body\"\n\t }, [_c('keep-alive', [_c('tab-switcher', [_c('div', {\n\t attrs: {\n\t \"label\": _vm.$t('settings.general')\n\t }\n\t }, [_c('div', {\n\t staticClass: \"setting-item\"\n\t }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.interface')))]), _vm._v(\" \"), _c('ul', {\n\t staticClass: \"setting-list\"\n\t }, [_c('li', [_c('interface-language-switcher')], 1), _vm._v(\" \"), (_vm.instanceSpecificPanelPresent) ? _c('li', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.hideISPLocal),\n\t expression: \"hideISPLocal\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"hideISP\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.hideISPLocal) ? _vm._i(_vm.hideISPLocal, null) > -1 : (_vm.hideISPLocal)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.hideISPLocal,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.hideISPLocal = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.hideISPLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.hideISPLocal = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"hideISP\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.hide_isp')))])]) : _vm._e()])]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"setting-item\"\n\t }, [_c('h2', [_vm._v(_vm._s(_vm.$t('nav.timeline')))]), _vm._v(\" \"), _c('ul', {\n\t staticClass: \"setting-list\"\n\t }, [_c('li', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.collapseMessageWithSubjectLocal),\n\t expression: \"collapseMessageWithSubjectLocal\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"collapseMessageWithSubject\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.collapseMessageWithSubjectLocal) ? _vm._i(_vm.collapseMessageWithSubjectLocal, null) > -1 : (_vm.collapseMessageWithSubjectLocal)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.collapseMessageWithSubjectLocal,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.collapseMessageWithSubjectLocal = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.collapseMessageWithSubjectLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.collapseMessageWithSubjectLocal = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"collapseMessageWithSubject\"\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.collapse_subject')) + \" \" + _vm._s(_vm.$t('settings.instance_default', {\n\t value: _vm.collapseMessageWithSubjectDefault\n\t })) + \"\\n \")])]), _vm._v(\" \"), _c('li', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.streamingLocal),\n\t expression: \"streamingLocal\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"streaming\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.streamingLocal) ? _vm._i(_vm.streamingLocal, null) > -1 : (_vm.streamingLocal)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.streamingLocal,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.streamingLocal = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.streamingLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.streamingLocal = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"streaming\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.streaming')))]), _vm._v(\" \"), _c('ul', {\n\t staticClass: \"setting-list suboptions\",\n\t class: [{\n\t disabled: !_vm.streamingLocal\n\t }]\n\t }, [_c('li', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.pauseOnUnfocusedLocal),\n\t expression: \"pauseOnUnfocusedLocal\"\n\t }],\n\t attrs: {\n\t \"disabled\": !_vm.streamingLocal,\n\t \"type\": \"checkbox\",\n\t \"id\": \"pauseOnUnfocused\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.pauseOnUnfocusedLocal) ? _vm._i(_vm.pauseOnUnfocusedLocal, null) > -1 : (_vm.pauseOnUnfocusedLocal)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.pauseOnUnfocusedLocal,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.pauseOnUnfocusedLocal = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.pauseOnUnfocusedLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.pauseOnUnfocusedLocal = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"pauseOnUnfocused\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.pause_on_unfocused')))])])])]), _vm._v(\" \"), _c('li', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.autoLoadLocal),\n\t expression: \"autoLoadLocal\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"autoload\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.autoLoadLocal) ? _vm._i(_vm.autoLoadLocal, null) > -1 : (_vm.autoLoadLocal)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.autoLoadLocal,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.autoLoadLocal = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.autoLoadLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.autoLoadLocal = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"autoload\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.autoload')))])]), _vm._v(\" \"), _c('li', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.hoverPreviewLocal),\n\t expression: \"hoverPreviewLocal\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"hoverPreview\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.hoverPreviewLocal) ? _vm._i(_vm.hoverPreviewLocal, null) > -1 : (_vm.hoverPreviewLocal)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.hoverPreviewLocal,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.hoverPreviewLocal = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.hoverPreviewLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.hoverPreviewLocal = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"hoverPreview\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.reply_link_preview')))])])])]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"setting-item\"\n\t }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.composing')))]), _vm._v(\" \"), _c('ul', {\n\t staticClass: \"setting-list\"\n\t }, [_c('li', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.scopeCopyLocal),\n\t expression: \"scopeCopyLocal\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"scopeCopy\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.scopeCopyLocal) ? _vm._i(_vm.scopeCopyLocal, null) > -1 : (_vm.scopeCopyLocal)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.scopeCopyLocal,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.scopeCopyLocal = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.scopeCopyLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.scopeCopyLocal = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"scopeCopy\"\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.scope_copy')) + \" \" + _vm._s(_vm.$t('settings.instance_default', {\n\t value: _vm.scopeCopyDefault\n\t })) + \"\\n \")])]), _vm._v(\" \"), _c('li', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.alwaysShowSubjectInputLocal),\n\t expression: \"alwaysShowSubjectInputLocal\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"subjectHide\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.alwaysShowSubjectInputLocal) ? _vm._i(_vm.alwaysShowSubjectInputLocal, null) > -1 : (_vm.alwaysShowSubjectInputLocal)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.alwaysShowSubjectInputLocal,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.alwaysShowSubjectInputLocal = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.alwaysShowSubjectInputLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.alwaysShowSubjectInputLocal = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"subjectHide\"\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.subject_input_always_show')) + \" \" + _vm._s(_vm.$t('settings.instance_default', {\n\t value: _vm.alwaysShowSubjectInputDefault\n\t })) + \"\\n \")])]), _vm._v(\" \"), _c('li', [_c('div', [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.subject_line_behavior')) + \"\\n \"), _c('label', {\n\t staticClass: \"select\",\n\t attrs: {\n\t \"for\": \"subjectLineBehavior\"\n\t }\n\t }, [_c('select', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.subjectLineBehaviorLocal),\n\t expression: \"subjectLineBehaviorLocal\"\n\t }],\n\t attrs: {\n\t \"id\": \"subjectLineBehavior\"\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n\t return o.selected\n\t }).map(function(o) {\n\t var val = \"_value\" in o ? o._value : o.value;\n\t return val\n\t });\n\t _vm.subjectLineBehaviorLocal = $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n\t }\n\t }\n\t }, [_c('option', {\n\t attrs: {\n\t \"value\": \"email\"\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.subject_line_email')) + \"\\n \" + _vm._s(_vm.subjectLineBehaviorDefault == 'email' ? _vm.$t('settings.instance_default_simple') : '') + \"\\n \")]), _vm._v(\" \"), _c('option', {\n\t attrs: {\n\t \"value\": \"masto\"\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.subject_line_mastodon')) + \"\\n \" + _vm._s(_vm.subjectLineBehaviorDefault == 'mastodon' ? _vm.$t('settings.instance_default_simple') : '') + \"\\n \")]), _vm._v(\" \"), _c('option', {\n\t attrs: {\n\t \"value\": \"noop\"\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.subject_line_noop')) + \"\\n \" + _vm._s(_vm.subjectLineBehaviorDefault == 'noop' ? _vm.$t('settings.instance_default_simple') : '') + \"\\n \")])]), _vm._v(\" \"), _c('i', {\n\t staticClass: \"icon-down-open\"\n\t })])])]), _vm._v(\" \"), _c('li', [_c('div', [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.post_status_content_type')) + \"\\n \"), _c('label', {\n\t staticClass: \"select\",\n\t attrs: {\n\t \"for\": \"postContentType\"\n\t }\n\t }, [_c('select', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.postContentTypeLocal),\n\t expression: \"postContentTypeLocal\"\n\t }],\n\t attrs: {\n\t \"id\": \"postContentType\"\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n\t return o.selected\n\t }).map(function(o) {\n\t var val = \"_value\" in o ? o._value : o.value;\n\t return val\n\t });\n\t _vm.postContentTypeLocal = $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n\t }\n\t }\n\t }, _vm._l((_vm.postFormats), function(postFormat) {\n\t return _c('option', {\n\t key: postFormat,\n\t domProps: {\n\t \"value\": postFormat\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t((\"post_status.content_type[\\\"\" + postFormat + \"\\\"]\"))) + \"\\n \" + _vm._s(_vm.postContentTypeDefault === postFormat ? _vm.$t('settings.instance_default_simple') : '') + \"\\n \")])\n\t }), 0), _vm._v(\" \"), _c('i', {\n\t staticClass: \"icon-down-open\"\n\t })])])])])]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"setting-item\"\n\t }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.attachments')))]), _vm._v(\" \"), _c('ul', {\n\t staticClass: \"setting-list\"\n\t }, [_c('li', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.hideAttachmentsLocal),\n\t expression: \"hideAttachmentsLocal\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"hideAttachments\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.hideAttachmentsLocal) ? _vm._i(_vm.hideAttachmentsLocal, null) > -1 : (_vm.hideAttachmentsLocal)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.hideAttachmentsLocal,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.hideAttachmentsLocal = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.hideAttachmentsLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.hideAttachmentsLocal = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"hideAttachments\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.hide_attachments_in_tl')))])]), _vm._v(\" \"), _c('li', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.hideAttachmentsInConvLocal),\n\t expression: \"hideAttachmentsInConvLocal\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"hideAttachmentsInConv\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.hideAttachmentsInConvLocal) ? _vm._i(_vm.hideAttachmentsInConvLocal, null) > -1 : (_vm.hideAttachmentsInConvLocal)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.hideAttachmentsInConvLocal,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.hideAttachmentsInConvLocal = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.hideAttachmentsInConvLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.hideAttachmentsInConvLocal = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"hideAttachmentsInConv\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.hide_attachments_in_convo')))])]), _vm._v(\" \"), _c('li', [_c('label', {\n\t attrs: {\n\t \"for\": \"maxThumbnails\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.max_thumbnails')))]), _vm._v(\" \"), _c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model.number\",\n\t value: (_vm.maxThumbnails),\n\t expression: \"maxThumbnails\",\n\t modifiers: {\n\t \"number\": true\n\t }\n\t }],\n\t staticClass: \"number-input\",\n\t attrs: {\n\t \"type\": \"number\",\n\t \"id\": \"maxThumbnails\",\n\t \"min\": \"0\",\n\t \"step\": \"1\"\n\t },\n\t domProps: {\n\t \"value\": (_vm.maxThumbnails)\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.maxThumbnails = _vm._n($event.target.value)\n\t },\n\t \"blur\": function($event) {\n\t _vm.$forceUpdate()\n\t }\n\t }\n\t })]), _vm._v(\" \"), _c('li', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.hideNsfwLocal),\n\t expression: \"hideNsfwLocal\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"hideNsfw\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.hideNsfwLocal) ? _vm._i(_vm.hideNsfwLocal, null) > -1 : (_vm.hideNsfwLocal)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.hideNsfwLocal,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.hideNsfwLocal = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.hideNsfwLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.hideNsfwLocal = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"hideNsfw\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.nsfw_clickthrough')))])]), _vm._v(\" \"), _c('ul', {\n\t staticClass: \"setting-list suboptions\"\n\t }, [_c('li', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.preloadImage),\n\t expression: \"preloadImage\"\n\t }],\n\t attrs: {\n\t \"disabled\": !_vm.hideNsfwLocal,\n\t \"type\": \"checkbox\",\n\t \"id\": \"preloadImage\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.preloadImage) ? _vm._i(_vm.preloadImage, null) > -1 : (_vm.preloadImage)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.preloadImage,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.preloadImage = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.preloadImage = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.preloadImage = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"preloadImage\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.preload_images')))])]), _vm._v(\" \"), _c('li', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.useOneClickNsfw),\n\t expression: \"useOneClickNsfw\"\n\t }],\n\t attrs: {\n\t \"disabled\": !_vm.hideNsfwLocal,\n\t \"type\": \"checkbox\",\n\t \"id\": \"useOneClickNsfw\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.useOneClickNsfw) ? _vm._i(_vm.useOneClickNsfw, null) > -1 : (_vm.useOneClickNsfw)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.useOneClickNsfw,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.useOneClickNsfw = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.useOneClickNsfw = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.useOneClickNsfw = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"useOneClickNsfw\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.use_one_click_nsfw')))])])]), _vm._v(\" \"), _c('li', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.stopGifs),\n\t expression: \"stopGifs\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"stopGifs\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.stopGifs) ? _vm._i(_vm.stopGifs, null) > -1 : (_vm.stopGifs)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.stopGifs,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.stopGifs = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.stopGifs = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.stopGifs = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"stopGifs\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.stop_gifs')))])]), _vm._v(\" \"), _c('li', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.loopVideoLocal),\n\t expression: \"loopVideoLocal\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"loopVideo\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.loopVideoLocal) ? _vm._i(_vm.loopVideoLocal, null) > -1 : (_vm.loopVideoLocal)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.loopVideoLocal,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.loopVideoLocal = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.loopVideoLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.loopVideoLocal = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"loopVideo\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.loop_video')))]), _vm._v(\" \"), _c('ul', {\n\t staticClass: \"setting-list suboptions\",\n\t class: [{\n\t disabled: !_vm.streamingLocal\n\t }]\n\t }, [_c('li', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.loopVideoSilentOnlyLocal),\n\t expression: \"loopVideoSilentOnlyLocal\"\n\t }],\n\t attrs: {\n\t \"disabled\": !_vm.loopVideoLocal || !_vm.loopSilentAvailable,\n\t \"type\": \"checkbox\",\n\t \"id\": \"loopVideoSilentOnly\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.loopVideoSilentOnlyLocal) ? _vm._i(_vm.loopVideoSilentOnlyLocal, null) > -1 : (_vm.loopVideoSilentOnlyLocal)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.loopVideoSilentOnlyLocal,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.loopVideoSilentOnlyLocal = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.loopVideoSilentOnlyLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.loopVideoSilentOnlyLocal = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"loopVideoSilentOnly\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.loop_video_silent_only')))]), _vm._v(\" \"), (!_vm.loopSilentAvailable) ? _c('div', {\n\t staticClass: \"unavailable\"\n\t }, [_c('i', {\n\t staticClass: \"icon-globe\"\n\t }), _vm._v(\"! \" + _vm._s(_vm.$t('settings.limited_availability')) + \"\\n \")]) : _vm._e()])])]), _vm._v(\" \"), _c('li', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.playVideosInModal),\n\t expression: \"playVideosInModal\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"playVideosInModal\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.playVideosInModal) ? _vm._i(_vm.playVideosInModal, null) > -1 : (_vm.playVideosInModal)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.playVideosInModal,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.playVideosInModal = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.playVideosInModal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.playVideosInModal = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"playVideosInModal\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.play_videos_in_modal')))])]), _vm._v(\" \"), _c('li', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.useContainFit),\n\t expression: \"useContainFit\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"useContainFit\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.useContainFit) ? _vm._i(_vm.useContainFit, null) > -1 : (_vm.useContainFit)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.useContainFit,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.useContainFit = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.useContainFit = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.useContainFit = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"useContainFit\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.use_contain_fit')))])])])]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"setting-item\"\n\t }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.notifications')))]), _vm._v(\" \"), _c('ul', {\n\t staticClass: \"setting-list\"\n\t }, [_c('li', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.webPushNotificationsLocal),\n\t expression: \"webPushNotificationsLocal\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"webPushNotifications\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.webPushNotificationsLocal) ? _vm._i(_vm.webPushNotificationsLocal, null) > -1 : (_vm.webPushNotificationsLocal)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.webPushNotificationsLocal,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.webPushNotificationsLocal = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.webPushNotificationsLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.webPushNotificationsLocal = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"webPushNotifications\"\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.enable_web_push_notifications')) + \"\\n \")])])])])]), _vm._v(\" \"), _c('div', {\n\t attrs: {\n\t \"label\": _vm.$t('settings.theme')\n\t }\n\t }, [_c('div', {\n\t staticClass: \"setting-item\"\n\t }, [_c('style-switcher')], 1)]), _vm._v(\" \"), _c('div', {\n\t attrs: {\n\t \"label\": _vm.$t('settings.filtering')\n\t }\n\t }, [_c('div', {\n\t staticClass: \"setting-item\"\n\t }, [_c('div', {\n\t staticClass: \"select-multiple\"\n\t }, [_c('span', {\n\t staticClass: \"label\"\n\t }, [_vm._v(_vm._s(_vm.$t('settings.notification_visibility')))]), _vm._v(\" \"), _c('ul', {\n\t staticClass: \"option-list\"\n\t }, [_c('li', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.notificationVisibilityLocal.likes),\n\t expression: \"notificationVisibilityLocal.likes\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"notification-visibility-likes\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.notificationVisibilityLocal.likes) ? _vm._i(_vm.notificationVisibilityLocal.likes, null) > -1 : (_vm.notificationVisibilityLocal.likes)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.notificationVisibilityLocal.likes,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.$set(_vm.notificationVisibilityLocal, \"likes\", $$a.concat([$$v])))\n\t } else {\n\t $$i > -1 && (_vm.$set(_vm.notificationVisibilityLocal, \"likes\", $$a.slice(0, $$i).concat($$a.slice($$i + 1))))\n\t }\n\t } else {\n\t _vm.$set(_vm.notificationVisibilityLocal, \"likes\", $$c)\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"notification-visibility-likes\"\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.notification_visibility_likes')) + \"\\n \")])]), _vm._v(\" \"), _c('li', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.notificationVisibilityLocal.repeats),\n\t expression: \"notificationVisibilityLocal.repeats\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"notification-visibility-repeats\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.notificationVisibilityLocal.repeats) ? _vm._i(_vm.notificationVisibilityLocal.repeats, null) > -1 : (_vm.notificationVisibilityLocal.repeats)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.notificationVisibilityLocal.repeats,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.$set(_vm.notificationVisibilityLocal, \"repeats\", $$a.concat([$$v])))\n\t } else {\n\t $$i > -1 && (_vm.$set(_vm.notificationVisibilityLocal, \"repeats\", $$a.slice(0, $$i).concat($$a.slice($$i + 1))))\n\t }\n\t } else {\n\t _vm.$set(_vm.notificationVisibilityLocal, \"repeats\", $$c)\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"notification-visibility-repeats\"\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.notification_visibility_repeats')) + \"\\n \")])]), _vm._v(\" \"), _c('li', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.notificationVisibilityLocal.follows),\n\t expression: \"notificationVisibilityLocal.follows\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"notification-visibility-follows\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.notificationVisibilityLocal.follows) ? _vm._i(_vm.notificationVisibilityLocal.follows, null) > -1 : (_vm.notificationVisibilityLocal.follows)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.notificationVisibilityLocal.follows,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.$set(_vm.notificationVisibilityLocal, \"follows\", $$a.concat([$$v])))\n\t } else {\n\t $$i > -1 && (_vm.$set(_vm.notificationVisibilityLocal, \"follows\", $$a.slice(0, $$i).concat($$a.slice($$i + 1))))\n\t }\n\t } else {\n\t _vm.$set(_vm.notificationVisibilityLocal, \"follows\", $$c)\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"notification-visibility-follows\"\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.notification_visibility_follows')) + \"\\n \")])]), _vm._v(\" \"), _c('li', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.notificationVisibilityLocal.mentions),\n\t expression: \"notificationVisibilityLocal.mentions\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"notification-visibility-mentions\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.notificationVisibilityLocal.mentions) ? _vm._i(_vm.notificationVisibilityLocal.mentions, null) > -1 : (_vm.notificationVisibilityLocal.mentions)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.notificationVisibilityLocal.mentions,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.$set(_vm.notificationVisibilityLocal, \"mentions\", $$a.concat([$$v])))\n\t } else {\n\t $$i > -1 && (_vm.$set(_vm.notificationVisibilityLocal, \"mentions\", $$a.slice(0, $$i).concat($$a.slice($$i + 1))))\n\t }\n\t } else {\n\t _vm.$set(_vm.notificationVisibilityLocal, \"mentions\", $$c)\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"notification-visibility-mentions\"\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.notification_visibility_mentions')) + \"\\n \")])])])]), _vm._v(\" \"), _c('div', [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.replies_in_timeline')) + \"\\n \"), _c('label', {\n\t staticClass: \"select\",\n\t attrs: {\n\t \"for\": \"replyVisibility\"\n\t }\n\t }, [_c('select', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.replyVisibilityLocal),\n\t expression: \"replyVisibilityLocal\"\n\t }],\n\t attrs: {\n\t \"id\": \"replyVisibility\"\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n\t return o.selected\n\t }).map(function(o) {\n\t var val = \"_value\" in o ? o._value : o.value;\n\t return val\n\t });\n\t _vm.replyVisibilityLocal = $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n\t }\n\t }\n\t }, [_c('option', {\n\t attrs: {\n\t \"value\": \"all\",\n\t \"selected\": \"\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.reply_visibility_all')))]), _vm._v(\" \"), _c('option', {\n\t attrs: {\n\t \"value\": \"following\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.reply_visibility_following')))]), _vm._v(\" \"), _c('option', {\n\t attrs: {\n\t \"value\": \"self\"\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('settings.reply_visibility_self')))])]), _vm._v(\" \"), _c('i', {\n\t staticClass: \"icon-down-open\"\n\t })])]), _vm._v(\" \"), _c('div', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.hidePostStatsLocal),\n\t expression: \"hidePostStatsLocal\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"hidePostStats\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.hidePostStatsLocal) ? _vm._i(_vm.hidePostStatsLocal, null) > -1 : (_vm.hidePostStatsLocal)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.hidePostStatsLocal,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.hidePostStatsLocal = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.hidePostStatsLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.hidePostStatsLocal = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"hidePostStats\"\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.hide_post_stats')) + \" \" + _vm._s(_vm.$t('settings.instance_default', {\n\t value: _vm.hidePostStatsDefault\n\t })) + \"\\n \")])]), _vm._v(\" \"), _c('div', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.hideUserStatsLocal),\n\t expression: \"hideUserStatsLocal\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"hideUserStats\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.hideUserStatsLocal) ? _vm._i(_vm.hideUserStatsLocal, null) > -1 : (_vm.hideUserStatsLocal)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.hideUserStatsLocal,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.hideUserStatsLocal = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.hideUserStatsLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.hideUserStatsLocal = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"hideUserStats\"\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.hide_user_stats')) + \" \" + _vm._s(_vm.$t('settings.instance_default', {\n\t value: _vm.hideUserStatsDefault\n\t })) + \"\\n \")])])]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"setting-item\"\n\t }, [_c('div', [_c('p', [_vm._v(_vm._s(_vm.$t('settings.filtering_explanation')))]), _vm._v(\" \"), _c('textarea', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.muteWordsString),\n\t expression: \"muteWordsString\"\n\t }],\n\t attrs: {\n\t \"id\": \"muteWords\"\n\t },\n\t domProps: {\n\t \"value\": (_vm.muteWordsString)\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.muteWordsString = $event.target.value\n\t }\n\t }\n\t })]), _vm._v(\" \"), _c('div', [_c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.hideFilteredStatusesLocal),\n\t expression: \"hideFilteredStatusesLocal\"\n\t }],\n\t attrs: {\n\t \"type\": \"checkbox\",\n\t \"id\": \"hideFilteredStatuses\"\n\t },\n\t domProps: {\n\t \"checked\": Array.isArray(_vm.hideFilteredStatusesLocal) ? _vm._i(_vm.hideFilteredStatusesLocal, null) > -1 : (_vm.hideFilteredStatusesLocal)\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$a = _vm.hideFilteredStatusesLocal,\n\t $$el = $event.target,\n\t $$c = $$el.checked ? (true) : (false);\n\t if (Array.isArray($$a)) {\n\t var $$v = null,\n\t $$i = _vm._i($$a, $$v);\n\t if ($$el.checked) {\n\t $$i < 0 && (_vm.hideFilteredStatusesLocal = $$a.concat([$$v]))\n\t } else {\n\t $$i > -1 && (_vm.hideFilteredStatusesLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n\t }\n\t } else {\n\t _vm.hideFilteredStatusesLocal = $$c\n\t }\n\t }\n\t }\n\t }), _vm._v(\" \"), _c('label', {\n\t attrs: {\n\t \"for\": \"hideFilteredStatuses\"\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.hide_filtered_statuses')) + \" \" + _vm._s(_vm.$t('settings.instance_default', {\n\t value: _vm.hideFilteredStatusesDefault\n\t })) + \"\\n \")])])])])])], 1)], 1)])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 734 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"nav-panel\"\n\t }, [_c('div', {\n\t staticClass: \"panel panel-default\"\n\t }, [_c('ul', [(_vm.currentUser) ? _c('li', [_c('router-link', {\n\t attrs: {\n\t \"to\": {\n\t name: 'friends'\n\t }\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.timeline\")) + \"\\n \")])], 1) : _vm._e(), _vm._v(\" \"), (_vm.currentUser) ? _c('li', [_c('router-link', {\n\t attrs: {\n\t \"to\": {\n\t name: 'mentions',\n\t params: {\n\t username: _vm.currentUser.screen_name\n\t }\n\t }\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.mentions\")) + \"\\n \")])], 1) : _vm._e(), _vm._v(\" \"), (_vm.currentUser) ? _c('li', [_c('router-link', {\n\t attrs: {\n\t \"to\": {\n\t name: 'dms',\n\t params: {\n\t username: _vm.currentUser.screen_name\n\t }\n\t }\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.dms\")) + \"\\n \")])], 1) : _vm._e(), _vm._v(\" \"), (_vm.currentUser && _vm.currentUser.locked) ? _c('li', [_c('router-link', {\n\t attrs: {\n\t \"to\": {\n\t name: 'friend-requests'\n\t }\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.friend_requests\")) + \"\\n \"), (_vm.followRequestCount > 0) ? _c('span', {\n\t staticClass: \"badge follow-request-count\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.followRequestCount) + \"\\n \")]) : _vm._e()])], 1) : _vm._e(), _vm._v(\" \"), _c('li', [_c('router-link', {\n\t attrs: {\n\t \"to\": {\n\t name: 'public-timeline'\n\t }\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.public_tl\")) + \"\\n \")])], 1), _vm._v(\" \"), _c('li', [_c('router-link', {\n\t attrs: {\n\t \"to\": {\n\t name: 'public-external-timeline'\n\t }\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.twkn\")) + \"\\n \")])], 1)])])])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 735 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t ref: \"galleryContainer\",\n\t staticStyle: {\n\t \"width\": \"100%\"\n\t }\n\t }, _vm._l((_vm.rows), function(row) {\n\t return _c('div', {\n\t staticClass: \"gallery-row\",\n\t class: {\n\t 'contain-fit': _vm.useContainFit, 'cover-fit': !_vm.useContainFit\n\t },\n\t style: (_vm.rowHeight(row.length))\n\t }, _vm._l((row), function(attachment) {\n\t return _c('attachment', {\n\t key: attachment.id,\n\t attrs: {\n\t \"setMedia\": _vm.setMedia,\n\t \"nsfw\": _vm.nsfw,\n\t \"attachment\": attachment,\n\t \"allowPlay\": false\n\t }\n\t })\n\t }), 1)\n\t }), 0)\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 736 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"who-to-follow-panel\"\n\t }, [_c('div', {\n\t staticClass: \"panel panel-default base01-background\"\n\t }, [_c('div', {\n\t staticClass: \"panel-heading timeline-heading base02-background base04\"\n\t }, [_c('div', {\n\t staticClass: \"title\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('who_to_follow.who_to_follow')) + \"\\n \")])]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"panel-body who-to-follow\"\n\t }, [_vm._l((_vm.usersToFollow), function(user) {\n\t return _c('span', [_c('img', {\n\t attrs: {\n\t \"src\": user.img\n\t }\n\t }), _vm._v(\" \"), _c('router-link', {\n\t attrs: {\n\t \"to\": _vm.userProfileLink(user.id, user.name)\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(user.name) + \"\\n \")]), _c('br')], 1)\n\t }), _vm._v(\" \"), _c('img', {\n\t attrs: {\n\t \"src\": _vm.$store.state.instance.logo\n\t }\n\t }), _vm._v(\" \"), _c('router-link', {\n\t attrs: {\n\t \"to\": {\n\t name: 'who-to-follow'\n\t }\n\t }\n\t }, [_vm._v(_vm._s(_vm.$t('who_to_follow.more')))])], 2)])])\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 737 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"import-export-container\"\n\t }, [_vm._t(\"before\"), _vm._v(\" \"), _c('button', {\n\t staticClass: \"btn\",\n\t on: {\n\t \"click\": _vm.exportData\n\t }\n\t }, [_vm._v(_vm._s(_vm.exportLabel))]), _vm._v(\" \"), _c('button', {\n\t staticClass: \"btn\",\n\t on: {\n\t \"click\": _vm.importData\n\t }\n\t }, [_vm._v(_vm._s(_vm.importLabel))]), _vm._v(\" \"), _vm._t(\"afterButtons\"), _vm._v(\" \"), (_vm.importFailed) ? _c('p', {\n\t staticClass: \"alert error\"\n\t }, [_vm._v(_vm._s(_vm.importFailedText))]) : _vm._e(), _vm._v(\" \"), _vm._t(\"afterError\")], 2)\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 738 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"user-panel\"\n\t }, [(_vm.user) ? _c('div', {\n\t staticClass: \"panel panel-default\",\n\t staticStyle: {\n\t \"overflow\": \"visible\"\n\t }\n\t }, [_c('UserCard', {\n\t attrs: {\n\t \"user\": _vm.user,\n\t \"hideBio\": true,\n\t \"rounded\": \"top\"\n\t }\n\t }), _vm._v(\" \"), _c('div', {\n\t staticClass: \"panel-footer\"\n\t }, [(_vm.user) ? _c('post-status-form') : _vm._e()], 1)], 1) : _vm._e(), _vm._v(\" \"), (!_vm.user) ? _c('login-form') : _vm._e()], 1)\n\t},staticRenderFns: []}\n\n/***/ }),\n/* 739 */\n/***/ (function(module, exports) {\n\n\tmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n\t return _c('div', {\n\t staticClass: \"user-card\",\n\t class: _vm.classes,\n\t style: (_vm.style)\n\t }, [_c('div', {\n\t staticClass: \"panel-heading\"\n\t }, [_c('div', {\n\t staticClass: \"user-info\"\n\t }, [_c('div', {\n\t staticClass: \"container\"\n\t }, [_c('router-link', {\n\t attrs: {\n\t \"to\": _vm.userProfileLink(_vm.user)\n\t }\n\t }, [_c('UserAvatar', {\n\t attrs: {\n\t \"betterShadow\": _vm.betterShadow,\n\t \"src\": _vm.user.profile_image_url_original\n\t }\n\t })], 1), _vm._v(\" \"), _c('div', {\n\t staticClass: \"name-and-screen-name\"\n\t }, [_c('div', {\n\t staticClass: \"top-line\"\n\t }, [(_vm.user.name_html) ? _c('div', {\n\t staticClass: \"user-name\",\n\t attrs: {\n\t \"title\": _vm.user.name\n\t },\n\t domProps: {\n\t \"innerHTML\": _vm._s(_vm.user.name_html)\n\t }\n\t }) : _c('div', {\n\t staticClass: \"user-name\",\n\t attrs: {\n\t \"title\": _vm.user.name\n\t }\n\t }, [_vm._v(_vm._s(_vm.user.name))]), _vm._v(\" \"), (!_vm.isOtherUser) ? _c('router-link', {\n\t attrs: {\n\t \"to\": {\n\t name: 'user-settings'\n\t }\n\t }\n\t }, [_c('i', {\n\t staticClass: \"button-icon icon-pencil usersettings\",\n\t attrs: {\n\t \"title\": _vm.$t('tool_tip.user_settings')\n\t }\n\t })]) : _vm._e(), _vm._v(\" \"), (_vm.isOtherUser && !_vm.user.is_local) ? _c('a', {\n\t attrs: {\n\t \"href\": _vm.user.statusnet_profile_url,\n\t \"target\": \"_blank\"\n\t }\n\t }, [_c('i', {\n\t staticClass: \"icon-link-ext usersettings\"\n\t })]) : _vm._e()], 1), _vm._v(\" \"), _c('router-link', {\n\t staticClass: \"user-screen-name\",\n\t attrs: {\n\t \"to\": _vm.userProfileLink(_vm.user)\n\t }\n\t }, [_c('span', {\n\t staticClass: \"handle\"\n\t }, [_vm._v(\"@\" + _vm._s(_vm.user.screen_name) + \"\\n \"), (!_vm.hideBio && !!_vm.visibleRole) ? _c('span', {\n\t staticClass: \"alert staff\"\n\t }, [_vm._v(_vm._s(_vm.visibleRole))]) : _vm._e()]), (_vm.user.locked) ? _c('span', [_c('i', {\n\t staticClass: \"icon icon-lock\"\n\t })]) : _vm._e(), _vm._v(\" \"), (!_vm.hideUserStatsLocal && !_vm.hideBio) ? _c('span', {\n\t staticClass: \"dailyAvg\"\n\t }, [_vm._v(_vm._s(_vm.dailyAvg) + \" \" + _vm._s(_vm.$t('user_card.per_day')))]) : _vm._e()])], 1)], 1), _vm._v(\" \"), _c('div', {\n\t staticClass: \"user-meta\"\n\t }, [(_vm.user.follows_you && _vm.loggedIn && _vm.isOtherUser) ? _c('div', {\n\t staticClass: \"following\"\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follows_you')) + \"\\n \")]) : _vm._e(), _vm._v(\" \"), (_vm.isOtherUser && (_vm.loggedIn || !_vm.switcher)) ? _c('div', {\n\t staticClass: \"highlighter\"\n\t }, [(_vm.userHighlightType !== 'disabled') ? _c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.userHighlightColor),\n\t expression: \"userHighlightColor\"\n\t }],\n\t staticClass: \"userHighlightText\",\n\t attrs: {\n\t \"type\": \"text\",\n\t \"id\": 'userHighlightColorTx' + _vm.user.id\n\t },\n\t domProps: {\n\t \"value\": (_vm.userHighlightColor)\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.userHighlightColor = $event.target.value\n\t }\n\t }\n\t }) : _vm._e(), _vm._v(\" \"), (_vm.userHighlightType !== 'disabled') ? _c('input', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.userHighlightColor),\n\t expression: \"userHighlightColor\"\n\t }],\n\t staticClass: \"userHighlightCl\",\n\t attrs: {\n\t \"type\": \"color\",\n\t \"id\": 'userHighlightColor' + _vm.user.id\n\t },\n\t domProps: {\n\t \"value\": (_vm.userHighlightColor)\n\t },\n\t on: {\n\t \"input\": function($event) {\n\t if ($event.target.composing) { return; }\n\t _vm.userHighlightColor = $event.target.value\n\t }\n\t }\n\t }) : _vm._e(), _vm._v(\" \"), _c('label', {\n\t staticClass: \"userHighlightSel select\",\n\t attrs: {\n\t \"for\": \"style-switcher\"\n\t }\n\t }, [_c('select', {\n\t directives: [{\n\t name: \"model\",\n\t rawName: \"v-model\",\n\t value: (_vm.userHighlightType),\n\t expression: \"userHighlightType\"\n\t }],\n\t staticClass: \"userHighlightSel\",\n\t attrs: {\n\t \"id\": 'userHighlightSel' + _vm.user.id\n\t },\n\t on: {\n\t \"change\": function($event) {\n\t var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n\t return o.selected\n\t }).map(function(o) {\n\t var val = \"_value\" in o ? o._value : o.value;\n\t return val\n\t });\n\t _vm.userHighlightType = $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n\t }\n\t }\n\t }, [_c('option', {\n\t attrs: {\n\t \"value\": \"disabled\"\n\t }\n\t }, [_vm._v(\"No highlight\")]), _vm._v(\" \"), _c('option', {\n\t attrs: {\n\t \"value\": \"solid\"\n\t }\n\t }, [_vm._v(\"Solid bg\")]), _vm._v(\" \"), _c('option', {\n\t attrs: {\n\t \"value\": \"striped\"\n\t }\n\t }, [_vm._v(\"Striped bg\")]), _vm._v(\" \"), _c('option', {\n\t attrs: {\n\t \"value\": \"side\"\n\t }\n\t }, [_vm._v(\"Side stripe\")])]), _vm._v(\" \"), _c('i', {\n\t staticClass: \"icon-down-open\"\n\t })])]) : _vm._e()]), _vm._v(\" \"), (_vm.isOtherUser) ? _c('div', {\n\t staticClass: \"user-interactions\"\n\t }, [(_vm.loggedIn) ? _c('div', {\n\t staticClass: \"follow\"\n\t }, [(_vm.user.following) ? _c('span', [_c('button', {\n\t staticClass: \"pressed\",\n\t attrs: {\n\t \"disabled\": _vm.followRequestInProgress,\n\t \"title\": _vm.$t('user_card.follow_unfollow')\n\t },\n\t on: {\n\t \"click\": _vm.unfollowUser\n\t }\n\t }, [(_vm.followRequestInProgress) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follow_progress')) + \"\\n \")] : [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.following')) + \"\\n \")]], 2)]) : _vm._e(), _vm._v(\" \"), (!_vm.user.following) ? _c('span', [_c('button', {\n\t attrs: {\n\t \"disabled\": _vm.followRequestInProgress,\n\t \"title\": _vm.followRequestSent ? _vm.$t('user_card.follow_again') : ''\n\t },\n\t on: {\n\t \"click\": _vm.followUser\n\t }\n\t }, [(_vm.followRequestInProgress) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follow_progress')) + \"\\n \")] : (_vm.followRequestSent) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follow_sent')) + \"\\n \")] : [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follow')) + \"\\n \")]], 2)]) : _vm._e()]) : _vm._e(), _vm._v(\" \"), (_vm.isOtherUser && _vm.loggedIn) ? _c('div', {\n\t staticClass: \"mute\"\n\t }, [(_vm.user.muted) ? _c('span', [_c('button', {\n\t staticClass: \"pressed\",\n\t on: {\n\t \"click\": _vm.toggleMute\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.muted')) + \"\\n \")])]) : _vm._e(), _vm._v(\" \"), (!_vm.user.muted) ? _c('span', [_c('button', {\n\t on: {\n\t \"click\": _vm.toggleMute\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.mute')) + \"\\n \")])]) : _vm._e()]) : _vm._e(), _vm._v(\" \"), (!_vm.loggedIn && _vm.user.is_local) ? _c('div', {\n\t staticClass: \"remote-follow\"\n\t }, [_c('form', {\n\t attrs: {\n\t \"method\": \"POST\",\n\t \"action\": _vm.subscribeUrl\n\t }\n\t }, [_c('input', {\n\t attrs: {\n\t \"type\": \"hidden\",\n\t \"name\": \"nickname\"\n\t },\n\t domProps: {\n\t \"value\": _vm.user.screen_name\n\t }\n\t }), _vm._v(\" \"), _c('input', {\n\t attrs: {\n\t \"type\": \"hidden\",\n\t \"name\": \"profile\",\n\t \"value\": \"\"\n\t }\n\t }), _vm._v(\" \"), _c('button', {\n\t staticClass: \"remote-button\",\n\t attrs: {\n\t \"click\": \"submit\"\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.remote_follow')) + \"\\n \")])])]) : _vm._e(), _vm._v(\" \"), (_vm.isOtherUser && _vm.loggedIn) ? _c('div', {\n\t staticClass: \"block\"\n\t }, [(_vm.user.statusnet_blocking) ? _c('span', [_c('button', {\n\t staticClass: \"pressed\",\n\t on: {\n\t \"click\": _vm.unblockUser\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.blocked')) + \"\\n \")])]) : _vm._e(), _vm._v(\" \"), (!_vm.user.statusnet_blocking) ? _c('span', [_c('button', {\n\t on: {\n\t \"click\": _vm.blockUser\n\t }\n\t }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.block')) + \"\\n \")])]) : _vm._e()]) : _vm._e()]) : _vm._e()])]), _vm._v(\" \"), (!_vm.hideBio) ? _c('div', {\n\t staticClass: \"panel-body\"\n\t }, [(!_vm.hideUserStatsLocal && _vm.switcher) ? _c('div', {\n\t staticClass: \"user-counts\"\n\t }, [_c('div', {\n\t staticClass: \"user-count\",\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t _vm.setProfileView('statuses')\n\t }\n\t }\n\t }, [_c('h5', [_vm._v(_vm._s(_vm.$t('user_card.statuses')))]), _vm._v(\" \"), _c('span', [_vm._v(_vm._s(_vm.user.statuses_count) + \" \"), _c('br')])]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"user-count\",\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t _vm.setProfileView('friends')\n\t }\n\t }\n\t }, [_c('h5', [_vm._v(_vm._s(_vm.$t('user_card.followees')))]), _vm._v(\" \"), _c('span', [_vm._v(_vm._s(_vm.user.friends_count))])]), _vm._v(\" \"), _c('div', {\n\t staticClass: \"user-count\",\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t _vm.setProfileView('followers')\n\t }\n\t }\n\t }, [_c('h5', [_vm._v(_vm._s(_vm.$t('user_card.followers')))]), _vm._v(\" \"), _c('span', [_vm._v(_vm._s(_vm.user.followers_count))])])]) : _vm._e(), _vm._v(\" \"), (!_vm.hideBio && _vm.user.description_html) ? _c('p', {\n\t staticClass: \"user-card-bio\",\n\t domProps: {\n\t \"innerHTML\": _vm._s(_vm.user.description_html)\n\t },\n\t on: {\n\t \"click\": function($event) {\n\t $event.preventDefault();\n\t return _vm.linkClicked($event)\n\t }\n\t }\n\t }) : (!_vm.hideBio) ? _c('p', {\n\t staticClass: \"user-card-bio\"\n\t }, [_vm._v(_vm._s(_vm.user.description))]) : _vm._e()]) : _vm._e()])\n\t},staticRenderFns: []}\n\n/***/ })\n]);\n\n\n// WEBPACK FOOTER //\n// static/js/app.77434de4e756a5d79672.js","import Vue from 'vue'\nimport VueRouter from 'vue-router'\nimport Vuex from 'vuex'\n\nimport interfaceModule from './modules/interface.js'\nimport instanceModule from './modules/instance.js'\nimport statusesModule from './modules/statuses.js'\nimport usersModule from './modules/users.js'\nimport apiModule from './modules/api.js'\nimport configModule from './modules/config.js'\nimport chatModule from './modules/chat.js'\nimport oauthModule from './modules/oauth.js'\nimport mediaViewerModule from './modules/media_viewer.js'\nimport oauthTokensModule from './modules/oauth_tokens.js'\n\nimport VueTimeago from 'vue-timeago'\nimport VueI18n from 'vue-i18n'\n\nimport createPersistedState from './lib/persisted_state.js'\nimport pushNotifications from './lib/push_notifications_plugin.js'\n\nimport messages from './i18n/messages.js'\n\nimport VueChatScroll from 'vue-chat-scroll'\n\nimport afterStoreSetup from './boot/after_store.js'\n\nconst currentLocale = (window.navigator.language || 'en').split('-')[0]\n\nVue.use(Vuex)\nVue.use(VueRouter)\nVue.use(VueTimeago, {\n locale: currentLocale === 'cs' ? 'cs' : currentLocale === 'ja' ? 'ja' : 'en',\n locales: {\n 'cs': require('../static/timeago-cs.json'),\n 'en': require('../static/timeago-en.json'),\n 'ja': require('../static/timeago-ja.json')\n }\n})\nVue.use(VueI18n)\nVue.use(VueChatScroll)\n\nconst i18n = new VueI18n({\n // By default, use the browser locale, we will update it if neccessary\n locale: currentLocale,\n fallbackLocale: 'en',\n messages\n})\n\nconst persistedStateOptions = {\n paths: [\n 'config',\n 'users.lastLoginName',\n 'oauth'\n ]\n}\n\ncreatePersistedState(persistedStateOptions).then((persistedState) => {\n const store = new Vuex.Store({\n modules: {\n interface: interfaceModule,\n instance: instanceModule,\n statuses: statusesModule,\n users: usersModule,\n api: apiModule,\n config: configModule,\n chat: chatModule,\n oauth: oauthModule,\n mediaViewer: mediaViewerModule,\n oauthTokens: oauthTokensModule\n },\n plugins: [persistedState, pushNotifications],\n strict: false // Socket modifies itself, let's ignore this for now.\n // strict: process.env.NODE_ENV !== 'production'\n })\n\n afterStoreSetup({ store, i18n })\n})\n\n// These are inlined by webpack's DefinePlugin\n/* eslint-disable */\nwindow.___pleromafe_mode = process.env\nwindow.___pleromafe_commit_hash = COMMIT_HASH\nwindow.___pleromafe_dev_overrides = DEV_OVERRIDES\n\n\n\n// WEBPACK FOOTER //\n// ./src/main.js","/* eslint-env browser */\nconst LOGIN_URL = '/api/account/verify_credentials.json'\nconst FRIENDS_TIMELINE_URL = '/api/statuses/friends_timeline.json'\nconst ALL_FOLLOWING_URL = '/api/qvitter/allfollowing'\nconst PUBLIC_TIMELINE_URL = '/api/statuses/public_timeline.json'\nconst PUBLIC_AND_EXTERNAL_TIMELINE_URL = '/api/statuses/public_and_external_timeline.json'\nconst TAG_TIMELINE_URL = '/api/statusnet/tags/timeline'\nconst FAVORITE_URL = '/api/favorites/create'\nconst UNFAVORITE_URL = '/api/favorites/destroy'\nconst RETWEET_URL = '/api/statuses/retweet'\nconst UNRETWEET_URL = '/api/statuses/unretweet'\nconst STATUS_UPDATE_URL = '/api/statuses/update.json'\nconst STATUS_DELETE_URL = '/api/statuses/destroy'\nconst STATUS_URL = '/api/statuses/show'\nconst MEDIA_UPLOAD_URL = '/api/statusnet/media/upload'\nconst CONVERSATION_URL = '/api/statusnet/conversation'\nconst MENTIONS_URL = '/api/statuses/mentions.json'\nconst DM_TIMELINE_URL = '/api/statuses/dm_timeline.json'\nconst FOLLOWERS_URL = '/api/statuses/followers.json'\nconst FRIENDS_URL = '/api/statuses/friends.json'\nconst BLOCKS_URL = '/api/statuses/blocks.json'\nconst FOLLOWING_URL = '/api/friendships/create.json'\nconst UNFOLLOWING_URL = '/api/friendships/destroy.json'\nconst QVITTER_USER_PREF_URL = '/api/qvitter/set_profile_pref.json'\nconst REGISTRATION_URL = '/api/account/register.json'\nconst AVATAR_UPDATE_URL = '/api/qvitter/update_avatar.json'\nconst BG_UPDATE_URL = '/api/qvitter/update_background_image.json'\nconst BANNER_UPDATE_URL = '/api/account/update_profile_banner.json'\nconst PROFILE_UPDATE_URL = '/api/account/update_profile.json'\nconst EXTERNAL_PROFILE_URL = '/api/externalprofile/show.json'\nconst QVITTER_USER_TIMELINE_URL = '/api/qvitter/statuses/user_timeline.json'\nconst QVITTER_USER_NOTIFICATIONS_URL = '/api/qvitter/statuses/notifications.json'\nconst QVITTER_USER_NOTIFICATIONS_READ_URL = '/api/qvitter/statuses/notifications/read.json'\nconst BLOCKING_URL = '/api/blocks/create.json'\nconst UNBLOCKING_URL = '/api/blocks/destroy.json'\nconst USER_URL = '/api/users/show.json'\nconst FOLLOW_IMPORT_URL = '/api/pleroma/follow_import'\nconst DELETE_ACCOUNT_URL = '/api/pleroma/delete_account'\nconst CHANGE_PASSWORD_URL = '/api/pleroma/change_password'\nconst FOLLOW_REQUESTS_URL = '/api/pleroma/friend_requests'\nconst APPROVE_USER_URL = '/api/pleroma/friendships/approve'\nconst DENY_USER_URL = '/api/pleroma/friendships/deny'\nconst SUGGESTIONS_URL = '/api/v1/suggestions'\n\nconst MASTODON_USER_FAVORITES_TIMELINE_URL = '/api/v1/favourites'\n\nimport { each, map } from 'lodash'\nimport { parseStatus, parseUser, parseNotification } from '../entity_normalizer/entity_normalizer.service.js'\nimport 'whatwg-fetch'\nimport { StatusCodeError } from '../errors/errors'\n\nconst oldfetch = window.fetch\n\nlet fetch = (url, options) => {\n options = options || {}\n const baseUrl = ''\n const fullUrl = baseUrl + url\n options.credentials = 'same-origin'\n return oldfetch(fullUrl, options)\n}\n\n// Params\n// cropH\n// cropW\n// cropX\n// cropY\n// img (base 64 encodend data url)\nconst updateAvatar = ({credentials, params}) => {\n let url = AVATAR_UPDATE_URL\n\n const form = new FormData()\n\n each(params, (value, key) => {\n if (value) {\n form.append(key, value)\n }\n })\n\n return fetch(url, {\n headers: authHeaders(credentials),\n method: 'POST',\n body: form\n }).then((data) => data.json())\n}\n\nconst updateBg = ({credentials, params}) => {\n let url = BG_UPDATE_URL\n\n const form = new FormData()\n\n each(params, (value, key) => {\n if (value) {\n form.append(key, value)\n }\n })\n\n return fetch(url, {\n headers: authHeaders(credentials),\n method: 'POST',\n body: form\n }).then((data) => data.json())\n}\n\n// Params\n// height\n// width\n// offset_left\n// offset_top\n// banner (base 64 encodend data url)\nconst updateBanner = ({credentials, params}) => {\n let url = BANNER_UPDATE_URL\n\n const form = new FormData()\n\n each(params, (value, key) => {\n if (value) {\n form.append(key, value)\n }\n })\n\n return fetch(url, {\n headers: authHeaders(credentials),\n method: 'POST',\n body: form\n }).then((data) => data.json())\n}\n\n// Params\n// name\n// url\n// location\n// description\nconst updateProfile = ({credentials, params}) => {\n // Always include these fields, because they might be empty or false\n const fields = ['description', 'locked', 'no_rich_text', 'hide_follows', 'hide_followers', 'show_role']\n let url = PROFILE_UPDATE_URL\n\n const form = new FormData()\n\n each(params, (value, key) => {\n if (fields.includes(key) || value) {\n form.append(key, value)\n }\n })\n return fetch(url, {\n headers: authHeaders(credentials),\n method: 'POST',\n body: form\n }).then((data) => data.json())\n}\n\n// Params needed:\n// nickname\n// email\n// fullname\n// password\n// password_confirm\n//\n// Optional\n// bio\n// homepage\n// location\n// token\nconst register = (params) => {\n const form = new FormData()\n\n each(params, (value, key) => {\n if (value) {\n form.append(key, value)\n }\n })\n\n return fetch(REGISTRATION_URL, {\n method: 'POST',\n body: form\n })\n}\n\nconst getCaptcha = () => fetch('/api/pleroma/captcha').then(resp => resp.json())\n\nconst authHeaders = (accessToken) => {\n if (accessToken) {\n return { 'Authorization': `Bearer ${accessToken}` }\n } else {\n return { }\n }\n}\n\nconst externalProfile = ({profileUrl, credentials}) => {\n let url = `${EXTERNAL_PROFILE_URL}?profileurl=${profileUrl}`\n return fetch(url, {\n headers: authHeaders(credentials),\n method: 'GET'\n }).then((data) => data.json())\n}\n\nconst followUser = ({id, credentials}) => {\n let url = `${FOLLOWING_URL}?user_id=${id}`\n return fetch(url, {\n headers: authHeaders(credentials),\n method: 'POST'\n }).then((data) => data.json())\n}\n\nconst unfollowUser = ({id, credentials}) => {\n let url = `${UNFOLLOWING_URL}?user_id=${id}`\n return fetch(url, {\n headers: authHeaders(credentials),\n method: 'POST'\n }).then((data) => data.json())\n}\n\nconst blockUser = ({id, credentials}) => {\n let url = `${BLOCKING_URL}?user_id=${id}`\n return fetch(url, {\n headers: authHeaders(credentials),\n method: 'POST'\n }).then((data) => data.json())\n}\n\nconst unblockUser = ({id, credentials}) => {\n let url = `${UNBLOCKING_URL}?user_id=${id}`\n return fetch(url, {\n headers: authHeaders(credentials),\n method: 'POST'\n }).then((data) => data.json())\n}\n\nconst approveUser = ({id, credentials}) => {\n let url = `${APPROVE_USER_URL}?user_id=${id}`\n return fetch(url, {\n headers: authHeaders(credentials),\n method: 'POST'\n }).then((data) => data.json())\n}\n\nconst denyUser = ({id, credentials}) => {\n let url = `${DENY_USER_URL}?user_id=${id}`\n return fetch(url, {\n headers: authHeaders(credentials),\n method: 'POST'\n }).then((data) => data.json())\n}\n\nconst fetchUser = ({id, credentials}) => {\n let url = `${USER_URL}?user_id=${id}`\n return fetch(url, { headers: authHeaders(credentials) })\n .then((response) => {\n return new Promise((resolve, reject) => response.json()\n .then((json) => {\n if (!response.ok) {\n return reject(new StatusCodeError(response.status, json, { url }, response))\n }\n return resolve(json)\n }))\n })\n .then((data) => parseUser(data))\n}\n\nconst fetchFriends = ({id, page, credentials}) => {\n let url = `${FRIENDS_URL}?user_id=${id}`\n if (page) {\n url = url + `&page=${page}`\n }\n return fetch(url, { headers: authHeaders(credentials) })\n .then((data) => data.json())\n .then((data) => data.map(parseUser))\n}\n\nconst exportFriends = ({id, credentials}) => {\n let url = `${FRIENDS_URL}?user_id=${id}&all=true`\n return fetch(url, { headers: authHeaders(credentials) })\n .then((data) => data.json())\n .then((data) => data.map(parseUser))\n}\n\nconst fetchFollowers = ({id, page, credentials}) => {\n let url = `${FOLLOWERS_URL}?user_id=${id}`\n if (page) {\n url = url + `&page=${page}`\n }\n return fetch(url, { headers: authHeaders(credentials) })\n .then((data) => data.json())\n .then((data) => data.map(parseUser))\n}\n\nconst fetchAllFollowing = ({username, credentials}) => {\n const url = `${ALL_FOLLOWING_URL}/${username}.json`\n return fetch(url, { headers: authHeaders(credentials) })\n .then((data) => data.json())\n .then((data) => data.map(parseUser))\n}\n\nconst fetchFollowRequests = ({credentials}) => {\n const url = FOLLOW_REQUESTS_URL\n return fetch(url, { headers: authHeaders(credentials) })\n .then((data) => data.json())\n}\n\nconst fetchConversation = ({id, credentials}) => {\n let url = `${CONVERSATION_URL}/${id}.json?count=100`\n return fetch(url, { headers: authHeaders(credentials) })\n .then((data) => {\n if (data.ok) {\n return data\n }\n throw new Error('Error fetching timeline', data)\n })\n .then((data) => data.json())\n .then((data) => data.map(parseStatus))\n}\n\nconst fetchStatus = ({id, credentials}) => {\n let url = `${STATUS_URL}/${id}.json`\n return fetch(url, { headers: authHeaders(credentials) })\n .then((data) => {\n if (data.ok) {\n return data\n }\n throw new Error('Error fetching timeline', data)\n })\n .then((data) => data.json())\n .then((data) => parseStatus(data))\n}\n\nconst setUserMute = ({id, credentials, muted = true}) => {\n const form = new FormData()\n\n const muteInteger = muted ? 1 : 0\n\n form.append('namespace', 'qvitter')\n form.append('data', muteInteger)\n form.append('topic', `mute:${id}`)\n\n return fetch(QVITTER_USER_PREF_URL, {\n method: 'POST',\n headers: authHeaders(credentials),\n body: form\n })\n}\n\nconst fetchTimeline = ({timeline, credentials, since = false, until = false, userId = false, tag = false}) => {\n const timelineUrls = {\n public: PUBLIC_TIMELINE_URL,\n friends: FRIENDS_TIMELINE_URL,\n mentions: MENTIONS_URL,\n dms: DM_TIMELINE_URL,\n notifications: QVITTER_USER_NOTIFICATIONS_URL,\n 'publicAndExternal': PUBLIC_AND_EXTERNAL_TIMELINE_URL,\n user: QVITTER_USER_TIMELINE_URL,\n media: QVITTER_USER_TIMELINE_URL,\n favorites: MASTODON_USER_FAVORITES_TIMELINE_URL,\n tag: TAG_TIMELINE_URL\n }\n const isNotifications = timeline === 'notifications'\n const params = []\n\n let url = timelineUrls[timeline]\n\n if (since) {\n params.push(['since_id', since])\n }\n if (until) {\n params.push(['max_id', until])\n }\n if (userId) {\n params.push(['user_id', userId])\n }\n if (tag) {\n url += `/${tag}.json`\n }\n if (timeline === 'media') {\n params.push(['only_media', 1])\n }\n\n params.push(['count', 20])\n\n const queryString = map(params, (param) => `${param[0]}=${param[1]}`).join('&')\n url += `?${queryString}`\n\n return fetch(url, { headers: authHeaders(credentials) })\n .then((data) => {\n if (data.ok) {\n return data\n }\n throw new Error('Error fetching timeline', data)\n })\n .then((data) => data.json())\n .then((data) => data.map(isNotifications ? parseNotification : parseStatus))\n}\n\nconst verifyCredentials = (user) => {\n return fetch(LOGIN_URL, {\n method: 'POST',\n headers: authHeaders(user)\n })\n .then((response) => {\n if (response.ok) {\n return response.json()\n } else {\n return {\n error: response\n }\n }\n })\n .then((data) => data.error ? data : parseUser(data))\n}\n\nconst favorite = ({ id, credentials }) => {\n return fetch(`${FAVORITE_URL}/${id}.json`, {\n headers: authHeaders(credentials),\n method: 'POST'\n })\n}\n\nconst unfavorite = ({ id, credentials }) => {\n return fetch(`${UNFAVORITE_URL}/${id}.json`, {\n headers: authHeaders(credentials),\n method: 'POST'\n })\n}\n\nconst retweet = ({ id, credentials }) => {\n return fetch(`${RETWEET_URL}/${id}.json`, {\n headers: authHeaders(credentials),\n method: 'POST'\n })\n}\n\nconst unretweet = ({ id, credentials }) => {\n return fetch(`${UNRETWEET_URL}/${id}.json`, {\n headers: authHeaders(credentials),\n method: 'POST'\n })\n}\n\nconst postStatus = ({credentials, status, spoilerText, visibility, sensitive, mediaIds, inReplyToStatusId, contentType, noAttachmentLinks}) => {\n const idsText = mediaIds.join(',')\n const form = new FormData()\n\n form.append('status', status)\n form.append('source', 'Pleroma FE')\n if (noAttachmentLinks) form.append('no_attachment_links', noAttachmentLinks)\n if (spoilerText) form.append('spoiler_text', spoilerText)\n if (visibility) form.append('visibility', visibility)\n if (sensitive) form.append('sensitive', sensitive)\n if (contentType) form.append('content_type', contentType)\n form.append('media_ids', idsText)\n if (inReplyToStatusId) {\n form.append('in_reply_to_status_id', inReplyToStatusId)\n }\n\n return fetch(STATUS_UPDATE_URL, {\n body: form,\n method: 'POST',\n headers: authHeaders(credentials)\n })\n .then((response) => {\n if (response.ok) {\n return response.json()\n } else {\n return {\n error: response\n }\n }\n })\n .then((data) => data.error ? data : parseStatus(data))\n}\n\nconst deleteStatus = ({ id, credentials }) => {\n return fetch(`${STATUS_DELETE_URL}/${id}.json`, {\n headers: authHeaders(credentials),\n method: 'POST'\n })\n}\n\nconst uploadMedia = ({formData, credentials}) => {\n return fetch(MEDIA_UPLOAD_URL, {\n body: formData,\n method: 'POST',\n headers: authHeaders(credentials)\n })\n .then((response) => response.text())\n .then((text) => (new DOMParser()).parseFromString(text, 'application/xml'))\n}\n\nconst followImport = ({params, credentials}) => {\n return fetch(FOLLOW_IMPORT_URL, {\n body: params,\n method: 'POST',\n headers: authHeaders(credentials)\n })\n .then((response) => response.ok)\n}\n\nconst deleteAccount = ({credentials, password}) => {\n const form = new FormData()\n\n form.append('password', password)\n\n return fetch(DELETE_ACCOUNT_URL, {\n body: form,\n method: 'POST',\n headers: authHeaders(credentials)\n })\n .then((response) => response.json())\n}\n\nconst changePassword = ({credentials, password, newPassword, newPasswordConfirmation}) => {\n const form = new FormData()\n\n form.append('password', password)\n form.append('new_password', newPassword)\n form.append('new_password_confirmation', newPasswordConfirmation)\n\n return fetch(CHANGE_PASSWORD_URL, {\n body: form,\n method: 'POST',\n headers: authHeaders(credentials)\n })\n .then((response) => response.json())\n}\n\nconst fetchMutes = ({credentials}) => {\n const url = '/api/qvitter/mutes.json'\n\n return fetch(url, {\n headers: authHeaders(credentials)\n }).then((data) => data.json())\n}\n\nconst fetchBlocks = ({page, credentials}) => {\n return fetch(BLOCKS_URL, {\n headers: authHeaders(credentials)\n }).then((data) => {\n if (data.ok) {\n return data.json()\n }\n throw new Error('Error fetching blocks', data)\n })\n}\n\nconst fetchOAuthTokens = ({credentials}) => {\n const url = '/api/oauth_tokens.json'\n\n return fetch(url, {\n headers: authHeaders(credentials)\n }).then((data) => data.json())\n}\n\nconst revokeOAuthToken = ({id, credentials}) => {\n const url = `/api/oauth_tokens/${id}`\n\n return fetch(url, {\n headers: authHeaders(credentials),\n method: 'DELETE'\n })\n}\n\nconst suggestions = ({credentials}) => {\n return fetch(SUGGESTIONS_URL, {\n headers: authHeaders(credentials)\n }).then((data) => data.json())\n}\n\nconst markNotificationsAsSeen = ({id, credentials}) => {\n const body = new FormData()\n\n body.append('latest_id', id)\n\n return fetch(QVITTER_USER_NOTIFICATIONS_READ_URL, {\n body,\n headers: authHeaders(credentials),\n method: 'POST'\n }).then((data) => data.json())\n}\n\nconst apiService = {\n verifyCredentials,\n fetchTimeline,\n fetchConversation,\n fetchStatus,\n fetchFriends,\n exportFriends,\n fetchFollowers,\n followUser,\n unfollowUser,\n blockUser,\n unblockUser,\n fetchUser,\n favorite,\n unfavorite,\n retweet,\n unretweet,\n postStatus,\n deleteStatus,\n uploadMedia,\n fetchAllFollowing,\n setUserMute,\n fetchMutes,\n fetchBlocks,\n fetchOAuthTokens,\n revokeOAuthToken,\n register,\n getCaptcha,\n updateAvatar,\n updateBg,\n updateProfile,\n updateBanner,\n externalProfile,\n followImport,\n deleteAccount,\n changePassword,\n fetchFollowRequests,\n approveUser,\n denyUser,\n suggestions,\n markNotificationsAsSeen\n}\n\nexport default apiService\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/api/api.service.js","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-0652fc80\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./timeline.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./timeline.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-0652fc80\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./timeline.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/timeline/timeline.vue\n// module id = 34\n// module chunks = 2","import { includes } from 'lodash'\n\nconst generateProfileLink = (id, screenName, restrictedNicknames) => {\n const complicated = (isExternal(screenName) || includes(restrictedNicknames, screenName))\n return {\n name: (complicated ? 'external-user-profile' : 'user-profile'),\n params: (complicated ? { id } : { name: screenName })\n }\n}\n\nconst isExternal = screenName => screenName && screenName.includes('@')\n\nexport default generateProfileLink\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/user_profile_link_generator/user_profile_link_generator.js","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-f117c42c\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./user_card.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./user_card.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-f117c42c\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./user_card.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/user_card/user_card.vue\n// module id = 43\n// module chunks = 2","import { map } from 'lodash'\n\nconst rgb2hex = (r, g, b) => {\n if (r === null || typeof r === 'undefined') {\n return undefined\n }\n if (r[0] === '#') {\n return r\n }\n if (typeof r === 'object') {\n ({ r, g, b } = r)\n }\n [r, g, b] = map([r, g, b], (val) => {\n val = Math.ceil(val)\n val = val < 0 ? 0 : val\n val = val > 255 ? 255 : val\n return val\n })\n return `#${((1 << 24) + (r << 16) + (g << 8) + b).toString(16).slice(1)}`\n}\n\n/**\n * Converts 8-bit RGB component into linear component\n * https://www.w3.org/TR/2008/REC-WCAG20-20081211/#relativeluminancedef\n * https://www.w3.org/TR/2008/REC-WCAG20-20081211/relative-luminance.xml\n * https://en.wikipedia.org/wiki/SRGB#The_reverse_transformation\n *\n * @param {Number} bit - color component [0..255]\n * @returns {Number} linear component [0..1]\n */\nconst c2linear = (bit) => {\n // W3C gives 0.03928 while wikipedia states 0.04045\n // what those magical numbers mean - I don't know.\n // something about gamma-correction, i suppose.\n // Sticking with W3C example.\n const c = bit / 255\n if (c < 0.03928) {\n return c / 12.92\n } else {\n return Math.pow((c + 0.055) / 1.055, 2.4)\n }\n}\n\n/**\n * Converts sRGB into linear RGB\n * @param {Object} srgb - sRGB color\n * @returns {Object} linear rgb color\n */\nconst srgbToLinear = (srgb) => {\n return 'rgb'.split('').reduce((acc, c) => { acc[c] = c2linear(srgb[c]); return acc }, {})\n}\n\n/**\n * Calculates relative luminance for given color\n * https://www.w3.org/TR/2008/REC-WCAG20-20081211/#relativeluminancedef\n * https://www.w3.org/TR/2008/REC-WCAG20-20081211/relative-luminance.xml\n *\n * @param {Object} srgb - sRGB color\n * @returns {Number} relative luminance\n */\nconst relativeLuminance = (srgb) => {\n const {r, g, b} = srgbToLinear(srgb)\n return 0.2126 * r + 0.7152 * g + 0.0722 * b\n}\n\n/**\n * Generates color ratio between two colors. Order is unimporant\n * https://www.w3.org/TR/2008/REC-WCAG20-20081211/#contrast-ratiodef\n *\n * @param {Object} a - sRGB color\n * @param {Object} b - sRGB color\n * @returns {Number} color ratio\n */\nconst getContrastRatio = (a, b) => {\n const la = relativeLuminance(a)\n const lb = relativeLuminance(b)\n const [l1, l2] = la > lb ? [la, lb] : [lb, la]\n\n return (l1 + 0.05) / (l2 + 0.05)\n}\n\n/**\n * This performs alpha blending between solid background and semi-transparent foreground\n *\n * @param {Object} fg - top layer color\n * @param {Number} fga - top layer's alpha\n * @param {Object} bg - bottom layer color\n * @returns {Object} sRGB of resulting color\n */\nconst alphaBlend = (fg, fga, bg) => {\n if (fga === 1 || typeof fga === 'undefined') return fg\n return 'rgb'.split('').reduce((acc, c) => {\n // Simplified https://en.wikipedia.org/wiki/Alpha_compositing#Alpha_blending\n // for opaque bg and transparent fg\n acc[c] = (fg[c] * fga + bg[c] * (1 - fga))\n return acc\n }, {})\n}\n\nconst invert = (rgb) => {\n return 'rgb'.split('').reduce((acc, c) => {\n acc[c] = 255 - rgb[c]\n return acc\n }, {})\n}\n\nconst hex2rgb = (hex) => {\n const result = /^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(hex)\n return result ? {\n r: parseInt(result[1], 16),\n g: parseInt(result[2], 16),\n b: parseInt(result[3], 16)\n } : null\n}\n\nconst mixrgb = (a, b) => {\n return Object.keys(a).reduce((acc, k) => {\n acc[k] = (a[k] + b[k]) / 2\n return acc\n }, {})\n}\n\nexport {\n rgb2hex,\n hex2rgb,\n mixrgb,\n invert,\n getContrastRatio,\n alphaBlend\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/color_convert/color_convert.js","// TODO this func might as well take the entire file and use its mimetype\n// or the entire service could be just mimetype service that only operates\n// on mimetypes and not files. Currently the naming is confusing.\nconst fileType = mimetype => {\n if (mimetype.match(/text\\/html/)) {\n return 'html'\n }\n\n if (mimetype.match(/image/)) {\n return 'image'\n }\n\n if (mimetype.match(/video/)) {\n return 'video'\n }\n\n if (mimetype.match(/audio/)) {\n return 'audio'\n }\n\n return 'unknown'\n}\n\nconst fileMatchesSomeType = (types, file) =>\n types.some(type => fileType(file.mimetype) === type)\n\nconst fileTypeService = {\n fileType,\n fileMatchesSomeType\n}\n\nexport default fileTypeService\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/file_type/file_type.service.js","import { times } from 'lodash'\nimport { brightness, invertLightness, convert, contrastRatio } from 'chromatism'\nimport { rgb2hex, hex2rgb, mixrgb, getContrastRatio, alphaBlend } from '../color_convert/color_convert.js'\n\n// While this is not used anymore right now, I left it in if we want to do custom\n// styles that aren't just colors, so user can pick from a few different distinct\n// styles as well as set their own colors in the future.\n\nconst setStyle = (href, commit) => {\n /***\n What's going on here?\n I want to make it easy for admins to style this application. To have\n a good set of default themes, I chose the system from base16\n (https://chriskempson.github.io/base16/) to style all elements. They\n all have the base00..0F classes. So the only thing an admin needs to\n do to style Pleroma is to change these colors in that one css file.\n Some default things (body text color, link color) need to be set dy-\n namically, so this is done here by waiting for the stylesheet to be\n loaded and then creating an element with the respective classes.\n\n It is a bit weird, but should make life for admins somewhat easier.\n ***/\n const head = document.head\n const body = document.body\n body.style.display = 'none'\n const cssEl = document.createElement('link')\n cssEl.setAttribute('rel', 'stylesheet')\n cssEl.setAttribute('href', href)\n head.appendChild(cssEl)\n\n const setDynamic = () => {\n const baseEl = document.createElement('div')\n body.appendChild(baseEl)\n\n let colors = {}\n times(16, (n) => {\n const name = `base0${n.toString(16).toUpperCase()}`\n baseEl.setAttribute('class', name)\n const color = window.getComputedStyle(baseEl).getPropertyValue('color')\n colors[name] = color\n })\n\n body.removeChild(baseEl)\n\n const styleEl = document.createElement('style')\n head.appendChild(styleEl)\n // const styleSheet = styleEl.sheet\n\n body.style.display = 'initial'\n }\n\n cssEl.addEventListener('load', setDynamic)\n}\n\nconst rgb2rgba = function (rgba) {\n return `rgba(${rgba.r}, ${rgba.g}, ${rgba.b}, ${rgba.a})`\n}\n\nconst getTextColor = function (bg, text, preserve) {\n const bgIsLight = convert(bg).hsl.l > 50\n const textIsLight = convert(text).hsl.l > 50\n\n if ((bgIsLight && textIsLight) || (!bgIsLight && !textIsLight)) {\n const base = typeof text.a !== 'undefined' ? { a: text.a } : {}\n const result = Object.assign(base, invertLightness(text).rgb)\n if (!preserve && getContrastRatio(bg, result) < 4.5) {\n return contrastRatio(bg, text).rgb\n }\n return result\n }\n return text\n}\n\nconst applyTheme = (input, commit) => {\n const { rules, theme } = generatePreset(input)\n const head = document.head\n const body = document.body\n body.style.display = 'none'\n\n const styleEl = document.createElement('style')\n head.appendChild(styleEl)\n const styleSheet = styleEl.sheet\n\n styleSheet.toString()\n styleSheet.insertRule(`body { ${rules.radii} }`, 'index-max')\n styleSheet.insertRule(`body { ${rules.colors} }`, 'index-max')\n styleSheet.insertRule(`body { ${rules.shadows} }`, 'index-max')\n styleSheet.insertRule(`body { ${rules.fonts} }`, 'index-max')\n body.style.display = 'initial'\n\n // commit('setOption', { name: 'colors', value: htmlColors })\n // commit('setOption', { name: 'radii', value: radii })\n commit('setOption', { name: 'customTheme', value: input })\n commit('setOption', { name: 'colors', value: theme.colors })\n}\n\nconst getCssShadow = (input, usesDropShadow) => {\n if (input.length === 0) {\n return 'none'\n }\n\n return input\n .filter(_ => usesDropShadow ? _.inset : _)\n .map((shad) => [\n shad.x,\n shad.y,\n shad.blur,\n shad.spread\n ].map(_ => _ + 'px').concat([\n getCssColor(shad.color, shad.alpha),\n shad.inset ? 'inset' : ''\n ]).join(' ')).join(', ')\n}\n\nconst getCssShadowFilter = (input) => {\n if (input.length === 0) {\n return 'none'\n }\n\n return input\n // drop-shadow doesn't support inset or spread\n .filter((shad) => !shad.inset && Number(shad.spread) === 0)\n .map((shad) => [\n shad.x,\n shad.y,\n // drop-shadow's blur is twice as strong compared to box-shadow\n shad.blur / 2\n ].map(_ => _ + 'px').concat([\n getCssColor(shad.color, shad.alpha)\n ]).join(' '))\n .map(_ => `drop-shadow(${_})`)\n .join(' ')\n}\n\nconst getCssColor = (input, a) => {\n let rgb = {}\n if (typeof input === 'object') {\n rgb = input\n } else if (typeof input === 'string') {\n if (input.startsWith('#')) {\n rgb = hex2rgb(input)\n } else if (input.startsWith('--')) {\n return `var(${input})`\n } else {\n return input\n }\n }\n return rgb2rgba({ ...rgb, a })\n}\n\nconst generateColors = (input) => {\n const colors = {}\n const opacity = Object.assign({\n alert: 0.5,\n input: 0.5,\n faint: 0.5\n }, Object.entries(input.opacity || {}).reduce((acc, [k, v]) => {\n if (typeof v !== 'undefined') {\n acc[k] = v\n }\n return acc\n }, {}))\n const col = Object.entries(input.colors || input).reduce((acc, [k, v]) => {\n if (typeof v === 'object') {\n acc[k] = v\n } else {\n acc[k] = hex2rgb(v)\n }\n return acc\n }, {})\n\n const isLightOnDark = convert(col.bg).hsl.l < convert(col.text).hsl.l\n const mod = isLightOnDark ? 1 : -1\n\n colors.text = col.text\n colors.lightText = brightness(20 * mod, colors.text).rgb\n colors.link = col.link\n colors.faint = col.faint || Object.assign({}, col.text)\n\n colors.bg = col.bg\n colors.lightBg = col.lightBg || brightness(5, colors.bg).rgb\n\n colors.fg = col.fg\n colors.fgText = col.fgText || getTextColor(colors.fg, colors.text)\n colors.fgLink = col.fgLink || getTextColor(colors.fg, colors.link, true)\n\n colors.border = col.border || brightness(2 * mod, colors.fg).rgb\n\n colors.btn = col.btn || Object.assign({}, col.fg)\n colors.btnText = col.btnText || getTextColor(colors.btn, colors.fgText)\n\n colors.input = col.input || Object.assign({}, col.fg)\n colors.inputText = col.inputText || getTextColor(colors.input, colors.lightText)\n\n colors.panel = col.panel || Object.assign({}, col.fg)\n colors.panelText = col.panelText || getTextColor(colors.panel, colors.fgText)\n colors.panelLink = col.panelLink || getTextColor(colors.panel, colors.fgLink)\n colors.panelFaint = col.panelFaint || getTextColor(colors.panel, colors.faint)\n\n colors.topBar = col.topBar || Object.assign({}, col.fg)\n colors.topBarText = col.topBarText || getTextColor(colors.topBar, colors.fgText)\n colors.topBarLink = col.topBarLink || getTextColor(colors.topBar, colors.fgLink)\n\n colors.faintLink = col.faintLink || Object.assign({}, col.link)\n\n colors.icon = mixrgb(colors.bg, colors.text)\n\n colors.cBlue = col.cBlue || hex2rgb('#0000FF')\n colors.cRed = col.cRed || hex2rgb('#FF0000')\n colors.cGreen = col.cGreen || hex2rgb('#00FF00')\n colors.cOrange = col.cOrange || hex2rgb('#E3FF00')\n\n colors.alertError = col.alertError || Object.assign({}, colors.cRed)\n colors.alertErrorText = getTextColor(alphaBlend(colors.alertError, opacity.alert, colors.bg), colors.text)\n colors.alertErrorPanelText = getTextColor(alphaBlend(colors.alertError, opacity.alert, colors.panel), colors.panelText)\n\n colors.badgeNotification = col.badgeNotification || Object.assign({}, colors.cRed)\n colors.badgeNotificationText = contrastRatio(colors.badgeNotification).rgb\n\n Object.entries(opacity).forEach(([ k, v ]) => {\n if (typeof v === 'undefined') return\n if (k === 'alert') {\n colors.alertError.a = v\n return\n }\n if (k === 'faint') {\n colors[k + 'Link'].a = v\n colors['panelFaint'].a = v\n }\n if (k === 'bg') {\n colors['lightBg'].a = v\n }\n if (colors[k]) {\n colors[k].a = v\n } else {\n console.error('Wrong key ' + k)\n }\n })\n\n const htmlColors = Object.entries(colors)\n .reduce((acc, [k, v]) => {\n if (!v) return acc\n acc.solid[k] = rgb2hex(v)\n acc.complete[k] = typeof v.a === 'undefined' ? rgb2hex(v) : rgb2rgba(v)\n return acc\n }, { complete: {}, solid: {} })\n return {\n rules: {\n colors: Object.entries(htmlColors.complete)\n .filter(([k, v]) => v)\n .map(([k, v]) => `--${k}: ${v}`)\n .join(';')\n },\n theme: {\n colors: htmlColors.solid,\n opacity\n }\n }\n}\n\nconst generateRadii = (input) => {\n let inputRadii = input.radii || {}\n // v1 -> v2\n if (typeof input.btnRadius !== 'undefined') {\n inputRadii = Object\n .entries(input)\n .filter(([k, v]) => k.endsWith('Radius'))\n .reduce((acc, e) => { acc[e[0].split('Radius')[0]] = e[1]; return acc }, {})\n }\n const radii = Object.entries(inputRadii).filter(([k, v]) => v).reduce((acc, [k, v]) => {\n acc[k] = v\n return acc\n }, {\n btn: 4,\n input: 4,\n checkbox: 2,\n panel: 10,\n avatar: 5,\n avatarAlt: 50,\n tooltip: 2,\n attachment: 5\n })\n\n return {\n rules: {\n radii: Object.entries(radii).filter(([k, v]) => v).map(([k, v]) => `--${k}Radius: ${v}px`).join(';')\n },\n theme: {\n radii\n }\n }\n}\n\nconst generateFonts = (input) => {\n const fonts = Object.entries(input.fonts || {}).filter(([k, v]) => v).reduce((acc, [k, v]) => {\n acc[k] = Object.entries(v).filter(([k, v]) => v).reduce((acc, [k, v]) => {\n acc[k] = v\n return acc\n }, acc[k])\n return acc\n }, {\n interface: {\n family: 'sans-serif'\n },\n input: {\n family: 'inherit'\n },\n post: {\n family: 'inherit'\n },\n postCode: {\n family: 'monospace'\n }\n })\n\n return {\n rules: {\n fonts: Object\n .entries(fonts)\n .filter(([k, v]) => v)\n .map(([k, v]) => `--${k}Font: ${v.family}`).join(';')\n },\n theme: {\n fonts\n }\n }\n}\n\nconst generateShadows = (input) => {\n const border = (top, shadow) => ({\n x: 0,\n y: top ? 1 : -1,\n blur: 0,\n spread: 0,\n color: shadow ? '#000000' : '#FFFFFF',\n alpha: 0.2,\n inset: true\n })\n const buttonInsetFakeBorders = [border(true, false), border(false, true)]\n const inputInsetFakeBorders = [border(true, true), border(false, false)]\n const hoverGlow = {\n x: 0,\n y: 0,\n blur: 4,\n spread: 0,\n color: '--faint',\n alpha: 1\n }\n\n const shadows = {\n panel: [{\n x: 1,\n y: 1,\n blur: 4,\n spread: 0,\n color: '#000000',\n alpha: 0.6\n }],\n topBar: [{\n x: 0,\n y: 0,\n blur: 4,\n spread: 0,\n color: '#000000',\n alpha: 0.6\n }],\n popup: [{\n x: 2,\n y: 2,\n blur: 3,\n spread: 0,\n color: '#000000',\n alpha: 0.5\n }],\n avatar: [{\n x: 0,\n y: 1,\n blur: 8,\n spread: 0,\n color: '#000000',\n alpha: 0.7\n }],\n avatarStatus: [],\n panelHeader: [],\n button: [{\n x: 0,\n y: 0,\n blur: 2,\n spread: 0,\n color: '#000000',\n alpha: 1\n }, ...buttonInsetFakeBorders],\n buttonHover: [hoverGlow, ...buttonInsetFakeBorders],\n buttonPressed: [hoverGlow, ...inputInsetFakeBorders],\n input: [...inputInsetFakeBorders, {\n x: 0,\n y: 0,\n blur: 2,\n inset: true,\n spread: 0,\n color: '#000000',\n alpha: 1\n }],\n ...(input.shadows || {})\n }\n\n return {\n rules: {\n shadows: Object\n .entries(shadows)\n // TODO for v2.1: if shadow doesn't have non-inset shadows with spread > 0 - optionally\n // convert all non-inset shadows into filter: drop-shadow() to boost performance\n .map(([k, v]) => [\n `--${k}Shadow: ${getCssShadow(v)}`,\n `--${k}ShadowFilter: ${getCssShadowFilter(v)}`,\n `--${k}ShadowInset: ${getCssShadow(v, true)}`\n ].join(';'))\n .join(';')\n },\n theme: {\n shadows\n }\n }\n}\n\nconst composePreset = (colors, radii, shadows, fonts) => {\n return {\n rules: {\n ...shadows.rules,\n ...colors.rules,\n ...radii.rules,\n ...fonts.rules\n },\n theme: {\n ...shadows.theme,\n ...colors.theme,\n ...radii.theme,\n ...fonts.theme\n }\n }\n}\n\nconst generatePreset = (input) => {\n const shadows = generateShadows(input)\n const colors = generateColors(input)\n const radii = generateRadii(input)\n const fonts = generateFonts(input)\n\n return composePreset(colors, radii, shadows, fonts)\n}\n\nconst getThemes = () => {\n return window.fetch('/static/styles.json')\n .then((data) => data.json())\n .then((themes) => {\n return Promise.all(Object.entries(themes).map(([k, v]) => {\n if (typeof v === 'object') {\n return Promise.resolve([k, v])\n } else if (typeof v === 'string') {\n return window.fetch(v)\n .then((data) => data.json())\n .then((theme) => {\n return [k, theme]\n })\n .catch((e) => {\n console.error(e)\n return []\n })\n }\n }))\n })\n .then((promises) => {\n return promises\n .filter(([k, v]) => v)\n .reduce((acc, [k, v]) => {\n acc[k] = v\n return acc\n }, {})\n })\n}\n\nconst setPreset = (val, commit) => {\n return getThemes().then((themes) => {\n const theme = themes[val] ? themes[val] : themes['pleroma-dark']\n const isV1 = Array.isArray(theme)\n const data = isV1 ? {} : theme.theme\n\n if (isV1) {\n const bgRgb = hex2rgb(theme[1])\n const fgRgb = hex2rgb(theme[2])\n const textRgb = hex2rgb(theme[3])\n const linkRgb = hex2rgb(theme[4])\n\n const cRedRgb = hex2rgb(theme[5] || '#FF0000')\n const cGreenRgb = hex2rgb(theme[6] || '#00FF00')\n const cBlueRgb = hex2rgb(theme[7] || '#0000FF')\n const cOrangeRgb = hex2rgb(theme[8] || '#E3FF00')\n\n data.colors = {\n bg: bgRgb,\n fg: fgRgb,\n text: textRgb,\n link: linkRgb,\n cRed: cRedRgb,\n cBlue: cBlueRgb,\n cGreen: cGreenRgb,\n cOrange: cOrangeRgb\n }\n }\n\n // This is a hack, this function is only called during initial load.\n // We want to cancel loading the theme from config.json if we're already\n // loading a theme from the persisted state.\n // Needed some way of dealing with the async way of things.\n // load config -> set preset -> wait for styles.json to load ->\n // load persisted state -> set colors -> styles.json loaded -> set colors\n if (!window.themeLoaded) {\n applyTheme(data, commit)\n }\n })\n}\n\nexport {\n setStyle,\n setPreset,\n applyTheme,\n getTextColor,\n generateColors,\n generateRadii,\n generateShadows,\n generateFonts,\n generatePreset,\n getThemes,\n composePreset,\n getCssShadow,\n getCssShadowFilter\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/style_setter/style_setter.js","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-67fc4208\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./basic_user_card.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./basic_user_card.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-67fc4208\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./basic_user_card.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/basic_user_card/basic_user_card.vue\n// module id = 86\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-769e38a0\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./status.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./status.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-769e38a0\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./status.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/status/status.vue\n// module id = 87\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-0a19e43c\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./user_avatar.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./user_avatar.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-0a19e43c\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./user_avatar.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/user_avatar/user_avatar.vue\n// module id = 88\n// module chunks = 2","import Vue from 'vue'\n\nimport './tab_switcher.scss'\n\nexport default Vue.component('tab-switcher', {\n name: 'TabSwitcher',\n props: ['renderOnlyFocused'],\n data () {\n return {\n active: this.$slots.default.findIndex(_ => _.tag)\n }\n },\n methods: {\n activateTab (index) {\n return () => {\n this.active = index\n }\n }\n },\n beforeUpdate () {\n const currentSlot = this.$slots.default[this.active]\n if (!currentSlot.tag) {\n this.active = this.$slots.default.findIndex(_ => _.tag)\n }\n },\n render (h) {\n const tabs = this.$slots.default\n .map((slot, index) => {\n if (!slot.tag) return\n const classesTab = ['tab']\n const classesWrapper = ['tab-wrapper']\n\n if (index === this.active) {\n classesTab.push('active')\n classesWrapper.push('active')\n }\n\n return (\n

    \n \n
    \n )\n })\n\n const contents = this.$slots.default.map((slot, index) => {\n if (!slot.tag) return\n const active = index === this.active\n if (this.renderOnlyFocused) {\n return active\n ?
    {slot}
    \n :
    \n }\n return
    {slot}
    \n })\n\n return (\n
    \n
    \n {tabs}\n
    \n
    \n {contents}\n
    \n
    \n )\n }\n})\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/tab_switcher/tab_switcher.js","import {reduce} from 'lodash'\n\nconst getOrCreateApp = ({oauth, instance}) => {\n const url = `${instance}/api/v1/apps`\n const form = new window.FormData()\n\n form.append('client_name', `PleromaFE_${Math.random()}`)\n form.append('redirect_uris', `${window.location.origin}/oauth-callback`)\n form.append('scopes', 'read write follow')\n\n return window.fetch(url, {\n method: 'POST',\n body: form\n }).then((data) => data.json())\n}\nconst login = (args) => {\n getOrCreateApp(args).then((app) => {\n args.commit('setClientData', app)\n\n const data = {\n response_type: 'code',\n client_id: app.client_id,\n redirect_uri: app.redirect_uri,\n scope: 'read write follow'\n }\n\n const dataString = reduce(data, (acc, v, k) => {\n const encoded = `${k}=${encodeURIComponent(v)}`\n if (!acc) {\n return encoded\n } else {\n return `${acc}&${encoded}`\n }\n }, false)\n\n // Do the redirect...\n const url = `${args.instance}/oauth/authorize?${dataString}`\n\n window.location.href = url\n })\n}\n\nconst getTokenWithCredentials = ({app, instance, username, password}) => {\n const url = `${instance}/oauth/token`\n const form = new window.FormData()\n\n form.append('client_id', app.client_id)\n form.append('client_secret', app.client_secret)\n form.append('grant_type', 'password')\n form.append('username', username)\n form.append('password', password)\n\n return window.fetch(url, {\n method: 'POST',\n body: form\n }).then((data) => data.json())\n}\n\nconst getToken = ({app, instance, code}) => {\n const url = `${instance}/oauth/token`\n const form = new window.FormData()\n\n form.append('client_id', app.client_id)\n form.append('client_secret', app.client_secret)\n form.append('grant_type', 'authorization_code')\n form.append('code', code)\n form.append('redirect_uri', `${window.location.origin}/oauth-callback`)\n\n return window.fetch(url, {\n method: 'POST',\n body: form\n }).then((data) => data.json())\n}\n\nconst oauth = {\n login,\n getToken,\n getTokenWithCredentials,\n getOrCreateApp\n}\n\nexport default oauth\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/new_api/oauth.js","import { filter, sortBy } from 'lodash'\n\nexport const notificationsFromStore = store => store.state.statuses.notifications.data\n\nexport const visibleTypes = store => ([\n store.state.config.notificationVisibility.likes && 'like',\n store.state.config.notificationVisibility.mentions && 'mention',\n store.state.config.notificationVisibility.repeats && 'repeat',\n store.state.config.notificationVisibility.follows && 'follow'\n].filter(_ => _))\n\nconst sortById = (a, b) => {\n const seqA = Number(a.action.id)\n const seqB = Number(b.action.id)\n const isSeqA = !Number.isNaN(seqA)\n const isSeqB = !Number.isNaN(seqB)\n if (isSeqA && isSeqB) {\n return seqA > seqB ? -1 : 1\n } else if (isSeqA && !isSeqB) {\n return 1\n } else if (!isSeqA && isSeqB) {\n return -1\n } else {\n return a.action.id > b.action.id ? -1 : 1\n }\n}\n\nexport const visibleNotificationsFromStore = store => {\n // map is just to clone the array since sort mutates it and it causes some issues\n let sortedNotifications = notificationsFromStore(store).map(_ => _).sort(sortById)\n sortedNotifications = sortBy(sortedNotifications, 'seen')\n return sortedNotifications.filter((notification) => visibleTypes(store).includes(notification.type))\n}\n\nexport const unseenNotificationsFromStore = store =>\n filter(visibleNotificationsFromStore(store), ({seen}) => !seen)\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/notification_utils/notification_utils.js","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-22921ede\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./follow_card.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./follow_card.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-22921ede\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./follow_card.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/follow_card/follow_card.vue\n// module id = 125\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-11ada5e0\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./post_status_form.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./post_status_form.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-11ada5e0\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./post_status_form.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/post_status_form/post_status_form.vue\n// module id = 126\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-6ecb31e4\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./still-image.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./still-image.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-6ecb31e4\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./still-image.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/still-image/still-image.vue\n// module id = 127\n// module chunks = 2","import Vue from 'vue'\nimport map from 'lodash/map'\nimport isEmpty from 'lodash/isEmpty'\nimport './with_list.scss'\n\nconst defaultEntryPropsGetter = entry => ({ entry })\nconst defaultKeyGetter = entry => entry.id\n\nconst withList = ({\n getEntryProps = defaultEntryPropsGetter, // function to accept entry and index values and return props to be passed into the item component\n getKey = defaultKeyGetter // funciton to accept entry and index values and return key prop value\n}) => (ItemComponent) => (\n Vue.component('withList', {\n props: [\n 'entries', // array of entry\n 'entryProps', // additional props to be passed into each entry\n 'entryListeners' // additional event listeners to be passed into each entry\n ],\n render (createElement) {\n return (\n
    \n {map(this.entries, (entry, index) => {\n const props = {\n key: getKey(entry, index),\n props: {\n ...this.$props.entryProps,\n ...getEntryProps(entry, index)\n },\n on: this.$props.entryListeners\n }\n return \n })}\n {isEmpty(this.entries) && this.$slots.empty &&
    {this.$slots.empty}
    }\n
    \n )\n }\n })\n)\n\nexport default withList\n\n\n\n// WEBPACK FOOTER //\n// ./src/hocs/with_list/with_list.js","// When contributing, please sort JSON before committing so it would be easier to see what's missing and what's being added compared to English and other languages. It's not obligatory, but just an advice.\n// To sort json use jq https://stedolan.github.io/jq and invoke it like `jq -S . xx.json > xx.sorted.json`, AFAIK, there's no inplace edit option like in sed\n// Also, when adding a new language to \"messages\" variable, please do it alphabetically by language code so that users can search or check their custom language easily.\n\n// For anyone contributing to old huge messages.js and in need to quickly convert it to JSON\n// sed command for converting currently formatted JS to JSON:\n// sed -i -e \"s/'//gm\" -e 's/\"/\\\\\"/gm' -re 's/^( +)(.+?): ((.+?))?(,?)(\\{?)$/\\1\"\\2\": \"\\4\"/gm' -e 's/\\\"\\{\\\"/{/g' -e 's/,\"$/\",/g' file.json\n// There's only problem that apostrophe character ' gets replaced by \\\\ so you have to fix it manually, sorry.\n\nconst messages = {\n ar: require('./ar.json'),\n ca: require('./ca.json'),\n cs: require('./cs.json'),\n de: require('./de.json'),\n en: require('./en.json'),\n eo: require('./eo.json'),\n es: require('./es.json'),\n et: require('./et.json'),\n fi: require('./fi.json'),\n fr: require('./fr.json'),\n ga: require('./ga.json'),\n he: require('./he.json'),\n hu: require('./hu.json'),\n it: require('./it.json'),\n ja: require('./ja.json'),\n ko: require('./ko.json'),\n nb: require('./nb.json'),\n nl: require('./nl.json'),\n oc: require('./oc.json'),\n pl: require('./pl.json'),\n pt: require('./pt.json'),\n ro: require('./ro.json'),\n ru: require('./ru.json'),\n zh: require('./zh.json')\n}\n\nexport default messages\n\n\n\n// WEBPACK FOOTER //\n// ./src/i18n/messages.js","import apiService from '../api/api.service.js'\nimport timelineFetcherService from '../timeline_fetcher/timeline_fetcher.service.js'\n\nconst backendInteractorService = (credentials) => {\n const fetchStatus = ({id}) => {\n return apiService.fetchStatus({id, credentials})\n }\n\n const fetchConversation = ({id}) => {\n return apiService.fetchConversation({id, credentials})\n }\n\n const fetchFriends = ({id, page}) => {\n return apiService.fetchFriends({id, page, credentials})\n }\n\n const exportFriends = ({id}) => {\n return apiService.exportFriends({id, credentials})\n }\n\n const fetchFollowers = ({id, page}) => {\n return apiService.fetchFollowers({id, page, credentials})\n }\n\n const fetchAllFollowing = ({username}) => {\n return apiService.fetchAllFollowing({username, credentials})\n }\n\n const fetchUser = ({id}) => {\n return apiService.fetchUser({id, credentials})\n }\n\n const followUser = (id) => {\n return apiService.followUser({credentials, id})\n }\n\n const unfollowUser = (id) => {\n return apiService.unfollowUser({credentials, id})\n }\n\n const blockUser = (id) => {\n return apiService.blockUser({credentials, id})\n }\n\n const unblockUser = (id) => {\n return apiService.unblockUser({credentials, id})\n }\n\n const approveUser = (id) => {\n return apiService.approveUser({credentials, id})\n }\n\n const denyUser = (id) => {\n return apiService.denyUser({credentials, id})\n }\n\n const startFetching = ({timeline, store, userId = false, tag}) => {\n return timelineFetcherService.startFetching({timeline, store, credentials, userId, tag})\n }\n\n const setUserMute = ({id, muted = true}) => {\n return apiService.setUserMute({id, muted, credentials})\n }\n\n const fetchMutes = () => apiService.fetchMutes({credentials})\n const fetchBlocks = (params) => apiService.fetchBlocks({credentials, ...params})\n const fetchFollowRequests = () => apiService.fetchFollowRequests({credentials})\n const fetchOAuthTokens = () => apiService.fetchOAuthTokens({credentials})\n const revokeOAuthToken = (id) => apiService.revokeOAuthToken({id, credentials})\n\n const getCaptcha = () => apiService.getCaptcha()\n const register = (params) => apiService.register(params)\n const updateAvatar = ({params}) => apiService.updateAvatar({credentials, params})\n const updateBg = ({params}) => apiService.updateBg({credentials, params})\n const updateBanner = ({params}) => apiService.updateBanner({credentials, params})\n const updateProfile = ({params}) => apiService.updateProfile({credentials, params})\n\n const externalProfile = (profileUrl) => apiService.externalProfile({profileUrl, credentials})\n const followImport = ({params}) => apiService.followImport({params, credentials})\n\n const deleteAccount = ({password}) => apiService.deleteAccount({credentials, password})\n const changePassword = ({password, newPassword, newPasswordConfirmation}) => apiService.changePassword({credentials, password, newPassword, newPasswordConfirmation})\n\n const backendInteractorServiceInstance = {\n fetchStatus,\n fetchConversation,\n fetchFriends,\n exportFriends,\n fetchFollowers,\n followUser,\n unfollowUser,\n blockUser,\n unblockUser,\n fetchUser,\n fetchAllFollowing,\n verifyCredentials: apiService.verifyCredentials,\n startFetching,\n setUserMute,\n fetchMutes,\n fetchBlocks,\n fetchOAuthTokens,\n revokeOAuthToken,\n register,\n getCaptcha,\n updateAvatar,\n updateBg,\n updateBanner,\n updateProfile,\n externalProfile,\n followImport,\n deleteAccount,\n changePassword,\n fetchFollowRequests,\n approveUser,\n denyUser\n }\n\n return backendInteractorServiceInstance\n}\n\nexport default backendInteractorService\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/backend_interactor_service/backend_interactor_service.js","import isFunction from 'lodash/isFunction'\n\nconst getComponentOptions = (Component) => (isFunction(Component)) ? Component.options : Component\n\nconst getComponentProps = (Component) => getComponentOptions(Component).props\n\nexport {\n getComponentOptions,\n getComponentProps\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/component_utils/component_utils.js","const fileSizeFormat = (num) => {\n var exponent\n var unit\n var units = ['B', 'KiB', 'MiB', 'GiB', 'TiB']\n if (num < 1) {\n return num + ' ' + units[0]\n }\n\n exponent = Math.min(Math.floor(Math.log(num) / Math.log(1024)), units.length - 1)\n num = (num / Math.pow(1024, exponent)).toFixed(2) * 1\n unit = units[exponent]\n return {num: num, unit: unit}\n}\nconst fileSizeFormatService = {\n fileSizeFormat\n}\nexport default fileSizeFormatService\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/file_size_format/file_size_format.js","const fetchUser = (attempt, user, store) => new Promise((resolve, reject) => {\n setTimeout(() => {\n store.state.api.backendInteractor.fetchUser({ id: user.id })\n .then((user) => store.commit('addNewUsers', [user]))\n .then(() => resolve([user.following, attempt]))\n .catch((e) => reject(e))\n }, 500)\n}).then(([following, attempt]) => {\n if (!following && attempt <= 3) {\n // If we BE reports that we still not following that user - retry,\n // increment attempts by one\n return fetchUser(++attempt, user, store)\n } else {\n // If we run out of attempts, just return whatever status is.\n return following\n }\n})\n\nexport const requestFollow = (user, store) => new Promise((resolve, reject) => {\n store.state.api.backendInteractor.followUser(user.id)\n .then((updated) => {\n store.commit('addNewUsers', [updated])\n\n // For locked users we just mark it that we sent the follow request\n if (updated.locked) {\n resolve({\n sent: true,\n updated\n })\n }\n\n if (updated.following) {\n // If we get result immediately, just stop.\n resolve({\n sent: false,\n updated\n })\n }\n\n // But usually we don't get result immediately, so we ask server\n // for updated user profile to confirm if we are following them\n // Sometimes it takes several tries. Sometimes we end up not following\n // user anyway, probably because they locked themselves and we\n // don't know that yet.\n // Recursive Promise, it will call itself up to 3 times.\n\n return fetchUser(1, user, store)\n .then((following) => {\n if (following) {\n // We confirmed and everything's good.\n resolve({\n sent: false,\n updated\n })\n } else {\n // If after all the tries, just treat it as if user is locked\n resolve({\n sent: false,\n updated\n })\n }\n })\n })\n})\n\nexport const requestUnfollow = (user, store) => new Promise((resolve, reject) => {\n store.state.api.backendInteractor.unfollowUser(user.id)\n .then((updated) => {\n store.commit('addNewUsers', [updated])\n resolve({\n updated\n })\n })\n})\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/follow_manipulate/follow_manipulate.js","import { map } from 'lodash'\nimport apiService from '../api/api.service.js'\n\nconst postStatus = ({ store, status, spoilerText, visibility, sensitive, media = [], inReplyToStatusId = undefined, contentType = 'text/plain' }) => {\n const mediaIds = map(media, 'id')\n\n return apiService.postStatus({credentials: store.state.users.currentUser.credentials, status, spoilerText, visibility, sensitive, mediaIds, inReplyToStatusId, contentType, noAttachmentLinks: store.state.instance.noAttachmentLinks})\n .then((data) => {\n if (!data.error) {\n store.dispatch('addNewStatuses', {\n statuses: [data],\n timeline: 'friends',\n showImmediately: true,\n noIdUpdate: true // To prevent missing notices on next pull.\n })\n }\n return data\n })\n .catch((err) => {\n return {\n error: err.message\n }\n })\n}\n\nconst uploadMedia = ({ store, formData }) => {\n const credentials = store.state.users.currentUser.credentials\n\n return apiService.uploadMedia({ credentials, formData }).then((xml) => {\n // Firefox and Chrome treat method differently...\n let link = xml.getElementsByTagName('link')\n\n if (link.length === 0) {\n link = xml.getElementsByTagName('atom:link')\n }\n\n link = link[0]\n\n const mediaData = {\n id: xml.getElementsByTagName('media_id')[0].textContent,\n url: xml.getElementsByTagName('media_url')[0].textContent,\n image: link.getAttribute('href'),\n mimetype: link.getAttribute('type')\n }\n\n return mediaData\n })\n}\n\nconst statusPosterService = {\n postStatus,\n uploadMedia\n}\n\nexport default statusPosterService\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/status_poster/status_poster.service.js","import { camelCase } from 'lodash'\n\nimport apiService from '../api/api.service.js'\n\nconst update = ({store, statuses, timeline, showImmediately, userId}) => {\n const ccTimeline = camelCase(timeline)\n\n store.dispatch('setError', { value: false })\n\n store.dispatch('addNewStatuses', {\n timeline: ccTimeline,\n userId,\n statuses,\n showImmediately\n })\n}\n\nconst fetchAndUpdate = ({store, credentials, timeline = 'friends', older = false, showImmediately = false, userId = false, tag = false, until}) => {\n const args = { timeline, credentials }\n const rootState = store.rootState || store.state\n const timelineData = rootState.statuses.timelines[camelCase(timeline)]\n\n if (older) {\n args['until'] = until || timelineData.minId\n } else {\n args['since'] = timelineData.maxId\n }\n\n args['userId'] = userId\n args['tag'] = tag\n\n const numStatusesBeforeFetch = timelineData.statuses.length\n\n return apiService.fetchTimeline(args)\n .then((statuses) => {\n if (!older && statuses.length >= 20 && !timelineData.loading && numStatusesBeforeFetch > 0) {\n store.dispatch('queueFlush', { timeline: timeline, id: timelineData.maxId })\n }\n update({store, statuses, timeline, showImmediately, userId})\n return statuses\n }, () => store.dispatch('setError', { value: true }))\n}\n\nconst startFetching = ({timeline = 'friends', credentials, store, userId = false, tag = false}) => {\n const rootState = store.rootState || store.state\n const timelineData = rootState.statuses.timelines[camelCase(timeline)]\n const showImmediately = timelineData.visibleStatuses.length === 0\n timelineData.userId = userId\n fetchAndUpdate({timeline, credentials, store, showImmediately, userId, tag})\n const boundFetchAndUpdate = () => fetchAndUpdate({ timeline, credentials, store, userId, tag })\n return setInterval(boundFetchAndUpdate, 10000)\n}\nconst timelineFetcher = {\n fetchAndUpdate,\n startFetching\n}\n\nexport default timelineFetcher\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/timeline_fetcher/timeline_fetcher.service.js","import { hex2rgb } from '../color_convert/color_convert.js'\nconst highlightStyle = (prefs) => {\n if (prefs === undefined) return\n const {color, type} = prefs\n if (typeof color !== 'string') return\n const rgb = hex2rgb(color)\n if (rgb == null) return\n const solidColor = `rgb(${Math.floor(rgb.r)}, ${Math.floor(rgb.g)}, ${Math.floor(rgb.b)})`\n const tintColor = `rgba(${Math.floor(rgb.r)}, ${Math.floor(rgb.g)}, ${Math.floor(rgb.b)}, .1)`\n const tintColor2 = `rgba(${Math.floor(rgb.r)}, ${Math.floor(rgb.g)}, ${Math.floor(rgb.b)}, .2)`\n if (type === 'striped') {\n return {\n backgroundImage: [\n 'repeating-linear-gradient(135deg,',\n `${tintColor} ,`,\n `${tintColor} 20px,`,\n `${tintColor2} 20px,`,\n `${tintColor2} 40px`\n ].join(' '),\n backgroundPosition: '0 0'\n }\n } else if (type === 'solid') {\n return {\n backgroundColor: tintColor2\n }\n } else if (type === 'side') {\n return {\n backgroundImage: [\n 'linear-gradient(to right,',\n `${solidColor} ,`,\n `${solidColor} 2px,`,\n `transparent 6px`\n ].join(' '),\n backgroundPosition: '0 0'\n }\n }\n}\n\nconst highlightClass = (user) => {\n return 'USER____' + user.screen_name\n .replace(/\\./g, '_')\n .replace(/@/g, '_AT_')\n}\n\nexport {\n highlightClass,\n highlightStyle\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/user_highlighter/user_highlighter.js","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-48d74080\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./attachment.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./attachment.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-48d74080\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./attachment.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/attachment/attachment.vue\n// module id = 206\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-37c7b840\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./chat_panel.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./chat_panel.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-37c7b840\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./chat_panel.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/chat_panel/chat_panel.vue\n// module id = 207\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-73de3e04\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./color_input.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!../../../node_modules/vue-loader/lib/selector?type=script&index=0!./color_input.vue\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-73de3e04\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./color_input.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/color_input/color_input.vue\n// module id = 208\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./conversation.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-12838600\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./conversation.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/conversation/conversation.vue\n// module id = 209\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-46b7c7a0\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./features_panel.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./features_panel.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-46b7c7a0\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./features_panel.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/features_panel/features_panel.vue\n// module id = 210\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-8ac93238\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./instance_specific_panel.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./instance_specific_panel.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-8ac93238\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./instance_specific_panel.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/instance_specific_panel/instance_specific_panel.vue\n// module id = 211\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-437c2fc0\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./login_form.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./login_form.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-437c2fc0\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./login_form.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/login_form/login_form.vue\n// module id = 212\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-00135b32\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!./notifications.scss\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./notifications.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-00135b32\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./notifications.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/notifications/notifications.vue\n// module id = 213\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!../../../node_modules/vue-loader/lib/selector?type=script&index=0!./opacity_input.vue\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-4cc8580e\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./opacity_input.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/opacity_input/opacity_input.vue\n// module id = 214\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-ae8f5000\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!./style_switcher.scss\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./style_switcher.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-ae8f5000\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./style_switcher.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/style_switcher/style_switcher.vue\n// module id = 215\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./video_attachment.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-526a5280\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./video_attachment.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/video_attachment/video_attachment.vue\n// module id = 216\n// module chunks = 2","import Vue from 'vue'\nimport VueRouter from 'vue-router'\nimport routes from './routes'\n\nimport App from '../App.vue'\n\nconst afterStoreSetup = ({ store, i18n }) => {\n window.fetch('/api/statusnet/config.json')\n .then((res) => res.json())\n .then((data) => {\n const { name, closed: registrationClosed, textlimit, uploadlimit, server, vapidPublicKey } = data.site\n\n store.dispatch('setInstanceOption', { name: 'name', value: name })\n store.dispatch('setInstanceOption', { name: 'registrationOpen', value: (registrationClosed === '0') })\n store.dispatch('setInstanceOption', { name: 'textlimit', value: parseInt(textlimit) })\n store.dispatch('setInstanceOption', { name: 'server', value: server })\n\n // TODO: default values for this stuff, added if to not make it break on\n // my dev config out of the box.\n if (uploadlimit) {\n store.dispatch('setInstanceOption', { name: 'uploadlimit', value: parseInt(uploadlimit.uploadlimit) })\n store.dispatch('setInstanceOption', { name: 'avatarlimit', value: parseInt(uploadlimit.avatarlimit) })\n store.dispatch('setInstanceOption', { name: 'backgroundlimit', value: parseInt(uploadlimit.backgroundlimit) })\n store.dispatch('setInstanceOption', { name: 'bannerlimit', value: parseInt(uploadlimit.bannerlimit) })\n }\n\n if (vapidPublicKey) {\n store.dispatch('setInstanceOption', { name: 'vapidPublicKey', value: vapidPublicKey })\n }\n\n var apiConfig = data.site.pleromafe\n\n window.fetch('/static/config.json')\n .then((res) => res.json())\n .catch((err) => {\n console.warn('Failed to load static/config.json, continuing without it.')\n console.warn(err)\n return {}\n })\n .then((staticConfig) => {\n const overrides = window.___pleromafe_dev_overrides || {}\n const env = window.___pleromafe_mode.NODE_ENV\n\n // This takes static config and overrides properties that are present in apiConfig\n let config = {}\n if (overrides.staticConfigPreference && env === 'development') {\n console.warn('OVERRIDING API CONFIG WITH STATIC CONFIG')\n config = Object.assign({}, apiConfig, staticConfig)\n } else {\n config = Object.assign({}, staticConfig, apiConfig)\n }\n\n const copyInstanceOption = (name) => {\n store.dispatch('setInstanceOption', {name, value: config[name]})\n }\n\n copyInstanceOption('nsfwCensorImage')\n copyInstanceOption('background')\n copyInstanceOption('hidePostStats')\n copyInstanceOption('hideUserStats')\n copyInstanceOption('hideFilteredStatuses')\n copyInstanceOption('logo')\n\n store.dispatch('setInstanceOption', {\n name: 'logoMask',\n value: typeof config.logoMask === 'undefined'\n ? true\n : config.logoMask\n })\n\n store.dispatch('setInstanceOption', {\n name: 'logoMargin',\n value: typeof config.logoMargin === 'undefined'\n ? 0\n : config.logoMargin\n })\n\n copyInstanceOption('redirectRootNoLogin')\n copyInstanceOption('redirectRootLogin')\n copyInstanceOption('showInstanceSpecificPanel')\n copyInstanceOption('scopeOptionsEnabled')\n copyInstanceOption('formattingOptionsEnabled')\n copyInstanceOption('collapseMessageWithSubject')\n copyInstanceOption('loginMethod')\n copyInstanceOption('scopeCopy')\n copyInstanceOption('subjectLineBehavior')\n copyInstanceOption('postContentType')\n copyInstanceOption('alwaysShowSubjectInput')\n copyInstanceOption('noAttachmentLinks')\n copyInstanceOption('showFeaturesPanel')\n\n if (config.chatDisabled) {\n store.dispatch('disableChat')\n }\n\n return store.dispatch('setTheme', config['theme'])\n })\n .then(() => {\n const router = new VueRouter({\n mode: 'history',\n routes: routes(store),\n scrollBehavior: (to, _from, savedPosition) => {\n if (to.matched.some(m => m.meta.dontScroll)) {\n return false\n }\n return savedPosition || { x: 0, y: 0 }\n }\n })\n\n /* eslint-disable no-new */\n new Vue({\n router,\n store,\n i18n,\n el: '#app',\n render: h => h(App)\n })\n })\n })\n\n window.fetch('/static/terms-of-service.html')\n .then((res) => res.text())\n .then((html) => {\n store.dispatch('setInstanceOption', { name: 'tos', value: html })\n })\n\n window.fetch('/api/pleroma/emoji.json')\n .then(\n (res) => res.json()\n .then(\n (values) => {\n const emoji = Object.keys(values).map((key) => {\n return { shortcode: key, image_url: values[key] }\n })\n store.dispatch('setInstanceOption', { name: 'customEmoji', value: emoji })\n store.dispatch('setInstanceOption', { name: 'pleromaBackend', value: true })\n },\n (failure) => {\n store.dispatch('setInstanceOption', { name: 'pleromaBackend', value: false })\n }\n ),\n (error) => console.log(error)\n )\n\n window.fetch('/static/emoji.json')\n .then((res) => res.json())\n .then((values) => {\n const emoji = Object.keys(values).map((key) => {\n return { shortcode: key, image_url: false, 'utf': values[key] }\n })\n store.dispatch('setInstanceOption', { name: 'emoji', value: emoji })\n })\n\n window.fetch('/instance/panel.html')\n .then((res) => res.text())\n .then((html) => {\n store.dispatch('setInstanceOption', { name: 'instanceSpecificPanelContent', value: html })\n })\n\n window.fetch('/nodeinfo/2.0.json')\n .then((res) => res.json())\n .then((data) => {\n const metadata = data.metadata\n\n const features = metadata.features\n store.dispatch('setInstanceOption', { name: 'mediaProxyAvailable', value: features.includes('media_proxy') })\n store.dispatch('setInstanceOption', { name: 'chatAvailable', value: features.includes('chat') })\n store.dispatch('setInstanceOption', { name: 'gopherAvailable', value: features.includes('gopher') })\n\n store.dispatch('setInstanceOption', { name: 'postFormats', value: metadata.postFormats })\n\n store.dispatch('setInstanceOption', { name: 'restrictedNicknames', value: metadata.restrictedNicknames })\n\n const suggestions = metadata.suggestions\n store.dispatch('setInstanceOption', { name: 'suggestionsEnabled', value: suggestions.enabled })\n store.dispatch('setInstanceOption', { name: 'suggestionsWeb', value: suggestions.web })\n })\n}\n\nexport default afterStoreSetup\n\n\n\n// WEBPACK FOOTER //\n// ./src/boot/after_store.js","import PublicTimeline from 'components/public_timeline/public_timeline.vue'\nimport PublicAndExternalTimeline from 'components/public_and_external_timeline/public_and_external_timeline.vue'\nimport FriendsTimeline from 'components/friends_timeline/friends_timeline.vue'\nimport TagTimeline from 'components/tag_timeline/tag_timeline.vue'\nimport ConversationPage from 'components/conversation-page/conversation-page.vue'\nimport Mentions from 'components/mentions/mentions.vue'\nimport DMs from 'components/dm_timeline/dm_timeline.vue'\nimport UserProfile from 'components/user_profile/user_profile.vue'\nimport Settings from 'components/settings/settings.vue'\nimport Registration from 'components/registration/registration.vue'\nimport UserSettings from 'components/user_settings/user_settings.vue'\nimport FollowRequests from 'components/follow_requests/follow_requests.vue'\nimport OAuthCallback from 'components/oauth_callback/oauth_callback.vue'\nimport UserSearch from 'components/user_search/user_search.vue'\nimport Notifications from 'components/notifications/notifications.vue'\nimport LoginForm from 'components/login_form/login_form.vue'\nimport ChatPanel from 'components/chat_panel/chat_panel.vue'\nimport WhoToFollow from 'components/who_to_follow/who_to_follow.vue'\nimport About from 'components/about/about.vue'\n\nexport default (store) => {\n return [\n { name: 'root',\n path: '/',\n redirect: _to => {\n return (store.state.users.currentUser\n ? store.state.instance.redirectRootLogin\n : store.state.instance.redirectRootNoLogin) || '/main/all'\n }\n },\n { name: 'public-external-timeline', path: '/main/all', component: PublicAndExternalTimeline },\n { name: 'public-timeline', path: '/main/public', component: PublicTimeline },\n { name: 'friends', path: '/main/friends', component: FriendsTimeline },\n { name: 'tag-timeline', path: '/tag/:tag', component: TagTimeline },\n { name: 'conversation', path: '/notice/:id', component: ConversationPage, meta: { dontScroll: true } },\n { name: 'external-user-profile', path: '/users/:id', component: UserProfile },\n { name: 'mentions', path: '/users/:username/mentions', component: Mentions },\n { name: 'dms', path: '/users/:username/dms', component: DMs },\n { name: 'settings', path: '/settings', component: Settings },\n { name: 'registration', path: '/registration', component: Registration },\n { name: 'registration-token', path: '/registration/:token', component: Registration },\n { name: 'friend-requests', path: '/friend-requests', component: FollowRequests },\n { name: 'user-settings', path: '/user-settings', component: UserSettings },\n { name: 'notifications', path: '/:username/notifications', component: Notifications },\n { name: 'login', path: '/login', component: LoginForm },\n { name: 'chat', path: '/chat', component: ChatPanel, props: () => ({ floating: false }) },\n { name: 'oauth-callback', path: '/oauth-callback', component: OAuthCallback, props: (route) => ({ code: route.query.code }) },\n { name: 'user-search', path: '/user-search', component: UserSearch, props: (route) => ({ query: route.query.query }) },\n { name: 'who-to-follow', path: '/who-to-follow', component: WhoToFollow },\n { name: 'about', path: '/about', component: About },\n { name: 'user-profile', path: '/(users/)?:name', component: UserProfile }\n ]\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/boot/routes.js","import Vue from 'vue'\nimport isEmpty from 'lodash/isEmpty'\nimport { getComponentProps } from '../../services/component_utils/component_utils'\nimport './with_load_more.scss'\n\nconst withLoadMore = ({\n fetch, // function to fetch entries and return a promise\n select, // function to select data from store\n destroy, // function called at \"destroyed\" lifecycle\n childPropName = 'entries', // name of the prop to be passed into the wrapped component\n additionalPropNames = [] // additional prop name list of the wrapper component\n}) => (WrappedComponent) => {\n const originalProps = Object.keys(getComponentProps(WrappedComponent))\n const props = originalProps.filter(v => v !== childPropName).concat(additionalPropNames)\n\n return Vue.component('withLoadMore', {\n render (createElement) {\n const props = {\n props: {\n ...this.$props,\n [childPropName]: this.entries\n },\n on: this.$listeners,\n scopedSlots: this.$scopedSlots\n }\n const children = Object.entries(this.$slots).map(([key, value]) => createElement('template', { slot: key }, value))\n return (\n
    \n \n {children}\n \n
    \n {this.error && {this.$t('general.generic_error')}}\n {!this.error && this.loading && }\n {!this.error && !this.loading && !this.bottomedOut && {this.$t('general.more')}}\n
    \n
    \n )\n },\n props,\n data () {\n return {\n loading: false,\n bottomedOut: false,\n error: false\n }\n },\n computed: {\n entries () {\n return select(this.$props, this.$store) || []\n }\n },\n created () {\n window.addEventListener('scroll', this.scrollLoad)\n if (this.entries.length === 0) {\n this.fetchEntries()\n }\n },\n destroyed () {\n window.removeEventListener('scroll', this.scrollLoad)\n destroy && destroy(this.$props, this.$store)\n },\n methods: {\n fetchEntries () {\n if (!this.loading) {\n this.loading = true\n this.error = false\n fetch(this.$props, this.$store)\n .then((newEntries) => {\n this.loading = false\n this.bottomedOut = isEmpty(newEntries)\n })\n .catch(() => {\n this.loading = false\n this.error = true\n })\n }\n },\n scrollLoad (e) {\n const bodyBRect = document.body.getBoundingClientRect()\n const height = Math.max(bodyBRect.height, -(bodyBRect.y))\n if (this.loading === false &&\n this.bottomedOut === false &&\n this.$el.offsetHeight > 0 &&\n (window.innerHeight + window.pageYOffset) >= (height - 750)\n ) {\n this.fetchEntries()\n }\n }\n }\n })\n}\n\nexport default withLoadMore\n\n\n\n// WEBPACK FOOTER //\n// ./src/hocs/with_load_more/with_load_more.js","import Vue from 'vue'\nimport isEmpty from 'lodash/isEmpty'\nimport { getComponentProps } from '../../services/component_utils/component_utils'\nimport './with_subscription.scss'\n\nconst withSubscription = ({\n fetch, // function to fetch entries and return a promise\n select, // function to select data from store\n childPropName = 'content', // name of the prop to be passed into the wrapped component\n additionalPropNames = [] // additional prop name list of the wrapper component\n}) => (WrappedComponent) => {\n const originalProps = Object.keys(getComponentProps(WrappedComponent))\n const props = originalProps.filter(v => v !== childPropName).concat(additionalPropNames)\n\n return Vue.component('withSubscription', {\n props: [\n ...props,\n 'refresh' // boolean saying to force-fetch data whenever created\n ],\n render (createElement) {\n if (!this.error && !this.loading) {\n const props = {\n props: {\n ...this.$props,\n [childPropName]: this.fetchedData\n },\n on: this.$listeners,\n scopedSlots: this.$scopedSlots\n }\n const children = Object.entries(this.$slots).map(([key, value]) => createElement('template', { slot: key }, value))\n return (\n
    \n \n {children}\n \n
    \n )\n } else {\n return (\n
    \n {this.error\n ? {this.$t('general.generic_error')}\n : \n }\n
    \n )\n }\n },\n data () {\n return {\n loading: false,\n error: false\n }\n },\n computed: {\n fetchedData () {\n return select(this.$props, this.$store)\n }\n },\n created () {\n if (this.refresh || isEmpty(this.fetchedData)) {\n this.fetchData()\n }\n },\n methods: {\n fetchData () {\n if (!this.loading) {\n this.loading = true\n this.error = false\n fetch(this.$props, this.$store)\n .then(() => {\n this.loading = false\n })\n .catch(() => {\n this.error = true\n this.loading = false\n })\n }\n }\n }\n })\n}\n\nexport default withSubscription\n\n\n\n// WEBPACK FOOTER //\n// ./src/hocs/with_subscription/with_subscription.js","import merge from 'lodash.merge'\nimport objectPath from 'object-path'\nimport localforage from 'localforage'\nimport { each } from 'lodash'\n\nlet loaded = false\n\nconst defaultReducer = (state, paths) => (\n paths.length === 0 ? state : paths.reduce((substate, path) => {\n objectPath.set(substate, path, objectPath.get(state, path))\n return substate\n }, {})\n)\n\nconst saveImmedeatelyActions = [\n 'markNotificationsAsSeen',\n 'clearCurrentUser',\n 'setCurrentUser',\n 'setHighlight',\n 'setOption',\n 'setClientData',\n 'setToken'\n]\n\nconst defaultStorage = (() => {\n return localforage\n})()\n\nexport default function createPersistedState ({\n key = 'vuex-lz',\n paths = [],\n getState = (key, storage) => {\n let value = storage.getItem(key)\n return value\n },\n setState = (key, state, storage) => {\n if (!loaded) {\n console.log('waiting for old state to be loaded...')\n return Promise.resolve()\n } else {\n return storage.setItem(key, state)\n }\n },\n reducer = defaultReducer,\n storage = defaultStorage,\n subscriber = store => handler => store.subscribe(handler)\n} = {}) {\n return getState(key, storage).then((savedState) => {\n return store => {\n try {\n if (savedState !== null && typeof savedState === 'object') {\n // build user cache\n const usersState = savedState.users || {}\n usersState.usersObject = {}\n const users = usersState.users || []\n each(users, (user) => { usersState.usersObject[user.id] = user })\n savedState.users = usersState\n\n store.replaceState(\n merge({}, store.state, savedState)\n )\n }\n if (store.state.config.customTheme) {\n // This is a hack to deal with async loading of config.json and themes\n // See: style_setter.js, setPreset()\n window.themeLoaded = true\n store.dispatch('setOption', {\n name: 'customTheme',\n value: store.state.config.customTheme\n })\n }\n if (store.state.oauth.token) {\n store.dispatch('loginUser', store.state.oauth.token)\n }\n loaded = true\n } catch (e) {\n console.log(\"Couldn't load state\")\n console.error(e)\n loaded = true\n }\n subscriber(store)((mutation, state) => {\n try {\n if (saveImmedeatelyActions.includes(mutation.type)) {\n setState(key, reducer(state, paths), storage)\n .then(success => {\n if (typeof success !== 'undefined') {\n if (mutation.type === 'setOption' || mutation.type === 'setCurrentUser') {\n store.dispatch('settingsSaved', { success })\n }\n }\n }, error => {\n if (mutation.type === 'setOption' || mutation.type === 'setCurrentUser') {\n store.dispatch('settingsSaved', { error })\n }\n })\n }\n } catch (e) {\n console.log(\"Couldn't persist state:\")\n console.log(e)\n }\n })\n }\n })\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/lib/persisted_state.js","export default (store) => {\n store.subscribe((mutation, state) => {\n const vapidPublicKey = state.instance.vapidPublicKey\n const webPushNotification = state.config.webPushNotifications\n const permission = state.interface.notificationPermission === 'granted'\n const user = state.users.currentUser\n\n const isUserMutation = mutation.type === 'setCurrentUser'\n const isVapidMutation = mutation.type === 'setInstanceOption' && mutation.payload.name === 'vapidPublicKey'\n const isPermMutation = mutation.type === 'setNotificationPermission' && mutation.payload === 'granted'\n const isUserConfigMutation = mutation.type === 'setOption' && mutation.payload.name === 'webPushNotifications'\n const isVisibilityMutation = mutation.type === 'setOption' && mutation.payload.name === 'notificationVisibility'\n\n if (isUserMutation || isVapidMutation || isPermMutation || isUserConfigMutation || isVisibilityMutation) {\n if (user && vapidPublicKey && permission && webPushNotification) {\n return store.dispatch('registerPushNotifications')\n } else if (isUserConfigMutation && !webPushNotification) {\n return store.dispatch('unregisterPushNotifications')\n }\n }\n })\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/lib/push_notifications_plugin.js","import backendInteractorService from '../services/backend_interactor_service/backend_interactor_service.js'\nimport { Socket } from 'phoenix'\n\nconst api = {\n state: {\n backendInteractor: backendInteractorService(),\n fetchers: {},\n socket: null,\n chatDisabled: false,\n followRequests: []\n },\n mutations: {\n setBackendInteractor (state, backendInteractor) {\n state.backendInteractor = backendInteractor\n },\n addFetcher (state, {timeline, fetcher}) {\n state.fetchers[timeline] = fetcher\n },\n removeFetcher (state, {timeline}) {\n delete state.fetchers[timeline]\n },\n setWsToken (state, token) {\n state.wsToken = token\n },\n setSocket (state, socket) {\n state.socket = socket\n },\n setChatDisabled (state, value) {\n state.chatDisabled = value\n },\n setFollowRequests (state, value) {\n state.followRequests = value\n }\n },\n actions: {\n startFetching (store, {timeline = 'friends', tag = false, userId = false}) {\n // Don't start fetching if we already are.\n if (store.state.fetchers[timeline]) return\n\n const fetcher = store.state.backendInteractor.startFetching({ timeline, store, userId, tag })\n store.commit('addFetcher', { timeline, fetcher })\n },\n stopFetching (store, timeline) {\n const fetcher = store.state.fetchers[timeline]\n window.clearInterval(fetcher)\n store.commit('removeFetcher', {timeline})\n },\n setWsToken (store, token) {\n store.commit('setWsToken', token)\n },\n initializeSocket (store) {\n // Set up websocket connection\n if (!store.state.chatDisabled) {\n const token = store.state.wsToken\n const socket = new Socket('/socket', {params: {token}})\n socket.connect()\n store.dispatch('initializeChat', socket)\n }\n },\n disableChat (store) {\n store.commit('setChatDisabled', true)\n },\n removeFollowRequest (store, request) {\n let requests = store.state.followRequests.filter((it) => it !== request)\n store.commit('setFollowRequests', requests)\n }\n }\n}\n\nexport default api\n\n\n\n// WEBPACK FOOTER //\n// ./src/modules/api.js","const chat = {\n state: {\n messages: [],\n channel: {state: ''},\n socket: null\n },\n mutations: {\n setChannel (state, channel) {\n state.channel = channel\n },\n setSocket (state, socket) {\n state.socket = socket\n },\n addMessage (state, message) {\n state.messages.push(message)\n state.messages = state.messages.slice(-19, 20)\n },\n setMessages (state, messages) {\n state.messages = messages.slice(-19, 20)\n }\n },\n actions: {\n disconnectFromChat (store) {\n store.state.socket.disconnect()\n },\n initializeChat (store, socket) {\n const channel = socket.channel('chat:public')\n store.commit('setSocket', socket)\n channel.on('new_msg', (msg) => {\n store.commit('addMessage', msg)\n })\n channel.on('messages', ({messages}) => {\n store.commit('setMessages', messages)\n })\n channel.join()\n store.commit('setChannel', channel)\n }\n }\n}\n\nexport default chat\n\n\n\n// WEBPACK FOOTER //\n// ./src/modules/chat.js","import { set, delete as del } from 'vue'\nimport { setPreset, applyTheme } from '../services/style_setter/style_setter.js'\n\nconst browserLocale = (window.navigator.language || 'en').split('-')[0]\n\nconst defaultState = {\n colors: {},\n collapseMessageWithSubject: undefined, // instance default\n hideAttachments: false,\n hideAttachmentsInConv: false,\n maxThumbnails: 16,\n hideNsfw: true,\n preloadImage: true,\n loopVideo: true,\n loopVideoSilentOnly: true,\n autoLoad: true,\n streaming: false,\n hoverPreview: true,\n pauseOnUnfocused: true,\n stopGifs: false,\n replyVisibility: 'all',\n notificationVisibility: {\n follows: true,\n mentions: true,\n likes: true,\n repeats: true\n },\n webPushNotifications: false,\n muteWords: [],\n highlight: {},\n interfaceLanguage: browserLocale,\n scopeCopy: undefined, // instance default\n subjectLineBehavior: undefined, // instance default\n alwaysShowSubjectInput: undefined, // instance default\n postContentType: undefined // instance default\n}\n\nconst config = {\n state: defaultState,\n mutations: {\n setOption (state, { name, value }) {\n set(state, name, value)\n },\n setHighlight (state, { user, color, type }) {\n const data = this.state.config.highlight[user]\n if (color || type) {\n set(state.highlight, user, { color: color || data.color, type: type || data.type })\n } else {\n del(state.highlight, user)\n }\n }\n },\n actions: {\n setHighlight ({ commit, dispatch }, { user, color, type }) {\n commit('setHighlight', {user, color, type})\n },\n setOption ({ commit, dispatch }, { name, value }) {\n commit('setOption', {name, value})\n switch (name) {\n case 'theme':\n setPreset(value, commit)\n break\n case 'customTheme':\n applyTheme(value, commit)\n }\n }\n }\n}\n\nexport default config\n\n\n\n// WEBPACK FOOTER //\n// ./src/modules/config.js","import { capitalize } from 'lodash'\n\nexport function humanizeErrors (errors) {\n return Object.entries(errors).reduce((errs, [k, val]) => {\n let message = val.reduce((acc, message) => {\n let key = capitalize(k.replace(/_/g, ' '))\n return acc + [key, message].join(' ') + '. '\n }, '')\n return [...errs, message]\n }, [])\n}\n\n\n\n\n// WEBPACK FOOTER //\n// ./src/modules/errors.js","import { set } from 'vue'\nimport { setPreset } from '../services/style_setter/style_setter.js'\n\nconst defaultState = {\n // Stuff from static/config.json and apiConfig\n name: 'Pleroma FE',\n registrationOpen: true,\n textlimit: 5000,\n server: 'http://localhost:4040/',\n theme: 'pleroma-dark',\n background: '/static/aurora_borealis.jpg',\n logo: '/static/logo.png',\n logoMask: true,\n logoMargin: '.2em',\n redirectRootNoLogin: '/main/all',\n redirectRootLogin: '/main/friends',\n showInstanceSpecificPanel: false,\n scopeOptionsEnabled: true,\n formattingOptionsEnabled: false,\n alwaysShowSubjectInput: true,\n collapseMessageWithSubject: false,\n hidePostStats: false,\n hideUserStats: false,\n hideFilteredStatuses: false,\n disableChat: false,\n scopeCopy: true,\n subjectLineBehavior: 'email',\n postContentType: 'text/plain',\n loginMethod: 'password',\n nsfwCensorImage: undefined,\n vapidPublicKey: undefined,\n noAttachmentLinks: false,\n showFeaturesPanel: true,\n\n // Nasty stuff\n pleromaBackend: true,\n emoji: [],\n customEmoji: [],\n restrictedNicknames: [],\n postFormats: [],\n\n // Feature-set, apparently, not everything here is reported...\n mediaProxyAvailable: false,\n chatAvailable: false,\n gopherAvailable: false,\n suggestionsEnabled: false,\n suggestionsWeb: '',\n\n // Html stuff\n instanceSpecificPanelContent: '',\n tos: ''\n}\n\nconst instance = {\n state: defaultState,\n mutations: {\n setInstanceOption (state, { name, value }) {\n if (typeof value !== 'undefined') {\n set(state, name, value)\n }\n }\n },\n actions: {\n setInstanceOption ({ commit, dispatch }, { name, value }) {\n commit('setInstanceOption', {name, value})\n switch (name) {\n case 'name':\n dispatch('setPageTitle')\n break\n }\n },\n setTheme ({ commit }, themeName) {\n commit('setInstanceOption', { name: 'theme', value: themeName })\n return setPreset(themeName, commit)\n }\n }\n}\n\nexport default instance\n\n\n\n// WEBPACK FOOTER //\n// ./src/modules/instance.js","import { set, delete as del } from 'vue'\n\nconst defaultState = {\n settings: {\n currentSaveStateNotice: null,\n noticeClearTimeout: null,\n notificationPermission: null\n },\n browserSupport: {\n cssFilter: window.CSS && window.CSS.supports && (\n window.CSS.supports('filter', 'drop-shadow(0 0)') ||\n window.CSS.supports('-webkit-filter', 'drop-shadow(0 0)')\n )\n }\n}\n\nconst interfaceMod = {\n state: defaultState,\n mutations: {\n settingsSaved (state, { success, error }) {\n if (success) {\n if (state.noticeClearTimeout) {\n clearTimeout(state.noticeClearTimeout)\n }\n set(state.settings, 'currentSaveStateNotice', { error: false, data: success })\n set(state.settings, 'noticeClearTimeout',\n setTimeout(() => del(state.settings, 'currentSaveStateNotice'), 2000))\n } else {\n set(state.settings, 'currentSaveStateNotice', { error: true, errorData: error })\n }\n },\n setNotificationPermission (state, permission) {\n state.notificationPermission = permission\n }\n },\n actions: {\n setPageTitle ({ rootState }, option = '') {\n document.title = `${option} ${rootState.instance.name}`\n },\n settingsSaved ({ commit, dispatch }, { success, error }) {\n commit('settingsSaved', { success, error })\n },\n setNotificationPermission ({ commit }, permission) {\n commit('setNotificationPermission', permission)\n }\n }\n}\n\nexport default interfaceMod\n\n\n\n// WEBPACK FOOTER //\n// ./src/modules/interface.js","import fileTypeService from '../services/file_type/file_type.service.js'\n\nconst mediaViewer = {\n state: {\n media: [],\n currentIndex: 0,\n activated: false\n },\n mutations: {\n setMedia (state, media) {\n state.media = media\n },\n setCurrent (state, index) {\n state.activated = true\n state.currentIndex = index\n },\n close (state) {\n state.activated = false\n }\n },\n actions: {\n setMedia ({ commit }, attachments) {\n const media = attachments.filter(attachment => {\n const type = fileTypeService.fileType(attachment.mimetype)\n return type === 'image' || type === 'video'\n })\n commit('setMedia', media)\n },\n setCurrent ({ commit, state }, current) {\n const index = state.media.indexOf(current)\n commit('setCurrent', index || 0)\n },\n closeMediaViewer ({ commit }) {\n commit('close')\n }\n }\n}\n\nexport default mediaViewer\n\n\n\n// WEBPACK FOOTER //\n// ./src/modules/media_viewer.js","const oauth = {\n state: {\n client_id: false,\n client_secret: false,\n token: false\n },\n mutations: {\n setClientData (state, data) {\n state.client_id = data.client_id\n state.client_secret = data.client_secret\n },\n setToken (state, token) {\n state.token = token\n }\n }\n}\n\nexport default oauth\n\n\n\n// WEBPACK FOOTER //\n// ./src/modules/oauth.js","const oauthTokens = {\n state: {\n tokens: []\n },\n actions: {\n fetchTokens ({rootState, commit}) {\n rootState.api.backendInteractor.fetchOAuthTokens().then((tokens) => {\n commit('swapTokens', tokens)\n })\n },\n revokeToken ({rootState, commit, state}, id) {\n rootState.api.backendInteractor.revokeOAuthToken(id).then((response) => {\n if (response.status === 201) {\n commit('swapTokens', state.tokens.filter(token => token.id !== id))\n }\n })\n }\n },\n mutations: {\n swapTokens (state, tokens) {\n state.tokens = tokens\n }\n }\n}\n\nexport default oauthTokens\n\n\n\n// WEBPACK FOOTER //\n// ./src/modules/oauth_tokens.js","import { remove, slice, each, find, maxBy, minBy, merge, first, last, isArray } from 'lodash'\nimport apiService from '../services/api/api.service.js'\n// import parse from '../services/status_parser/status_parser.js'\n\nconst emptyTl = (userId = 0) => ({\n statuses: [],\n statusesObject: {},\n faves: [],\n visibleStatuses: [],\n visibleStatusesObject: {},\n newStatusCount: 0,\n maxId: 0,\n minId: 0,\n minVisibleId: 0,\n loading: false,\n followers: [],\n friends: [],\n userId,\n flushMarker: 0\n})\n\nexport const defaultState = () => ({\n allStatuses: [],\n allStatusesObject: {},\n maxId: 0,\n notifications: {\n desktopNotificationSilence: true,\n maxId: 0,\n minId: Number.POSITIVE_INFINITY,\n data: [],\n idStore: {},\n loading: false,\n error: false,\n fetcherId: null\n },\n favorites: new Set(),\n error: false,\n timelines: {\n mentions: emptyTl(),\n public: emptyTl(),\n user: emptyTl(),\n favorites: emptyTl(),\n media: emptyTl(),\n publicAndExternal: emptyTl(),\n friends: emptyTl(),\n tag: emptyTl(),\n dms: emptyTl()\n }\n})\n\nexport const prepareStatus = (status) => {\n // Set deleted flag\n status.deleted = false\n\n // To make the array reactive\n status.attachments = status.attachments || []\n\n return status\n}\n\nconst visibleNotificationTypes = (rootState) => {\n return [\n rootState.config.notificationVisibility.likes && 'like',\n rootState.config.notificationVisibility.mentions && 'mention',\n rootState.config.notificationVisibility.repeats && 'repeat',\n rootState.config.notificationVisibility.follows && 'follow'\n ].filter(_ => _)\n}\n\nconst mergeOrAdd = (arr, obj, item) => {\n const oldItem = obj[item.id]\n\n if (oldItem) {\n // We already have this, so only merge the new info.\n merge(oldItem, item)\n // Reactivity fix.\n oldItem.attachments.splice(oldItem.attachments.length)\n return {item: oldItem, new: false}\n } else {\n // This is a new item, prepare it\n prepareStatus(item)\n arr.push(item)\n obj[item.id] = item\n return {item, new: true}\n }\n}\n\nconst sortById = (a, b) => {\n const seqA = Number(a.id)\n const seqB = Number(b.id)\n const isSeqA = !Number.isNaN(seqA)\n const isSeqB = !Number.isNaN(seqB)\n if (isSeqA && isSeqB) {\n return seqA > seqB ? -1 : 1\n } else if (isSeqA && !isSeqB) {\n return 1\n } else if (!isSeqA && isSeqB) {\n return -1\n } else {\n return a.id > b.id ? -1 : 1\n }\n}\n\nconst sortTimeline = (timeline) => {\n timeline.visibleStatuses = timeline.visibleStatuses.sort(sortById)\n timeline.statuses = timeline.statuses.sort(sortById)\n timeline.minVisibleId = (last(timeline.visibleStatuses) || {}).id\n return timeline\n}\n\nconst addNewStatuses = (state, { statuses, showImmediately = false, timeline, user = {}, noIdUpdate = false, userId }) => {\n // Sanity check\n if (!isArray(statuses)) {\n return false\n }\n\n const allStatuses = state.allStatuses\n const allStatusesObject = state.allStatusesObject\n const timelineObject = state.timelines[timeline]\n\n const maxNew = statuses.length > 0 ? maxBy(statuses, 'id').id : 0\n const minNew = statuses.length > 0 ? minBy(statuses, 'id').id : 0\n const newer = timeline && maxNew > timelineObject.maxId && statuses.length > 0\n const older = timeline && (minNew < timelineObject.minId || timelineObject.minId === 0) && statuses.length > 0\n\n if (!noIdUpdate && newer) {\n timelineObject.maxId = maxNew\n }\n if (!noIdUpdate && older) {\n timelineObject.minId = minNew\n }\n\n // This makes sure that user timeline won't get data meant for other\n // user. I.e. opening different user profiles makes request which could\n // return data late after user already viewing different user profile\n if ((timeline === 'user' || timeline === 'media') && timelineObject.userId !== userId) {\n return\n }\n\n const addStatus = (data, showImmediately, addToTimeline = true) => {\n const result = mergeOrAdd(allStatuses, allStatusesObject, data)\n const status = result.item\n\n if (result.new) {\n // We are mentioned in a post\n if (status.type === 'status' && find(status.attentions, { id: user.id })) {\n const mentions = state.timelines.mentions\n\n // Add the mention to the mentions timeline\n if (timelineObject !== mentions) {\n mergeOrAdd(mentions.statuses, mentions.statusesObject, status)\n mentions.newStatusCount += 1\n\n sortTimeline(mentions)\n }\n }\n if (status.visibility === 'direct') {\n const dms = state.timelines.dms\n\n mergeOrAdd(dms.statuses, dms.statusesObject, status)\n dms.newStatusCount += 1\n\n sortTimeline(dms)\n }\n }\n\n // Decide if we should treat the status as new for this timeline.\n let resultForCurrentTimeline\n // Some statuses should only be added to the global status repository.\n if (timeline && addToTimeline) {\n resultForCurrentTimeline = mergeOrAdd(timelineObject.statuses, timelineObject.statusesObject, status)\n }\n\n if (timeline && showImmediately) {\n // Add it directly to the visibleStatuses, don't change\n // newStatusCount\n mergeOrAdd(timelineObject.visibleStatuses, timelineObject.visibleStatusesObject, status)\n } else if (timeline && addToTimeline && resultForCurrentTimeline.new) {\n // Just change newStatuscount\n timelineObject.newStatusCount += 1\n }\n\n return status\n }\n\n const favoriteStatus = (favorite, counter) => {\n const status = find(allStatuses, { id: favorite.in_reply_to_status_id })\n if (status) {\n // This is our favorite, so the relevant bit.\n if (favorite.user.id === user.id) {\n status.favorited = true\n } else {\n status.fave_num += 1\n }\n }\n return status\n }\n\n const processors = {\n 'status': (status) => {\n addStatus(status, showImmediately)\n },\n 'retweet': (status) => {\n // RetweetedStatuses are never shown immediately\n const retweetedStatus = addStatus(status.retweeted_status, false, false)\n\n let retweet\n // If the retweeted status is already there, don't add the retweet\n // to the timeline.\n if (timeline && find(timelineObject.statuses, (s) => {\n if (s.retweeted_status) {\n return s.id === retweetedStatus.id || s.retweeted_status.id === retweetedStatus.id\n } else {\n return s.id === retweetedStatus.id\n }\n })) {\n // Already have it visible (either as the original or another RT), don't add to timeline, don't show.\n retweet = addStatus(status, false, false)\n } else {\n retweet = addStatus(status, showImmediately)\n }\n\n retweet.retweeted_status = retweetedStatus\n },\n 'favorite': (favorite) => {\n // Only update if this is a new favorite.\n // Ignore our own favorites because we get info about likes as response to like request\n if (!state.favorites.has(favorite.id)) {\n state.favorites.add(favorite.id)\n favoriteStatus(favorite)\n }\n },\n 'deletion': (deletion) => {\n const uri = deletion.uri\n\n // Remove possible notification\n const status = find(allStatuses, {uri})\n if (!status) {\n return\n }\n\n remove(state.notifications.data, ({action: {id}}) => id === status.id)\n\n remove(allStatuses, { uri })\n if (timeline) {\n remove(timelineObject.statuses, { uri })\n remove(timelineObject.visibleStatuses, { uri })\n }\n },\n 'follow': (follow) => {\n // NOOP, it is known status but we don't do anything about it for now\n },\n 'default': (unknown) => {\n console.log('unknown status type')\n console.log(unknown)\n }\n }\n\n each(statuses, (status) => {\n const type = status.type\n const processor = processors[type] || processors['default']\n processor(status)\n })\n\n // Keep the visible statuses sorted\n if (timeline) {\n sortTimeline(timelineObject)\n }\n}\n\nconst addNewNotifications = (state, { dispatch, notifications, older, visibleNotificationTypes }) => {\n const allStatuses = state.allStatuses\n const allStatusesObject = state.allStatusesObject\n each(notifications, (notification) => {\n notification.action = mergeOrAdd(allStatuses, allStatusesObject, notification.action).item\n notification.status = notification.status && mergeOrAdd(allStatuses, allStatusesObject, notification.status).item\n\n // Only add a new notification if we don't have one for the same action\n if (!state.notifications.idStore.hasOwnProperty(notification.id)) {\n state.notifications.maxId = notification.id > state.notifications.maxId\n ? notification.id\n : state.notifications.maxId\n state.notifications.minId = notification.id < state.notifications.minId\n ? notification.id\n : state.notifications.minId\n\n state.notifications.data.push(notification)\n state.notifications.idStore[notification.id] = notification\n\n if ('Notification' in window && window.Notification.permission === 'granted') {\n const notifObj = {}\n const action = notification.action\n const title = action.user.name\n notifObj.icon = action.user.profile_image_url\n notifObj.body = action.text // there's a problem that it doesn't put a space before links tho\n\n // Shows first attached non-nsfw image, if any. Should add configuration for this somehow...\n if (action.attachments && action.attachments.length > 0 && !action.nsfw &&\n action.attachments[0].mimetype.startsWith('image/')) {\n notifObj.image = action.attachments[0].url\n }\n\n if (!notification.seen && !state.notifications.desktopNotificationSilence && visibleNotificationTypes.includes(notification.type)) {\n let notification = new window.Notification(title, notifObj)\n // Chrome is known for not closing notifications automatically\n // according to MDN, anyway.\n setTimeout(notification.close.bind(notification), 5000)\n }\n }\n } else if (notification.seen) {\n state.notifications.idStore[notification.id].seen = true\n }\n })\n}\n\nconst removeStatus = (state, { timeline, userId }) => {\n const timelineObject = state.timelines[timeline]\n if (userId) {\n remove(timelineObject.statuses, { user: { id: userId } })\n remove(timelineObject.visibleStatuses, { user: { id: userId } })\n timelineObject.minVisibleId = timelineObject.visibleStatuses.length > 0 ? last(timelineObject.visibleStatuses).id : 0\n timelineObject.maxId = timelineObject.statuses.length > 0 ? first(timelineObject.statuses).id : 0\n }\n}\n\nexport const mutations = {\n addNewStatuses,\n addNewNotifications,\n removeStatus,\n showNewStatuses (state, { timeline }) {\n const oldTimeline = (state.timelines[timeline])\n\n oldTimeline.newStatusCount = 0\n oldTimeline.visibleStatuses = slice(oldTimeline.statuses, 0, 50)\n oldTimeline.minVisibleId = last(oldTimeline.visibleStatuses).id\n oldTimeline.minId = oldTimeline.minVisibleId\n oldTimeline.visibleStatusesObject = {}\n each(oldTimeline.visibleStatuses, (status) => { oldTimeline.visibleStatusesObject[status.id] = status })\n },\n setNotificationFetcher (state, { fetcherId }) {\n state.notifications.fetcherId = fetcherId\n },\n resetStatuses (state) {\n const emptyState = defaultState()\n Object.entries(emptyState).forEach(([key, value]) => {\n state[key] = value\n })\n },\n clearTimeline (state, { timeline }) {\n state.timelines[timeline] = emptyTl(state.timelines[timeline].userId)\n },\n setFavorited (state, { status, value }) {\n const newStatus = state.allStatusesObject[status.id]\n newStatus.favorited = value\n },\n setFavoritedConfirm (state, { status }) {\n const newStatus = state.allStatusesObject[status.id]\n newStatus.favorited = status.favorited\n newStatus.fave_num = status.fave_num\n },\n setRetweeted (state, { status, value }) {\n const newStatus = state.allStatusesObject[status.id]\n newStatus.repeated = value\n },\n setDeleted (state, { status }) {\n const newStatus = state.allStatusesObject[status.id]\n newStatus.deleted = true\n },\n setLoading (state, { timeline, value }) {\n state.timelines[timeline].loading = value\n },\n setNsfw (state, { id, nsfw }) {\n const newStatus = state.allStatusesObject[id]\n newStatus.nsfw = nsfw\n },\n setError (state, { value }) {\n state.error = value\n },\n setNotificationsLoading (state, { value }) {\n state.notifications.loading = value\n },\n setNotificationsError (state, { value }) {\n state.notifications.error = value\n },\n setNotificationsSilence (state, { value }) {\n state.notifications.desktopNotificationSilence = value\n },\n markNotificationsAsSeen (state) {\n each(state.notifications.data, (notification) => {\n notification.seen = true\n })\n },\n queueFlush (state, { timeline, id }) {\n state.timelines[timeline].flushMarker = id\n }\n}\n\nconst statuses = {\n state: defaultState(),\n actions: {\n addNewStatuses ({ rootState, commit }, { statuses, showImmediately = false, timeline = false, noIdUpdate = false, userId }) {\n commit('addNewStatuses', { statuses, showImmediately, timeline, noIdUpdate, user: rootState.users.currentUser, userId })\n },\n addNewNotifications ({ rootState, commit, dispatch }, { notifications, older }) {\n commit('addNewNotifications', { visibleNotificationTypes: visibleNotificationTypes(rootState), dispatch, notifications, older })\n },\n setError ({ rootState, commit }, { value }) {\n commit('setError', { value })\n },\n setNotificationsLoading ({ rootState, commit }, { value }) {\n commit('setNotificationsLoading', { value })\n },\n setNotificationsError ({ rootState, commit }, { value }) {\n commit('setNotificationsError', { value })\n },\n setNotificationsSilence ({ rootState, commit }, { value }) {\n commit('setNotificationsSilence', { value })\n },\n stopFetchingNotifications ({ rootState, commit }) {\n if (rootState.statuses.notifications.fetcherId) {\n window.clearInterval(rootState.statuses.notifications.fetcherId)\n }\n commit('setNotificationFetcher', { fetcherId: null })\n },\n deleteStatus ({ rootState, commit }, status) {\n commit('setDeleted', { status })\n apiService.deleteStatus({ id: status.id, credentials: rootState.users.currentUser.credentials })\n },\n favorite ({ rootState, commit }, status) {\n // Optimistic favoriting...\n commit('setFavorited', { status, value: true })\n apiService.favorite({ id: status.id, credentials: rootState.users.currentUser.credentials })\n .then(response => {\n if (response.ok) {\n return response.json()\n } else {\n return {}\n }\n })\n .then(status => {\n commit('setFavoritedConfirm', { status })\n })\n },\n unfavorite ({ rootState, commit }, status) {\n // Optimistic favoriting...\n commit('setFavorited', { status, value: false })\n apiService.unfavorite({ id: status.id, credentials: rootState.users.currentUser.credentials })\n .then(response => {\n if (response.ok) {\n return response.json()\n } else {\n return {}\n }\n })\n .then(status => {\n commit('setFavoritedConfirm', { status })\n })\n },\n retweet ({ rootState, commit }, status) {\n // Optimistic retweeting...\n commit('setRetweeted', { status, value: true })\n apiService.retweet({ id: status.id, credentials: rootState.users.currentUser.credentials })\n },\n unretweet ({ rootState, commit }, status) {\n commit('setRetweeted', { status, value: false })\n apiService.unretweet({ id: status.id, credentials: rootState.users.currentUser.credentials })\n },\n queueFlush ({ rootState, commit }, { timeline, id }) {\n commit('queueFlush', { timeline, id })\n },\n markNotificationsAsSeen ({ rootState, commit }) {\n commit('markNotificationsAsSeen')\n apiService.markNotificationsAsSeen({\n id: rootState.statuses.notifications.maxId,\n credentials: rootState.users.currentUser.credentials\n })\n }\n },\n mutations\n}\n\nexport default statuses\n\n\n\n// WEBPACK FOOTER //\n// ./src/modules/statuses.js","import backendInteractorService from '../services/backend_interactor_service/backend_interactor_service.js'\nimport { compact, map, each, merge, find } from 'lodash'\nimport { set } from 'vue'\nimport { registerPushNotifications, unregisterPushNotifications } from '../services/push/push.js'\nimport oauthApi from '../services/new_api/oauth'\nimport { humanizeErrors } from './errors'\n\n// TODO: Unify with mergeOrAdd in statuses.js\nexport const mergeOrAdd = (arr, obj, item) => {\n if (!item) { return false }\n const oldItem = obj[item.id]\n if (oldItem) {\n // We already have this, so only merge the new info.\n merge(oldItem, item)\n return { item: oldItem, new: false }\n } else {\n // This is a new item, prepare it\n arr.push(item)\n obj[item.id] = item\n if (item.screen_name && !item.screen_name.includes('@')) {\n obj[item.screen_name] = item\n }\n return { item, new: true }\n }\n}\n\nconst getNotificationPermission = () => {\n const Notification = window.Notification\n\n if (!Notification) return Promise.resolve(null)\n if (Notification.permission === 'default') return Notification.requestPermission()\n return Promise.resolve(Notification.permission)\n}\n\nexport const mutations = {\n setMuted (state, { user: { id }, muted }) {\n const user = state.usersObject[id]\n set(user, 'muted', muted)\n },\n setCurrentUser (state, user) {\n state.lastLoginName = user.screen_name\n state.currentUser = merge(state.currentUser || {}, user)\n },\n clearCurrentUser (state) {\n state.currentUser = false\n state.lastLoginName = false\n },\n beginLogin (state) {\n state.loggingIn = true\n },\n endLogin (state) {\n state.loggingIn = false\n },\n // TODO Clean after ourselves?\n addFriends (state, { id, friends, page }) {\n const user = state.usersObject[id]\n each(friends, friend => {\n if (!find(user.friends, { id: friend.id })) {\n user.friends.push(friend)\n }\n })\n user.friendsPage = page + 1\n },\n addFollowers (state, { id, followers, page }) {\n const user = state.usersObject[id]\n each(followers, follower => {\n if (!find(user.followers, { id: follower.id })) {\n user.followers.push(follower)\n }\n })\n user.followersPage = page + 1\n },\n // Because frontend doesn't have a reason to keep these stuff in memory\n // outside of viewing someones user profile.\n clearFriends (state, userId) {\n const user = state.usersObject[userId]\n if (!user) {\n return\n }\n user.friends = []\n user.friendsPage = 0\n },\n clearFollowers (state, userId) {\n const user = state.usersObject[userId]\n if (!user) {\n return\n }\n user.followers = []\n user.followersPage = 0\n },\n addNewUsers (state, users) {\n each(users, (user) => mergeOrAdd(state.users, state.usersObject, user))\n },\n saveBlocks (state, blockIds) {\n state.currentUser.blockIds = blockIds\n },\n saveMutes (state, muteIds) {\n state.currentUser.muteIds = muteIds\n },\n setUserForStatus (state, status) {\n status.user = state.usersObject[status.user.id]\n },\n setUserForNotification (state, notification) {\n notification.action.user = state.usersObject[notification.action.user.id]\n notification.from_profile = state.usersObject[notification.action.user.id]\n },\n setColor (state, { user: { id }, highlighted }) {\n const user = state.usersObject[id]\n set(user, 'highlight', highlighted)\n },\n signUpPending (state) {\n state.signUpPending = true\n state.signUpErrors = []\n },\n signUpSuccess (state) {\n state.signUpPending = false\n },\n signUpFailure (state, errors) {\n state.signUpPending = false\n state.signUpErrors = errors\n }\n}\n\nexport const getters = {\n userById: state => id =>\n state.users.find(user => user.id === id),\n userByName: state => name =>\n state.users.find(user => user.screen_name &&\n (user.screen_name.toLowerCase() === name.toLowerCase())\n )\n}\n\nexport const defaultState = {\n loggingIn: false,\n lastLoginName: false,\n currentUser: false,\n users: [],\n usersObject: {},\n signUpPending: false,\n signUpErrors: []\n}\n\nconst users = {\n state: defaultState,\n mutations,\n getters,\n actions: {\n fetchUser (store, id) {\n return store.rootState.api.backendInteractor.fetchUser({ id })\n .then((user) => store.commit('addNewUsers', [user]))\n },\n fetchBlocks (store) {\n return store.rootState.api.backendInteractor.fetchBlocks()\n .then((blocks) => {\n store.commit('saveBlocks', map(blocks, 'id'))\n store.commit('addNewUsers', blocks)\n return blocks\n })\n },\n blockUser (store, id) {\n return store.rootState.api.backendInteractor.blockUser(id)\n .then((user) => store.commit('addNewUsers', [user]))\n },\n unblockUser (store, id) {\n return store.rootState.api.backendInteractor.unblockUser(id)\n .then((user) => store.commit('addNewUsers', [user]))\n },\n fetchMutes (store) {\n return store.rootState.api.backendInteractor.fetchMutes()\n .then((mutedUsers) => {\n each(mutedUsers, (user) => { user.muted = true })\n store.commit('addNewUsers', mutedUsers)\n store.commit('saveMutes', map(mutedUsers, 'id'))\n })\n },\n muteUser (store, id) {\n return store.state.api.backendInteractor.setUserMute({ id, muted: true })\n .then((user) => store.commit('addNewUsers', [user]))\n },\n unmuteUser (store, id) {\n return store.state.api.backendInteractor.setUserMute({ id, muted: false })\n .then((user) => store.commit('addNewUsers', [user]))\n },\n addFriends ({ rootState, commit }, fetchBy) {\n return new Promise((resolve, reject) => {\n const user = rootState.users.usersObject[fetchBy]\n const page = user.friendsPage || 1\n rootState.api.backendInteractor.fetchFriends({ id: user.id, page })\n .then((friends) => {\n commit('addFriends', { id: user.id, friends, page })\n resolve(friends)\n }).catch(() => {\n reject()\n })\n })\n },\n addFollowers ({ rootState, commit }, fetchBy) {\n const user = rootState.users.usersObject[fetchBy]\n const page = user.followersPage || 1\n return rootState.api.backendInteractor.fetchFollowers({ id: user.id, page })\n .then((followers) => {\n commit('addFollowers', { id: user.id, followers, page })\n return followers\n })\n },\n clearFriends ({ commit }, userId) {\n commit('clearFriends', userId)\n },\n clearFollowers ({ commit }, userId) {\n commit('clearFollowers', userId)\n },\n registerPushNotifications (store) {\n const token = store.state.currentUser.credentials\n const vapidPublicKey = store.rootState.instance.vapidPublicKey\n const isEnabled = store.rootState.config.webPushNotifications\n const notificationVisibility = store.rootState.config.notificationVisibility\n\n registerPushNotifications(isEnabled, vapidPublicKey, token, notificationVisibility)\n },\n unregisterPushNotifications (store) {\n const token = store.state.currentUser.credentials\n\n unregisterPushNotifications(token)\n },\n addNewStatuses (store, { statuses }) {\n const users = map(statuses, 'user')\n const retweetedUsers = compact(map(statuses, 'retweeted_status.user'))\n store.commit('addNewUsers', users)\n store.commit('addNewUsers', retweetedUsers)\n\n // Reconnect users to statuses\n each(statuses, (status) => {\n store.commit('setUserForStatus', status)\n })\n // Reconnect users to retweets\n each(compact(map(statuses, 'retweeted_status')), (status) => {\n store.commit('setUserForStatus', status)\n })\n },\n addNewNotifications (store, { notifications }) {\n const users = map(notifications, 'from_profile')\n const notificationIds = notifications.map(_ => _.id)\n store.commit('addNewUsers', users)\n\n const notificationsObject = store.rootState.statuses.notifications.idStore\n const relevantNotifications = Object.entries(notificationsObject)\n .filter(([k, val]) => notificationIds.includes(k))\n .map(([k, val]) => val)\n\n // Reconnect users to notifications\n each(relevantNotifications, (notification) => {\n store.commit('setUserForNotification', notification)\n })\n },\n async signUp (store, userInfo) {\n store.commit('signUpPending')\n\n let rootState = store.rootState\n\n let response = await rootState.api.backendInteractor.register(userInfo)\n if (response.ok) {\n const data = {\n oauth: rootState.oauth,\n instance: rootState.instance.server\n }\n let app = await oauthApi.getOrCreateApp(data)\n let result = await oauthApi.getTokenWithCredentials({\n app,\n instance: data.instance,\n username: userInfo.username,\n password: userInfo.password\n })\n store.commit('signUpSuccess')\n store.commit('setToken', result.access_token)\n store.dispatch('loginUser', result.access_token)\n } else {\n const data = await response.json()\n let errors = JSON.parse(data.error)\n // replace ap_id with username\n if (errors.ap_id) {\n errors.username = errors.ap_id\n delete errors.ap_id\n }\n errors = humanizeErrors(errors)\n store.commit('signUpFailure', errors)\n throw Error(errors)\n }\n },\n async getCaptcha (store) {\n return await store.rootState.api.backendInteractor.getCaptcha()\n },\n\n logout (store) {\n store.commit('clearCurrentUser')\n store.dispatch('disconnectFromChat')\n store.commit('setToken', false)\n store.dispatch('stopFetching', 'friends')\n store.commit('setBackendInteractor', backendInteractorService())\n store.dispatch('stopFetchingNotifications')\n store.commit('resetStatuses')\n },\n loginUser (store, accessToken) {\n return new Promise((resolve, reject) => {\n const commit = store.commit\n commit('beginLogin')\n store.rootState.api.backendInteractor.verifyCredentials(accessToken)\n .then((data) => {\n if (!data.error) {\n const user = data\n // user.credentials = userCredentials\n user.credentials = accessToken\n user.blockIds = []\n user.muteIds = []\n commit('setCurrentUser', user)\n commit('addNewUsers', [user])\n\n getNotificationPermission()\n .then(permission => commit('setNotificationPermission', permission))\n\n // Set our new backend interactor\n commit('setBackendInteractor', backendInteractorService(accessToken))\n\n if (user.token) {\n store.dispatch('setWsToken', user.token)\n\n // Initialize the chat socket.\n store.dispatch('initializeSocket')\n }\n\n // Start getting fresh posts.\n store.dispatch('startFetching', { timeline: 'friends' })\n\n // Get user mutes\n store.dispatch('fetchMutes')\n\n // Fetch our friends\n store.rootState.api.backendInteractor.fetchFriends({ id: user.id })\n .then((friends) => commit('addNewUsers', friends))\n } else {\n const response = data.error\n // Authentication failed\n commit('endLogin')\n if (response.status === 401) {\n reject('Wrong username or password')\n } else {\n reject('An error occurred, please try again')\n }\n }\n commit('endLogin')\n resolve()\n })\n .catch((error) => {\n console.log(error)\n commit('endLogin')\n reject('Failed to connect to server, try again')\n })\n })\n }\n }\n}\n\nexport default users\n\n\n\n// WEBPACK FOOTER //\n// ./src/modules/users.js","import { reduce, find } from 'lodash'\n\nexport const replaceWord = (str, toReplace, replacement) => {\n return str.slice(0, toReplace.start) + replacement + str.slice(toReplace.end)\n}\n\nexport const wordAtPosition = (str, pos) => {\n const words = splitIntoWords(str)\n const wordsWithPosition = addPositionToWords(words)\n\n return find(wordsWithPosition, ({start, end}) => start <= pos && end > pos)\n}\n\nexport const addPositionToWords = (words) => {\n return reduce(words, (result, word) => {\n const data = {\n word,\n start: 0,\n end: word.length\n }\n\n if (result.length > 0) {\n const previous = result.pop()\n\n data.start += previous.end\n data.end += previous.end\n\n result.push(previous)\n }\n\n result.push(data)\n\n return result\n }, [])\n}\n\nexport const splitIntoWords = (str) => {\n // Split at word boundaries\n const regex = /\\b/\n const triggers = /[@#:]+$/\n\n let split = str.split(regex)\n\n // Add trailing @ and # to the following word.\n const words = reduce(split, (result, word) => {\n if (result.length > 0) {\n let previous = result.pop()\n const matches = previous.match(triggers)\n if (matches) {\n previous = previous.replace(triggers, '')\n word = matches[0] + word\n }\n result.push(previous)\n }\n result.push(word)\n\n return result\n }, [])\n\n return words\n}\n\nconst completion = {\n wordAtPosition,\n addPositionToWords,\n splitIntoWords,\n replaceWord\n}\n\nexport default completion\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/completion/completion.js","const qvitterStatusType = (status) => {\n if (status.is_post_verb) {\n return 'status'\n }\n\n if (status.retweeted_status) {\n return 'retweet'\n }\n\n if ((typeof status.uri === 'string' && status.uri.match(/(fave|objectType=Favourite)/)) ||\n (typeof status.text === 'string' && status.text.match(/favorited/))) {\n return 'favorite'\n }\n\n if (status.text.match(/deleted notice {{tag/) || status.qvitter_delete_notice) {\n return 'deletion'\n }\n\n if (status.text.match(/started following/) || status.activity_type === 'follow') {\n return 'follow'\n }\n\n return 'unknown'\n}\n\nexport const parseUser = (data) => {\n const output = {}\n const masto = data.hasOwnProperty('acct')\n // case for users in \"mentions\" property for statuses in MastoAPI\n const mastoShort = masto && !data.hasOwnProperty('avatar')\n\n output.id = String(data.id)\n\n if (masto) {\n output.screen_name = data.acct\n\n // There's nothing else to get\n if (mastoShort) {\n return output\n }\n\n output.name = null // missing\n output.name_html = data.display_name\n\n output.description = null // missing\n output.description_html = data.note\n\n // Utilize avatar_static for gif avatars?\n output.profile_image_url = data.avatar\n output.profile_image_url_original = data.avatar\n\n // Same, utilize header_static?\n output.cover_photo = data.header\n\n output.friends_count = data.following_count\n\n output.bot = data.bot\n\n output.statusnet_profile_url = data.url\n\n if (data.pleroma) {\n const pleroma = data.pleroma\n output.follows_you = pleroma.follows_you\n output.statusnet_blocking = pleroma.statusnet_blocking\n output.muted = pleroma.muted\n }\n\n // Missing, trying to recover\n output.is_local = !output.screen_name.includes('@')\n } else {\n output.screen_name = data.screen_name\n\n output.name = data.name\n output.name_html = data.name_html\n\n output.description = data.description\n output.description_html = data.description_html\n\n output.profile_image_url = data.profile_image_url\n output.profile_image_url_original = data.profile_image_url_original\n\n output.cover_photo = data.cover_photo\n\n output.friends_count = data.friends_count\n\n output.bot = null // missing\n\n output.statusnet_profile_url = data.statusnet_profile_url\n\n output.statusnet_blocking = data.statusnet_blocking\n\n output.is_local = data.is_local\n output.role = data.role\n output.show_role = data.show_role\n\n output.follows_you = data.follows_you\n\n output.muted = data.muted\n\n // QVITTER ONLY FOR NOW\n // Really only applies to logged in user, really.. I THINK\n output.rights = data.rights\n output.no_rich_text = data.no_rich_text\n output.default_scope = data.default_scope\n output.hide_follows = data.hide_follows\n output.hide_followers = data.hide_followers\n output.background_image = data.background_image\n // on mastoapi this info is contained in a \"relationship\"\n output.following = data.following\n // Websocket token\n output.token = data.token\n }\n\n output.created_at = new Date(data.created_at)\n output.locked = data.locked\n output.followers_count = data.followers_count\n output.statuses_count = data.statuses_count\n output.friends = []\n output.followers = []\n if (data.pleroma) {\n output.follow_request_count = data.pleroma.follow_request_count\n }\n\n return output\n}\n\nconst parseAttachment = (data) => {\n const output = {}\n const masto = !data.hasOwnProperty('oembed')\n\n if (masto) {\n // Not exactly same...\n output.mimetype = data.type\n output.meta = data.meta // not present in BE yet\n } else {\n output.mimetype = data.mimetype\n output.meta = null // missing\n }\n\n output.url = data.url\n output.description = data.description\n\n return output\n}\n\nexport const parseStatus = (data) => {\n const output = {}\n const masto = data.hasOwnProperty('account')\n\n if (masto) {\n output.favorited = data.favourited\n output.fave_num = data.favourites_count\n\n output.repeated = data.reblogged\n output.repeat_num = data.reblogs_count\n\n output.type = data.reblog ? 'retweet' : 'status'\n output.nsfw = data.sensitive\n\n output.statusnet_html = data.content\n\n // Not exactly the same but works?\n output.text = data.content\n\n output.in_reply_to_status_id = data.in_reply_to_id\n output.in_reply_to_user_id = data.in_reply_to_account_id\n\n // Missing!! fix in UI?\n output.in_reply_to_screen_name = null\n\n // Not exactly the same but works\n output.statusnet_conversation_id = data.id\n\n if (output.type === 'retweet') {\n output.retweeted_status = parseStatus(data.reblog)\n }\n\n output.summary = data.spoiler_text\n output.summary_html = data.spoiler_text\n output.external_url = data.url\n\n // FIXME missing!!\n output.is_local = false\n } else {\n output.favorited = data.favorited\n output.fave_num = data.fave_num\n\n output.repeated = data.repeated\n output.repeat_num = data.repeat_num\n\n // catchall, temporary\n // Object.assign(output, data)\n\n output.type = qvitterStatusType(data)\n\n if (data.nsfw === undefined) {\n output.nsfw = isNsfw(data)\n if (data.retweeted_status) {\n output.nsfw = data.retweeted_status.nsfw\n }\n } else {\n output.nsfw = data.nsfw\n }\n\n output.statusnet_html = data.statusnet_html\n output.text = data.text\n\n output.in_reply_to_status_id = data.in_reply_to_status_id\n output.in_reply_to_user_id = data.in_reply_to_user_id\n output.in_reply_to_screen_name = data.in_reply_to_screen_name\n\n output.statusnet_conversation_id = data.statusnet_conversation_id\n\n if (output.type === 'retweet') {\n output.retweeted_status = parseStatus(data.retweeted_status)\n }\n\n output.summary = data.summary\n output.summary_html = data.summary_html\n output.external_url = data.external_url\n output.is_local = data.is_local\n }\n\n output.id = String(data.id)\n output.visibility = data.visibility\n output.card = data.card\n output.created_at = new Date(data.created_at)\n\n // Converting to string, the right way.\n output.in_reply_to_status_id = output.in_reply_to_status_id\n ? String(output.in_reply_to_status_id)\n : null\n output.in_reply_to_user_id = output.in_reply_to_user_id\n ? String(output.in_reply_to_user_id)\n : null\n\n output.user = parseUser(masto ? data.account : data.user)\n\n output.attentions = ((masto ? data.mentions : data.attentions) || []).map(parseUser)\n\n output.attachments = ((masto ? data.media_attachments : data.attachments) || [])\n .map(parseAttachment)\n\n const retweetedStatus = masto ? data.reblog : data.retweeted_status\n if (retweetedStatus) {\n output.retweeted_status = parseStatus(retweetedStatus)\n }\n\n return output\n}\n\nexport const parseNotification = (data) => {\n const mastoDict = {\n 'favourite': 'like',\n 'reblog': 'repeat'\n }\n const masto = !data.hasOwnProperty('ntype')\n const output = {}\n\n if (masto) {\n output.type = mastoDict[data.type] || data.type\n output.seen = null // missing\n output.status = parseStatus(data.status)\n output.action = output.status // not sure\n output.from_profile = parseUser(data.account)\n } else {\n const parsedNotice = parseStatus(data.notice)\n output.type = data.ntype\n output.seen = Boolean(data.is_seen)\n output.status = output.type === 'like'\n ? parseStatus(data.notice.favorited_status)\n : parsedNotice\n output.action = parsedNotice\n output.from_profile = parseUser(data.from_profile)\n }\n\n output.created_at = new Date(data.created_at)\n output.id = data.id\n\n return output\n}\n\nconst isNsfw = (status) => {\n const nsfwRegex = /#nsfw/i\n return (status.tags || []).includes('nsfw') || !!status.text.match(nsfwRegex)\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/entity_normalizer/entity_normalizer.service.js","export function StatusCodeError (statusCode, body, options, response) {\n this.name = 'StatusCodeError'\n this.statusCode = statusCode\n this.message = statusCode + ' - ' + (JSON && JSON.stringify ? JSON.stringify(body) : body)\n this.error = body // legacy attribute\n this.options = options\n this.response = response\n\n if (Error.captureStackTrace) { // required for non-V8 environments\n Error.captureStackTrace(this)\n }\n}\nStatusCodeError.prototype = Object.create(Error.prototype)\nStatusCodeError.prototype.constructor = StatusCodeError\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/errors/errors.js","import apiService from '../api/api.service.js'\n\nconst fetchAndUpdate = ({ store, credentials }) => {\n return apiService.fetchFollowRequests({ credentials })\n .then((requests) => {\n store.commit('setFollowRequests', requests)\n }, () => {})\n .catch(() => {})\n}\n\nconst startFetching = ({credentials, store}) => {\n fetchAndUpdate({ credentials, store })\n const boundFetchAndUpdate = () => fetchAndUpdate({ credentials, store })\n return setInterval(boundFetchAndUpdate, 10000)\n}\n\nconst followRequestFetcher = {\n startFetching\n}\n\nexport default followRequestFetcher\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/follow_request_fetcher/follow_request_fetcher.service.js","export const mentionMatchesUrl = (attention, url) => {\n if (url === attention.statusnet_profile_url) {\n return true\n }\n const [namepart, instancepart] = attention.screen_name.split('@')\n const matchstring = new RegExp('://' + instancepart + '/.*' + namepart + '$', 'g')\n\n return !!url.match(matchstring)\n}\n\n/**\n * Extract tag name from pleroma or mastodon url.\n * i.e https://bikeshed.party/tag/photo or https://quey.org/tags/sky\n * @param {string} url\n */\nexport const extractTagFromUrl = (url) => {\n const regex = /tag[s]*\\/(\\w+)$/g\n const result = regex.exec(url)\n if (!result) {\n return false\n }\n return result[1]\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/matcher/matcher.service.js","import utils from './utils.js'\n\nconst search = ({query, store}) => {\n return utils.request({\n store,\n url: '/api/pleroma/search_user',\n params: {\n query\n }\n }).then((data) => data.json())\n}\nconst UserSearch = {\n search\n}\n\nexport default UserSearch\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/new_api/user_search.js","const queryParams = (params) => {\n return Object.keys(params)\n .map(k => encodeURIComponent(k) + '=' + encodeURIComponent(params[k]))\n .join('&')\n}\n\nconst headers = (store) => {\n const accessToken = store.state.oauth.token\n if (accessToken) {\n return {'Authorization': `Bearer ${accessToken}`}\n } else {\n return {}\n }\n}\n\nconst request = ({method = 'GET', url, params, store}) => {\n const instance = store.state.instance.server\n let fullUrl = `${instance}${url}`\n\n if (method === 'GET' && params) {\n fullUrl = fullUrl + `?${queryParams(params)}`\n }\n\n return window.fetch(fullUrl, {\n method,\n headers: headers(store),\n credentials: 'same-origin'\n })\n}\n\nconst utils = {\n queryParams,\n request\n}\n\nexport default utils\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/new_api/utils.js","import apiService from '../api/api.service.js'\n\nconst update = ({store, notifications, older}) => {\n store.dispatch('setNotificationsError', { value: false })\n\n store.dispatch('addNewNotifications', { notifications, older })\n}\n\nconst fetchAndUpdate = ({store, credentials, older = false}) => {\n const args = { credentials }\n const rootState = store.rootState || store.state\n const timelineData = rootState.statuses.notifications\n\n if (older) {\n if (timelineData.minId !== Number.POSITIVE_INFINITY) {\n args['until'] = timelineData.minId\n }\n } else {\n // load unread notifications repeadedly to provide consistency between browser tabs\n const notifications = timelineData.data\n const unread = notifications.filter(n => !n.seen).map(n => n.id)\n if (!unread.length) {\n args['since'] = timelineData.maxId\n } else {\n args['since'] = Math.min(...unread) - 1\n if (timelineData.maxId !== Math.max(...unread)) {\n args['until'] = Math.max(...unread, args['since'] + 20)\n }\n }\n }\n\n args['timeline'] = 'notifications'\n\n return apiService.fetchTimeline(args)\n .then((notifications) => {\n update({store, notifications, older})\n return notifications\n }, () => store.dispatch('setNotificationsError', { value: true }))\n .catch(() => store.dispatch('setNotificationsError', { value: true }))\n}\n\nconst startFetching = ({credentials, store}) => {\n fetchAndUpdate({ credentials, store })\n const boundFetchAndUpdate = () => fetchAndUpdate({ credentials, store })\n // Initially there's set flag to silence all desktop notifications so\n // that there won't spam of them when user just opened up the FE we\n // reset that flag after a while to show new notifications once again.\n setTimeout(() => store.dispatch('setNotificationsSilence', false), 10000)\n return setInterval(boundFetchAndUpdate, 10000)\n}\n\nconst notificationsFetcher = {\n fetchAndUpdate,\n startFetching\n}\n\nexport default notificationsFetcher\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/notifications_fetcher/notifications_fetcher.service.js","import runtime from 'serviceworker-webpack-plugin/lib/runtime'\n\nfunction urlBase64ToUint8Array (base64String) {\n const padding = '='.repeat((4 - base64String.length % 4) % 4)\n const base64 = (base64String + padding)\n .replace(/-/g, '+')\n .replace(/_/g, '/')\n\n const rawData = window.atob(base64)\n return Uint8Array.from([...rawData].map((char) => char.charCodeAt(0)))\n}\n\nfunction isPushSupported () {\n return 'serviceWorker' in navigator && 'PushManager' in window\n}\n\nfunction getOrCreateServiceWorker () {\n return runtime.register()\n .catch((err) => console.error('Unable to get or create a service worker.', err))\n}\n\nfunction subscribePush (registration, isEnabled, vapidPublicKey) {\n if (!isEnabled) return Promise.reject(new Error('Web Push is disabled in config'))\n if (!vapidPublicKey) return Promise.reject(new Error('VAPID public key is not found'))\n\n const subscribeOptions = {\n userVisibleOnly: true,\n applicationServerKey: urlBase64ToUint8Array(vapidPublicKey)\n }\n return registration.pushManager.subscribe(subscribeOptions)\n}\n\nfunction unsubscribePush (registration) {\n return registration.pushManager.getSubscription()\n .then((subscribtion) => {\n if (subscribtion === null) { return }\n return subscribtion.unsubscribe()\n })\n}\n\nfunction deleteSubscriptionFromBackEnd (token) {\n return window.fetch('/api/v1/push/subscription/', {\n method: 'DELETE',\n headers: {\n 'Content-Type': 'application/json',\n 'Authorization': `Bearer ${token}`\n }\n }).then((response) => {\n if (!response.ok) throw new Error('Bad status code from server.')\n return response\n })\n}\n\nfunction sendSubscriptionToBackEnd (subscription, token, notificationVisibility) {\n return window.fetch('/api/v1/push/subscription/', {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n 'Authorization': `Bearer ${token}`\n },\n body: JSON.stringify({\n subscription,\n data: {\n alerts: {\n follow: notificationVisibility.follows,\n favourite: notificationVisibility.likes,\n mention: notificationVisibility.mentions,\n reblog: notificationVisibility.repeats\n }\n }\n })\n }).then((response) => {\n if (!response.ok) throw new Error('Bad status code from server.')\n return response.json()\n }).then((responseData) => {\n if (!responseData.id) throw new Error('Bad response from server.')\n return responseData\n })\n}\n\nexport function registerPushNotifications (isEnabled, vapidPublicKey, token, notificationVisibility) {\n if (isPushSupported()) {\n getOrCreateServiceWorker()\n .then((registration) => subscribePush(registration, isEnabled, vapidPublicKey))\n .then((subscription) => sendSubscriptionToBackEnd(subscription, token, notificationVisibility))\n .catch((e) => console.warn(`Failed to setup Web Push Notifications: ${e.message}`))\n }\n}\n\nexport function unregisterPushNotifications (token) {\n if (isPushSupported()) {\n Promise.all([\n deleteSubscriptionFromBackEnd(token),\n getOrCreateServiceWorker()\n .then((registration) => {\n return unsubscribePush(registration).then((result) => [registration, result])\n })\n .then(([registration, unsubResult]) => {\n if (!unsubResult) {\n console.warn('Push subscription cancellation wasn\\'t successful, killing SW anyway...')\n }\n return registration.unregister().then((result) => {\n if (!result) {\n console.warn('Failed to kill SW')\n }\n })\n })\n ]).catch((e) => console.warn(`Failed to disable Web Push Notifications: ${e.message}`))\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/services/push/push.js","\n\n\n\n\n\n\n\n// WEBPACK FOOTER //\n// color_input.vue?77e7e595","\n\n\n\n\n\n\n\n// WEBPACK FOOTER //\n// contrast_ratio.vue?3da6379e","\n\n\n\n\n\n\n\n// WEBPACK FOOTER //\n// export_import.vue?3c652c60","\n\n\n\n\n\n// WEBPACK FOOTER //\n// interface_language_switcher.vue?71c943eb","\n\n\n\n\n\n// WEBPACK FOOTER //\n// opacity_input.vue?aea9ac64","\n\n\n\n\n\n// WEBPACK FOOTER //\n// range_input.vue?63c72290","import UserPanel from './components/user_panel/user_panel.vue'\nimport NavPanel from './components/nav_panel/nav_panel.vue'\nimport Notifications from './components/notifications/notifications.vue'\nimport UserFinder from './components/user_finder/user_finder.vue'\nimport InstanceSpecificPanel from './components/instance_specific_panel/instance_specific_panel.vue'\nimport FeaturesPanel from './components/features_panel/features_panel.vue'\nimport WhoToFollowPanel from './components/who_to_follow_panel/who_to_follow_panel.vue'\nimport ChatPanel from './components/chat_panel/chat_panel.vue'\nimport MediaModal from './components/media_modal/media_modal.vue'\nimport SideDrawer from './components/side_drawer/side_drawer.vue'\nimport MobilePostStatusModal from './components/mobile_post_status_modal/mobile_post_status_modal.vue'\nimport { unseenNotificationsFromStore } from './services/notification_utils/notification_utils'\n\nexport default {\n name: 'app',\n components: {\n UserPanel,\n NavPanel,\n Notifications,\n UserFinder,\n InstanceSpecificPanel,\n FeaturesPanel,\n WhoToFollowPanel,\n ChatPanel,\n MediaModal,\n SideDrawer,\n MobilePostStatusModal\n },\n data: () => ({\n mobileActivePanel: 'timeline',\n finderHidden: true,\n supportsMask: window.CSS && window.CSS.supports && (\n window.CSS.supports('mask-size', 'contain') ||\n window.CSS.supports('-webkit-mask-size', 'contain') ||\n window.CSS.supports('-moz-mask-size', 'contain') ||\n window.CSS.supports('-ms-mask-size', 'contain') ||\n window.CSS.supports('-o-mask-size', 'contain')\n )\n }),\n created () {\n // Load the locale from the storage\n this.$i18n.locale = this.$store.state.config.interfaceLanguage\n },\n computed: {\n currentUser () { return this.$store.state.users.currentUser },\n background () {\n return this.currentUser.background_image || this.$store.state.instance.background\n },\n enableMask () { return this.supportsMask && this.$store.state.instance.logoMask },\n logoStyle () {\n return {\n 'visibility': this.enableMask ? 'hidden' : 'visible'\n }\n },\n logoMaskStyle () {\n return this.enableMask ? {\n 'mask-image': `url(${this.$store.state.instance.logo})`\n } : {\n 'background-color': this.enableMask ? '' : 'transparent'\n }\n },\n logoBgStyle () {\n return Object.assign({\n 'margin': `${this.$store.state.instance.logoMargin} 0`,\n opacity: this.finderHidden ? 1 : 0\n }, this.enableMask ? {} : {\n 'background-color': this.enableMask ? '' : 'transparent'\n })\n },\n logo () { return this.$store.state.instance.logo },\n bgStyle () {\n return {\n 'background-image': `url(${this.background})`\n }\n },\n bgAppStyle () {\n return {\n '--body-background-image': `url(${this.background})`\n }\n },\n sitename () { return this.$store.state.instance.name },\n chat () { return this.$store.state.chat.channel.state === 'joined' },\n suggestionsEnabled () { return this.$store.state.instance.suggestionsEnabled },\n showInstanceSpecificPanel () { return this.$store.state.instance.showInstanceSpecificPanel },\n unseenNotifications () {\n return unseenNotificationsFromStore(this.$store)\n },\n unseenNotificationsCount () {\n return this.unseenNotifications.length\n },\n showFeaturesPanel () { return this.$store.state.instance.showFeaturesPanel }\n },\n methods: {\n scrollToTop () {\n window.scrollTo(0, 0)\n },\n logout () {\n this.$router.replace('/main/public')\n this.$store.dispatch('logout')\n },\n onFinderToggled (hidden) {\n this.finderHidden = hidden\n },\n toggleMobileSidebar () {\n this.$refs.sideDrawer.toggleDrawer()\n }\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/App.js","import InstanceSpecificPanel from '../instance_specific_panel/instance_specific_panel.vue'\nimport FeaturesPanel from '../features_panel/features_panel.vue'\nimport TermsOfServicePanel from '../terms_of_service_panel/terms_of_service_panel.vue'\n\nconst About = {\n components: {\n InstanceSpecificPanel,\n FeaturesPanel,\n TermsOfServicePanel\n },\n computed: {\n showFeaturesPanel () { return this.$store.state.instance.showFeaturesPanel }\n }\n}\n\nexport default About\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/about/about.js","import StillImage from '../still-image/still-image.vue'\nimport VideoAttachment from '../video_attachment/video_attachment.vue'\nimport nsfwImage from '../../assets/nsfw.png'\nimport fileTypeService from '../../services/file_type/file_type.service.js'\n\nconst Attachment = {\n props: [\n 'attachment',\n 'nsfw',\n 'statusId',\n 'size',\n 'allowPlay',\n 'setMedia'\n ],\n data () {\n return {\n nsfwImage: this.$store.state.instance.nsfwCensorImage || nsfwImage,\n hideNsfwLocal: this.$store.state.config.hideNsfw,\n preloadImage: this.$store.state.config.preloadImage,\n loading: false,\n img: fileTypeService.fileType(this.attachment.mimetype) === 'image' && document.createElement('img'),\n modalOpen: false,\n showHidden: false\n }\n },\n components: {\n StillImage,\n VideoAttachment\n },\n computed: {\n usePlaceHolder () {\n return this.size === 'hide' || this.type === 'unknown'\n },\n referrerpolicy () {\n return this.$store.state.instance.mediaProxyAvailable ? '' : 'no-referrer'\n },\n type () {\n return fileTypeService.fileType(this.attachment.mimetype)\n },\n hidden () {\n return this.nsfw && this.hideNsfwLocal && !this.showHidden\n },\n isEmpty () {\n return (this.type === 'html' && !this.attachment.oembed) || this.type === 'unknown'\n },\n isSmall () {\n return this.size === 'small'\n },\n fullwidth () {\n return this.type === 'html' || this.type === 'audio'\n }\n },\n methods: {\n linkClicked ({target}) {\n if (target.tagName === 'A') {\n window.open(target.href, '_blank')\n }\n },\n openModal (event) {\n const modalTypes = this.$store.state.config.playVideosInModal\n ? ['image', 'video']\n : ['image']\n if (fileTypeService.fileMatchesSomeType(modalTypes, this.attachment) ||\n this.usePlaceHolder\n ) {\n event.stopPropagation()\n event.preventDefault()\n this.setMedia()\n this.$store.dispatch('setCurrent', this.attachment)\n }\n },\n toggleHidden (event) {\n if (this.$store.state.config.useOneClickNsfw && !this.showHidden) {\n this.openModal(event)\n return\n }\n if (this.img && !this.preloadImage) {\n if (this.img.onload) {\n this.img.onload()\n } else {\n this.loading = true\n this.img.src = this.attachment.url\n this.img.onload = () => {\n this.loading = false\n this.showHidden = !this.showHidden\n }\n }\n } else {\n this.showHidden = !this.showHidden\n }\n }\n }\n}\n\nexport default Attachment\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/attachment/attachment.js","import UserCard from '../user_card/user_card.vue'\nimport UserAvatar from '../user_avatar/user_avatar.vue'\nimport generateProfileLink from 'src/services/user_profile_link_generator/user_profile_link_generator'\n\nconst BasicUserCard = {\n props: [\n 'user'\n ],\n data () {\n return {\n userExpanded: false\n }\n },\n components: {\n UserCard,\n UserAvatar\n },\n methods: {\n toggleUserExpanded () {\n this.userExpanded = !this.userExpanded\n },\n userProfileLink (user) {\n return generateProfileLink(user.id, user.screen_name, this.$store.state.instance.restrictedNicknames)\n }\n }\n}\n\nexport default BasicUserCard\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/basic_user_card/basic_user_card.js","import BasicUserCard from '../basic_user_card/basic_user_card.vue'\n\nconst BlockCard = {\n props: ['userId'],\n data () {\n return {\n progress: false\n }\n },\n computed: {\n user () {\n return this.$store.getters.userById(this.userId)\n },\n blocked () {\n return this.user.statusnet_blocking\n }\n },\n components: {\n BasicUserCard\n },\n methods: {\n unblockUser () {\n this.progress = true\n this.$store.dispatch('unblockUser', this.user.id).then(() => {\n this.progress = false\n })\n },\n blockUser () {\n this.progress = true\n this.$store.dispatch('blockUser', this.user.id).then(() => {\n this.progress = false\n })\n }\n }\n}\n\nexport default BlockCard\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/block_card/block_card.js","import generateProfileLink from 'src/services/user_profile_link_generator/user_profile_link_generator'\n\nconst chatPanel = {\n props: [ 'floating' ],\n data () {\n return {\n currentMessage: '',\n channel: null,\n collapsed: true\n }\n },\n computed: {\n messages () {\n return this.$store.state.chat.messages\n }\n },\n methods: {\n submit (message) {\n this.$store.state.chat.channel.push('new_msg', {text: message}, 10000)\n this.currentMessage = ''\n },\n togglePanel () {\n this.collapsed = !this.collapsed\n },\n userProfileLink (user) {\n return generateProfileLink(user.id, user.username, this.$store.state.instance.restrictedNicknames)\n }\n }\n}\n\nexport default chatPanel\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/chat_panel/chat_panel.js","import Conversation from '../conversation/conversation.vue'\nimport { find } from 'lodash'\n\nconst conversationPage = {\n components: {\n Conversation\n },\n computed: {\n statusoid () {\n const id = this.$route.params.id\n const statuses = this.$store.state.statuses.allStatuses\n const status = find(statuses, {id})\n\n return status\n }\n }\n}\n\nexport default conversationPage\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/conversation-page/conversation-page.js","import { reduce, filter } from 'lodash'\nimport Status from '../status/status.vue'\n\nconst sortById = (a, b) => {\n const seqA = Number(a.id)\n const seqB = Number(b.id)\n const isSeqA = !Number.isNaN(seqA)\n const isSeqB = !Number.isNaN(seqB)\n if (isSeqA && isSeqB) {\n return seqA < seqB ? -1 : 1\n } else if (isSeqA && !isSeqB) {\n return -1\n } else if (!isSeqA && isSeqB) {\n return 1\n } else {\n return a.id < b.id ? -1 : 1\n }\n}\n\nconst sortAndFilterConversation = (conversation) => {\n conversation = filter(conversation, (status) => status.type !== 'retweet')\n return conversation.filter(_ => _).sort(sortById)\n}\n\nconst conversation = {\n data () {\n return {\n highlight: null\n }\n },\n props: [\n 'statusoid',\n 'collapsable'\n ],\n computed: {\n status () {\n return this.statusoid\n },\n statusId () {\n if (this.statusoid.retweeted_status) {\n return this.statusoid.retweeted_status.id\n } else {\n return this.statusoid.id\n }\n },\n conversation () {\n if (!this.status) {\n return []\n }\n\n const conversationId = this.status.statusnet_conversation_id\n const statuses = this.$store.state.statuses.allStatuses\n const conversation = filter(statuses, { statusnet_conversation_id: conversationId })\n return sortAndFilterConversation(conversation)\n },\n replies () {\n let i = 1\n return reduce(this.conversation, (result, {id, in_reply_to_status_id}) => {\n /* eslint-disable camelcase */\n const irid = in_reply_to_status_id\n /* eslint-enable camelcase */\n if (irid) {\n result[irid] = result[irid] || []\n result[irid].push({\n name: `#${i}`,\n id: id\n })\n }\n i++\n return result\n }, {})\n }\n },\n components: {\n Status\n },\n created () {\n this.fetchConversation()\n },\n watch: {\n '$route': 'fetchConversation'\n },\n methods: {\n fetchConversation () {\n if (this.status) {\n const conversationId = this.status.statusnet_conversation_id\n this.$store.state.api.backendInteractor.fetchConversation({id: conversationId})\n .then((statuses) => this.$store.dispatch('addNewStatuses', { statuses }))\n .then(() => this.setHighlight(this.statusId))\n } else {\n const id = this.$route.params.id\n this.$store.state.api.backendInteractor.fetchStatus({id})\n .then((status) => this.$store.dispatch('addNewStatuses', { statuses: [status] }))\n .then(() => this.fetchConversation())\n }\n },\n getReplies (id) {\n return this.replies[id] || []\n },\n focused (id) {\n return id === this.statusId\n },\n setHighlight (id) {\n this.highlight = id\n }\n }\n}\n\nexport default conversation\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/conversation/conversation.js","const DeleteButton = {\n props: [ 'status' ],\n methods: {\n deleteStatus () {\n const confirmed = window.confirm('Do you really want to delete this status?')\n if (confirmed) {\n this.$store.dispatch('deleteStatus', { id: this.status.id })\n }\n }\n },\n computed: {\n currentUser () { return this.$store.state.users.currentUser },\n canDelete () { return this.currentUser && this.currentUser.rights.delete_others_notice || this.status.user.id === this.currentUser.id }\n }\n}\n\nexport default DeleteButton\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/delete_button/delete_button.js","import Timeline from '../timeline/timeline.vue'\n\nconst DMs = {\n computed: {\n timeline () {\n return this.$store.state.statuses.timelines.dms\n }\n },\n components: {\n Timeline\n }\n}\n\nexport default DMs\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/dm_timeline/dm_timeline.js","const FavoriteButton = {\n props: ['status', 'loggedIn'],\n data () {\n return {\n hidePostStatsLocal: typeof this.$store.state.config.hidePostStats === 'undefined'\n ? this.$store.state.instance.hidePostStats\n : this.$store.state.config.hidePostStats,\n animated: false\n }\n },\n methods: {\n favorite () {\n if (!this.status.favorited) {\n this.$store.dispatch('favorite', {id: this.status.id})\n } else {\n this.$store.dispatch('unfavorite', {id: this.status.id})\n }\n this.animated = true\n setTimeout(() => {\n this.animated = false\n }, 500)\n }\n },\n computed: {\n classes () {\n return {\n 'icon-star-empty': !this.status.favorited,\n 'icon-star': this.status.favorited,\n 'animate-spin': this.animated\n }\n }\n }\n}\n\nexport default FavoriteButton\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/favorite_button/favorite_button.js","const FeaturesPanel = {\n computed: {\n chat: function () {\n return this.$store.state.instance.chatAvailable && (!this.$store.state.chatDisabled)\n },\n gopher: function () { return this.$store.state.instance.gopherAvailable },\n whoToFollow: function () { return this.$store.state.instance.suggestionsEnabled },\n mediaProxy: function () { return this.$store.state.instance.mediaProxyAvailable },\n scopeOptions: function () { return this.$store.state.instance.scopeOptionsEnabled },\n textlimit: function () { return this.$store.state.instance.textlimit }\n }\n}\n\nexport default FeaturesPanel\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/features_panel/features_panel.js","import BasicUserCard from '../basic_user_card/basic_user_card.vue'\nimport { requestFollow, requestUnfollow } from '../../services/follow_manipulate/follow_manipulate'\n\nconst FollowCard = {\n props: [\n 'user',\n 'noFollowsYou'\n ],\n data () {\n return {\n inProgress: false,\n requestSent: false,\n updated: false\n }\n },\n components: {\n BasicUserCard\n },\n computed: {\n isMe () { return this.$store.state.users.currentUser.id === this.user.id },\n following () { return this.updated ? this.updated.following : this.user.following },\n showFollow () {\n return !this.following || this.updated && !this.updated.following\n }\n },\n methods: {\n followUser () {\n this.inProgress = true\n requestFollow(this.user, this.$store).then(({ sent, updated }) => {\n this.inProgress = false\n this.requestSent = sent\n this.updated = updated\n })\n },\n unfollowUser () {\n this.inProgress = true\n requestUnfollow(this.user, this.$store).then(({ updated }) => {\n this.inProgress = false\n this.updated = updated\n })\n }\n }\n}\n\nexport default FollowCard\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/follow_card/follow_card.js","import BasicUserCard from '../basic_user_card/basic_user_card.vue'\n\nconst FollowRequestCard = {\n props: ['user'],\n components: {\n BasicUserCard\n },\n methods: {\n approveUser () {\n this.$store.state.api.backendInteractor.approveUser(this.user.id)\n this.$store.dispatch('removeFollowRequest', this.user)\n },\n denyUser () {\n this.$store.state.api.backendInteractor.denyUser(this.user.id)\n this.$store.dispatch('removeFollowRequest', this.user)\n }\n }\n}\n\nexport default FollowRequestCard\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/follow_request_card/follow_request_card.js","import FollowRequestCard from '../follow_request_card/follow_request_card.vue'\n\nconst FollowRequests = {\n components: {\n FollowRequestCard\n },\n computed: {\n requests () {\n return this.$store.state.api.followRequests\n }\n }\n}\n\nexport default FollowRequests\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/follow_requests/follow_requests.js","import { set } from 'vue'\n\nexport default {\n props: [\n 'name', 'label', 'value', 'fallback', 'options', 'no-inherit'\n ],\n data () {\n return {\n lValue: this.value,\n availableOptions: [\n this.noInherit ? '' : 'inherit',\n 'custom',\n ...(this.options || []),\n 'serif',\n 'monospace',\n 'sans-serif'\n ].filter(_ => _)\n }\n },\n beforeUpdate () {\n this.lValue = this.value\n },\n computed: {\n present () {\n return typeof this.lValue !== 'undefined'\n },\n dValue () {\n return this.lValue || this.fallback || {}\n },\n family: {\n get () {\n return this.dValue.family\n },\n set (v) {\n set(this.lValue, 'family', v)\n this.$emit('input', this.lValue)\n }\n },\n isCustom () {\n return this.preset === 'custom'\n },\n preset: {\n get () {\n if (this.family === 'serif' ||\n this.family === 'sans-serif' ||\n this.family === 'monospace' ||\n this.family === 'inherit') {\n return this.family\n } else {\n return 'custom'\n }\n },\n set (v) {\n this.family = v === 'custom' ? '' : v\n }\n }\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/font_control/font_control.js","import Timeline from '../timeline/timeline.vue'\nconst FriendsTimeline = {\n components: {\n Timeline\n },\n computed: {\n timeline () { return this.$store.state.statuses.timelines.friends }\n }\n}\n\nexport default FriendsTimeline\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/friends_timeline/friends_timeline.js","import Attachment from '../attachment/attachment.vue'\nimport { chunk, last, dropRight } from 'lodash'\n\nconst Gallery = {\n data: () => ({\n width: 500\n }),\n props: [\n 'attachments',\n 'nsfw',\n 'setMedia'\n ],\n components: { Attachment },\n mounted () {\n this.resize()\n window.addEventListener('resize', this.resize)\n },\n destroyed () {\n window.removeEventListener('resize', this.resize)\n },\n computed: {\n rows () {\n if (!this.attachments) {\n return []\n }\n const rows = chunk(this.attachments, 3)\n if (last(rows).length === 1 && rows.length > 1) {\n // if 1 attachment on last row -> add it to the previous row instead\n const lastAttachment = last(rows)[0]\n const allButLastRow = dropRight(rows)\n last(allButLastRow).push(lastAttachment)\n return allButLastRow\n }\n return rows\n },\n rowHeight () {\n return itemsPerRow => ({ 'height': `${(this.width / (itemsPerRow + 0.6))}px` })\n },\n useContainFit () {\n return this.$store.state.config.useContainFit\n }\n },\n methods: {\n resize () {\n // Quick optimization to make resizing not always trigger state change,\n // only update attachment size in 10px steps\n const width = Math.floor(this.$el.getBoundingClientRect().width / 10) * 10\n if (this.width !== width) {\n this.width = width\n }\n }\n }\n}\n\nexport default Gallery\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/gallery/gallery.js","import Cropper from 'cropperjs'\nimport 'cropperjs/dist/cropper.css'\n\nconst ImageCropper = {\n props: {\n trigger: {\n type: [String, window.Element],\n required: true\n },\n submitHandler: {\n type: Function,\n required: true\n },\n cropperOptions: {\n type: Object,\n default () {\n return {\n aspectRatio: 1,\n autoCropArea: 1,\n viewMode: 1,\n movable: false,\n zoomable: false,\n guides: false\n }\n }\n },\n mimes: {\n type: String,\n default: 'image/png, image/gif, image/jpeg, image/bmp, image/x-icon'\n },\n saveButtonLabel: {\n type: String\n },\n cancelButtonLabel: {\n type: String\n }\n },\n data () {\n return {\n cropper: undefined,\n dataUrl: undefined,\n filename: undefined,\n submitting: false,\n submitError: null\n }\n },\n computed: {\n saveText () {\n return this.saveButtonLabel || this.$t('image_cropper.save')\n },\n cancelText () {\n return this.cancelButtonLabel || this.$t('image_cropper.cancel')\n },\n submitErrorMsg () {\n return this.submitError && this.submitError instanceof Error ? this.submitError.toString() : this.submitError\n }\n },\n methods: {\n destroy () {\n if (this.cropper) {\n this.cropper.destroy()\n }\n this.$refs.input.value = ''\n this.dataUrl = undefined\n this.$emit('close')\n },\n submit () {\n this.submitting = true\n this.avatarUploadError = null\n this.submitHandler(this.cropper, this.file)\n .then(() => this.destroy())\n .catch((err) => {\n this.submitError = err\n })\n .finally(() => {\n this.submitting = false\n })\n },\n pickImage () {\n this.$refs.input.click()\n },\n createCropper () {\n this.cropper = new Cropper(this.$refs.img, this.cropperOptions)\n },\n getTriggerDOM () {\n return typeof this.trigger === 'object' ? this.trigger : document.querySelector(this.trigger)\n },\n readFile () {\n const fileInput = this.$refs.input\n if (fileInput.files != null && fileInput.files[0] != null) {\n this.file = fileInput.files[0]\n let reader = new window.FileReader()\n reader.onload = (e) => {\n this.dataUrl = e.target.result\n this.$emit('open')\n }\n reader.readAsDataURL(this.file)\n this.$emit('changed', this.file, reader)\n }\n },\n clearError () {\n this.submitError = null\n }\n },\n mounted () {\n // listen for click event on trigger\n const trigger = this.getTriggerDOM()\n if (!trigger) {\n this.$emit('error', 'No image make trigger found.', 'user')\n } else {\n trigger.addEventListener('click', this.pickImage)\n }\n // listen for input file changes\n const fileInput = this.$refs.input\n fileInput.addEventListener('change', this.readFile)\n },\n beforeDestroy: function () {\n // remove the event listeners\n const trigger = this.getTriggerDOM()\n if (trigger) {\n trigger.removeEventListener('click', this.pickImage)\n }\n const fileInput = this.$refs.input\n fileInput.removeEventListener('change', this.readFile)\n }\n}\n\nexport default ImageCropper\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/image_cropper/image_cropper.js","const InstanceSpecificPanel = {\n computed: {\n instanceSpecificPanelContent () {\n return this.$store.state.instance.instanceSpecificPanelContent\n },\n show () {\n return !this.$store.state.config.hideISP\n }\n }\n}\n\nexport default InstanceSpecificPanel\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/instance_specific_panel/instance_specific_panel.js","const LinkPreview = {\n name: 'LinkPreview',\n props: [\n 'card',\n 'size',\n 'nsfw'\n ],\n computed: {\n useImage () {\n // Currently BE shoudn't give cards if tagged NSFW, this is a bit paranoid\n // as it makes sure to hide the image if somehow NSFW tagged preview can\n // exist.\n return this.card.image && !this.nsfw && this.size !== 'hide'\n },\n useDescription () {\n return this.card.description && /\\S/.test(this.card.description)\n }\n }\n}\n\nexport default LinkPreview\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/link-preview/link-preview.js","import oauthApi from '../../services/new_api/oauth.js'\nconst LoginForm = {\n data: () => ({\n user: {},\n authError: false\n }),\n computed: {\n loginMethod () { return this.$store.state.instance.loginMethod },\n loggingIn () { return this.$store.state.users.loggingIn },\n registrationOpen () { return this.$store.state.instance.registrationOpen }\n },\n methods: {\n oAuthLogin () {\n oauthApi.login({\n oauth: this.$store.state.oauth,\n instance: this.$store.state.instance.server,\n commit: this.$store.commit\n })\n },\n submit () {\n const data = {\n oauth: this.$store.state.oauth,\n instance: this.$store.state.instance.server\n }\n this.clearError()\n oauthApi.getOrCreateApp(data).then((app) => {\n oauthApi.getTokenWithCredentials(\n {\n app,\n instance: data.instance,\n username: this.user.username,\n password: this.user.password\n }\n ).then((result) => {\n if (result.error) {\n this.authError = result.error\n this.user.password = ''\n return\n }\n this.$store.commit('setToken', result.access_token)\n this.$store.dispatch('loginUser', result.access_token)\n this.$router.push({name: 'friends'})\n })\n })\n },\n clearError () {\n this.authError = false\n }\n }\n}\n\nexport default LoginForm\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/login_form/login_form.js","import StillImage from '../still-image/still-image.vue'\nimport VideoAttachment from '../video_attachment/video_attachment.vue'\nimport fileTypeService from '../../services/file_type/file_type.service.js'\n\nconst MediaModal = {\n components: {\n StillImage,\n VideoAttachment\n },\n computed: {\n showing () {\n return this.$store.state.mediaViewer.activated\n },\n media () {\n return this.$store.state.mediaViewer.media\n },\n currentIndex () {\n return this.$store.state.mediaViewer.currentIndex\n },\n currentMedia () {\n return this.media[this.currentIndex]\n },\n canNavigate () {\n return this.media.length > 1\n },\n type () {\n return this.currentMedia ? fileTypeService.fileType(this.currentMedia.mimetype) : null\n }\n },\n methods: {\n hide () {\n this.$store.dispatch('closeMediaViewer')\n },\n goPrev () {\n if (this.canNavigate) {\n const prevIndex = this.currentIndex === 0 ? this.media.length - 1 : (this.currentIndex - 1)\n this.$store.dispatch('setCurrent', this.media[prevIndex])\n }\n },\n goNext () {\n if (this.canNavigate) {\n const nextIndex = this.currentIndex === this.media.length - 1 ? 0 : (this.currentIndex + 1)\n this.$store.dispatch('setCurrent', this.media[nextIndex])\n }\n },\n handleKeyupEvent (e) {\n if (this.showing && e.keyCode === 27) { // escape\n this.hide()\n }\n },\n handleKeydownEvent (e) {\n if (!this.showing) {\n return\n }\n\n if (e.keyCode === 39) { // arrow right\n this.goNext()\n } else if (e.keyCode === 37) { // arrow left\n this.goPrev()\n }\n }\n },\n mounted () {\n document.addEventListener('keyup', this.handleKeyupEvent)\n document.addEventListener('keydown', this.handleKeydownEvent)\n },\n destroyed () {\n document.removeEventListener('keyup', this.handleKeyupEvent)\n document.removeEventListener('keydown', this.handleKeydownEvent)\n }\n}\n\nexport default MediaModal\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/media_modal/media_modal.js","/* eslint-env browser */\nimport statusPosterService from '../../services/status_poster/status_poster.service.js'\nimport fileSizeFormatService from '../../services/file_size_format/file_size_format.js'\n\nconst mediaUpload = {\n data () {\n return {\n uploading: false,\n uploadReady: true\n }\n },\n methods: {\n uploadFile (file) {\n const self = this\n const store = this.$store\n if (file.size > store.state.instance.uploadlimit) {\n const filesize = fileSizeFormatService.fileSizeFormat(file.size)\n const allowedsize = fileSizeFormatService.fileSizeFormat(store.state.instance.uploadlimit)\n self.$emit('upload-failed', 'file_too_big', {filesize: filesize.num, filesizeunit: filesize.unit, allowedsize: allowedsize.num, allowedsizeunit: allowedsize.unit})\n return\n }\n const formData = new FormData()\n formData.append('media', file)\n\n self.$emit('uploading')\n self.uploading = true\n\n statusPosterService.uploadMedia({ store, formData })\n .then((fileData) => {\n self.$emit('uploaded', fileData)\n self.uploading = false\n }, (error) => { // eslint-disable-line handle-callback-err\n self.$emit('upload-failed', 'default')\n self.uploading = false\n })\n },\n fileDrop (e) {\n if (e.dataTransfer.files.length > 0) {\n e.preventDefault() // allow dropping text like before\n this.uploadFile(e.dataTransfer.files[0])\n }\n },\n fileDrag (e) {\n let types = e.dataTransfer.types\n if (types.contains('Files')) {\n e.dataTransfer.dropEffect = 'copy'\n } else {\n e.dataTransfer.dropEffect = 'none'\n }\n },\n clearFile () {\n this.uploadReady = false\n this.$nextTick(() => {\n this.uploadReady = true\n })\n },\n change ({target}) {\n for (var i = 0; i < target.files.length; i++) {\n let file = target.files[i]\n this.uploadFile(file)\n }\n }\n },\n props: [\n 'dropFiles'\n ],\n watch: {\n 'dropFiles': function (fileInfos) {\n if (!this.uploading) {\n this.uploadFile(fileInfos[0])\n }\n }\n }\n}\n\nexport default mediaUpload\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/media_upload/media_upload.js","import Timeline from '../timeline/timeline.vue'\n\nconst Mentions = {\n computed: {\n timeline () {\n return this.$store.state.statuses.timelines.mentions\n }\n },\n components: {\n Timeline\n }\n}\n\nexport default Mentions\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/mentions/mentions.js","import PostStatusForm from '../post_status_form/post_status_form.vue'\nimport { throttle } from 'lodash'\n\nconst MobilePostStatusModal = {\n components: {\n PostStatusForm\n },\n data () {\n return {\n hidden: false,\n postFormOpen: false,\n scrollingDown: false,\n inputActive: false,\n oldScrollPos: 0,\n amountScrolled: 0\n }\n },\n created () {\n window.addEventListener('scroll', this.handleScroll)\n window.addEventListener('resize', this.handleOSK)\n },\n destroyed () {\n window.removeEventListener('scroll', this.handleScroll)\n window.removeEventListener('resize', this.handleOSK)\n },\n computed: {\n currentUser () {\n return this.$store.state.users.currentUser\n },\n isHidden () {\n return this.hidden || this.inputActive\n }\n },\n methods: {\n openPostForm () {\n this.postFormOpen = true\n this.hidden = true\n\n const el = this.$el.querySelector('textarea')\n this.$nextTick(function () {\n el.focus()\n })\n },\n closePostForm () {\n this.postFormOpen = false\n this.hidden = false\n },\n handleOSK () {\n // This is a big hack: we're guessing from changed window sizes if the\n // on-screen keyboard is active or not. This is only really important\n // for phones in portrait mode and it's more important to show the button\n // in normal scenarios on all phones, than it is to hide it when the\n // keyboard is active.\n // Guesswork based on https://www.mydevice.io/#compare-devices\n\n // for example, iphone 4 and android phones from the same time period\n const smallPhone = window.innerWidth < 350\n const smallPhoneKbOpen = smallPhone && window.innerHeight < 345\n\n const biggerPhone = !smallPhone && window.innerWidth < 450\n const biggerPhoneKbOpen = biggerPhone && window.innerHeight < 560\n if (smallPhoneKbOpen || biggerPhoneKbOpen) {\n this.inputActive = true\n } else {\n this.inputActive = false\n }\n },\n handleScroll: throttle(function () {\n const scrollAmount = window.scrollY - this.oldScrollPos\n const scrollingDown = scrollAmount > 0\n\n if (scrollingDown !== this.scrollingDown) {\n this.amountScrolled = 0\n this.scrollingDown = scrollingDown\n if (!scrollingDown) {\n this.hidden = false\n }\n } else if (scrollingDown) {\n this.amountScrolled += scrollAmount\n if (this.amountScrolled > 100 && !this.hidden) {\n this.hidden = true\n }\n }\n\n this.oldScrollPos = window.scrollY\n this.scrollingDown = scrollingDown\n }, 100)\n }\n}\n\nexport default MobilePostStatusModal\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/mobile_post_status_modal/mobile_post_status_modal.js","import BasicUserCard from '../basic_user_card/basic_user_card.vue'\n\nconst MuteCard = {\n props: ['userId'],\n data () {\n return {\n progress: false\n }\n },\n computed: {\n user () {\n return this.$store.getters.userById(this.userId)\n },\n muted () {\n return this.user.muted\n }\n },\n components: {\n BasicUserCard\n },\n methods: {\n unmuteUser () {\n this.progress = true\n this.$store.dispatch('unmuteUser', this.user.id).then(() => {\n this.progress = false\n })\n },\n muteUser () {\n this.progress = true\n this.$store.dispatch('muteUser', this.user.id).then(() => {\n this.progress = false\n })\n }\n }\n}\n\nexport default MuteCard\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/mute_card/mute_card.js","import followRequestFetcher from '../../services/follow_request_fetcher/follow_request_fetcher.service'\n\nconst NavPanel = {\n created () {\n if (this.currentUser && this.currentUser.locked) {\n const store = this.$store\n const credentials = store.state.users.currentUser.credentials\n\n followRequestFetcher.startFetching({ store, credentials })\n }\n },\n computed: {\n currentUser () {\n return this.$store.state.users.currentUser\n },\n chat () {\n return this.$store.state.chat.channel\n },\n followRequestCount () {\n return this.$store.state.api.followRequests.length\n }\n }\n}\n\nexport default NavPanel\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/nav_panel/nav_panel.js","import Status from '../status/status.vue'\nimport UserAvatar from '../user_avatar/user_avatar.vue'\nimport UserCard from '../user_card/user_card.vue'\nimport { highlightClass, highlightStyle } from '../../services/user_highlighter/user_highlighter.js'\nimport generateProfileLink from 'src/services/user_profile_link_generator/user_profile_link_generator'\n\nconst Notification = {\n data () {\n return {\n userExpanded: false,\n betterShadow: this.$store.state.interface.browserSupport.cssFilter\n }\n },\n props: [ 'notification' ],\n components: {\n Status, UserAvatar, UserCard\n },\n methods: {\n toggleUserExpanded () {\n this.userExpanded = !this.userExpanded\n },\n userProfileLink (user) {\n return generateProfileLink(user.id, user.screen_name, this.$store.state.instance.restrictedNicknames)\n }\n },\n computed: {\n userClass () {\n return highlightClass(this.notification.action.user)\n },\n userStyle () {\n const highlight = this.$store.state.config.highlight\n const user = this.notification.action.user\n return highlightStyle(highlight[user.screen_name])\n }\n }\n}\n\nexport default Notification\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/notification/notification.js","import Notification from '../notification/notification.vue'\nimport notificationsFetcher from '../../services/notifications_fetcher/notifications_fetcher.service.js'\nimport {\n notificationsFromStore,\n visibleNotificationsFromStore,\n unseenNotificationsFromStore\n} from '../../services/notification_utils/notification_utils.js'\n\nconst Notifications = {\n created () {\n const store = this.$store\n const credentials = store.state.users.currentUser.credentials\n\n const fetcherId = notificationsFetcher.startFetching({ store, credentials })\n this.$store.commit('setNotificationFetcher', { fetcherId })\n },\n data () {\n return {\n bottomedOut: false\n }\n },\n computed: {\n notifications () {\n return notificationsFromStore(this.$store)\n },\n error () {\n return this.$store.state.statuses.notifications.error\n },\n unseenNotifications () {\n return unseenNotificationsFromStore(this.$store)\n },\n visibleNotifications () {\n return visibleNotificationsFromStore(this.$store)\n },\n unseenCount () {\n return this.unseenNotifications.length\n },\n loading () {\n return this.$store.state.statuses.notifications.loading\n }\n },\n components: {\n Notification\n },\n watch: {\n unseenCount (count) {\n if (count > 0) {\n this.$store.dispatch('setPageTitle', `(${count})`)\n } else {\n this.$store.dispatch('setPageTitle', '')\n }\n }\n },\n methods: {\n markAsSeen () {\n this.$store.dispatch('markNotificationsAsSeen', this.visibleNotifications)\n },\n fetchOlderNotifications () {\n const store = this.$store\n const credentials = store.state.users.currentUser.credentials\n store.commit('setNotificationsLoading', { value: true })\n notificationsFetcher.fetchAndUpdate({\n store,\n credentials,\n older: true\n }).then(notifs => {\n store.commit('setNotificationsLoading', { value: false })\n if (notifs.length === 0) {\n this.bottomedOut = true\n }\n })\n }\n }\n}\n\nexport default Notifications\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/notifications/notifications.js","import oauth from '../../services/new_api/oauth.js'\n\nconst oac = {\n props: ['code'],\n mounted () {\n if (this.code) {\n oauth.getToken({\n app: this.$store.state.oauth,\n instance: this.$store.state.instance.server,\n code: this.code\n }).then((result) => {\n this.$store.commit('setToken', result.access_token)\n this.$store.dispatch('loginUser', result.access_token)\n this.$router.push({name: 'friends'})\n })\n }\n }\n}\n\nexport default oac\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/oauth_callback/oauth_callback.js","import statusPoster from '../../services/status_poster/status_poster.service.js'\nimport MediaUpload from '../media_upload/media_upload.vue'\nimport fileTypeService from '../../services/file_type/file_type.service.js'\nimport Completion from '../../services/completion/completion.js'\nimport { take, filter, reject, map, uniqBy } from 'lodash'\n\nconst buildMentionsString = ({user, attentions}, currentUser) => {\n let allAttentions = [...attentions]\n\n allAttentions.unshift(user)\n\n allAttentions = uniqBy(allAttentions, 'id')\n allAttentions = reject(allAttentions, {id: currentUser.id})\n\n let mentions = map(allAttentions, (attention) => {\n return `@${attention.screen_name}`\n })\n\n return mentions.length > 0 ? mentions.join(' ') + ' ' : ''\n}\n\nconst PostStatusForm = {\n props: [\n 'replyTo',\n 'repliedUser',\n 'attentions',\n 'copyMessageScope',\n 'subject'\n ],\n components: {\n MediaUpload\n },\n mounted () {\n this.resize(this.$refs.textarea)\n const textLength = this.$refs.textarea.value.length\n this.$refs.textarea.setSelectionRange(textLength, textLength)\n\n if (this.replyTo) {\n this.$refs.textarea.focus()\n }\n },\n data () {\n const preset = this.$route.query.message\n let statusText = preset || ''\n\n const scopeCopy = typeof this.$store.state.config.scopeCopy === 'undefined'\n ? this.$store.state.instance.scopeCopy\n : this.$store.state.config.scopeCopy\n\n if (this.replyTo) {\n const currentUser = this.$store.state.users.currentUser\n statusText = buildMentionsString({ user: this.repliedUser, attentions: this.attentions }, currentUser)\n }\n\n const scope = (this.copyMessageScope && scopeCopy || this.copyMessageScope === 'direct')\n ? this.copyMessageScope\n : this.$store.state.users.currentUser.default_scope\n\n const contentType = typeof this.$store.state.config.postContentType === 'undefined'\n ? this.$store.state.instance.postContentType\n : this.$store.state.config.postContentType\n\n return {\n dropFiles: [],\n submitDisabled: false,\n error: null,\n posting: false,\n highlighted: 0,\n newStatus: {\n spoilerText: this.subject || '',\n status: statusText,\n nsfw: false,\n files: [],\n visibility: scope,\n contentType\n },\n caret: 0\n }\n },\n computed: {\n vis () {\n return {\n public: { selected: this.newStatus.visibility === 'public' },\n unlisted: { selected: this.newStatus.visibility === 'unlisted' },\n private: { selected: this.newStatus.visibility === 'private' },\n direct: { selected: this.newStatus.visibility === 'direct' }\n }\n },\n candidates () {\n const firstchar = this.textAtCaret.charAt(0)\n if (firstchar === '@') {\n const query = this.textAtCaret.slice(1).toUpperCase()\n const matchedUsers = filter(this.users, (user) => {\n return user.screen_name.toUpperCase().startsWith(query) ||\n user.name && user.name.toUpperCase().startsWith(query)\n })\n if (matchedUsers.length <= 0) {\n return false\n }\n // eslint-disable-next-line camelcase\n return map(take(matchedUsers, 5), ({screen_name, name, profile_image_url_original}, index) => ({\n // eslint-disable-next-line camelcase\n screen_name: `@${screen_name}`,\n name: name,\n img: profile_image_url_original,\n highlighted: index === this.highlighted\n }))\n } else if (firstchar === ':') {\n if (this.textAtCaret === ':') { return }\n const matchedEmoji = filter(this.emoji.concat(this.customEmoji), (emoji) => emoji.shortcode.startsWith(this.textAtCaret.slice(1)))\n if (matchedEmoji.length <= 0) {\n return false\n }\n return map(take(matchedEmoji, 5), ({shortcode, image_url, utf}, index) => ({\n screen_name: `:${shortcode}:`,\n name: '',\n utf: utf || '',\n // eslint-disable-next-line camelcase\n img: utf ? '' : this.$store.state.instance.server + image_url,\n highlighted: index === this.highlighted\n }))\n } else {\n return false\n }\n },\n textAtCaret () {\n return (this.wordAtCaret || {}).word || ''\n },\n wordAtCaret () {\n const word = Completion.wordAtPosition(this.newStatus.status, this.caret - 1) || {}\n return word\n },\n users () {\n return this.$store.state.users.users\n },\n emoji () {\n return this.$store.state.instance.emoji || []\n },\n customEmoji () {\n return this.$store.state.instance.customEmoji || []\n },\n statusLength () {\n return this.newStatus.status.length\n },\n spoilerTextLength () {\n return this.newStatus.spoilerText.length\n },\n statusLengthLimit () {\n return this.$store.state.instance.textlimit\n },\n hasStatusLengthLimit () {\n return this.statusLengthLimit > 0\n },\n charactersLeft () {\n return this.statusLengthLimit - (this.statusLength + this.spoilerTextLength)\n },\n isOverLengthLimit () {\n return this.hasStatusLengthLimit && (this.charactersLeft < 0)\n },\n scopeOptionsEnabled () {\n return this.$store.state.instance.scopeOptionsEnabled\n },\n alwaysShowSubject () {\n if (typeof this.$store.state.config.alwaysShowSubjectInput !== 'undefined') {\n return this.$store.state.config.alwaysShowSubjectInput\n } else if (typeof this.$store.state.instance.alwaysShowSubjectInput !== 'undefined') {\n return this.$store.state.instance.alwaysShowSubjectInput\n } else {\n return this.$store.state.instance.scopeOptionsEnabled\n }\n },\n formattingOptionsEnabled () {\n return this.$store.state.instance.formattingOptionsEnabled\n },\n postFormats () {\n return this.$store.state.instance.postFormats || []\n }\n },\n methods: {\n replace (replacement) {\n this.newStatus.status = Completion.replaceWord(this.newStatus.status, this.wordAtCaret, replacement)\n const el = this.$el.querySelector('textarea')\n el.focus()\n this.caret = 0\n },\n replaceCandidate (e) {\n const len = this.candidates.length || 0\n if (this.textAtCaret === ':' || e.ctrlKey) { return }\n if (len > 0) {\n e.preventDefault()\n const candidate = this.candidates[this.highlighted]\n const replacement = candidate.utf || (candidate.screen_name + ' ')\n this.newStatus.status = Completion.replaceWord(this.newStatus.status, this.wordAtCaret, replacement)\n const el = this.$el.querySelector('textarea')\n el.focus()\n this.caret = 0\n this.highlighted = 0\n }\n },\n cycleBackward (e) {\n const len = this.candidates.length || 0\n if (len > 0) {\n e.preventDefault()\n this.highlighted -= 1\n if (this.highlighted < 0) {\n this.highlighted = this.candidates.length - 1\n }\n } else {\n this.highlighted = 0\n }\n },\n cycleForward (e) {\n const len = this.candidates.length || 0\n if (len > 0) {\n if (e.shiftKey) { return }\n e.preventDefault()\n this.highlighted += 1\n if (this.highlighted >= len) {\n this.highlighted = 0\n }\n } else {\n this.highlighted = 0\n }\n },\n onKeydown (e) {\n e.stopPropagation()\n },\n setCaret ({target: {selectionStart}}) {\n this.caret = selectionStart\n },\n postStatus (newStatus) {\n if (this.posting) { return }\n if (this.submitDisabled) { return }\n\n if (this.newStatus.status === '') {\n if (this.newStatus.files.length > 0) {\n this.newStatus.status = '\\u200b' // hack\n } else {\n this.error = 'Cannot post an empty status with no files'\n return\n }\n }\n\n this.posting = true\n statusPoster.postStatus({\n status: newStatus.status,\n spoilerText: newStatus.spoilerText || null,\n visibility: newStatus.visibility,\n sensitive: newStatus.nsfw,\n media: newStatus.files,\n store: this.$store,\n inReplyToStatusId: this.replyTo,\n contentType: newStatus.contentType\n }).then((data) => {\n if (!data.error) {\n this.newStatus = {\n status: '',\n spoilerText: '',\n files: [],\n visibility: newStatus.visibility,\n contentType: newStatus.contentType\n }\n this.$refs.mediaUpload.clearFile()\n this.$emit('posted')\n let el = this.$el.querySelector('textarea')\n el.style.height = 'auto'\n el.style.height = undefined\n this.error = null\n } else {\n this.error = data.error\n }\n this.posting = false\n })\n },\n addMediaFile (fileInfo) {\n this.newStatus.files.push(fileInfo)\n this.enableSubmit()\n },\n removeMediaFile (fileInfo) {\n let index = this.newStatus.files.indexOf(fileInfo)\n this.newStatus.files.splice(index, 1)\n },\n uploadFailed (errString, templateArgs) {\n templateArgs = templateArgs || {}\n this.error = this.$t('upload.error.base') + ' ' + this.$t('upload.error.' + errString, templateArgs)\n this.enableSubmit()\n },\n disableSubmit () {\n this.submitDisabled = true\n },\n enableSubmit () {\n this.submitDisabled = false\n },\n type (fileInfo) {\n return fileTypeService.fileType(fileInfo.mimetype)\n },\n paste (e) {\n if (e.clipboardData.files.length > 0) {\n // Strangely, files property gets emptied after event propagation\n // Trying to wrap it in array doesn't work. Plus I doubt it's possible\n // to hold more than one file in clipboard.\n this.dropFiles = [e.clipboardData.files[0]]\n }\n },\n fileDrop (e) {\n if (e.dataTransfer.files.length > 0) {\n e.preventDefault() // allow dropping text like before\n this.dropFiles = e.dataTransfer.files\n }\n },\n fileDrag (e) {\n e.dataTransfer.dropEffect = 'copy'\n },\n resize (e) {\n const target = e.target || e\n if (!(target instanceof window.Element)) { return }\n const vertPadding = Number(window.getComputedStyle(target)['padding-top'].substr(0, 1)) +\n Number(window.getComputedStyle(target)['padding-bottom'].substr(0, 1))\n // Auto is needed to make textbox shrink when removing lines\n target.style.height = 'auto'\n target.style.height = `${target.scrollHeight - vertPadding}px`\n if (target.value === '') {\n target.style.height = null\n }\n },\n clearError () {\n this.error = null\n },\n changeVis (visibility) {\n this.newStatus.visibility = visibility\n }\n }\n}\n\nexport default PostStatusForm\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/post_status_form/post_status_form.js","import Timeline from '../timeline/timeline.vue'\nconst PublicAndExternalTimeline = {\n components: {\n Timeline\n },\n computed: {\n timeline () { return this.$store.state.statuses.timelines.publicAndExternal }\n },\n created () {\n this.$store.dispatch('startFetching', { timeline: 'publicAndExternal' })\n },\n destroyed () {\n this.$store.dispatch('stopFetching', 'publicAndExternal')\n }\n}\n\nexport default PublicAndExternalTimeline\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/public_and_external_timeline/public_and_external_timeline.js","import Timeline from '../timeline/timeline.vue'\nconst PublicTimeline = {\n components: {\n Timeline\n },\n computed: {\n timeline () { return this.$store.state.statuses.timelines.public }\n },\n created () {\n this.$store.dispatch('startFetching', { timeline: 'public' })\n },\n destroyed () {\n this.$store.dispatch('stopFetching', 'public')\n }\n\n}\n\nexport default PublicTimeline\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/public_timeline/public_timeline.js","import { validationMixin } from 'vuelidate'\nimport { required, sameAs } from 'vuelidate/lib/validators'\nimport { mapActions, mapState } from 'vuex'\n\nconst registration = {\n mixins: [validationMixin],\n data: () => ({\n user: {\n email: '',\n fullname: '',\n username: '',\n password: '',\n confirm: ''\n },\n captcha: {}\n }),\n validations: {\n user: {\n email: { required },\n username: { required },\n fullname: { required },\n password: { required },\n confirm: {\n required,\n sameAsPassword: sameAs('password')\n }\n }\n },\n created () {\n if ((!this.registrationOpen && !this.token) || this.signedIn) {\n this.$router.push({name: 'root'})\n }\n\n this.setCaptcha()\n },\n computed: {\n token () { return this.$route.params.token },\n ...mapState({\n registrationOpen: (state) => state.instance.registrationOpen,\n signedIn: (state) => !!state.users.currentUser,\n isPending: (state) => state.users.signUpPending,\n serverValidationErrors: (state) => state.users.signUpErrors,\n termsOfService: (state) => state.instance.tos\n })\n },\n methods: {\n ...mapActions(['signUp', 'getCaptcha']),\n async submit () {\n this.user.nickname = this.user.username\n this.user.token = this.token\n\n this.user.captcha_solution = this.captcha.solution\n this.user.captcha_token = this.captcha.token\n this.user.captcha_answer_data = this.captcha.answer_data\n\n this.$v.$touch()\n\n if (!this.$v.$invalid) {\n try {\n await this.signUp(this.user)\n this.$router.push({name: 'friends'})\n } catch (error) {\n console.warn('Registration failed: ' + error)\n }\n }\n },\n setCaptcha () {\n this.getCaptcha().then(cpt => { this.captcha = cpt })\n }\n }\n}\n\nexport default registration\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/registration/registration.js","const RetweetButton = {\n props: ['status', 'loggedIn', 'visibility'],\n data () {\n return {\n hidePostStatsLocal: typeof this.$store.state.config.hidePostStats === 'undefined'\n ? this.$store.state.instance.hidePostStats\n : this.$store.state.config.hidePostStats,\n animated: false\n }\n },\n methods: {\n retweet () {\n if (!this.status.repeated) {\n this.$store.dispatch('retweet', {id: this.status.id})\n } else {\n this.$store.dispatch('unretweet', {id: this.status.id})\n }\n this.animated = true\n setTimeout(() => {\n this.animated = false\n }, 500)\n }\n },\n computed: {\n classes () {\n return {\n 'retweeted': this.status.repeated,\n 'retweeted-empty': !this.status.repeated,\n 'animate-spin': this.animated\n }\n }\n }\n}\n\nexport default RetweetButton\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/retweet_button/retweet_button.js","/* eslint-env browser */\nimport TabSwitcher from '../tab_switcher/tab_switcher.js'\nimport StyleSwitcher from '../style_switcher/style_switcher.vue'\nimport InterfaceLanguageSwitcher from '../interface_language_switcher/interface_language_switcher.vue'\nimport { filter, trim } from 'lodash'\n\nconst settings = {\n data () {\n const user = this.$store.state.config\n const instance = this.$store.state.instance\n\n return {\n hideAttachmentsLocal: user.hideAttachments,\n hideAttachmentsInConvLocal: user.hideAttachmentsInConv,\n maxThumbnails: user.maxThumbnails,\n hideNsfwLocal: user.hideNsfw,\n useOneClickNsfw: user.useOneClickNsfw,\n hideISPLocal: user.hideISP,\n preloadImage: user.preloadImage,\n\n hidePostStatsLocal: typeof user.hidePostStats === 'undefined'\n ? instance.hidePostStats\n : user.hidePostStats,\n hidePostStatsDefault: this.$t('settings.values.' + instance.hidePostStats),\n\n hideUserStatsLocal: typeof user.hideUserStats === 'undefined'\n ? instance.hideUserStats\n : user.hideUserStats,\n hideUserStatsDefault: this.$t('settings.values.' + instance.hideUserStats),\n\n hideFilteredStatusesLocal: typeof user.hideFilteredStatuses === 'undefined'\n ? instance.hideFilteredStatuses\n : user.hideFilteredStatuses,\n hideFilteredStatusesDefault: this.$t('settings.values.' + instance.hideFilteredStatuses),\n\n notificationVisibilityLocal: user.notificationVisibility,\n replyVisibilityLocal: user.replyVisibility,\n loopVideoLocal: user.loopVideo,\n muteWordsString: user.muteWords.join('\\n'),\n autoLoadLocal: user.autoLoad,\n streamingLocal: user.streaming,\n pauseOnUnfocusedLocal: user.pauseOnUnfocused,\n hoverPreviewLocal: user.hoverPreview,\n\n collapseMessageWithSubjectLocal: typeof user.collapseMessageWithSubject === 'undefined'\n ? instance.collapseMessageWithSubject\n : user.collapseMessageWithSubject,\n collapseMessageWithSubjectDefault: this.$t('settings.values.' + instance.collapseMessageWithSubject),\n\n subjectLineBehaviorLocal: typeof user.subjectLineBehavior === 'undefined'\n ? instance.subjectLineBehavior\n : user.subjectLineBehavior,\n subjectLineBehaviorDefault: instance.subjectLineBehavior,\n\n postContentTypeLocal: typeof user.postContentType === 'undefined'\n ? instance.postContentType\n : user.postContentType,\n postContentTypeDefault: instance.postContentType,\n\n alwaysShowSubjectInputLocal: typeof user.alwaysShowSubjectInput === 'undefined'\n ? instance.alwaysShowSubjectInput\n : user.alwaysShowSubjectInput,\n alwaysShowSubjectInputDefault: instance.alwaysShowSubjectInput,\n\n scopeCopyLocal: typeof user.scopeCopy === 'undefined'\n ? instance.scopeCopy\n : user.scopeCopy,\n scopeCopyDefault: this.$t('settings.values.' + instance.scopeCopy),\n\n stopGifs: user.stopGifs,\n webPushNotificationsLocal: user.webPushNotifications,\n loopVideoSilentOnlyLocal: user.loopVideosSilentOnly,\n loopSilentAvailable:\n // Firefox\n Object.getOwnPropertyDescriptor(HTMLVideoElement.prototype, 'mozHasAudio') ||\n // Chrome-likes\n Object.getOwnPropertyDescriptor(HTMLMediaElement.prototype, 'webkitAudioDecodedByteCount') ||\n // Future spec, still not supported in Nightly 63 as of 08/2018\n Object.getOwnPropertyDescriptor(HTMLMediaElement.prototype, 'audioTracks'),\n playVideosInModal: user.playVideosInModal,\n useContainFit: user.useContainFit\n }\n },\n components: {\n TabSwitcher,\n StyleSwitcher,\n InterfaceLanguageSwitcher\n },\n computed: {\n user () {\n return this.$store.state.users.currentUser\n },\n currentSaveStateNotice () {\n return this.$store.state.interface.settings.currentSaveStateNotice\n },\n postFormats () {\n return this.$store.state.instance.postFormats || []\n },\n instanceSpecificPanelPresent () { return this.$store.state.instance.showInstanceSpecificPanel }\n },\n watch: {\n hideAttachmentsLocal (value) {\n this.$store.dispatch('setOption', { name: 'hideAttachments', value })\n },\n hideAttachmentsInConvLocal (value) {\n this.$store.dispatch('setOption', { name: 'hideAttachmentsInConv', value })\n },\n hidePostStatsLocal (value) {\n this.$store.dispatch('setOption', { name: 'hidePostStats', value })\n },\n hideUserStatsLocal (value) {\n this.$store.dispatch('setOption', { name: 'hideUserStats', value })\n },\n hideFilteredStatusesLocal (value) {\n this.$store.dispatch('setOption', { name: 'hideFilteredStatuses', value })\n },\n hideNsfwLocal (value) {\n this.$store.dispatch('setOption', { name: 'hideNsfw', value })\n },\n useOneClickNsfw (value) {\n this.$store.dispatch('setOption', { name: 'useOneClickNsfw', value })\n },\n preloadImage (value) {\n this.$store.dispatch('setOption', { name: 'preloadImage', value })\n },\n hideISPLocal (value) {\n this.$store.dispatch('setOption', { name: 'hideISP', value })\n },\n 'notificationVisibilityLocal.likes' (value) {\n this.$store.dispatch('setOption', { name: 'notificationVisibility', value: this.$store.state.config.notificationVisibility })\n },\n 'notificationVisibilityLocal.follows' (value) {\n this.$store.dispatch('setOption', { name: 'notificationVisibility', value: this.$store.state.config.notificationVisibility })\n },\n 'notificationVisibilityLocal.repeats' (value) {\n this.$store.dispatch('setOption', { name: 'notificationVisibility', value: this.$store.state.config.notificationVisibility })\n },\n 'notificationVisibilityLocal.mentions' (value) {\n this.$store.dispatch('setOption', { name: 'notificationVisibility', value: this.$store.state.config.notificationVisibility })\n },\n replyVisibilityLocal (value) {\n this.$store.dispatch('setOption', { name: 'replyVisibility', value })\n },\n loopVideoLocal (value) {\n this.$store.dispatch('setOption', { name: 'loopVideo', value })\n },\n loopVideoSilentOnlyLocal (value) {\n this.$store.dispatch('setOption', { name: 'loopVideoSilentOnly', value })\n },\n autoLoadLocal (value) {\n this.$store.dispatch('setOption', { name: 'autoLoad', value })\n },\n streamingLocal (value) {\n this.$store.dispatch('setOption', { name: 'streaming', value })\n },\n pauseOnUnfocusedLocal (value) {\n this.$store.dispatch('setOption', { name: 'pauseOnUnfocused', value })\n },\n hoverPreviewLocal (value) {\n this.$store.dispatch('setOption', { name: 'hoverPreview', value })\n },\n muteWordsString (value) {\n value = filter(value.split('\\n'), (word) => trim(word).length > 0)\n this.$store.dispatch('setOption', { name: 'muteWords', value })\n },\n collapseMessageWithSubjectLocal (value) {\n this.$store.dispatch('setOption', { name: 'collapseMessageWithSubject', value })\n },\n scopeCopyLocal (value) {\n this.$store.dispatch('setOption', { name: 'scopeCopy', value })\n },\n alwaysShowSubjectInputLocal (value) {\n this.$store.dispatch('setOption', { name: 'alwaysShowSubjectInput', value })\n },\n subjectLineBehaviorLocal (value) {\n this.$store.dispatch('setOption', { name: 'subjectLineBehavior', value })\n },\n postContentTypeLocal (value) {\n this.$store.dispatch('setOption', { name: 'postContentType', value })\n },\n stopGifs (value) {\n this.$store.dispatch('setOption', { name: 'stopGifs', value })\n },\n webPushNotificationsLocal (value) {\n this.$store.dispatch('setOption', { name: 'webPushNotifications', value })\n if (value) this.$store.dispatch('registerPushNotifications')\n },\n playVideosInModal (value) {\n this.$store.dispatch('setOption', { name: 'playVideosInModal', value })\n },\n useContainFit (value) {\n this.$store.dispatch('setOption', { name: 'useContainFit', value })\n },\n maxThumbnails (value) {\n value = this.maxThumbnails = Math.floor(Math.max(value, 0))\n this.$store.dispatch('setOption', { name: 'maxThumbnails', value })\n }\n }\n}\n\nexport default settings\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/settings/settings.js","import ColorInput from '../color_input/color_input.vue'\nimport OpacityInput from '../opacity_input/opacity_input.vue'\nimport { getCssShadow } from '../../services/style_setter/style_setter.js'\nimport { hex2rgb } from '../../services/color_convert/color_convert.js'\n\nexport default {\n // 'Value' and 'Fallback' can be undefined, but if they are\n // initially vue won't detect it when they become something else\n // therefore i'm using \"ready\" which should be passed as true when\n // data becomes available\n props: [\n 'value', 'fallback', 'ready'\n ],\n data () {\n return {\n selectedId: 0,\n // TODO there are some bugs regarding display of array (it's not getting updated when deleting for some reason)\n cValue: this.value || this.fallback || []\n }\n },\n components: {\n ColorInput,\n OpacityInput\n },\n methods: {\n add () {\n this.cValue.push(Object.assign({}, this.selected))\n this.selectedId = this.cValue.length - 1\n },\n del () {\n this.cValue.splice(this.selectedId, 1)\n this.selectedId = this.cValue.length === 0 ? undefined : this.selectedId - 1\n },\n moveUp () {\n const movable = this.cValue.splice(this.selectedId, 1)[0]\n this.cValue.splice(this.selectedId - 1, 0, movable)\n this.selectedId -= 1\n },\n moveDn () {\n const movable = this.cValue.splice(this.selectedId, 1)[0]\n this.cValue.splice(this.selectedId + 1, 0, movable)\n this.selectedId += 1\n }\n },\n beforeUpdate () {\n this.cValue = this.value || this.fallback\n },\n computed: {\n selected () {\n if (this.ready && this.cValue.length > 0) {\n return this.cValue[this.selectedId]\n } else {\n return {\n x: 0,\n y: 0,\n blur: 0,\n spread: 0,\n inset: false,\n color: '#000000',\n alpha: 1\n }\n }\n },\n moveUpValid () {\n return this.ready && this.selectedId > 0\n },\n moveDnValid () {\n return this.ready && this.selectedId < this.cValue.length - 1\n },\n present () {\n return this.ready &&\n typeof this.cValue[this.selectedId] !== 'undefined' &&\n !this.usingFallback\n },\n usingFallback () {\n return typeof this.value === 'undefined'\n },\n rgb () {\n return hex2rgb(this.selected.color)\n },\n style () {\n return this.ready ? {\n boxShadow: getCssShadow(this.cValue)\n } : {}\n }\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/shadow_control/shadow_control.js","import UserCard from '../user_card/user_card.vue'\nimport { unseenNotificationsFromStore } from '../../services/notification_utils/notification_utils'\n\n// TODO: separate touch gesture stuff into their own utils if more components want them\nconst deltaCoord = (oldCoord, newCoord) => [newCoord[0] - oldCoord[0], newCoord[1] - oldCoord[1]]\n\nconst touchEventCoord = e => ([e.touches[0].screenX, e.touches[0].screenY])\n\nconst SideDrawer = {\n props: [ 'logout' ],\n data: () => ({\n closed: true,\n touchCoord: [0, 0]\n }),\n components: { UserCard },\n computed: {\n currentUser () {\n return this.$store.state.users.currentUser\n },\n chat () { return this.$store.state.chat.channel.state === 'joined' },\n unseenNotifications () {\n return unseenNotificationsFromStore(this.$store)\n },\n unseenNotificationsCount () {\n return this.unseenNotifications.length\n },\n suggestionsEnabled () {\n return this.$store.state.instance.suggestionsEnabled\n },\n logo () {\n return this.$store.state.instance.logo\n },\n sitename () {\n return this.$store.state.instance.name\n },\n followRequestCount () {\n return this.$store.state.api.followRequests.length\n }\n },\n methods: {\n toggleDrawer () {\n this.closed = !this.closed\n },\n doLogout () {\n this.logout()\n this.toggleDrawer()\n },\n touchStart (e) {\n this.touchCoord = touchEventCoord(e)\n },\n touchMove (e) {\n const delta = deltaCoord(this.touchCoord, touchEventCoord(e))\n if (delta[0] < -30 && Math.abs(delta[1]) < Math.abs(delta[0]) && !this.closed) {\n this.toggleDrawer()\n }\n }\n }\n}\n\nexport default SideDrawer\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/side_drawer/side_drawer.js","import Attachment from '../attachment/attachment.vue'\nimport FavoriteButton from '../favorite_button/favorite_button.vue'\nimport RetweetButton from '../retweet_button/retweet_button.vue'\nimport DeleteButton from '../delete_button/delete_button.vue'\nimport PostStatusForm from '../post_status_form/post_status_form.vue'\nimport UserCard from '../user_card/user_card.vue'\nimport UserAvatar from '../user_avatar/user_avatar.vue'\nimport Gallery from '../gallery/gallery.vue'\nimport LinkPreview from '../link-preview/link-preview.vue'\nimport generateProfileLink from 'src/services/user_profile_link_generator/user_profile_link_generator'\nimport fileType from 'src/services/file_type/file_type.service'\nimport { highlightClass, highlightStyle } from '../../services/user_highlighter/user_highlighter.js'\nimport { mentionMatchesUrl, extractTagFromUrl } from 'src/services/matcher/matcher.service.js'\nimport { filter, find, unescape } from 'lodash'\n\nconst Status = {\n name: 'Status',\n props: [\n 'statusoid',\n 'expandable',\n 'inConversation',\n 'focused',\n 'highlight',\n 'compact',\n 'replies',\n 'isPreview',\n 'noHeading',\n 'inlineExpanded'\n ],\n data () {\n return {\n replying: false,\n expanded: false,\n unmuted: false,\n userExpanded: false,\n preview: null,\n showPreview: false,\n showingTall: this.inConversation && this.focused,\n showingLongSubject: false,\n expandingSubject: typeof this.$store.state.config.collapseMessageWithSubject === 'undefined'\n ? !this.$store.state.instance.collapseMessageWithSubject\n : !this.$store.state.config.collapseMessageWithSubject,\n betterShadow: this.$store.state.interface.browserSupport.cssFilter\n }\n },\n computed: {\n localCollapseSubjectDefault () {\n return typeof this.$store.state.config.collapseMessageWithSubject === 'undefined'\n ? this.$store.state.instance.collapseMessageWithSubject\n : this.$store.state.config.collapseMessageWithSubject\n },\n muteWords () {\n return this.$store.state.config.muteWords\n },\n repeaterClass () {\n const user = this.statusoid.user\n return highlightClass(user)\n },\n userClass () {\n const user = this.retweet ? (this.statusoid.retweeted_status.user) : this.statusoid.user\n return highlightClass(user)\n },\n deleted () {\n return this.statusoid.deleted\n },\n repeaterStyle () {\n const user = this.statusoid.user\n const highlight = this.$store.state.config.highlight\n return highlightStyle(highlight[user.screen_name])\n },\n userStyle () {\n if (this.noHeading) return\n const user = this.retweet ? (this.statusoid.retweeted_status.user) : this.statusoid.user\n const highlight = this.$store.state.config.highlight\n return highlightStyle(highlight[user.screen_name])\n },\n hideAttachments () {\n return (this.$store.state.config.hideAttachments && !this.inConversation) ||\n (this.$store.state.config.hideAttachmentsInConv && this.inConversation)\n },\n userProfileLink () {\n return this.generateUserProfileLink(this.status.user.id, this.status.user.screen_name)\n },\n replyProfileLink () {\n if (this.isReply) {\n return this.generateUserProfileLink(this.status.in_reply_to_user_id, this.replyToName)\n }\n },\n retweet () { return !!this.statusoid.retweeted_status },\n retweeter () { return this.statusoid.user.name || this.statusoid.user.screen_name },\n retweeterHtml () { return this.statusoid.user.name_html },\n retweeterProfileLink () { return this.generateUserProfileLink(this.statusoid.user.id, this.statusoid.user.screen_name) },\n status () {\n if (this.retweet) {\n return this.statusoid.retweeted_status\n } else {\n return this.statusoid\n }\n },\n loggedIn () {\n return !!this.$store.state.users.currentUser\n },\n muteWordHits () {\n const statusText = this.status.text.toLowerCase()\n const hits = filter(this.muteWords, (muteWord) => {\n return statusText.includes(muteWord.toLowerCase())\n })\n\n return hits\n },\n muted () { return !this.unmuted && (this.status.user.muted || this.muteWordHits.length > 0) },\n hideFilteredStatuses () {\n return typeof this.$store.state.config.hideFilteredStatuses === 'undefined'\n ? this.$store.state.instance.hideFilteredStatuses\n : this.$store.state.config.hideFilteredStatuses\n },\n hideStatus () {\n return (this.hideReply || this.deleted) || (this.muted && this.hideFilteredStatuses)\n },\n isFocused () {\n // retweet or root of an expanded conversation\n if (this.focused) {\n return true\n } else if (!this.inConversation) {\n return false\n }\n // use conversation highlight only when in conversation\n return this.status.id === this.highlight\n },\n // This is a bit hacky, but we want to approximate post height before rendering\n // so we count newlines (masto uses

    for paragraphs, GS uses
    between them)\n // as well as approximate line count by counting characters and approximating ~80\n // per line.\n //\n // Using max-height + overflow: auto for status components resulted in false positives\n // very often with japanese characters, and it was very annoying.\n tallStatus () {\n const lengthScore = this.status.statusnet_html.split(/ 20\n },\n longSubject () {\n return this.status.summary.length > 900\n },\n isReply () {\n return !!(this.status.in_reply_to_status_id && this.status.in_reply_to_user_id)\n },\n replyToName () {\n const user = this.$store.state.users.usersObject[this.status.in_reply_to_user_id]\n if (user) {\n return user.screen_name\n } else {\n return this.status.in_reply_to_screen_name\n }\n },\n hideReply () {\n if (this.$store.state.config.replyVisibility === 'all') {\n return false\n }\n if (this.inlineExpanded || this.expanded || this.inConversation || !this.isReply) {\n return false\n }\n if (this.status.user.id === this.$store.state.users.currentUser.id) {\n return false\n }\n if (this.status.type === 'retweet') {\n return false\n }\n var checkFollowing = this.$store.state.config.replyVisibility === 'following'\n for (var i = 0; i < this.status.attentions.length; ++i) {\n if (this.status.user.id === this.status.attentions[i].id) {\n continue\n }\n if (checkFollowing && this.status.attentions[i].following) {\n return false\n }\n if (this.status.attentions[i].id === this.$store.state.users.currentUser.id) {\n return false\n }\n }\n return this.status.attentions.length > 0\n },\n hideSubjectStatus () {\n if (this.tallStatus && !this.localCollapseSubjectDefault) {\n return false\n }\n return !this.expandingSubject && this.status.summary\n },\n hideTallStatus () {\n if (this.status.summary && this.localCollapseSubjectDefault) {\n return false\n }\n if (this.showingTall) {\n return false\n }\n return this.tallStatus\n },\n showingMore () {\n return (this.tallStatus && this.showingTall) || (this.status.summary && this.expandingSubject)\n },\n nsfwClickthrough () {\n if (!this.status.nsfw) {\n return false\n }\n if (this.status.summary && this.localCollapseSubjectDefault) {\n return false\n }\n return true\n },\n replySubject () {\n if (!this.status.summary) return ''\n const decodedSummary = unescape(this.status.summary)\n const behavior = typeof this.$store.state.config.subjectLineBehavior === 'undefined'\n ? this.$store.state.instance.subjectLineBehavior\n : this.$store.state.config.subjectLineBehavior\n const startsWithRe = decodedSummary.match(/^re[: ]/i)\n if (behavior !== 'noop' && startsWithRe || behavior === 'masto') {\n return decodedSummary\n } else if (behavior === 'email') {\n return 're: '.concat(decodedSummary)\n } else if (behavior === 'noop') {\n return ''\n }\n },\n attachmentSize () {\n if ((this.$store.state.config.hideAttachments && !this.inConversation) ||\n (this.$store.state.config.hideAttachmentsInConv && this.inConversation) ||\n (this.status.attachments.length > this.maxThumbnails)) {\n return 'hide'\n } else if (this.compact) {\n return 'small'\n }\n return 'normal'\n },\n galleryTypes () {\n if (this.attachmentSize === 'hide') {\n return []\n }\n return this.$store.state.config.playVideosInModal\n ? ['image', 'video']\n : ['image']\n },\n galleryAttachments () {\n return this.status.attachments.filter(\n file => fileType.fileMatchesSomeType(this.galleryTypes, file)\n )\n },\n nonGalleryAttachments () {\n return this.status.attachments.filter(\n file => !fileType.fileMatchesSomeType(this.galleryTypes, file)\n )\n },\n maxThumbnails () {\n return this.$store.state.config.maxThumbnails\n }\n },\n components: {\n Attachment,\n FavoriteButton,\n RetweetButton,\n DeleteButton,\n PostStatusForm,\n UserCard,\n UserAvatar,\n Gallery,\n LinkPreview\n },\n methods: {\n visibilityIcon (visibility) {\n switch (visibility) {\n case 'private':\n return 'icon-lock'\n case 'unlisted':\n return 'icon-lock-open-alt'\n case 'direct':\n return 'icon-mail-alt'\n default:\n return 'icon-globe'\n }\n },\n linkClicked (event) {\n let { target } = event\n if (target.tagName === 'SPAN') {\n target = target.parentNode\n }\n if (target.tagName === 'A') {\n if (target.className.match(/mention/)) {\n const href = target.href\n const attn = this.status.attentions.find(attn => mentionMatchesUrl(attn, href))\n if (attn) {\n event.stopPropagation()\n event.preventDefault()\n const link = this.generateUserProfileLink(attn.id, attn.screen_name)\n this.$router.push(link)\n return\n }\n }\n if (target.className.match(/hashtag/)) {\n // Extract tag name from link url\n const tag = extractTagFromUrl(target.href)\n if (tag) {\n const link = this.generateTagLink(tag)\n this.$router.push(link)\n return\n }\n }\n window.open(target.href, '_blank')\n }\n },\n toggleReplying () {\n this.replying = !this.replying\n },\n gotoOriginal (id) {\n // only handled by conversation, not status_or_conversation\n if (this.inConversation) {\n this.$emit('goto', id)\n }\n },\n toggleExpanded () {\n this.$emit('toggleExpanded')\n },\n toggleMute () {\n this.unmuted = !this.unmuted\n },\n toggleUserExpanded () {\n this.userExpanded = !this.userExpanded\n },\n toggleShowMore () {\n if (this.showingTall) {\n this.showingTall = false\n } else if (this.expandingSubject && this.status.summary) {\n this.expandingSubject = false\n } else if (this.hideTallStatus) {\n this.showingTall = true\n } else if (this.hideSubjectStatus && this.status.summary) {\n this.expandingSubject = true\n }\n },\n replyEnter (id, event) {\n this.showPreview = true\n const targetId = id\n const statuses = this.$store.state.statuses.allStatuses\n\n if (!this.preview) {\n // if we have the status somewhere already\n this.preview = find(statuses, { 'id': targetId })\n // or if we have to fetch it\n if (!this.preview) {\n this.$store.state.api.backendInteractor.fetchStatus({id}).then((status) => {\n this.preview = status\n })\n }\n } else if (this.preview.id !== targetId) {\n this.preview = find(statuses, { 'id': targetId })\n }\n },\n replyLeave () {\n this.showPreview = false\n },\n generateUserProfileLink (id, name) {\n return generateProfileLink(id, name, this.$store.state.instance.restrictedNicknames)\n },\n generateTagLink (tag) {\n return `/tag/${tag}`\n },\n setMedia () {\n const attachments = this.attachmentSize === 'hide' ? this.status.attachments : this.galleryAttachments\n return () => this.$store.dispatch('setMedia', attachments)\n }\n },\n watch: {\n 'highlight': function (id) {\n if (this.status.id === id) {\n let rect = this.$el.getBoundingClientRect()\n if (rect.top < 100) {\n // Post is above screen, match its top to screen top\n window.scrollBy(0, rect.top - 100)\n } else if (rect.height >= (window.innerHeight - 50)) {\n // Post we want to see is taller than screen so match its top to screen top\n window.scrollBy(0, rect.top - 100)\n } else if (rect.bottom > window.innerHeight - 50) {\n // Post is below screen, match its bottom to screen bottom\n window.scrollBy(0, rect.bottom - window.innerHeight + 50)\n }\n }\n }\n },\n filters: {\n capitalize: function (str) {\n return str.charAt(0).toUpperCase() + str.slice(1)\n }\n }\n}\n\nexport default Status\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/status/status.js","import Status from '../status/status.vue'\nimport Conversation from '../conversation/conversation.vue'\n\nconst statusOrConversation = {\n props: ['statusoid'],\n data () {\n return {\n expanded: false\n }\n },\n components: {\n Status,\n Conversation\n },\n methods: {\n toggleExpanded () {\n this.expanded = !this.expanded\n }\n }\n}\n\nexport default statusOrConversation\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/status_or_conversation/status_or_conversation.js","const StillImage = {\n props: [\n 'src',\n 'referrerpolicy',\n 'mimetype',\n 'imageLoadError'\n ],\n data () {\n return {\n stopGifs: this.$store.state.config.stopGifs\n }\n },\n computed: {\n animated () {\n return this.stopGifs && (this.mimetype === 'image/gif' || this.src.endsWith('.gif'))\n }\n },\n methods: {\n onLoad () {\n const canvas = this.$refs.canvas\n if (!canvas) return\n const width = this.$refs.src.naturalWidth\n const height = this.$refs.src.naturalHeight\n canvas.width = width\n canvas.height = height\n canvas.getContext('2d').drawImage(this.$refs.src, 0, 0, width, height)\n },\n onError () {\n this.imageLoadError && this.imageLoadError()\n }\n }\n}\n\nexport default StillImage\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/still-image/still-image.js","import { rgb2hex, hex2rgb, getContrastRatio, alphaBlend } from '../../services/color_convert/color_convert.js'\nimport { set, delete as del } from 'vue'\nimport { generateColors, generateShadows, generateRadii, generateFonts, composePreset, getThemes } from '../../services/style_setter/style_setter.js'\nimport ColorInput from '../color_input/color_input.vue'\nimport RangeInput from '../range_input/range_input.vue'\nimport OpacityInput from '../opacity_input/opacity_input.vue'\nimport ShadowControl from '../shadow_control/shadow_control.vue'\nimport FontControl from '../font_control/font_control.vue'\nimport ContrastRatio from '../contrast_ratio/contrast_ratio.vue'\nimport TabSwitcher from '../tab_switcher/tab_switcher.js'\nimport Preview from './preview.vue'\nimport ExportImport from '../export_import/export_import.vue'\n\n// List of color values used in v1\nconst v1OnlyNames = [\n 'bg',\n 'fg',\n 'text',\n 'link',\n 'cRed',\n 'cGreen',\n 'cBlue',\n 'cOrange'\n].map(_ => _ + 'ColorLocal')\n\nexport default {\n data () {\n return {\n availableStyles: [],\n selected: this.$store.state.config.theme,\n\n previewShadows: {},\n previewColors: {},\n previewRadii: {},\n previewFonts: {},\n\n shadowsInvalid: true,\n colorsInvalid: true,\n radiiInvalid: true,\n\n keepColor: false,\n keepShadows: false,\n keepOpacity: false,\n keepRoundness: false,\n keepFonts: false,\n\n textColorLocal: '',\n linkColorLocal: '',\n\n bgColorLocal: '',\n bgOpacityLocal: undefined,\n\n fgColorLocal: '',\n fgTextColorLocal: undefined,\n fgLinkColorLocal: undefined,\n\n btnColorLocal: undefined,\n btnTextColorLocal: undefined,\n btnOpacityLocal: undefined,\n\n inputColorLocal: undefined,\n inputTextColorLocal: undefined,\n inputOpacityLocal: undefined,\n\n panelColorLocal: undefined,\n panelTextColorLocal: undefined,\n panelLinkColorLocal: undefined,\n panelFaintColorLocal: undefined,\n panelOpacityLocal: undefined,\n\n topBarColorLocal: undefined,\n topBarTextColorLocal: undefined,\n topBarLinkColorLocal: undefined,\n\n alertErrorColorLocal: undefined,\n\n badgeOpacityLocal: undefined,\n badgeNotificationColorLocal: undefined,\n\n borderColorLocal: undefined,\n borderOpacityLocal: undefined,\n\n faintColorLocal: undefined,\n faintOpacityLocal: undefined,\n faintLinkColorLocal: undefined,\n\n cRedColorLocal: '',\n cBlueColorLocal: '',\n cGreenColorLocal: '',\n cOrangeColorLocal: '',\n\n shadowSelected: undefined,\n shadowsLocal: {},\n fontsLocal: {},\n\n btnRadiusLocal: '',\n inputRadiusLocal: '',\n checkboxRadiusLocal: '',\n panelRadiusLocal: '',\n avatarRadiusLocal: '',\n avatarAltRadiusLocal: '',\n attachmentRadiusLocal: '',\n tooltipRadiusLocal: ''\n }\n },\n created () {\n const self = this\n\n getThemes().then((themesComplete) => {\n self.availableStyles = themesComplete\n })\n },\n mounted () {\n this.normalizeLocalState(this.$store.state.config.customTheme)\n if (typeof this.shadowSelected === 'undefined') {\n this.shadowSelected = this.shadowsAvailable[0]\n }\n },\n computed: {\n selectedVersion () {\n return Array.isArray(this.selected) ? 1 : 2\n },\n currentColors () {\n return {\n bg: this.bgColorLocal,\n text: this.textColorLocal,\n link: this.linkColorLocal,\n\n fg: this.fgColorLocal,\n fgText: this.fgTextColorLocal,\n fgLink: this.fgLinkColorLocal,\n\n panel: this.panelColorLocal,\n panelText: this.panelTextColorLocal,\n panelLink: this.panelLinkColorLocal,\n panelFaint: this.panelFaintColorLocal,\n\n input: this.inputColorLocal,\n inputText: this.inputTextColorLocal,\n\n topBar: this.topBarColorLocal,\n topBarText: this.topBarTextColorLocal,\n topBarLink: this.topBarLinkColorLocal,\n\n btn: this.btnColorLocal,\n btnText: this.btnTextColorLocal,\n\n alertError: this.alertErrorColorLocal,\n badgeNotification: this.badgeNotificationColorLocal,\n\n faint: this.faintColorLocal,\n faintLink: this.faintLinkColorLocal,\n border: this.borderColorLocal,\n\n cRed: this.cRedColorLocal,\n cBlue: this.cBlueColorLocal,\n cGreen: this.cGreenColorLocal,\n cOrange: this.cOrangeColorLocal\n }\n },\n currentOpacity () {\n return {\n bg: this.bgOpacityLocal,\n btn: this.btnOpacityLocal,\n input: this.inputOpacityLocal,\n panel: this.panelOpacityLocal,\n topBar: this.topBarOpacityLocal,\n border: this.borderOpacityLocal,\n faint: this.faintOpacityLocal\n }\n },\n currentRadii () {\n return {\n btn: this.btnRadiusLocal,\n input: this.inputRadiusLocal,\n checkbox: this.checkboxRadiusLocal,\n panel: this.panelRadiusLocal,\n avatar: this.avatarRadiusLocal,\n avatarAlt: this.avatarAltRadiusLocal,\n tooltip: this.tooltipRadiusLocal,\n attachment: this.attachmentRadiusLocal\n }\n },\n preview () {\n return composePreset(this.previewColors, this.previewRadii, this.previewShadows, this.previewFonts)\n },\n previewTheme () {\n if (!this.preview.theme.colors) return { colors: {}, opacity: {}, radii: {}, shadows: {}, fonts: {} }\n return this.preview.theme\n },\n // This needs optimization maybe\n previewContrast () {\n if (!this.previewTheme.colors.bg) return {}\n const colors = this.previewTheme.colors\n const opacity = this.previewTheme.opacity\n if (!colors.bg) return {}\n const hints = (ratio) => ({\n text: ratio.toPrecision(3) + ':1',\n // AA level, AAA level\n aa: ratio >= 4.5,\n aaa: ratio >= 7,\n // same but for 18pt+ texts\n laa: ratio >= 3,\n laaa: ratio >= 4.5\n })\n\n // fgsfds :DDDD\n const fgs = {\n text: hex2rgb(colors.text),\n panelText: hex2rgb(colors.panelText),\n panelLink: hex2rgb(colors.panelLink),\n btnText: hex2rgb(colors.btnText),\n topBarText: hex2rgb(colors.topBarText),\n inputText: hex2rgb(colors.inputText),\n\n link: hex2rgb(colors.link),\n topBarLink: hex2rgb(colors.topBarLink),\n\n red: hex2rgb(colors.cRed),\n green: hex2rgb(colors.cGreen),\n blue: hex2rgb(colors.cBlue),\n orange: hex2rgb(colors.cOrange)\n }\n\n const bgs = {\n bg: hex2rgb(colors.bg),\n btn: hex2rgb(colors.btn),\n panel: hex2rgb(colors.panel),\n topBar: hex2rgb(colors.topBar),\n input: hex2rgb(colors.input),\n alertError: hex2rgb(colors.alertError),\n badgeNotification: hex2rgb(colors.badgeNotification)\n }\n\n /* This is a bit confusing because \"bottom layer\" used is text color\n * This is done to get worst case scenario when background below transparent\n * layer matches text color, making it harder to read the lower alpha is.\n */\n const ratios = {\n bgText: getContrastRatio(alphaBlend(bgs.bg, opacity.bg, fgs.text), fgs.text),\n bgLink: getContrastRatio(alphaBlend(bgs.bg, opacity.bg, fgs.link), fgs.link),\n bgRed: getContrastRatio(alphaBlend(bgs.bg, opacity.bg, fgs.red), fgs.red),\n bgGreen: getContrastRatio(alphaBlend(bgs.bg, opacity.bg, fgs.green), fgs.green),\n bgBlue: getContrastRatio(alphaBlend(bgs.bg, opacity.bg, fgs.blue), fgs.blue),\n bgOrange: getContrastRatio(alphaBlend(bgs.bg, opacity.bg, fgs.orange), fgs.orange),\n\n tintText: getContrastRatio(alphaBlend(bgs.bg, 0.5, fgs.panelText), fgs.text),\n\n panelText: getContrastRatio(alphaBlend(bgs.panel, opacity.panel, fgs.panelText), fgs.panelText),\n panelLink: getContrastRatio(alphaBlend(bgs.panel, opacity.panel, fgs.panelLink), fgs.panelLink),\n\n btnText: getContrastRatio(alphaBlend(bgs.btn, opacity.btn, fgs.btnText), fgs.btnText),\n\n inputText: getContrastRatio(alphaBlend(bgs.input, opacity.input, fgs.inputText), fgs.inputText),\n\n topBarText: getContrastRatio(alphaBlend(bgs.topBar, opacity.topBar, fgs.topBarText), fgs.topBarText),\n topBarLink: getContrastRatio(alphaBlend(bgs.topBar, opacity.topBar, fgs.topBarLink), fgs.topBarLink)\n }\n\n return Object.entries(ratios).reduce((acc, [k, v]) => { acc[k] = hints(v); return acc }, {})\n },\n previewRules () {\n if (!this.preview.rules) return ''\n return [\n ...Object.values(this.preview.rules),\n 'color: var(--text)',\n 'font-family: var(--interfaceFont, sans-serif)'\n ].join(';')\n },\n shadowsAvailable () {\n return Object.keys(this.previewTheme.shadows).sort()\n },\n currentShadowOverriden: {\n get () {\n return !!this.currentShadow\n },\n set (val) {\n if (val) {\n set(this.shadowsLocal, this.shadowSelected, this.currentShadowFallback.map(_ => Object.assign({}, _)))\n } else {\n del(this.shadowsLocal, this.shadowSelected)\n }\n }\n },\n currentShadowFallback () {\n return this.previewTheme.shadows[this.shadowSelected]\n },\n currentShadow: {\n get () {\n return this.shadowsLocal[this.shadowSelected]\n },\n set (v) {\n set(this.shadowsLocal, this.shadowSelected, v)\n }\n },\n themeValid () {\n return !this.shadowsInvalid && !this.colorsInvalid && !this.radiiInvalid\n },\n exportedTheme () {\n const saveEverything = (\n !this.keepFonts &&\n !this.keepShadows &&\n !this.keepOpacity &&\n !this.keepRoundness &&\n !this.keepColor\n )\n\n const theme = {}\n\n if (this.keepFonts || saveEverything) {\n theme.fonts = this.fontsLocal\n }\n if (this.keepShadows || saveEverything) {\n theme.shadows = this.shadowsLocal\n }\n if (this.keepOpacity || saveEverything) {\n theme.opacity = this.currentOpacity\n }\n if (this.keepColor || saveEverything) {\n theme.colors = this.currentColors\n }\n if (this.keepRoundness || saveEverything) {\n theme.radii = this.currentRadii\n }\n\n return {\n // To separate from other random JSON files and possible future theme formats\n _pleroma_theme_version: 2, theme\n }\n }\n },\n components: {\n ColorInput,\n OpacityInput,\n RangeInput,\n ContrastRatio,\n ShadowControl,\n FontControl,\n TabSwitcher,\n Preview,\n ExportImport\n },\n methods: {\n setCustomTheme () {\n this.$store.dispatch('setOption', {\n name: 'customTheme',\n value: {\n shadows: this.shadowsLocal,\n fonts: this.fontsLocal,\n opacity: this.currentOpacity,\n colors: this.currentColors,\n radii: this.currentRadii\n }\n })\n },\n onImport (parsed) {\n if (parsed._pleroma_theme_version === 1) {\n this.normalizeLocalState(parsed, 1)\n } else if (parsed._pleroma_theme_version === 2) {\n this.normalizeLocalState(parsed.theme, 2)\n }\n },\n importValidator (parsed) {\n const version = parsed._pleroma_theme_version\n return version >= 1 || version <= 2\n },\n clearAll () {\n const state = this.$store.state.config.customTheme\n const version = state.colors ? 2 : 'l1'\n this.normalizeLocalState(this.$store.state.config.customTheme, version)\n },\n\n // Clears all the extra stuff when loading V1 theme\n clearV1 () {\n Object.keys(this.$data)\n .filter(_ => _.endsWith('ColorLocal') || _.endsWith('OpacityLocal'))\n .filter(_ => !v1OnlyNames.includes(_))\n .forEach(key => {\n set(this.$data, key, undefined)\n })\n },\n\n clearRoundness () {\n Object.keys(this.$data)\n .filter(_ => _.endsWith('RadiusLocal'))\n .forEach(key => {\n set(this.$data, key, undefined)\n })\n },\n\n clearOpacity () {\n Object.keys(this.$data)\n .filter(_ => _.endsWith('OpacityLocal'))\n .forEach(key => {\n set(this.$data, key, undefined)\n })\n },\n\n clearShadows () {\n this.shadowsLocal = {}\n },\n\n clearFonts () {\n this.fontsLocal = {}\n },\n\n /**\n * This applies stored theme data onto form. Supports three versions of data:\n * v2 (version = 2) - newer version of themes.\n * v1 (version = 1) - older version of themes (import from file)\n * v1l (version = l1) - older version of theme (load from local storage)\n * v1 and v1l differ because of way themes were stored/exported.\n * @param {Object} input - input data\n * @param {Number} version - version of data. 0 means try to guess based on data. \"l1\" means v1, locastorage type\n */\n normalizeLocalState (input, version = 0) {\n const colors = input.colors || input\n const radii = input.radii || input\n const opacity = input.opacity\n const shadows = input.shadows || {}\n const fonts = input.fonts || {}\n\n if (version === 0) {\n if (input.version) version = input.version\n // Old v1 naming: fg is text, btn is foreground\n if (typeof colors.text === 'undefined' && typeof colors.fg !== 'undefined') {\n version = 1\n }\n // New v2 naming: text is text, fg is foreground\n if (typeof colors.text !== 'undefined' && typeof colors.fg !== 'undefined') {\n version = 2\n }\n }\n\n // Stuff that differs between V1 and V2\n if (version === 1) {\n this.fgColorLocal = rgb2hex(colors.btn)\n this.textColorLocal = rgb2hex(colors.fg)\n }\n\n if (!this.keepColor) {\n this.clearV1()\n const keys = new Set(version !== 1 ? Object.keys(colors) : [])\n if (version === 1 || version === 'l1') {\n keys\n .add('bg')\n .add('link')\n .add('cRed')\n .add('cBlue')\n .add('cGreen')\n .add('cOrange')\n }\n\n keys.forEach(key => {\n this[key + 'ColorLocal'] = rgb2hex(colors[key])\n })\n }\n\n if (!this.keepRoundness) {\n this.clearRoundness()\n Object.entries(radii).forEach(([k, v]) => {\n // 'Radius' is kept mostly for v1->v2 localstorage transition\n const key = k.endsWith('Radius') ? k.split('Radius')[0] : k\n this[key + 'RadiusLocal'] = v\n })\n }\n\n if (!this.keepShadows) {\n this.clearShadows()\n this.shadowsLocal = shadows\n this.shadowSelected = this.shadowsAvailable[0]\n }\n\n if (!this.keepFonts) {\n this.clearFonts()\n this.fontsLocal = fonts\n }\n\n if (opacity && !this.keepOpacity) {\n this.clearOpacity()\n Object.entries(opacity).forEach(([k, v]) => {\n if (typeof v === 'undefined' || v === null || Number.isNaN(v)) return\n this[k + 'OpacityLocal'] = v\n })\n }\n }\n },\n watch: {\n currentRadii () {\n try {\n this.previewRadii = generateRadii({ radii: this.currentRadii })\n this.radiiInvalid = false\n } catch (e) {\n this.radiiInvalid = true\n console.warn(e)\n }\n },\n shadowsLocal: {\n handler () {\n try {\n this.previewShadows = generateShadows({ shadows: this.shadowsLocal })\n this.shadowsInvalid = false\n } catch (e) {\n this.shadowsInvalid = true\n console.warn(e)\n }\n },\n deep: true\n },\n fontsLocal: {\n handler () {\n try {\n this.previewFonts = generateFonts({ fonts: this.fontsLocal })\n this.fontsInvalid = false\n } catch (e) {\n this.fontsInvalid = true\n console.warn(e)\n }\n },\n deep: true\n },\n currentColors () {\n try {\n this.previewColors = generateColors({\n opacity: this.currentOpacity,\n colors: this.currentColors\n })\n this.colorsInvalid = false\n } catch (e) {\n this.colorsInvalid = true\n console.warn(e)\n }\n },\n currentOpacity () {\n try {\n this.previewColors = generateColors({\n opacity: this.currentOpacity,\n colors: this.currentColors\n })\n } catch (e) {\n console.warn(e)\n }\n },\n selected () {\n if (this.selectedVersion === 1) {\n if (!this.keepRoundness) {\n this.clearRoundness()\n }\n\n if (!this.keepShadows) {\n this.clearShadows()\n }\n\n if (!this.keepOpacity) {\n this.clearOpacity()\n }\n\n if (!this.keepColor) {\n this.clearV1()\n\n this.bgColorLocal = this.selected[1]\n this.fgColorLocal = this.selected[2]\n this.textColorLocal = this.selected[3]\n this.linkColorLocal = this.selected[4]\n this.cRedColorLocal = this.selected[5]\n this.cGreenColorLocal = this.selected[6]\n this.cBlueColorLocal = this.selected[7]\n this.cOrangeColorLocal = this.selected[8]\n }\n } else if (this.selectedVersion >= 2) {\n this.normalizeLocalState(this.selected.theme, 2)\n }\n }\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/style_switcher/style_switcher.js","import Timeline from '../timeline/timeline.vue'\n\nconst TagTimeline = {\n created () {\n this.$store.commit('clearTimeline', { timeline: 'tag' })\n this.$store.dispatch('startFetching', { timeline: 'tag', tag: this.tag })\n },\n components: {\n Timeline\n },\n computed: {\n tag () { return this.$route.params.tag },\n timeline () { return this.$store.state.statuses.timelines.tag }\n },\n watch: {\n tag () {\n this.$store.commit('clearTimeline', { timeline: 'tag' })\n this.$store.dispatch('startFetching', { timeline: 'tag', tag: this.tag })\n }\n },\n destroyed () {\n this.$store.dispatch('stopFetching', 'tag')\n }\n}\n\nexport default TagTimeline\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/tag_timeline/tag_timeline.js","const TermsOfServicePanel = {\n computed: {\n content () {\n return this.$store.state.instance.tos\n }\n }\n}\n\nexport default TermsOfServicePanel\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/terms_of_service_panel/terms_of_service_panel.js","import Status from '../status/status.vue'\nimport timelineFetcher from '../../services/timeline_fetcher/timeline_fetcher.service.js'\nimport StatusOrConversation from '../status_or_conversation/status_or_conversation.vue'\nimport { throttle } from 'lodash'\n\nconst Timeline = {\n props: [\n 'timeline',\n 'timelineName',\n 'title',\n 'userId',\n 'tag',\n 'embedded',\n 'count'\n ],\n data () {\n return {\n paused: false,\n unfocused: false,\n bottomedOut: false\n }\n },\n computed: {\n timelineError () { return this.$store.state.statuses.error },\n newStatusCount () {\n return this.timeline.newStatusCount\n },\n newStatusCountStr () {\n if (this.timeline.flushMarker !== 0) {\n return ''\n } else {\n return ` (${this.newStatusCount})`\n }\n },\n classes () {\n return {\n root: ['timeline'].concat(!this.embedded ? ['panel', 'panel-default'] : []),\n header: ['timeline-heading'].concat(!this.embedded ? ['panel-heading'] : []),\n body: ['timeline-body'].concat(!this.embedded ? ['panel-body'] : []),\n footer: ['timeline-footer'].concat(!this.embedded ? ['panel-footer'] : [])\n }\n }\n },\n components: {\n Status,\n StatusOrConversation\n },\n created () {\n const store = this.$store\n const credentials = store.state.users.currentUser.credentials\n const showImmediately = this.timeline.visibleStatuses.length === 0\n\n window.addEventListener('scroll', this.scrollLoad)\n\n if (this.timelineName === 'friends' && !credentials) { return false }\n\n timelineFetcher.fetchAndUpdate({\n store,\n credentials,\n timeline: this.timelineName,\n showImmediately,\n userId: this.userId,\n tag: this.tag\n })\n },\n mounted () {\n if (typeof document.hidden !== 'undefined') {\n document.addEventListener('visibilitychange', this.handleVisibilityChange, false)\n this.unfocused = document.hidden\n }\n window.addEventListener('keydown', this.handleShortKey)\n },\n destroyed () {\n window.removeEventListener('scroll', this.scrollLoad)\n window.removeEventListener('keydown', this.handleShortKey)\n if (typeof document.hidden !== 'undefined') document.removeEventListener('visibilitychange', this.handleVisibilityChange, false)\n this.$store.commit('setLoading', { timeline: this.timelineName, value: false })\n },\n methods: {\n handleShortKey (e) {\n if (e.key === '.') this.showNewStatuses()\n },\n showNewStatuses () {\n if (this.newStatusCount === 0) return\n\n if (this.timeline.flushMarker !== 0) {\n this.$store.commit('clearTimeline', { timeline: this.timelineName })\n this.$store.commit('queueFlush', { timeline: this.timelineName, id: 0 })\n this.fetchOlderStatuses()\n } else {\n this.$store.commit('showNewStatuses', { timeline: this.timelineName })\n this.paused = false\n }\n },\n fetchOlderStatuses: throttle(function () {\n const store = this.$store\n const credentials = store.state.users.currentUser.credentials\n store.commit('setLoading', { timeline: this.timelineName, value: true })\n timelineFetcher.fetchAndUpdate({\n store,\n credentials,\n timeline: this.timelineName,\n older: true,\n showImmediately: true,\n userId: this.userId,\n tag: this.tag\n }).then(statuses => {\n store.commit('setLoading', { timeline: this.timelineName, value: false })\n if (statuses && statuses.length === 0) {\n this.bottomedOut = true\n }\n })\n }, 1000, this),\n scrollLoad (e) {\n const bodyBRect = document.body.getBoundingClientRect()\n const height = Math.max(bodyBRect.height, -(bodyBRect.y))\n if (this.timeline.loading === false &&\n this.$store.state.config.autoLoad &&\n this.$el.offsetHeight > 0 &&\n (window.innerHeight + window.pageYOffset) >= (height - 750)) {\n this.fetchOlderStatuses()\n }\n },\n handleVisibilityChange () {\n this.unfocused = document.hidden\n }\n },\n watch: {\n newStatusCount (count) {\n if (!this.$store.state.config.streaming) {\n return\n }\n if (count > 0) {\n // only 'stream' them when you're scrolled to the top\n const doc = document.documentElement\n const top = (window.pageYOffset || doc.scrollTop) - (doc.clientTop || 0)\n if (top < 15 &&\n !this.paused &&\n !(this.unfocused && this.$store.state.config.pauseOnUnfocused)\n ) {\n this.showNewStatuses()\n } else {\n this.paused = true\n }\n }\n }\n }\n}\n\nexport default Timeline\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/timeline/timeline.js","import StillImage from '../still-image/still-image.vue'\n\nconst UserAvatar = {\n props: [\n 'src',\n 'betterShadow',\n 'compact'\n ],\n data () {\n return {\n showPlaceholder: false\n }\n },\n components: {\n StillImage\n },\n computed: {\n imgSrc () {\n return this.showPlaceholder ? '/images/avi.png' : this.src\n }\n },\n methods: {\n imageLoadError () {\n this.showPlaceholder = true\n }\n }\n}\n\nexport default UserAvatar\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/user_avatar/user_avatar.js","import UserAvatar from '../user_avatar/user_avatar.vue'\nimport { hex2rgb } from '../../services/color_convert/color_convert.js'\nimport { requestFollow, requestUnfollow } from '../../services/follow_manipulate/follow_manipulate'\nimport generateProfileLink from 'src/services/user_profile_link_generator/user_profile_link_generator'\n\nexport default {\n props: [ 'user', 'switcher', 'selected', 'hideBio', 'rounded', 'bordered' ],\n data () {\n return {\n followRequestInProgress: false,\n followRequestSent: false,\n hideUserStatsLocal: typeof this.$store.state.config.hideUserStats === 'undefined'\n ? this.$store.state.instance.hideUserStats\n : this.$store.state.config.hideUserStats,\n betterShadow: this.$store.state.interface.browserSupport.cssFilter\n }\n },\n computed: {\n classes () {\n return [{\n 'user-card-rounded-t': this.rounded === 'top', // set border-top-left-radius and border-top-right-radius\n 'user-card-rounded': this.rounded === true, // set border-radius for all sides\n 'user-card-bordered': this.bordered === true // set border for all sides\n }]\n },\n style () {\n const color = this.$store.state.config.customTheme.colors\n ? this.$store.state.config.customTheme.colors.bg // v2\n : this.$store.state.config.colors.bg // v1\n\n if (color) {\n const rgb = (typeof color === 'string') ? hex2rgb(color) : color\n const tintColor = `rgba(${Math.floor(rgb.r)}, ${Math.floor(rgb.g)}, ${Math.floor(rgb.b)}, .5)`\n\n const gradient = [\n [tintColor, this.hideBio ? '60%' : ''],\n this.hideBio ? [\n color, '100%'\n ] : [\n tintColor, ''\n ]\n ].map(_ => _.join(' ')).join(', ')\n\n return {\n backgroundColor: `rgb(${Math.floor(rgb.r * 0.53)}, ${Math.floor(rgb.g * 0.56)}, ${Math.floor(rgb.b * 0.59)})`,\n backgroundImage: [\n `linear-gradient(to bottom, ${gradient})`,\n `url(${this.user.cover_photo})`\n ].join(', ')\n }\n }\n },\n isOtherUser () {\n return this.user.id !== this.$store.state.users.currentUser.id\n },\n subscribeUrl () {\n // eslint-disable-next-line no-undef\n const serverUrl = new URL(this.user.statusnet_profile_url)\n return `${serverUrl.protocol}//${serverUrl.host}/main/ostatus`\n },\n loggedIn () {\n return this.$store.state.users.currentUser\n },\n dailyAvg () {\n const days = Math.ceil((new Date() - new Date(this.user.created_at)) / (60 * 60 * 24 * 1000))\n return Math.round(this.user.statuses_count / days)\n },\n userHighlightType: {\n get () {\n const data = this.$store.state.config.highlight[this.user.screen_name]\n return data && data.type || 'disabled'\n },\n set (type) {\n const data = this.$store.state.config.highlight[this.user.screen_name]\n if (type !== 'disabled') {\n this.$store.dispatch('setHighlight', { user: this.user.screen_name, color: data && data.color || '#FFFFFF', type })\n } else {\n this.$store.dispatch('setHighlight', { user: this.user.screen_name, color: undefined })\n }\n }\n },\n userHighlightColor: {\n get () {\n const data = this.$store.state.config.highlight[this.user.screen_name]\n return data && data.color\n },\n set (color) {\n this.$store.dispatch('setHighlight', { user: this.user.screen_name, color })\n }\n },\n visibleRole () {\n const validRole = (this.user.role === 'admin' || this.user.role === 'moderator')\n const showRole = this.isOtherUser || this.user.show_role\n\n return validRole && showRole && this.user.role\n }\n },\n components: {\n UserAvatar\n },\n methods: {\n followUser () {\n const store = this.$store\n this.followRequestInProgress = true\n requestFollow(this.user, store).then(({sent}) => {\n this.followRequestInProgress = false\n this.followRequestSent = sent\n })\n },\n unfollowUser () {\n const store = this.$store\n this.followRequestInProgress = true\n requestUnfollow(this.user, store).then(() => {\n this.followRequestInProgress = false\n store.commit('removeStatus', { timeline: 'friends', userId: this.user.id })\n })\n },\n blockUser () {\n const store = this.$store\n store.state.api.backendInteractor.blockUser(this.user.id)\n .then((blockedUser) => {\n store.commit('addNewUsers', [blockedUser])\n store.commit('removeStatus', { timeline: 'friends', userId: this.user.id })\n store.commit('removeStatus', { timeline: 'public', userId: this.user.id })\n store.commit('removeStatus', { timeline: 'publicAndExternal', userId: this.user.id })\n })\n },\n unblockUser () {\n const store = this.$store\n store.state.api.backendInteractor.unblockUser(this.user.id)\n .then((unblockedUser) => store.commit('addNewUsers', [unblockedUser]))\n },\n toggleMute () {\n const store = this.$store\n store.commit('setMuted', {user: this.user, muted: !this.user.muted})\n store.state.api.backendInteractor.setUserMute(this.user)\n },\n setProfileView (v) {\n if (this.switcher) {\n const store = this.$store\n store.commit('setProfileView', { v })\n }\n },\n linkClicked ({target}) {\n if (target.tagName === 'SPAN') {\n target = target.parentNode\n }\n if (target.tagName === 'A') {\n window.open(target.href, '_blank')\n }\n },\n userProfileLink (user) {\n return generateProfileLink(user.id, user.screen_name, this.$store.state.instance.restrictedNicknames)\n }\n }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/user_card/user_card.js","const UserFinder = {\n data: () => ({\n username: undefined,\n hidden: true,\n error: false,\n loading: false\n }),\n methods: {\n findUser (username) {\n this.$router.push({ name: 'user-search', query: { query: username } })\n this.$refs.userSearchInput.focus()\n },\n toggleHidden () {\n this.hidden = !this.hidden\n this.$emit('toggled', this.hidden)\n }\n }\n}\n\nexport default UserFinder\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/user_finder/user_finder.js","import LoginForm from '../login_form/login_form.vue'\nimport PostStatusForm from '../post_status_form/post_status_form.vue'\nimport UserCard from '../user_card/user_card.vue'\n\nconst UserPanel = {\n computed: {\n user () { return this.$store.state.users.currentUser }\n },\n components: {\n LoginForm,\n PostStatusForm,\n UserCard\n }\n}\n\nexport default UserPanel\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/user_panel/user_panel.js","import { compose } from 'vue-compose'\nimport get from 'lodash/get'\nimport UserCard from '../user_card/user_card.vue'\nimport FollowCard from '../follow_card/follow_card.vue'\nimport Timeline from '../timeline/timeline.vue'\nimport withLoadMore from '../../hocs/with_load_more/with_load_more'\nimport withList from '../../hocs/with_list/with_list'\n\nconst FollowerList = compose(\n withLoadMore({\n fetch: (props, $store) => $store.dispatch('addFollowers', props.userId),\n select: (props, $store) => get($store.getters.userById(props.userId), 'followers', []),\n destory: (props, $store) => $store.dispatch('clearFollowers', props.userId),\n childPropName: 'entries',\n additionalPropNames: ['userId']\n }),\n withList({ getEntryProps: user => ({ user }) })\n)(FollowCard)\n\nconst FriendList = compose(\n withLoadMore({\n fetch: (props, $store) => $store.dispatch('addFriends', props.userId),\n select: (props, $store) => get($store.getters.userById(props.userId), 'friends', []),\n destory: (props, $store) => $store.dispatch('clearFriends', props.userId),\n childPropName: 'entries',\n additionalPropNames: ['userId']\n }),\n withList({ getEntryProps: user => ({ user }) })\n)(FollowCard)\n\nconst UserProfile = {\n data () {\n return {\n error: false\n }\n },\n created () {\n this.$store.commit('clearTimeline', { timeline: 'user' })\n this.$store.commit('clearTimeline', { timeline: 'favorites' })\n this.$store.commit('clearTimeline', { timeline: 'media' })\n this.$store.dispatch('startFetching', { timeline: 'user', userId: this.fetchBy })\n this.$store.dispatch('startFetching', { timeline: 'media', userId: this.fetchBy })\n this.startFetchFavorites()\n if (!this.user.id) {\n this.$store.dispatch('fetchUser', this.fetchBy)\n .catch((reason) => {\n const errorMessage = get(reason, 'error.error')\n if (errorMessage === 'No user with such user_id') { // Known error\n this.error = this.$t('user_profile.profile_does_not_exist')\n } else if (errorMessage) {\n this.error = errorMessage\n } else {\n this.error = this.$t('user_profile.profile_loading_error')\n }\n })\n }\n },\n destroyed () {\n this.cleanUp()\n },\n computed: {\n timeline () {\n return this.$store.state.statuses.timelines.user\n },\n favorites () {\n return this.$store.state.statuses.timelines.favorites\n },\n media () {\n return this.$store.state.statuses.timelines.media\n },\n userId () {\n return this.$route.params.id || this.user.id\n },\n userName () {\n return this.$route.params.name || this.user.screen_name\n },\n isUs () {\n return this.userId && this.$store.state.users.currentUser.id &&\n this.userId === this.$store.state.users.currentUser.id\n },\n userInStore () {\n if (this.isExternal) {\n return this.$store.getters.userById(this.userId)\n }\n return this.$store.getters.userByName(this.userName)\n },\n user () {\n if (this.timeline.statuses[0]) {\n return this.timeline.statuses[0].user\n }\n if (this.userInStore) {\n return this.userInStore\n }\n return {}\n },\n fetchBy () {\n return this.isExternal ? this.userId : this.userName\n },\n isExternal () {\n return this.$route.name === 'external-user-profile'\n },\n followsTabVisible () {\n return this.isUs || !this.user.hide_follows\n },\n followersTabVisible () {\n return this.isUs || !this.user.hide_followers\n }\n },\n methods: {\n startFetchFavorites () {\n if (this.isUs) {\n this.$store.dispatch('startFetching', { timeline: 'favorites', userId: this.fetchBy })\n }\n },\n startUp () {\n this.$store.dispatch('startFetching', { timeline: 'user', userId: this.fetchBy })\n this.$store.dispatch('startFetching', { timeline: 'media', userId: this.fetchBy })\n\n this.startFetchFavorites()\n },\n cleanUp () {\n this.$store.dispatch('stopFetching', 'user')\n this.$store.dispatch('stopFetching', 'favorites')\n this.$store.dispatch('stopFetching', 'media')\n this.$store.commit('clearTimeline', { timeline: 'user' })\n this.$store.commit('clearTimeline', { timeline: 'favorites' })\n this.$store.commit('clearTimeline', { timeline: 'media' })\n }\n },\n watch: {\n userName () {\n if (this.isExternal) {\n return\n }\n this.cleanUp()\n this.startUp()\n },\n userId () {\n if (!this.isExternal) {\n return\n }\n this.cleanUp()\n this.startUp()\n },\n $route () {\n this.$refs.tabSwitcher.activateTab(0)()\n }\n },\n components: {\n UserCard,\n Timeline,\n FollowerList,\n FriendList\n }\n}\n\nexport default UserProfile\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/user_profile/user_profile.js","import FollowCard from '../follow_card/follow_card.vue'\nimport userSearchApi from '../../services/new_api/user_search.js'\nconst userSearch = {\n components: {\n FollowCard\n },\n props: [\n 'query'\n ],\n data () {\n return {\n username: '',\n users: [],\n loading: false\n }\n },\n mounted () {\n this.search(this.query)\n },\n watch: {\n query (newV) {\n this.search(newV)\n }\n },\n methods: {\n newQuery (query) {\n this.$router.push({ name: 'user-search', query: { query } })\n this.$refs.userSearchInput.focus()\n },\n search (query) {\n if (!query) {\n this.users = []\n return\n }\n this.loading = true\n userSearchApi.search({query, store: this.$store})\n .then((res) => {\n this.loading = false\n this.users = res\n })\n }\n }\n}\n\nexport default userSearch\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/user_search/user_search.js","import { compose } from 'vue-compose'\nimport unescape from 'lodash/unescape'\nimport get from 'lodash/get'\nimport TabSwitcher from '../tab_switcher/tab_switcher.js'\nimport ImageCropper from '../image_cropper/image_cropper.vue'\nimport StyleSwitcher from '../style_switcher/style_switcher.vue'\nimport fileSizeFormatService from '../../services/file_size_format/file_size_format.js'\nimport BlockCard from '../block_card/block_card.vue'\nimport MuteCard from '../mute_card/mute_card.vue'\nimport withSubscription from '../../hocs/with_subscription/with_subscription'\nimport withList from '../../hocs/with_list/with_list'\n\nconst BlockList = compose(\n withSubscription({\n fetch: (props, $store) => $store.dispatch('fetchBlocks'),\n select: (props, $store) => get($store.state.users.currentUser, 'blockIds', []),\n childPropName: 'entries'\n }),\n withList({ getEntryProps: userId => ({ userId }) })\n)(BlockCard)\n\nconst MuteList = compose(\n withSubscription({\n fetch: (props, $store) => $store.dispatch('fetchMutes'),\n select: (props, $store) => get($store.state.users.currentUser, 'muteIds', []),\n childPropName: 'entries'\n }),\n withList({ getEntryProps: userId => ({ userId }) })\n)(MuteCard)\n\nconst UserSettings = {\n data () {\n return {\n newName: this.$store.state.users.currentUser.name,\n newBio: unescape(this.$store.state.users.currentUser.description),\n newLocked: this.$store.state.users.currentUser.locked,\n newNoRichText: this.$store.state.users.currentUser.no_rich_text,\n newDefaultScope: this.$store.state.users.currentUser.default_scope,\n hideFollows: this.$store.state.users.currentUser.hide_follows,\n hideFollowers: this.$store.state.users.currentUser.hide_followers,\n showRole: this.$store.state.users.currentUser.show_role,\n role: this.$store.state.users.currentUser.role,\n followList: null,\n followImportError: false,\n followsImported: false,\n enableFollowsExport: true,\n pickAvatarBtnVisible: true,\n bannerUploading: false,\n backgroundUploading: false,\n followListUploading: false,\n bannerPreview: null,\n backgroundPreview: null,\n bannerUploadError: null,\n backgroundUploadError: null,\n deletingAccount: false,\n deleteAccountConfirmPasswordInput: '',\n deleteAccountError: false,\n changePasswordInputs: [ '', '', '' ],\n changedPassword: false,\n changePasswordError: false,\n activeTab: 'profile'\n }\n },\n created () {\n this.$store.dispatch('fetchTokens')\n },\n components: {\n StyleSwitcher,\n TabSwitcher,\n ImageCropper,\n BlockList,\n MuteList\n },\n computed: {\n user () {\n return this.$store.state.users.currentUser\n },\n pleromaBackend () {\n return this.$store.state.instance.pleromaBackend\n },\n scopeOptionsEnabled () {\n return this.$store.state.instance.scopeOptionsEnabled\n },\n vis () {\n return {\n public: { selected: this.newDefaultScope === 'public' },\n unlisted: { selected: this.newDefaultScope === 'unlisted' },\n private: { selected: this.newDefaultScope === 'private' },\n direct: { selected: this.newDefaultScope === 'direct' }\n }\n },\n currentSaveStateNotice () {\n return this.$store.state.interface.settings.currentSaveStateNotice\n },\n oauthTokens () {\n return this.$store.state.oauthTokens.tokens.map(oauthToken => {\n return {\n id: oauthToken.id,\n appName: oauthToken.app_name,\n validUntil: new Date(oauthToken.valid_until).toLocaleDateString()\n }\n })\n }\n },\n methods: {\n updateProfile () {\n const name = this.newName\n const description = this.newBio\n const locked = this.newLocked\n // Backend notation.\n /* eslint-disable camelcase */\n const default_scope = this.newDefaultScope\n const no_rich_text = this.newNoRichText\n const hide_follows = this.hideFollows\n const hide_followers = this.hideFollowers\n const show_role = this.showRole\n\n /* eslint-enable camelcase */\n this.$store.state.api.backendInteractor\n .updateProfile({\n params: {\n name,\n description,\n locked,\n // Backend notation.\n /* eslint-disable camelcase */\n default_scope,\n no_rich_text,\n hide_follows,\n hide_followers,\n show_role\n /* eslint-enable camelcase */\n }}).then((user) => {\n if (!user.error) {\n this.$store.commit('addNewUsers', [user])\n this.$store.commit('setCurrentUser', user)\n }\n })\n },\n changeVis (visibility) {\n this.newDefaultScope = visibility\n },\n uploadFile (slot, e) {\n const file = e.target.files[0]\n if (!file) { return }\n if (file.size > this.$store.state.instance[slot + 'limit']) {\n const filesize = fileSizeFormatService.fileSizeFormat(file.size)\n const allowedsize = fileSizeFormatService.fileSizeFormat(this.$store.state.instance[slot + 'limit'])\n this[slot + 'UploadError'] = this.$t('upload.error.base') + ' ' + this.$t('upload.error.file_too_big', {filesize: filesize.num, filesizeunit: filesize.unit, allowedsize: allowedsize.num, allowedsizeunit: allowedsize.unit})\n return\n }\n // eslint-disable-next-line no-undef\n const reader = new FileReader()\n reader.onload = ({target}) => {\n const img = target.result\n this[slot + 'Preview'] = img\n }\n reader.readAsDataURL(file)\n },\n submitAvatar (cropper, file) {\n const img = cropper.getCroppedCanvas().toDataURL(file.type)\n return this.$store.state.api.backendInteractor.updateAvatar({ params: { img } }).then((user) => {\n if (!user.error) {\n this.$store.commit('addNewUsers', [user])\n this.$store.commit('setCurrentUser', user)\n } else {\n throw new Error(this.$t('upload.error.base') + user.error)\n }\n })\n },\n clearUploadError (slot) {\n this[slot + 'UploadError'] = null\n },\n submitBanner () {\n if (!this.bannerPreview) { return }\n\n let banner = this.bannerPreview\n // eslint-disable-next-line no-undef\n let imginfo = new Image()\n /* eslint-disable camelcase */\n let offset_top, offset_left, width, height\n imginfo.src = banner\n width = imginfo.width\n height = imginfo.height\n offset_top = 0\n offset_left = 0\n this.bannerUploading = true\n this.$store.state.api.backendInteractor.updateBanner({params: {banner, offset_top, offset_left, width, height}}).then((data) => {\n if (!data.error) {\n let clone = JSON.parse(JSON.stringify(this.$store.state.users.currentUser))\n clone.cover_photo = data.url\n this.$store.commit('addNewUsers', [clone])\n this.$store.commit('setCurrentUser', clone)\n this.bannerPreview = null\n } else {\n this.bannerUploadError = this.$t('upload.error.base') + data.error\n }\n this.bannerUploading = false\n })\n /* eslint-enable camelcase */\n },\n submitBg () {\n if (!this.backgroundPreview) { return }\n let img = this.backgroundPreview\n // eslint-disable-next-line no-undef\n let imginfo = new Image()\n let cropX, cropY, cropW, cropH\n imginfo.src = img\n cropX = 0\n cropY = 0\n cropW = imginfo.width\n cropH = imginfo.width\n this.backgroundUploading = true\n this.$store.state.api.backendInteractor.updateBg({params: {img, cropX, cropY, cropW, cropH}}).then((data) => {\n if (!data.error) {\n let clone = JSON.parse(JSON.stringify(this.$store.state.users.currentUser))\n clone.background_image = data.url\n this.$store.commit('addNewUsers', [clone])\n this.$store.commit('setCurrentUser', clone)\n this.backgroundPreview = null\n } else {\n this.backgroundUploadError = this.$t('upload.error.base') + data.error\n }\n this.backgroundUploading = false\n })\n },\n importFollows () {\n this.followListUploading = true\n const followList = this.followList\n this.$store.state.api.backendInteractor.followImport({params: followList})\n .then((status) => {\n if (status) {\n this.followsImported = true\n } else {\n this.followImportError = true\n }\n this.followListUploading = false\n })\n },\n /* This function takes an Array of Users\n * and outputs a file with all the addresses for the user to download\n */\n exportPeople (users, filename) {\n // Get all the friends addresses\n var UserAddresses = users.map(function (user) {\n // check is it's a local user\n if (user && user.is_local) {\n // append the instance address\n // eslint-disable-next-line no-undef\n user.screen_name += '@' + location.hostname\n }\n return user.screen_name\n }).join('\\n')\n // Make the user download the file\n var fileToDownload = document.createElement('a')\n fileToDownload.setAttribute('href', 'data:text/plain;charset=utf-8,' + encodeURIComponent(UserAddresses))\n fileToDownload.setAttribute('download', filename)\n fileToDownload.style.display = 'none'\n document.body.appendChild(fileToDownload)\n fileToDownload.click()\n document.body.removeChild(fileToDownload)\n },\n exportFollows () {\n this.enableFollowsExport = false\n this.$store.state.api.backendInteractor\n .exportFriends({\n id: this.$store.state.users.currentUser.id\n })\n .then((friendList) => {\n this.exportPeople(friendList, 'friends.csv')\n setTimeout(() => { this.enableFollowsExport = true }, 2000)\n })\n },\n followListChange () {\n // eslint-disable-next-line no-undef\n let formData = new FormData()\n formData.append('list', this.$refs.followlist.files[0])\n this.followList = formData\n },\n dismissImported () {\n this.followsImported = false\n this.followImportError = false\n },\n confirmDelete () {\n this.deletingAccount = true\n },\n deleteAccount () {\n this.$store.state.api.backendInteractor.deleteAccount({password: this.deleteAccountConfirmPasswordInput})\n .then((res) => {\n if (res.status === 'success') {\n this.$store.dispatch('logout')\n this.$router.push({name: 'root'})\n } else {\n this.deleteAccountError = res.error\n }\n })\n },\n changePassword () {\n const params = {\n password: this.changePasswordInputs[0],\n newPassword: this.changePasswordInputs[1],\n newPasswordConfirmation: this.changePasswordInputs[2]\n }\n this.$store.state.api.backendInteractor.changePassword(params)\n .then((res) => {\n if (res.status === 'success') {\n this.changedPassword = true\n this.changePasswordError = false\n this.logout()\n } else {\n this.changedPassword = false\n this.changePasswordError = res.error\n }\n })\n },\n activateTab (tabName) {\n this.activeTab = tabName\n },\n logout () {\n this.$store.dispatch('logout')\n this.$router.replace('/')\n },\n revokeToken (id) {\n if (window.confirm(`${this.$i18n.t('settings.revoke_token')}?`)) {\n this.$store.dispatch('revokeToken', id)\n }\n }\n }\n}\n\nexport default UserSettings\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/user_settings/user_settings.js","\nconst VideoAttachment = {\n props: ['attachment', 'controls'],\n data () {\n return {\n loopVideo: this.$store.state.config.loopVideo\n }\n },\n methods: {\n onVideoDataLoad (e) {\n const target = e.srcElement || e.target\n if (typeof target.webkitAudioDecodedByteCount !== 'undefined') {\n // non-zero if video has audio track\n if (target.webkitAudioDecodedByteCount > 0) {\n this.loopVideo = this.loopVideo && !this.$store.state.config.loopVideoSilentOnly\n }\n } else if (typeof target.mozHasAudio !== 'undefined') {\n // true if video has audio track\n if (target.mozHasAudio) {\n this.loopVideo = this.loopVideo && !this.$store.state.config.loopVideoSilentOnly\n }\n } else if (typeof target.audioTracks !== 'undefined') {\n if (target.audioTracks.length > 0) {\n this.loopVideo = this.loopVideo && !this.$store.state.config.loopVideoSilentOnly\n }\n }\n }\n }\n}\n\nexport default VideoAttachment\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/video_attachment/video_attachment.js","import apiService from '../../services/api/api.service.js'\nimport FollowCard from '../follow_card/follow_card.vue'\n\nconst WhoToFollow = {\n components: {\n FollowCard\n },\n data () {\n return {\n users: []\n }\n },\n mounted () {\n this.getWhoToFollow()\n },\n methods: {\n showWhoToFollow (reply) {\n reply.forEach((i, index) => {\n const user = {\n id: 0,\n name: i.display_name,\n screen_name: i.acct,\n profile_image_url: i.avatar || '/images/avi.png'\n }\n this.users.push(user)\n\n this.$store.state.api.backendInteractor.externalProfile(user.screen_name)\n .then((externalUser) => {\n if (!externalUser.error) {\n this.$store.commit('addNewUsers', [externalUser])\n user.id = externalUser.id\n }\n })\n })\n },\n getWhoToFollow () {\n const credentials = this.$store.state.users.currentUser.credentials\n if (credentials) {\n apiService.suggestions({credentials: credentials})\n .then((reply) => {\n this.showWhoToFollow(reply)\n })\n }\n }\n }\n}\n\nexport default WhoToFollow\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/who_to_follow/who_to_follow.js","import apiService from '../../services/api/api.service.js'\nimport generateProfileLink from 'src/services/user_profile_link_generator/user_profile_link_generator'\nimport { shuffle } from 'lodash'\n\nfunction showWhoToFollow (panel, reply) {\n const shuffled = shuffle(reply)\n\n panel.usersToFollow.forEach((toFollow, index) => {\n let user = shuffled[index]\n let img = user.avatar || '/images/avi.png'\n let name = user.acct\n\n toFollow.img = img\n toFollow.name = name\n\n panel.$store.state.api.backendInteractor.externalProfile(name)\n .then((externalUser) => {\n if (!externalUser.error) {\n panel.$store.commit('addNewUsers', [externalUser])\n toFollow.id = externalUser.id\n }\n })\n })\n}\n\nfunction getWhoToFollow (panel) {\n var credentials = panel.$store.state.users.currentUser.credentials\n if (credentials) {\n panel.usersToFollow.forEach(toFollow => {\n toFollow.name = 'Loading...'\n })\n apiService.suggestions({credentials: credentials})\n .then((reply) => {\n showWhoToFollow(panel, reply)\n })\n }\n}\n\nconst WhoToFollowPanel = {\n data: () => ({\n usersToFollow: new Array(3).fill().map(x => (\n {\n img: '/images/avi.png',\n name: '',\n id: 0\n }\n ))\n }),\n computed: {\n user: function () {\n return this.$store.state.users.currentUser.screen_name\n },\n suggestionsEnabled () {\n return this.$store.state.instance.suggestionsEnabled\n }\n },\n methods: {\n userProfileLink (id, name) {\n return generateProfileLink(id, name, this.$store.state.instance.restrictedNicknames)\n }\n },\n watch: {\n user: function (user, oldUser) {\n if (this.suggestionsEnabled) {\n getWhoToFollow(this)\n }\n }\n },\n mounted:\n function () {\n if (this.suggestionsEnabled) {\n getWhoToFollow(this)\n }\n }\n}\n\nexport default WhoToFollowPanel\n\n\n\n// WEBPACK FOOTER //\n// ./src/components/who_to_follow_panel/who_to_follow_panel.js","module.exports = {\"chat\":{\"title\":\"الدردشة\"},\"features_panel\":{\"chat\":\"الدردشة\",\"gopher\":\"غوفر\",\"media_proxy\":\"بروكسي الوسائط\",\"scope_options\":\"\",\"text_limit\":\"الحد الأقصى للنص\",\"title\":\"الميّزات\",\"who_to_follow\":\"للمتابعة\"},\"finder\":{\"error_fetching_user\":\"خطأ أثناء جلب صفحة المستخدم\",\"find_user\":\"البحث عن مستخدِم\"},\"general\":{\"apply\":\"تطبيق\",\"submit\":\"إرسال\"},\"login\":{\"login\":\"تسجيل الدخول\",\"logout\":\"الخروج\",\"password\":\"الكلمة السرية\",\"placeholder\":\"مثال lain\",\"register\":\"انشاء حساب\",\"username\":\"إسم المستخدم\"},\"nav\":{\"chat\":\"الدردشة المحلية\",\"friend_requests\":\"طلبات المتابَعة\",\"mentions\":\"الإشارات\",\"public_tl\":\"الخيط الزمني العام\",\"timeline\":\"الخيط الزمني\",\"twkn\":\"كافة الشبكة المعروفة\"},\"notifications\":{\"broken_favorite\":\"منشور مجهول، جارٍ البحث عنه…\",\"favorited_you\":\"أعجِب بمنشورك\",\"followed_you\":\"يُتابعك\",\"load_older\":\"تحميل الإشعارات الأقدم\",\"notifications\":\"الإخطارات\",\"read\":\"مقروء!\",\"repeated_you\":\"شارَك منشورك\"},\"post_status\":{\"account_not_locked_warning\":\"\",\"account_not_locked_warning_link\":\"مقفل\",\"attachments_sensitive\":\"اعتبر المرفقات كلها كمحتوى حساس\",\"content_type\":{\"plain_text\":\"نص صافٍ\"},\"content_warning\":\"الموضوع (اختياري)\",\"default\":\"وصلت للتوّ إلى لوس أنجلس.\",\"direct_warning\":\"\",\"posting\":\"النشر\",\"scope\":{\"direct\":\"\",\"private\":\"\",\"public\":\"علني - يُنشر على الخيوط الزمنية العمومية\",\"unlisted\":\"غير مُدرَج - لا يُنشَر على الخيوط الزمنية العمومية\"}},\"registration\":{\"bio\":\"السيرة الذاتية\",\"email\":\"عنوان البريد الإلكتروني\",\"fullname\":\"الإسم المعروض\",\"password_confirm\":\"تأكيد الكلمة السرية\",\"registration\":\"التسجيل\",\"token\":\"رمز الدعوة\"},\"settings\":{\"attachmentRadius\":\"المُرفَقات\",\"attachments\":\"المُرفَقات\",\"autoload\":\"\",\"avatar\":\"الصورة الرمزية\",\"avatarAltRadius\":\"الصور الرمزية (الإشعارات)\",\"avatarRadius\":\"الصور الرمزية\",\"background\":\"الخلفية\",\"bio\":\"السيرة الذاتية\",\"btnRadius\":\"الأزرار\",\"cBlue\":\"أزرق (الرد، المتابَعة)\",\"cGreen\":\"أخضر (إعادة النشر)\",\"cOrange\":\"برتقالي (مفضلة)\",\"cRed\":\"أحمر (إلغاء)\",\"change_password\":\"تغيير كلمة السر\",\"change_password_error\":\"وقع هناك خلل أثناء تعديل كلمتك السرية.\",\"changed_password\":\"تم تغيير كلمة المرور بنجاح!\",\"collapse_subject\":\"\",\"confirm_new_password\":\"تأكيد كلمة السر الجديدة\",\"current_avatar\":\"صورتك الرمزية الحالية\",\"current_password\":\"كلمة السر الحالية\",\"current_profile_banner\":\"الرأسية الحالية لصفحتك الشخصية\",\"data_import_export_tab\":\"تصدير واستيراد البيانات\",\"default_vis\":\"أسلوب العرض الافتراضي\",\"delete_account\":\"حذف الحساب\",\"delete_account_description\":\"حذف حسابك و كافة منشوراتك نهائيًا.\",\"delete_account_error\":\"\",\"delete_account_instructions\":\"يُرجى إدخال كلمتك السرية أدناه لتأكيد عملية حذف الحساب.\",\"export_theme\":\"حفظ النموذج\",\"filtering\":\"التصفية\",\"filtering_explanation\":\"سيتم إخفاء كافة المنشورات التي تحتوي على هذه الكلمات، كلمة واحدة في كل سطر\",\"follow_export\":\"تصدير الاشتراكات\",\"follow_export_button\":\"تصدير الاشتراكات كملف csv\",\"follow_export_processing\":\"التصدير جارٍ، سوف يُطلَب منك تنزيل ملفك بعد حين\",\"follow_import\":\"استيراد الاشتراكات\",\"follow_import_error\":\"خطأ أثناء استيراد المتابِعين\",\"follows_imported\":\"\",\"foreground\":\"الأمامية\",\"general\":\"الإعدادات العامة\",\"hide_attachments_in_convo\":\"إخفاء المرفقات على المحادثات\",\"hide_attachments_in_tl\":\"إخفاء المرفقات على الخيط الزمني\",\"hide_post_stats\":\"\",\"hide_user_stats\":\"\",\"import_followers_from_a_csv_file\":\"\",\"import_theme\":\"تحميل نموذج\",\"inputRadius\":\"\",\"instance_default\":\"\",\"interfaceLanguage\":\"لغة الواجهة\",\"invalid_theme_imported\":\"\",\"limited_availability\":\"غير متوفر على متصفحك\",\"links\":\"الروابط\",\"lock_account_description\":\"\",\"loop_video\":\"\",\"loop_video_silent_only\":\"\",\"name\":\"الاسم\",\"name_bio\":\"الاسم والسيرة الذاتية\",\"new_password\":\"كلمة السر الجديدة\",\"no_rich_text_description\":\"\",\"notification_visibility\":\"نوع الإشعارات التي تريد عرضها\",\"notification_visibility_follows\":\"يتابع\",\"notification_visibility_likes\":\"الإعجابات\",\"notification_visibility_mentions\":\"الإشارات\",\"notification_visibility_repeats\":\"\",\"nsfw_clickthrough\":\"\",\"oauth_tokens\":\"رموز OAuth\",\"token\":\"رمز\",\"refresh_token\":\"رمز التحديث\",\"valid_until\":\"صالح حتى\",\"revoke_token\":\"سحب\",\"panelRadius\":\"\",\"pause_on_unfocused\":\"\",\"presets\":\"النماذج\",\"profile_background\":\"خلفية الصفحة الشخصية\",\"profile_banner\":\"رأسية الصفحة الشخصية\",\"profile_tab\":\"الملف الشخصي\",\"radii_help\":\"\",\"replies_in_timeline\":\"الردود على الخيط الزمني\",\"reply_link_preview\":\"\",\"reply_visibility_all\":\"عرض كافة الردود\",\"reply_visibility_following\":\"\",\"reply_visibility_self\":\"\",\"saving_err\":\"خطأ أثناء حفظ الإعدادات\",\"saving_ok\":\"تم حفظ الإعدادات\",\"security_tab\":\"الأمان\",\"set_new_avatar\":\"اختيار صورة رمزية جديدة\",\"set_new_profile_background\":\"اختيار خلفية جديدة للملف الشخصي\",\"set_new_profile_banner\":\"اختيار رأسية جديدة للصفحة الشخصية\",\"settings\":\"الإعدادات\",\"stop_gifs\":\"\",\"streaming\":\"\",\"text\":\"النص\",\"theme\":\"المظهر\",\"theme_help\":\"\",\"tooltipRadius\":\"\",\"user_settings\":\"إعدادات المستخدم\",\"values\":{\"false\":\"لا\",\"true\":\"نعم\"}},\"timeline\":{\"collapse\":\"\",\"conversation\":\"محادثة\",\"error_fetching\":\"خطأ أثناء جلب التحديثات\",\"load_older\":\"تحميل المنشورات القديمة\",\"no_retweet_hint\":\"\",\"repeated\":\"\",\"show_new\":\"عرض الجديد\",\"up_to_date\":\"تم تحديثه\"},\"user_card\":{\"approve\":\"قبول\",\"block\":\"حظر\",\"blocked\":\"تم حظره!\",\"deny\":\"رفض\",\"follow\":\"اتبع\",\"followees\":\"\",\"followers\":\"مُتابِعون\",\"following\":\"\",\"follows_you\":\"يتابعك!\",\"mute\":\"كتم\",\"muted\":\"تم كتمه\",\"per_day\":\"في اليوم\",\"remote_follow\":\"مُتابَعة عن بُعد\",\"statuses\":\"المنشورات\"},\"user_profile\":{\"timeline_title\":\"الخيط الزمني للمستخدم\"},\"who_to_follow\":{\"more\":\"المزيد\",\"who_to_follow\":\"للمتابعة\"}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/ar.json\n// module id = 433\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Xat\"},\"features_panel\":{\"chat\":\"Xat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Proxy per multimèdia\",\"scope_options\":\"Opcions d'abast i visibilitat\",\"text_limit\":\"Límit de text\",\"title\":\"Funcionalitats\",\"who_to_follow\":\"A qui seguir\"},\"finder\":{\"error_fetching_user\":\"No s'ha pogut carregar l'usuari/a\",\"find_user\":\"Find user\"},\"general\":{\"apply\":\"Aplica\",\"submit\":\"Desa\"},\"login\":{\"login\":\"Inicia sessió\",\"logout\":\"Tanca la sessió\",\"password\":\"Contrasenya\",\"placeholder\":\"p.ex.: Maria\",\"register\":\"Registra't\",\"username\":\"Nom d'usuari/a\"},\"nav\":{\"chat\":\"Xat local públic\",\"friend_requests\":\"Soŀlicituds de connexió\",\"mentions\":\"Mencions\",\"public_tl\":\"Flux públic del node\",\"timeline\":\"Flux personal\",\"twkn\":\"Flux de la xarxa coneguda\"},\"notifications\":{\"broken_favorite\":\"No es coneix aquest estat. S'està cercant.\",\"favorited_you\":\"ha marcat un estat teu\",\"followed_you\":\"ha començat a seguir-te\",\"load_older\":\"Carrega més notificacions\",\"notifications\":\"Notificacions\",\"read\":\"Read!\",\"repeated_you\":\"ha repetit el teu estat\"},\"post_status\":{\"account_not_locked_warning\":\"El teu compte no està {0}. Qualsevol persona pot seguir-te per llegir les teves entrades reservades només a seguidores.\",\"account_not_locked_warning_link\":\"bloquejat\",\"attachments_sensitive\":\"Marca l'adjunt com a delicat\",\"content_type\":{\"plain_text\":\"Text pla\"},\"content_warning\":\"Assumpte (opcional)\",\"default\":\"Em sento…\",\"direct_warning\":\"Aquesta entrada només serà visible per les usuràries que etiquetis\",\"posting\":\"Publicació\",\"scope\":{\"direct\":\"Directa - Publica només per les usuàries etiquetades\",\"private\":\"Només seguidors/es - Publica només per comptes que et segueixin\",\"public\":\"Pública - Publica als fluxos públics\",\"unlisted\":\"Silenciosa - No la mostris en fluxos públics\"}},\"registration\":{\"bio\":\"Presentació\",\"email\":\"Correu\",\"fullname\":\"Nom per mostrar\",\"password_confirm\":\"Confirma la contrasenya\",\"registration\":\"Registra't\",\"token\":\"Codi d'invitació\"},\"settings\":{\"attachmentRadius\":\"Adjunts\",\"attachments\":\"Adjunts\",\"autoload\":\"Recarrega automàticament en arribar a sota de tot.\",\"avatar\":\"Avatar\",\"avatarAltRadius\":\"Avatars en les notificacions\",\"avatarRadius\":\"Avatars\",\"background\":\"Fons de pantalla\",\"bio\":\"Presentació\",\"btnRadius\":\"Botons\",\"cBlue\":\"Blau (respon, segueix)\",\"cGreen\":\"Verd (republica)\",\"cOrange\":\"Taronja (marca com a preferit)\",\"cRed\":\"Vermell (canceŀla)\",\"change_password\":\"Canvia la contrasenya\",\"change_password_error\":\"No s'ha pogut canviar la contrasenya\",\"changed_password\":\"S'ha canviat la contrasenya\",\"collapse_subject\":\"Replega les entrades amb títol\",\"confirm_new_password\":\"Confirma la nova contrasenya\",\"current_avatar\":\"L'avatar actual\",\"current_password\":\"La contrasenya actual\",\"current_profile_banner\":\"El fons de perfil actual\",\"data_import_export_tab\":\"Importa o exporta dades\",\"default_vis\":\"Abast per defecte de les entrades\",\"delete_account\":\"Esborra el compte\",\"delete_account_description\":\"Esborra permanentment el teu compte i tots els missatges\",\"delete_account_error\":\"No s'ha pogut esborrar el compte. Si continua el problema, contacta amb l'administració del node\",\"delete_account_instructions\":\"Confirma que vols esborrar el compte escrivint la teva contrasenya aquí sota\",\"export_theme\":\"Desa el tema\",\"filtering\":\"Filtres\",\"filtering_explanation\":\"Es silenciaran totes les entrades que continguin aquestes paraules. Separa-les per línies\",\"follow_export\":\"Exporta la llista de contactes\",\"follow_export_button\":\"Exporta tots els comptes que segueixes a un fitxer CSV\",\"follow_export_processing\":\"S'està processant la petició. Aviat podràs descarregar el fitxer\",\"follow_import\":\"Importa els contactes\",\"follow_import_error\":\"No s'ha pogut importar els contactes\",\"follows_imported\":\"S'han importat els contactes. Trigaran una estoneta en ser processats.\",\"foreground\":\"Primer pla\",\"general\":\"General\",\"hide_attachments_in_convo\":\"Amaga els adjunts en les converses\",\"hide_attachments_in_tl\":\"Amaga els adjunts en el flux d'entrades\",\"import_followers_from_a_csv_file\":\"Importa els contactes des d'un fitxer CSV\",\"import_theme\":\"Carrega un tema\",\"inputRadius\":\"Caixes d'entrada de text\",\"instance_default\":\"(default: {value})\",\"interfaceLanguage\":\"Llengua de la interfície\",\"invalid_theme_imported\":\"No s'ha entès l'arxiu carregat perquè no és un tema vàlid de Pleroma. No s'ha fet cap canvi als temes actuals.\",\"limited_availability\":\"No està disponible en aquest navegador\",\"links\":\"Enllaços\",\"lock_account_description\":\"Restringeix el teu compte només a seguidores aprovades.\",\"loop_video\":\"Reprodueix els vídeos en bucle\",\"loop_video_silent_only\":\"Reprodueix en bucles només els vídeos sense so (com els \\\"GIF\\\" de Mastodon)\",\"name\":\"Nom\",\"name_bio\":\"Nom i presentació\",\"new_password\":\"Contrasenya nova\",\"notification_visibility\":\"Notifica'm quan algú\",\"notification_visibility_follows\":\"Comença a seguir-me\",\"notification_visibility_likes\":\"Marca com a preferida una entrada meva\",\"notification_visibility_mentions\":\"Em menciona\",\"notification_visibility_repeats\":\"Republica una entrada meva\",\"no_rich_text_description\":\"Neteja el formatat de text de totes les entrades\",\"nsfw_clickthrough\":\"Amaga el contingut NSFW darrer d'una imatge clicable\",\"oauth_tokens\":\"Llistats OAuth\",\"token\":\"Token\",\"refresh_token\":\"Actualitza el token\",\"valid_until\":\"Vàlid fins\",\"revoke_token\":\"Revocar\",\"panelRadius\":\"Panells\",\"pause_on_unfocused\":\"Pausa la reproducció en continu quan la pestanya perdi el focus\",\"presets\":\"Temes\",\"profile_background\":\"Fons de pantalla\",\"profile_banner\":\"Fons de perfil\",\"profile_tab\":\"Perfil\",\"radii_help\":\"Configura l'arrodoniment de les vores (en píxels)\",\"replies_in_timeline\":\"Replies in timeline\",\"reply_link_preview\":\"Mostra el missatge citat en passar el ratolí per sobre de l'enllaç de resposta\",\"reply_visibility_all\":\"Mostra totes les respostes\",\"reply_visibility_following\":\"Mostra només les respostes a entrades meves o d'usuàries que jo segueixo\",\"reply_visibility_self\":\"Mostra només les respostes a entrades meves\",\"saving_err\":\"No s'ha pogut desar la configuració\",\"saving_ok\":\"S'ha desat la configuració\",\"security_tab\":\"Seguretat\",\"set_new_avatar\":\"Canvia l'avatar\",\"set_new_profile_background\":\"Canvia el fons de pantalla\",\"set_new_profile_banner\":\"Canvia el fons del perfil\",\"settings\":\"Configuració\",\"stop_gifs\":\"Anima els GIF només en passar-hi el ratolí per sobre\",\"streaming\":\"Carrega automàticament entrades noves quan estigui a dalt de tot\",\"text\":\"Text\",\"theme\":\"Tema\",\"theme_help\":\"Personalitza els colors del tema. Escriu-los en format RGB hexadecimal (#rrggbb)\",\"tooltipRadius\":\"Missatges sobreposats\",\"user_settings\":\"Configuració personal\",\"values\":{\"false\":\"no\",\"true\":\"sí\"}},\"timeline\":{\"collapse\":\"Replega\",\"conversation\":\"Conversa\",\"error_fetching\":\"S'ha produït un error en carregar les entrades\",\"load_older\":\"Carrega entrades anteriors\",\"no_retweet_hint\":\"L'entrada és només per a seguidores o és \\\"directa\\\", i per tant no es pot republicar\",\"repeated\":\"republicat\",\"show_new\":\"Mostra els nous\",\"up_to_date\":\"Actualitzat\"},\"user_card\":{\"approve\":\"Aprova\",\"block\":\"Bloqueja\",\"blocked\":\"Bloquejat!\",\"deny\":\"Denega\",\"follow\":\"Segueix\",\"followees\":\"Segueixo\",\"followers\":\"Seguidors/es\",\"following\":\"Seguint!\",\"follows_you\":\"Et segueix!\",\"mute\":\"Silencia\",\"muted\":\"Silenciat\",\"per_day\":\"per dia\",\"remote_follow\":\"Seguiment remot\",\"statuses\":\"Estats\"},\"user_profile\":{\"timeline_title\":\"Flux personal\"},\"who_to_follow\":{\"more\":\"More\",\"who_to_follow\":\"A qui seguir\"}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/ca.json\n// module id = 434\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Chat\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Mediální proxy\",\"scope_options\":\"Možnosti rozsahů\",\"text_limit\":\"Textový limit\",\"title\":\"Vlastnosti\",\"who_to_follow\":\"Koho sledovat\"},\"finder\":{\"error_fetching_user\":\"Chyba při načítání uživatele\",\"find_user\":\"Najít uživatele\"},\"general\":{\"apply\":\"Použít\",\"submit\":\"Odeslat\",\"more\":\"Více\",\"generic_error\":\"Vyskytla se chyba\",\"optional\":\"volitelné\"},\"image_cropper\":{\"crop_picture\":\"Oříznout obrázek\",\"save\":\"Uložit\",\"cancel\":\"Zrušit\"},\"login\":{\"login\":\"Přihlásit\",\"description\":\"Přihlásit pomocí OAuth\",\"logout\":\"Odhlásit\",\"password\":\"Heslo\",\"placeholder\":\"např. lain\",\"register\":\"Registrovat\",\"username\":\"Uživatelské jméno\",\"hint\":\"Chcete-li se přidat do diskuze, přihlaste se\"},\"media_modal\":{\"previous\":\"Předchozí\",\"next\":\"Další\"},\"nav\":{\"about\":\"O instanci\",\"back\":\"Zpět\",\"chat\":\"Místní chat\",\"friend_requests\":\"Požadavky o sledování\",\"mentions\":\"Zmínky\",\"dms\":\"Přímé zprávy\",\"public_tl\":\"Veřejná časová osa\",\"timeline\":\"Časová osa\",\"twkn\":\"Celá známá síť\",\"user_search\":\"Hledání uživatelů\",\"who_to_follow\":\"Koho sledovat\",\"preferences\":\"Předvolby\"},\"notifications\":{\"broken_favorite\":\"Neznámý příspěvek, hledám jej…\",\"favorited_you\":\"si oblíbil/a váš příspěvek\",\"followed_you\":\"vás nyní sleduje\",\"load_older\":\"Načíst starší oznámení\",\"notifications\":\"Oznámení\",\"read\":\"Číst!\",\"repeated_you\":\"zopakoval/a váš příspěvek\",\"no_more_notifications\":\"Žádná další oznámení\"},\"post_status\":{\"new_status\":\"Napsat nový příspěvek\",\"account_not_locked_warning\":\"Váš účet není {0}. Kdokoliv vás může sledovat a vidět vaše příspěvky pouze pro sledující.\",\"account_not_locked_warning_link\":\"uzamčen\",\"attachments_sensitive\":\"Označovat přílohy jako citlivé\",\"content_type\":{\"plain_text\":\"Prostý text\",\"text/html\":\"HTML\",\"text/markdown\":\"Markdown\"},\"content_warning\":\"Předmět (volitelný)\",\"default\":\"Právě jsem přistál v L.A.\",\"direct_warning\":\"Tento příspěvek uvidí pouze všichni zmínění uživatelé.\",\"posting\":\"Přispívání\",\"scope\":{\"direct\":\"Přímý - Poslat pouze zmíněným uživatelům\",\"private\":\"Pouze pro sledující - Poslat pouze sledujícím\",\"public\":\"Veřejný - Poslat na veřejné časové osy\",\"unlisted\":\"Neuvedený - Neposlat na veřejné časové osy\"}},\"registration\":{\"bio\":\"O vás\",\"email\":\"E-mail\",\"fullname\":\"Zobrazované jméno\",\"password_confirm\":\"Potvrzení hesla\",\"registration\":\"Registrace\",\"token\":\"Token pozvánky\",\"captcha\":\"CAPTCHA\",\"new_captcha\":\"Kliknutím na obrázek získáte novou CAPTCHA\",\"username_placeholder\":\"např. lain\",\"fullname_placeholder\":\"např. Lain Iwakura\",\"bio_placeholder\":\"např.\\nNazdar, jsem Lain\\nJsem anime dívka žijící v příměstském Japonsku. Možná mě znáte z Wired.\",\"validations\":{\"username_required\":\"nemůže být prázdné\",\"fullname_required\":\"nemůže být prázdné\",\"email_required\":\"nemůže být prázdný\",\"password_required\":\"nemůže být prázdné\",\"password_confirmation_required\":\"nemůže být prázdné\",\"password_confirmation_match\":\"musí být stejné jako heslo\"}},\"settings\":{\"app_name\":\"Název aplikace\",\"attachmentRadius\":\"Přílohy\",\"attachments\":\"Přílohy\",\"autoload\":\"Povolit automatické načítání při rolování dolů\",\"avatar\":\"Avatar\",\"avatarAltRadius\":\"Avatary (oznámení)\",\"avatarRadius\":\"Avatary\",\"background\":\"Pozadí\",\"bio\":\"O vás\",\"blocks_tab\":\"Blokování\",\"btnRadius\":\"Tlačítka\",\"cBlue\":\"Modrá (Odpovědět, sledovat)\",\"cGreen\":\"Zelená (Zopakovat)\",\"cOrange\":\"Oranžová (Oblíbit)\",\"cRed\":\"Červená (Zrušit)\",\"change_password\":\"Změnit heslo\",\"change_password_error\":\"Při změně vašeho hesla se vyskytla chyba.\",\"changed_password\":\"Heslo bylo úspěšně změněno!\",\"collapse_subject\":\"Zabalit příspěvky s předměty\",\"composing\":\"Komponování\",\"confirm_new_password\":\"Potvrďte nové heslo\",\"current_avatar\":\"Váš současný avatar\",\"current_password\":\"Současné heslo\",\"current_profile_banner\":\"Váš současný profilový banner\",\"data_import_export_tab\":\"Import/export dat\",\"default_vis\":\"Výchozí rozsah viditelnosti\",\"delete_account\":\"Smazat účet\",\"delete_account_description\":\"Trvale smaže váš účet a všechny vaše příspěvky.\",\"delete_account_error\":\"Při mazání vašeho účtu nastala chyba. Pokud tato chyba bude trvat, kontaktujte prosím admministrátora vaší instance.\",\"delete_account_instructions\":\"Pro potvrzení smazání účtu napište své heslo do pole níže.\",\"avatar_size_instruction\":\"Doporučená minimální velikost pro avatarové obrázky je 150x150 pixelů.\",\"export_theme\":\"Uložit přednastavení\",\"filtering\":\"Filtrování\",\"filtering_explanation\":\"Všechny příspěvky obsahující tato slova budou skryty. Napište jedno slovo na každý řádek\",\"follow_export\":\"Export sledovaných\",\"follow_export_button\":\"Exportovat vaše sledované do souboru CSV\",\"follow_export_processing\":\"Zpracovávám, brzy si budete moci stáhnout váš soubor\",\"follow_import\":\"Import sledovaných\",\"follow_import_error\":\"Chyba při importování sledovaných\",\"follows_imported\":\"Sledovaní importováni! Jejich zpracování bude chvilku trvat.\",\"foreground\":\"Popředí\",\"general\":\"Obecné\",\"hide_attachments_in_convo\":\"Skrývat přílohy v konverzacích\",\"hide_attachments_in_tl\":\"Skrývat přílohy v časové ose\",\"max_thumbnails\":\"Maximální počet miniatur na příspěvek\",\"hide_isp\":\"Skrýt panel specifický pro instanci\",\"preload_images\":\"Přednačítat obrázky\",\"use_one_click_nsfw\":\"Otevírat citlivé přílohy pouze jedním kliknutím\",\"hide_post_stats\":\"Skrývat statistiky příspěvků (např. počet oblíbení)\",\"hide_user_stats\":\"Skrývat statistiky uživatelů (např. počet sledujících)\",\"hide_filtered_statuses\":\"Skrývat filtrované příspěvky\",\"import_followers_from_a_csv_file\":\"Importovat sledované ze souboru CSV\",\"import_theme\":\"Načíst přednastavení\",\"inputRadius\":\"Vstupní pole\",\"checkboxRadius\":\"Zaškrtávací pole\",\"instance_default\":\"(výchozí: {value})\",\"instance_default_simple\":\"(výchozí)\",\"interface\":\"Rozhraní\",\"interfaceLanguage\":\"Jazyk rozhraní\",\"invalid_theme_imported\":\"Zvolený soubor není podporovaný motiv Pleroma. Nebyly provedeny žádné změny s vaším motivem.\",\"limited_availability\":\"Nedostupné ve vašem prohlížeči\",\"links\":\"Odkazy\",\"lock_account_description\":\"Omezit váš účet pouze na schválené sledující\",\"loop_video\":\"Opakovat videa\",\"loop_video_silent_only\":\"Opakovat pouze videa beze zvuku (t.j. „GIFy“ na Mastodonu)\",\"mutes_tab\":\"Ignorování\",\"play_videos_in_modal\":\"Přehrávat videa přímo v prohlížeči médií\",\"use_contain_fit\":\"Neořezávat přílohu v miniaturách\",\"name\":\"Jméno\",\"name_bio\":\"Jméno a popis\",\"new_password\":\"Nové heslo\",\"notification_visibility\":\"Typy oznámení k zobrazení\",\"notification_visibility_follows\":\"Sledující\",\"notification_visibility_likes\":\"Oblíbení\",\"notification_visibility_mentions\":\"Zmínky\",\"notification_visibility_repeats\":\"Zopakování\",\"no_rich_text_description\":\"Odstranit ze všech příspěvků formátování textu\",\"no_blocks\":\"Žádná blokování\",\"no_mutes\":\"Žádná ignorování\",\"hide_follows_description\":\"Nezobrazovat, koho sleduji\",\"hide_followers_description\":\"Nezobrazovat, kdo mě sleduje\",\"show_admin_badge\":\"Zobrazovat v mém profilu odznak administrátora\",\"show_moderator_badge\":\"Zobrazovat v mém profilu odznak moderátora\",\"nsfw_clickthrough\":\"Povolit prokliknutelné skrývání citlivých příloh\",\"oauth_tokens\":\"Tokeny OAuth\",\"token\":\"Token\",\"refresh_token\":\"Obnovit token\",\"valid_until\":\"Platný do\",\"revoke_token\":\"Odvolat\",\"panelRadius\":\"Panely\",\"pause_on_unfocused\":\"Pozastavit streamování, pokud není záložka prohlížeče v soustředění\",\"presets\":\"Přednastavení\",\"profile_background\":\"Profilové pozadí\",\"profile_banner\":\"Profilový banner\",\"profile_tab\":\"Profil\",\"radii_help\":\"Nastavit zakulacení rohů rozhraní (v pixelech)\",\"replies_in_timeline\":\"Odpovědi v časové ose\",\"reply_link_preview\":\"Povolit náhledy odkazu pro odpověď při přejetí myši\",\"reply_visibility_all\":\"Zobrazit všechny odpovědi\",\"reply_visibility_following\":\"Zobrazit pouze odpovědi směřované na mě nebo uživatele, které sleduji\",\"reply_visibility_self\":\"Zobrazit pouze odpovědi směřované na mě\",\"saving_err\":\"Chyba při ukládání nastavení\",\"saving_ok\":\"Nastavení uložena\",\"security_tab\":\"Bezpečnost\",\"scope_copy\":\"Kopírovat rozsah při odpovídání (přímé zprávy jsou vždy kopírovány)\",\"set_new_avatar\":\"Nastavit nový avatar\",\"set_new_profile_background\":\"Nastavit nové profilové pozadí\",\"set_new_profile_banner\":\"Nastavit nový profilový banner\",\"settings\":\"Nastavení\",\"subject_input_always_show\":\"Vždy zobrazit pole pro předmět\",\"subject_line_behavior\":\"Kopírovat předmět při odpovídání\",\"subject_line_email\":\"Jako u e-mailu: „re: předmět“\",\"subject_line_mastodon\":\"Jako u Mastodonu: zkopírovat tak, jak je\",\"subject_line_noop\":\"Nekopírovat\",\"post_status_content_type\":\"Publikovat typ obsahu příspěvku\",\"stop_gifs\":\"Přehrávat GIFy při přejetí myši\",\"streaming\":\"Povolit automatické streamování nových příspěvků při rolování nahoru\",\"text\":\"Text\",\"theme\":\"Motiv\",\"theme_help\":\"Použijte hexadecimální barevné kódy (#rrggbb) pro přizpůsobení vašeho barevného motivu.\",\"theme_help_v2_1\":\"Zaškrtnutím pole můžete také přepsat barvy a průhlednost některých komponentů, pro smazání všech přednastavení použijte tlačítko „Smazat vše“.\",\"theme_help_v2_2\":\"Ikony pod některými položkami jsou indikátory kontrastu pozadí/textu, pro detailní informace nad nimi přejeďte myší. Prosím berte na vědomí, že při používání kontrastu průhlednosti ukazují indikátory nejhorší možný případ.\",\"tooltipRadius\":\"Popisky/upozornění\",\"upload_a_photo\":\"Nahrát fotku\",\"user_settings\":\"Uživatelská nastavení\",\"values\":{\"false\":\"ne\",\"true\":\"ano\"},\"notifications\":\"Oznámení\",\"enable_web_push_notifications\":\"Povolit webová push oznámení\",\"style\":{\"switcher\":{\"keep_color\":\"Ponechat barvy\",\"keep_shadows\":\"Ponechat stíny\",\"keep_opacity\":\"Ponechat průhlednost\",\"keep_roundness\":\"Ponechat kulatost\",\"keep_fonts\":\"Keep fonts\",\"save_load_hint\":\"Možnosti „Ponechat“ dočasně ponechávají aktuálně nastavené možností při volení či nahrávání motivů, také tyto možnosti ukládají při exportování motivu. Pokud není žádné pole zaškrtnuto, uloží export motivu všechno.\",\"reset\":\"Resetovat\",\"clear_all\":\"Vymazat vše\",\"clear_opacity\":\"Vymazat průhlednost\"},\"common\":{\"color\":\"Barva\",\"opacity\":\"Průhlednost\",\"contrast\":{\"hint\":\"Poměr kontrastu je {ratio}, {level} {context}\",\"level\":{\"aa\":\"splňuje směrnici úrovně AA (minimální)\",\"aaa\":\"splňuje směrnici úrovně AAA (doporučováno)\",\"bad\":\"nesplňuje žádné směrnice přístupnosti\"},\"context\":{\"18pt\":\"pro velký (18+ bodů) text\",\"text\":\"pro text\"}}},\"common_colors\":{\"_tab_label\":\"Obvyklé\",\"main\":\"Obvyklé barvy\",\"foreground_hint\":\"Pro detailnější kontrolu viz záložka „Pokročilé“\",\"rgbo\":\"Ikony, odstíny, odznaky\"},\"advanced_colors\":{\"_tab_label\":\"Pokročilé\",\"alert\":\"Pozadí upozornění\",\"alert_error\":\"Chyba\",\"badge\":\"Pozadí odznaků\",\"badge_notification\":\"Oznámení\",\"panel_header\":\"Záhlaví panelu\",\"top_bar\":\"Vrchní pruh\",\"borders\":\"Okraje\",\"buttons\":\"Tlačítka\",\"inputs\":\"Vstupní pole\",\"faint_text\":\"Vybledlý text\"},\"radii\":{\"_tab_label\":\"Kulatost\"},\"shadows\":{\"_tab_label\":\"Stín a osvětlení\",\"component\":\"Komponent\",\"override\":\"Přepsat\",\"shadow_id\":\"Stín #{value}\",\"blur\":\"Rozmazání\",\"spread\":\"Rozsah\",\"inset\":\"Vsazení\",\"hint\":\"Pro stíny můžete také použít --variable jako hodnotu barvy pro použití proměnných CSS3. Prosím berte na vědomí, že nastavení průhlednosti v tomto případě nebude fungovat.\",\"filter_hint\":{\"always_drop_shadow\":\"Varování, tento stín vždy používá {0}, když to prohlížeč podporuje.\",\"drop_shadow_syntax\":\"{0} nepodporuje parametr {1} a klíčové slovo {2}.\",\"avatar_inset\":\"Prosím berte na vědomí, že kombinování vsazených i nevsazených stínů u avatarů může u průhledných avatarů dát neočekávané výsledky.\",\"spread_zero\":\"Stíny s rozsahem > 0 se zobrazí, jako kdyby byl rozsah nastaven na nulu\",\"inset_classic\":\"Vsazené stíny budou používat {0}\"},\"components\":{\"panel\":\"Panel\",\"panelHeader\":\"Záhlaví panelu\",\"topBar\":\"Vrchní pruh\",\"avatar\":\"Avatar uživatele (v zobrazení profilu)\",\"avatarStatus\":\"Avatar uživatele (v zobrazení příspěvku)\",\"popup\":\"Vyskakovací okna a popisky\",\"button\":\"Tlačítko\",\"buttonHover\":\"Tlačítko (přejetí myši)\",\"buttonPressed\":\"Tlačítko (stisknuto)\",\"buttonPressedHover\":\"Button (stisknuto+přejetí myši)\",\"input\":\"Vstupní pole\"}},\"fonts\":{\"_tab_label\":\"Písma\",\"help\":\"Zvolte písmo, které bude použito pro prvky rozhraní. U možnosti „vlastní“ musíte zadat přesný název písma tak, jak se zobrazuje v systému.\",\"components\":{\"interface\":\"Rozhraní\",\"input\":\"Vstupní pole\",\"post\":\"Text příspěvků\",\"postCode\":\"Neproporcionální text v příspěvku (formátovaný text)\"},\"family\":\"Název písma\",\"size\":\"Velikost (v pixelech)\",\"weight\":\"Tloušťka\",\"custom\":\"Vlastní\"},\"preview\":{\"header\":\"Náhled\",\"content\":\"Obsah\",\"error\":\"Příklad chyby\",\"button\":\"Tlačítko\",\"text\":\"Spousta dalšího {0} a {1}\",\"mono\":\"obsahu\",\"input\":\"Právě jsem přistál v L.A.\",\"faint_link\":\"pomocný manuál\",\"fine_print\":\"Přečtěte si náš {0} a nenaučte se nic užitečného!\",\"header_faint\":\"Tohle je v pohodě\",\"checkbox\":\"Pročetl/a jsem podmínky používání\",\"link\":\"hezký malý odkaz\"}}},\"timeline\":{\"collapse\":\"Zabalit\",\"conversation\":\"Konverzace\",\"error_fetching\":\"Chyba při načítání aktualizací\",\"load_older\":\"Načíst starší příspěvky\",\"no_retweet_hint\":\"Příspěvek je označen jako pouze pro sledující či přímý a nemůže být zopakován\",\"repeated\":\"zopakoval/a\",\"show_new\":\"Zobrazit nové\",\"up_to_date\":\"Aktuální\",\"no_more_statuses\":\"Žádné další příspěvky\",\"no_statuses\":\"Žádné příspěvky\"},\"status\":{\"reply_to\":\"Odpověď uživateli\",\"replies_list\":\"Odpovědi:\"},\"user_card\":{\"approve\":\"Schválit\",\"block\":\"Blokovat\",\"blocked\":\"Blokován/a!\",\"deny\":\"Zamítnout\",\"favorites\":\"Oblíbené\",\"follow\":\"Sledovat\",\"follow_sent\":\"Požadavek odeslán!\",\"follow_progress\":\"Odeslílám požadavek…\",\"follow_again\":\"Odeslat požadavek znovu?\",\"follow_unfollow\":\"Přestat sledovat\",\"followees\":\"Sledovaní\",\"followers\":\"Sledující\",\"following\":\"Sledujete!\",\"follows_you\":\"Sleduje vás!\",\"its_you\":\"Jste to vy!\",\"media\":\"Média\",\"mute\":\"Ignorovat\",\"muted\":\"Ignorován/a\",\"per_day\":\"za den\",\"remote_follow\":\"Vzdálené sledování\",\"statuses\":\"Příspěvky\",\"unblock\":\"Odblokovat\",\"unblock_progress\":\"Odblokuji…\",\"block_progress\":\"Blokuji…\",\"unmute\":\"Přestat ignorovat\",\"unmute_progress\":\"Ruším ignorování…\",\"mute_progress\":\"Ignoruji…\"},\"user_profile\":{\"timeline_title\":\"Uživatelská časová osa\",\"profile_does_not_exist\":\"Omlouváme se, tento profil neexistuje.\",\"profile_loading_error\":\"Omlouváme se, při načítání tohoto profilu se vyskytla chyba.\"},\"who_to_follow\":{\"more\":\"Více\",\"who_to_follow\":\"Koho sledovat\"},\"tool_tip\":{\"media_upload\":\"Nahrát média\",\"repeat\":\"Zopakovat\",\"reply\":\"Odpovědět\",\"favorite\":\"Oblíbit\",\"user_settings\":\"Uživatelské nastavení\"},\"upload\":{\"error\":{\"base\":\"Nahrávání selhalo.\",\"file_too_big\":\"Soubor je příliš velký [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"Zkuste to znovu později\"},\"file_size_units\":{\"B\":\"B\",\"KiB\":\"KiB\",\"MiB\":\"MiB\",\"GiB\":\"GiB\",\"TiB\":\"TiB\"}}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/cs.json\n// module id = 435\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Chat\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Media Proxy\",\"scope_options\":\"Reichweitenoptionen\",\"text_limit\":\"Textlimit\",\"title\":\"Features\",\"who_to_follow\":\"Who to follow\"},\"finder\":{\"error_fetching_user\":\"Fehler beim Suchen des Benutzers\",\"find_user\":\"Finde Benutzer\"},\"general\":{\"apply\":\"Anwenden\",\"submit\":\"Absenden\"},\"login\":{\"login\":\"Anmelden\",\"description\":\"Mit OAuth anmelden\",\"logout\":\"Abmelden\",\"password\":\"Passwort\",\"placeholder\":\"z.B. lain\",\"register\":\"Registrieren\",\"username\":\"Benutzername\"},\"nav\":{\"back\":\"Zurück\",\"chat\":\"Lokaler Chat\",\"friend_requests\":\"Followanfragen\",\"mentions\":\"Erwähnungen\",\"dms\":\"Direktnachrichten\",\"public_tl\":\"Öffentliche Zeitleiste\",\"timeline\":\"Zeitleiste\",\"twkn\":\"Das gesamte bekannte Netzwerk\",\"user_search\":\"Benutzersuche\",\"preferences\":\"Voreinstellungen\"},\"notifications\":{\"broken_favorite\":\"Unbekannte Nachricht, suche danach...\",\"favorited_you\":\"favorisierte deine Nachricht\",\"followed_you\":\"folgt dir\",\"load_older\":\"Ältere Benachrichtigungen laden\",\"notifications\":\"Benachrichtigungen\",\"read\":\"Gelesen!\",\"repeated_you\":\"wiederholte deine Nachricht\"},\"post_status\":{\"new_status\":\"Neuen Status veröffentlichen\",\"account_not_locked_warning\":\"Dein Profil ist nicht {0}. Wer dir folgen will, kann das jederzeit tun und dann auch deine privaten Beiträge sehen.\",\"account_not_locked_warning_link\":\"gesperrt\",\"attachments_sensitive\":\"Anhänge als heikel markieren\",\"content_type\":{\"plain_text\":\"Nur Text\"},\"content_warning\":\"Betreff (optional)\",\"default\":\"Sitze gerade im Hofbräuhaus.\",\"direct_warning\":\"Dieser Beitrag wird nur für die erwähnten Nutzer sichtbar sein.\",\"posting\":\"Veröffentlichen\",\"scope\":{\"direct\":\"Direkt - Beitrag nur an erwähnte Profile\",\"private\":\"Nur Follower - Beitrag nur für Follower sichtbar\",\"public\":\"Öffentlich - Beitrag an öffentliche Zeitleisten\",\"unlisted\":\"Nicht gelistet - Nicht in öffentlichen Zeitleisten anzeigen\"}},\"registration\":{\"bio\":\"Bio\",\"email\":\"Email\",\"fullname\":\"Angezeigter Name\",\"password_confirm\":\"Passwort bestätigen\",\"registration\":\"Registrierung\",\"token\":\"Einladungsschlüssel\",\"captcha\":\"CAPTCHA\",\"new_captcha\":\"Zum Erstellen eines neuen Captcha auf das Bild klicken.\",\"validations\":{\"username_required\":\"darf nicht leer sein\",\"fullname_required\":\"darf nicht leer sein\",\"email_required\":\"darf nicht leer sein\",\"password_required\":\"darf nicht leer sein\",\"password_confirmation_required\":\"darf nicht leer sein\",\"password_confirmation_match\":\"sollte mit dem Passwort identisch sein.\"}},\"settings\":{\"attachmentRadius\":\"Anhänge\",\"attachments\":\"Anhänge\",\"autoload\":\"Aktiviere automatisches Laden von älteren Beiträgen beim scrollen\",\"avatar\":\"Avatar\",\"avatarAltRadius\":\"Avatare (Benachrichtigungen)\",\"avatarRadius\":\"Avatare\",\"background\":\"Hintergrund\",\"bio\":\"Bio\",\"btnRadius\":\"Buttons\",\"cBlue\":\"Blau (Antworten, Folgt dir)\",\"cGreen\":\"Grün (Retweet)\",\"cOrange\":\"Orange (Favorisieren)\",\"cRed\":\"Rot (Abbrechen)\",\"change_password\":\"Passwort ändern\",\"change_password_error\":\"Es gab ein Problem bei der Änderung des Passworts.\",\"changed_password\":\"Passwort erfolgreich geändert!\",\"collapse_subject\":\"Beiträge mit Betreff einklappen\",\"composing\":\"Verfassen\",\"confirm_new_password\":\"Neues Passwort bestätigen\",\"current_avatar\":\"Dein derzeitiger Avatar\",\"current_password\":\"Aktuelles Passwort\",\"current_profile_banner\":\"Der derzeitige Banner deines Profils\",\"data_import_export_tab\":\"Datenimport/-export\",\"default_vis\":\"Standard-Sichtbarkeitsumfang\",\"delete_account\":\"Account löschen\",\"delete_account_description\":\"Lösche deinen Account und alle deine Nachrichten unwiderruflich.\",\"delete_account_error\":\"Es ist ein Fehler beim Löschen deines Accounts aufgetreten. Tritt dies weiterhin auf, wende dich an den Administrator der Instanz.\",\"delete_account_instructions\":\"Tippe dein Passwort unten in das Feld ein, um die Löschung deines Accounts zu bestätigen.\",\"export_theme\":\"Farbschema speichern\",\"filtering\":\"Filtern\",\"filtering_explanation\":\"Alle Beiträge die diese Wörter enthalten werden ausgeblendet. Ein Wort pro Zeile.\",\"follow_export\":\"Follower exportieren\",\"follow_export_button\":\"Exportiere deine Follows in eine csv-Datei\",\"follow_export_processing\":\"In Bearbeitung. Die Liste steht gleich zum herunterladen bereit.\",\"follow_import\":\"Followers importieren\",\"follow_import_error\":\"Fehler beim importieren der Follower\",\"follows_imported\":\"Followers importiert! Die Bearbeitung kann eine Zeit lang dauern.\",\"foreground\":\"Vordergrund\",\"general\":\"Allgemein\",\"hide_attachments_in_convo\":\"Anhänge in Unterhaltungen ausblenden\",\"hide_attachments_in_tl\":\"Anhänge in der Zeitleiste ausblenden\",\"hide_isp\":\"Instanz-spezifisches Panel ausblenden\",\"preload_images\":\"Bilder vorausladen\",\"hide_post_stats\":\"Beitragsstatistiken verbergen (z.B. die Anzahl der Favoriten)\",\"hide_user_stats\":\"Benutzerstatistiken verbergen (z.B. die Anzahl der Follower)\",\"hide_filtered_statuses\":\"Gefilterte Beiträge verbergen\",\"import_followers_from_a_csv_file\":\"Importiere Follower, denen du folgen möchtest, aus einer CSV-Datei\",\"import_theme\":\"Farbschema laden\",\"inputRadius\":\"Eingabefelder\",\"checkboxRadius\":\"Auswahlfelder\",\"instance_default\":\"(Standard: {value})\",\"instance_default_simple\":\"(Standard)\",\"interface\":\"Oberfläche\",\"interfaceLanguage\":\"Sprache der Oberfläche\",\"invalid_theme_imported\":\"Die ausgewählte Datei ist kein unterstütztes Pleroma-Theme. Keine Änderungen wurden vorgenommen.\",\"limited_availability\":\"In deinem Browser nicht verfügbar\",\"links\":\"Links\",\"lock_account_description\":\"Sperre deinen Account, um neue Follower zu genehmigen oder abzulehnen\",\"loop_video\":\"Videos wiederholen\",\"loop_video_silent_only\":\"Nur Videos ohne Ton wiederholen (z.B. Mastodons \\\"gifs\\\")\",\"name\":\"Name\",\"name_bio\":\"Name & Bio\",\"new_password\":\"Neues Passwort\",\"notification_visibility\":\"Benachrichtigungstypen, die angezeigt werden sollen\",\"notification_visibility_follows\":\"Follows\",\"notification_visibility_likes\":\"Favoriten\",\"notification_visibility_mentions\":\"Erwähnungen\",\"notification_visibility_repeats\":\"Wiederholungen\",\"no_rich_text_description\":\"Rich-Text Formatierungen von allen Beiträgen entfernen\",\"hide_follows_description\":\"Zeige nicht, wem ich folge\",\"hide_followers_description\":\"Zeige nicht, wer mir folgt\",\"nsfw_clickthrough\":\"Aktiviere ausblendbares Overlay für Anhänge, die als NSFW markiert sind\",\"oauth_tokens\":\"OAuth-Token\",\"token\":\"Zeichen\",\"refresh_token\":\"Token aktualisieren\",\"valid_until\":\"Gültig bis\",\"revoke_token\":\"Widerrufen\",\"panelRadius\":\"Panel\",\"pause_on_unfocused\":\"Streaming pausieren, wenn das Tab nicht fokussiert ist\",\"presets\":\"Voreinstellungen\",\"profile_background\":\"Profilhintergrund\",\"profile_banner\":\"Profilbanner\",\"profile_tab\":\"Profil\",\"radii_help\":\"Kantenrundung (in Pixel) der Oberfläche anpassen\",\"replies_in_timeline\":\"Antworten in der Zeitleiste\",\"reply_link_preview\":\"Antwortlink-Vorschau beim Überfahren mit der Maus aktivieren\",\"reply_visibility_all\":\"Alle Antworten zeigen\",\"reply_visibility_following\":\"Zeige nur Antworten an mich oder an Benutzer, denen ich folge\",\"reply_visibility_self\":\"Nur Antworten an mich anzeigen\",\"saving_err\":\"Fehler beim Speichern der Einstellungen\",\"saving_ok\":\"Einstellungen gespeichert\",\"security_tab\":\"Sicherheit\",\"scope_copy\":\"Reichweite beim Antworten übernehmen (Direktnachrichten werden immer kopiert)\",\"set_new_avatar\":\"Setze einen neuen Avatar\",\"set_new_profile_background\":\"Setze einen neuen Hintergrund für dein Profil\",\"set_new_profile_banner\":\"Setze einen neuen Banner für dein Profil\",\"settings\":\"Einstellungen\",\"subject_input_always_show\":\"Betreff-Feld immer anzeigen\",\"subject_line_behavior\":\"Betreff beim Antworten kopieren\",\"subject_line_email\":\"Wie Email: \\\"re: Betreff\\\"\",\"subject_line_mastodon\":\"Wie Mastodon: unverändert kopieren\",\"subject_line_noop\":\"Nicht kopieren\",\"stop_gifs\":\"Play-on-hover GIFs\",\"streaming\":\"Aktiviere automatisches Laden (Streaming) von neuen Beiträgen\",\"text\":\"Text\",\"theme\":\"Farbschema\",\"theme_help\":\"Benutze HTML-Farbcodes (#rrggbb) um dein Farbschema anzupassen\",\"theme_help_v2_1\":\"Du kannst auch die Farben und die Deckkraft bestimmter Komponenten überschreiben, indem du das Kontrollkästchen umschaltest. Verwende die Schaltfläche \\\"Alle löschen\\\", um alle Überschreibungen zurückzusetzen.\",\"theme_help_v2_2\":\"Unter einigen Einträgen befinden sich Symbole für Hintergrund-/Textkontrastindikatoren, für detaillierte Informationen fahre mit der Maus darüber. Bitte beachte, dass bei der Verwendung von Transparenz Kontrastindikatoren den schlechtest möglichen Fall darstellen.\",\"tooltipRadius\":\"Tooltips/Warnungen\",\"user_settings\":\"Benutzereinstellungen\",\"values\":{\"false\":\"nein\",\"true\":\"Ja\"},\"notifications\":\"Benachrichtigungen\",\"enable_web_push_notifications\":\"Web-Pushbenachrichtigungen aktivieren\",\"style\":{\"switcher\":{\"keep_color\":\"Farben beibehalten\",\"keep_shadows\":\"Schatten beibehalten\",\"keep_opacity\":\"Deckkraft beibehalten\",\"keep_roundness\":\"Abrundungen beibehalten\",\"keep_fonts\":\"Schriften beibehalten\",\"save_load_hint\":\"Die \\\"Beibehalten\\\"-Optionen behalten die aktuell eingestellten Optionen beim Auswählen oder Laden von Designs bei, sie speichern diese Optionen auch beim Exportieren eines Designs. Wenn alle Kontrollkästchen deaktiviert sind, wird beim Exportieren des Designs alles gespeichert.\",\"reset\":\"Zurücksetzen\",\"clear_all\":\"Alles leeren\",\"clear_opacity\":\"Deckkraft leeren\"},\"common\":{\"color\":\"Farbe\",\"opacity\":\"Deckkraft\",\"contrast\":{\"hint\":\"Das Kontrastverhältnis ist {ratio}, es {level} {context}\",\"level\":{\"aa\":\"entspricht Level AA Richtlinie (minimum)\",\"aaa\":\"entspricht Level AAA Richtlinie (empfohlen)\",\"bad\":\"entspricht keiner Richtlinien zur Barrierefreiheit\"},\"context\":{\"18pt\":\"für großen (18pt+) Text\",\"text\":\"für Text\"}}},\"common_colors\":{\"_tab_label\":\"Allgemein\",\"main\":\"Allgemeine Farben\",\"foreground_hint\":\"Siehe Reiter \\\"Erweitert\\\" für eine detailliertere Einstellungen\",\"rgbo\":\"Symbole, Betonungen, Kennzeichnungen\"},\"advanced_colors\":{\"_tab_label\":\"Erweitert\",\"alert\":\"Warnhinweis-Hintergrund\",\"alert_error\":\"Fehler\",\"badge\":\"Kennzeichnungs-Hintergrund\",\"badge_notification\":\"Benachrichtigung\",\"panel_header\":\"Panel-Kopf\",\"top_bar\":\"Obere Leiste\",\"borders\":\"Rahmen\",\"buttons\":\"Schaltflächen\",\"inputs\":\"Eingabefelder\",\"faint_text\":\"Verblasster Text\"},\"radii\":{\"_tab_label\":\"Abrundungen\"},\"shadows\":{\"_tab_label\":\"Schatten und Beleuchtung\",\"component\":\"Komponente\",\"override\":\"Überschreiben\",\"shadow_id\":\"Schatten #{value}\",\"blur\":\"Unschärfe\",\"spread\":\"Streuung\",\"inset\":\"Einsatz\",\"hint\":\"Für Schatten kannst du auch --variable als Farbwert verwenden, um CSS3-Variablen zu verwenden. Bitte beachte, dass die Einstellung der Deckkraft in diesem Fall nicht funktioniert.\",\"filter_hint\":{\"always_drop_shadow\":\"Achtung, dieser Schatten verwendet immer {0}, wenn der Browser dies unterstützt.\",\"drop_shadow_syntax\":\"{0} unterstützt Parameter {1} und Schlüsselwort {2} nicht.\",\"avatar_inset\":\"Bitte beachte, dass die Kombination von eingesetzten und nicht eingesetzten Schatten auf Avataren zu unerwarteten Ergebnissen bei transparenten Avataren führen kann.\",\"spread_zero\":\"Schatten mit einer Streuung > 0 erscheinen so, als ob sie auf Null gesetzt wären.\",\"inset_classic\":\"Eingesetzte Schatten werden mit {0} verwendet\"},\"components\":{\"panel\":\"Panel\",\"panelHeader\":\"Panel-Kopf\",\"topBar\":\"Obere Leiste\",\"avatar\":\"Benutzer-Avatar (in der Profilansicht)\",\"avatarStatus\":\"Benutzer-Avatar (in der Beitragsanzeige)\",\"popup\":\"Dialogfenster und Hinweistexte\",\"button\":\"Schaltfläche\",\"buttonHover\":\"Schaltfläche (hover)\",\"buttonPressed\":\"Schaltfläche (gedrückt)\",\"buttonPressedHover\":\"Schaltfläche (gedrückt+hover)\",\"input\":\"Input field\"}},\"fonts\":{\"_tab_label\":\"Schriften\",\"help\":\"Wähl die Schriftart, die für Elemente der Benutzeroberfläche verwendet werden soll. Für \\\" Benutzerdefiniert\\\" musst du den genauen Schriftnamen eingeben, wie er im System angezeigt wird.\",\"components\":{\"interface\":\"Oberfläche\",\"input\":\"Eingabefelder\",\"post\":\"Beitragstext\",\"postCode\":\"Dicktengleicher Text in einem Beitrag (Rich-Text)\"},\"family\":\"Schriftname\",\"size\":\"Größe (in px)\",\"weight\":\"Gewicht (Dicke)\",\"custom\":\"Benutzerdefiniert\"},\"preview\":{\"header\":\"Vorschau\",\"content\":\"Inhalt\",\"error\":\"Beispielfehler\",\"button\":\"Schaltfläche\",\"text\":\"Ein Haufen mehr von {0} und {1}\",\"mono\":\"Inhalt\",\"input\":\"Sitze gerade im Hofbräuhaus.\",\"faint_link\":\"Hilfreiche Anleitung\",\"fine_print\":\"Lies unser {0}, um nichts Nützliches zu lernen!\",\"header_faint\":\"Das ist in Ordnung\",\"checkbox\":\"Ich habe die Allgemeinen Geschäftsbedingungen überflogen\",\"link\":\"ein netter kleiner Link\"}}},\"timeline\":{\"collapse\":\"Einklappen\",\"conversation\":\"Unterhaltung\",\"error_fetching\":\"Fehler beim Laden\",\"load_older\":\"Lade ältere Beiträge\",\"no_retweet_hint\":\"Der Beitrag ist als nur-für-Follower oder als Direktnachricht markiert und kann nicht wiederholt werden.\",\"repeated\":\"wiederholte\",\"show_new\":\"Zeige Neuere\",\"up_to_date\":\"Aktuell\"},\"user_card\":{\"approve\":\"Genehmigen\",\"block\":\"Blockieren\",\"blocked\":\"Blockiert!\",\"deny\":\"Ablehnen\",\"follow\":\"Folgen\",\"follow_sent\":\"Anfrage gesendet!\",\"follow_progress\":\"Anfragen…\",\"follow_again\":\"Anfrage erneut senden?\",\"follow_unfollow\":\"Folgen beenden\",\"followees\":\"Folgt\",\"followers\":\"Followers\",\"following\":\"Folgst du!\",\"follows_you\":\"Folgt dir!\",\"its_you\":\"Das bist du!\",\"mute\":\"Stummschalten\",\"muted\":\"Stummgeschaltet\",\"per_day\":\"pro Tag\",\"remote_follow\":\"Folgen\",\"statuses\":\"Beiträge\"},\"user_profile\":{\"timeline_title\":\"Beiträge\"},\"who_to_follow\":{\"more\":\"Mehr\",\"who_to_follow\":\"Wem soll ich folgen\"},\"tool_tip\":{\"media_upload\":\"Medien hochladen\",\"repeat\":\"Wiederholen\",\"reply\":\"Antworten\",\"favorite\":\"Favorisieren\",\"user_settings\":\"Benutzereinstellungen\"},\"upload\":{\"error\":{\"base\":\"Hochladen fehlgeschlagen.\",\"file_too_big\":\"Datei ist zu groß [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"Bitte versuche es später erneut\"},\"file_size_units\":{\"B\":\"B\",\"KiB\":\"KiB\",\"MiB\":\"MiB\",\"GiB\":\"GiB\",\"TiB\":\"TiB\"}}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/de.json\n// module id = 436\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Chat\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Media proxy\",\"scope_options\":\"Scope options\",\"text_limit\":\"Text limit\",\"title\":\"Features\",\"who_to_follow\":\"Who to follow\"},\"finder\":{\"error_fetching_user\":\"Error fetching user\",\"find_user\":\"Find user\"},\"general\":{\"apply\":\"Apply\",\"submit\":\"Submit\",\"more\":\"More\",\"generic_error\":\"An error occured\",\"optional\":\"optional\"},\"image_cropper\":{\"crop_picture\":\"Crop picture\",\"save\":\"Save\",\"cancel\":\"Cancel\"},\"login\":{\"login\":\"Log in\",\"description\":\"Log in with OAuth\",\"logout\":\"Log out\",\"password\":\"Password\",\"placeholder\":\"e.g. lain\",\"register\":\"Register\",\"username\":\"Username\",\"hint\":\"Log in to join the discussion\"},\"media_modal\":{\"previous\":\"Previous\",\"next\":\"Next\"},\"nav\":{\"about\":\"About\",\"back\":\"Back\",\"chat\":\"Local Chat\",\"friend_requests\":\"Follow Requests\",\"mentions\":\"Mentions\",\"dms\":\"Direct Messages\",\"public_tl\":\"Public Timeline\",\"timeline\":\"Timeline\",\"twkn\":\"The Whole Known Network\",\"user_search\":\"User Search\",\"who_to_follow\":\"Who to follow\",\"preferences\":\"Preferences\"},\"notifications\":{\"broken_favorite\":\"Unknown status, searching for it...\",\"favorited_you\":\"favorited your status\",\"followed_you\":\"followed you\",\"load_older\":\"Load older notifications\",\"notifications\":\"Notifications\",\"read\":\"Read!\",\"repeated_you\":\"repeated your status\",\"no_more_notifications\":\"No more notifications\"},\"post_status\":{\"new_status\":\"Post new status\",\"account_not_locked_warning\":\"Your account is not {0}. Anyone can follow you to view your follower-only posts.\",\"account_not_locked_warning_link\":\"locked\",\"attachments_sensitive\":\"Mark attachments as sensitive\",\"content_type\":{\"text/plain\":\"Plain text\",\"text/html\":\"HTML\",\"text/markdown\":\"Markdown\"},\"content_warning\":\"Subject (optional)\",\"default\":\"Just landed in L.A.\",\"direct_warning\":\"This post will only be visible to all the mentioned users.\",\"posting\":\"Posting\",\"scope\":{\"direct\":\"Direct - Post to mentioned users only\",\"private\":\"Followers-only - Post to followers only\",\"public\":\"Public - Post to public timelines\",\"unlisted\":\"Unlisted - Do not post to public timelines\"}},\"registration\":{\"bio\":\"Bio\",\"email\":\"Email\",\"fullname\":\"Display name\",\"password_confirm\":\"Password confirmation\",\"registration\":\"Registration\",\"token\":\"Invite token\",\"captcha\":\"CAPTCHA\",\"new_captcha\":\"Click the image to get a new captcha\",\"username_placeholder\":\"e.g. lain\",\"fullname_placeholder\":\"e.g. Lain Iwakura\",\"bio_placeholder\":\"e.g.\\nHi, I'm Lain\\nI’m an anime girl living in suburban Japan. You may know me from the Wired.\",\"validations\":{\"username_required\":\"cannot be left blank\",\"fullname_required\":\"cannot be left blank\",\"email_required\":\"cannot be left blank\",\"password_required\":\"cannot be left blank\",\"password_confirmation_required\":\"cannot be left blank\",\"password_confirmation_match\":\"should be the same as password\"}},\"settings\":{\"app_name\":\"App name\",\"attachmentRadius\":\"Attachments\",\"attachments\":\"Attachments\",\"autoload\":\"Enable automatic loading when scrolled to the bottom\",\"avatar\":\"Avatar\",\"avatarAltRadius\":\"Avatars (Notifications)\",\"avatarRadius\":\"Avatars\",\"background\":\"Background\",\"bio\":\"Bio\",\"blocks_tab\":\"Blocks\",\"btnRadius\":\"Buttons\",\"cBlue\":\"Blue (Reply, follow)\",\"cGreen\":\"Green (Retweet)\",\"cOrange\":\"Orange (Favorite)\",\"cRed\":\"Red (Cancel)\",\"change_password\":\"Change Password\",\"change_password_error\":\"There was an issue changing your password.\",\"changed_password\":\"Password changed successfully!\",\"collapse_subject\":\"Collapse posts with subjects\",\"composing\":\"Composing\",\"confirm_new_password\":\"Confirm new password\",\"current_avatar\":\"Your current avatar\",\"current_password\":\"Current password\",\"current_profile_banner\":\"Your current profile banner\",\"data_import_export_tab\":\"Data Import / Export\",\"default_vis\":\"Default visibility scope\",\"delete_account\":\"Delete Account\",\"delete_account_description\":\"Permanently delete your account and all your messages.\",\"delete_account_error\":\"There was an issue deleting your account. If this persists please contact your instance administrator.\",\"delete_account_instructions\":\"Type your password in the input below to confirm account deletion.\",\"avatar_size_instruction\":\"The recommended minimum size for avatar images is 150x150 pixels.\",\"export_theme\":\"Save preset\",\"filtering\":\"Filtering\",\"filtering_explanation\":\"All statuses containing these words will be muted, one per line\",\"follow_export\":\"Follow export\",\"follow_export_button\":\"Export your follows to a csv file\",\"follow_export_processing\":\"Processing, you'll soon be asked to download your file\",\"follow_import\":\"Follow import\",\"follow_import_error\":\"Error importing followers\",\"follows_imported\":\"Follows imported! Processing them will take a while.\",\"foreground\":\"Foreground\",\"general\":\"General\",\"hide_attachments_in_convo\":\"Hide attachments in conversations\",\"hide_attachments_in_tl\":\"Hide attachments in timeline\",\"max_thumbnails\":\"Maximum amount of thumbnails per post\",\"hide_isp\":\"Hide instance-specific panel\",\"preload_images\":\"Preload images\",\"use_one_click_nsfw\":\"Open NSFW attachments with just one click\",\"hide_post_stats\":\"Hide post statistics (e.g. the number of favorites)\",\"hide_user_stats\":\"Hide user statistics (e.g. the number of followers)\",\"hide_filtered_statuses\":\"Hide filtered statuses\",\"import_followers_from_a_csv_file\":\"Import follows from a csv file\",\"import_theme\":\"Load preset\",\"inputRadius\":\"Input fields\",\"checkboxRadius\":\"Checkboxes\",\"instance_default\":\"(default: {value})\",\"instance_default_simple\":\"(default)\",\"interface\":\"Interface\",\"interfaceLanguage\":\"Interface language\",\"invalid_theme_imported\":\"The selected file is not a supported Pleroma theme. No changes to your theme were made.\",\"limited_availability\":\"Unavailable in your browser\",\"links\":\"Links\",\"lock_account_description\":\"Restrict your account to approved followers only\",\"loop_video\":\"Loop videos\",\"loop_video_silent_only\":\"Loop only videos without sound (i.e. Mastodon's \\\"gifs\\\")\",\"mutes_tab\":\"Mutes\",\"play_videos_in_modal\":\"Play videos directly in the media viewer\",\"use_contain_fit\":\"Don't crop the attachment in thumbnails\",\"name\":\"Name\",\"name_bio\":\"Name & Bio\",\"new_password\":\"New password\",\"notification_visibility\":\"Types of notifications to show\",\"notification_visibility_follows\":\"Follows\",\"notification_visibility_likes\":\"Likes\",\"notification_visibility_mentions\":\"Mentions\",\"notification_visibility_repeats\":\"Repeats\",\"no_rich_text_description\":\"Strip rich text formatting from all posts\",\"no_blocks\":\"No blocks\",\"no_mutes\":\"No mutes\",\"hide_follows_description\":\"Don't show who I'm following\",\"hide_followers_description\":\"Don't show who's following me\",\"show_admin_badge\":\"Show Admin badge in my profile\",\"show_moderator_badge\":\"Show Moderator badge in my profile\",\"nsfw_clickthrough\":\"Enable clickthrough NSFW attachment hiding\",\"oauth_tokens\":\"OAuth tokens\",\"token\":\"Token\",\"refresh_token\":\"Refresh Token\",\"valid_until\":\"Valid Until\",\"revoke_token\":\"Revoke\",\"panelRadius\":\"Panels\",\"pause_on_unfocused\":\"Pause streaming when tab is not focused\",\"presets\":\"Presets\",\"profile_background\":\"Profile Background\",\"profile_banner\":\"Profile Banner\",\"profile_tab\":\"Profile\",\"radii_help\":\"Set up interface edge rounding (in pixels)\",\"replies_in_timeline\":\"Replies in timeline\",\"reply_link_preview\":\"Enable reply-link preview on mouse hover\",\"reply_visibility_all\":\"Show all replies\",\"reply_visibility_following\":\"Only show replies directed at me or users I'm following\",\"reply_visibility_self\":\"Only show replies directed at me\",\"saving_err\":\"Error saving settings\",\"saving_ok\":\"Settings saved\",\"security_tab\":\"Security\",\"scope_copy\":\"Copy scope when replying (DMs are always copied)\",\"set_new_avatar\":\"Set new avatar\",\"set_new_profile_background\":\"Set new profile background\",\"set_new_profile_banner\":\"Set new profile banner\",\"settings\":\"Settings\",\"subject_input_always_show\":\"Always show subject field\",\"subject_line_behavior\":\"Copy subject when replying\",\"subject_line_email\":\"Like email: \\\"re: subject\\\"\",\"subject_line_mastodon\":\"Like mastodon: copy as is\",\"subject_line_noop\":\"Do not copy\",\"post_status_content_type\":\"Post status content type\",\"stop_gifs\":\"Play-on-hover GIFs\",\"streaming\":\"Enable automatic streaming of new posts when scrolled to the top\",\"text\":\"Text\",\"theme\":\"Theme\",\"theme_help\":\"Use hex color codes (#rrggbb) to customize your color theme.\",\"theme_help_v2_1\":\"You can also override certain component's colors and opacity by toggling the checkbox, use \\\"Clear all\\\" button to clear all overrides.\",\"theme_help_v2_2\":\"Icons underneath some entries are background/text contrast indicators, hover over for detailed info. Please keep in mind that when using transparency contrast indicators show the worst possible case.\",\"tooltipRadius\":\"Tooltips/alerts\",\"upload_a_photo\":\"Upload a photo\",\"user_settings\":\"User Settings\",\"values\":{\"false\":\"no\",\"true\":\"yes\"},\"notifications\":\"Notifications\",\"enable_web_push_notifications\":\"Enable web push notifications\",\"style\":{\"switcher\":{\"keep_color\":\"Keep colors\",\"keep_shadows\":\"Keep shadows\",\"keep_opacity\":\"Keep opacity\",\"keep_roundness\":\"Keep roundness\",\"keep_fonts\":\"Keep fonts\",\"save_load_hint\":\"\\\"Keep\\\" options preserve currently set options when selecting or loading themes, it also stores said options when exporting a theme. When all checkboxes unset, exporting theme will save everything.\",\"reset\":\"Reset\",\"clear_all\":\"Clear all\",\"clear_opacity\":\"Clear opacity\"},\"common\":{\"color\":\"Color\",\"opacity\":\"Opacity\",\"contrast\":{\"hint\":\"Contrast ratio is {ratio}, it {level} {context}\",\"level\":{\"aa\":\"meets Level AA guideline (minimal)\",\"aaa\":\"meets Level AAA guideline (recommended)\",\"bad\":\"doesn't meet any accessibility guidelines\"},\"context\":{\"18pt\":\"for large (18pt+) text\",\"text\":\"for text\"}}},\"common_colors\":{\"_tab_label\":\"Common\",\"main\":\"Common colors\",\"foreground_hint\":\"See \\\"Advanced\\\" tab for more detailed control\",\"rgbo\":\"Icons, accents, badges\"},\"advanced_colors\":{\"_tab_label\":\"Advanced\",\"alert\":\"Alert background\",\"alert_error\":\"Error\",\"badge\":\"Badge background\",\"badge_notification\":\"Notification\",\"panel_header\":\"Panel header\",\"top_bar\":\"Top bar\",\"borders\":\"Borders\",\"buttons\":\"Buttons\",\"inputs\":\"Input fields\",\"faint_text\":\"Faded text\"},\"radii\":{\"_tab_label\":\"Roundness\"},\"shadows\":{\"_tab_label\":\"Shadow and lighting\",\"component\":\"Component\",\"override\":\"Override\",\"shadow_id\":\"Shadow #{value}\",\"blur\":\"Blur\",\"spread\":\"Spread\",\"inset\":\"Inset\",\"hint\":\"For shadows you can also use --variable as a color value to use CSS3 variables. Please note that setting opacity won't work in this case.\",\"filter_hint\":{\"always_drop_shadow\":\"Warning, this shadow always uses {0} when browser supports it.\",\"drop_shadow_syntax\":\"{0} does not support {1} parameter and {2} keyword.\",\"avatar_inset\":\"Please note that combining both inset and non-inset shadows on avatars might give unexpected results with transparent avatars.\",\"spread_zero\":\"Shadows with spread > 0 will appear as if it was set to zero\",\"inset_classic\":\"Inset shadows will be using {0}\"},\"components\":{\"panel\":\"Panel\",\"panelHeader\":\"Panel header\",\"topBar\":\"Top bar\",\"avatar\":\"User avatar (in profile view)\",\"avatarStatus\":\"User avatar (in post display)\",\"popup\":\"Popups and tooltips\",\"button\":\"Button\",\"buttonHover\":\"Button (hover)\",\"buttonPressed\":\"Button (pressed)\",\"buttonPressedHover\":\"Button (pressed+hover)\",\"input\":\"Input field\"}},\"fonts\":{\"_tab_label\":\"Fonts\",\"help\":\"Select font to use for elements of UI. For \\\"custom\\\" you have to enter exact font name as it appears in system.\",\"components\":{\"interface\":\"Interface\",\"input\":\"Input fields\",\"post\":\"Post text\",\"postCode\":\"Monospaced text in a post (rich text)\"},\"family\":\"Font name\",\"size\":\"Size (in px)\",\"weight\":\"Weight (boldness)\",\"custom\":\"Custom\"},\"preview\":{\"header\":\"Preview\",\"content\":\"Content\",\"error\":\"Example error\",\"button\":\"Button\",\"text\":\"A bunch of more {0} and {1}\",\"mono\":\"content\",\"input\":\"Just landed in L.A.\",\"faint_link\":\"helpful manual\",\"fine_print\":\"Read our {0} to learn nothing useful!\",\"header_faint\":\"This is fine\",\"checkbox\":\"I have skimmed over terms and conditions\",\"link\":\"a nice lil' link\"}}},\"timeline\":{\"collapse\":\"Collapse\",\"conversation\":\"Conversation\",\"error_fetching\":\"Error fetching updates\",\"load_older\":\"Load older statuses\",\"no_retweet_hint\":\"Post is marked as followers-only or direct and cannot be repeated\",\"repeated\":\"repeated\",\"show_new\":\"Show new\",\"up_to_date\":\"Up-to-date\",\"no_more_statuses\":\"No more statuses\",\"no_statuses\":\"No statuses\"},\"status\":{\"reply_to\":\"Reply to\",\"replies_list\":\"Replies:\"},\"user_card\":{\"approve\":\"Approve\",\"block\":\"Block\",\"blocked\":\"Blocked!\",\"deny\":\"Deny\",\"favorites\":\"Favorites\",\"follow\":\"Follow\",\"follow_sent\":\"Request sent!\",\"follow_progress\":\"Requesting…\",\"follow_again\":\"Send request again?\",\"follow_unfollow\":\"Unfollow\",\"followees\":\"Following\",\"followers\":\"Followers\",\"following\":\"Following!\",\"follows_you\":\"Follows you!\",\"its_you\":\"It's you!\",\"media\":\"Media\",\"mute\":\"Mute\",\"muted\":\"Muted\",\"per_day\":\"per day\",\"remote_follow\":\"Remote follow\",\"statuses\":\"Statuses\",\"unblock\":\"Unblock\",\"unblock_progress\":\"Unblocking...\",\"block_progress\":\"Blocking...\",\"unmute\":\"Unmute\",\"unmute_progress\":\"Unmuting...\",\"mute_progress\":\"Muting...\"},\"user_profile\":{\"timeline_title\":\"User Timeline\",\"profile_does_not_exist\":\"Sorry, this profile does not exist.\",\"profile_loading_error\":\"Sorry, there was an error loading this profile.\"},\"who_to_follow\":{\"more\":\"More\",\"who_to_follow\":\"Who to follow\"},\"tool_tip\":{\"media_upload\":\"Upload Media\",\"repeat\":\"Repeat\",\"reply\":\"Reply\",\"favorite\":\"Favorite\",\"user_settings\":\"User Settings\"},\"upload\":{\"error\":{\"base\":\"Upload failed.\",\"file_too_big\":\"File too big [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"Try again later\"},\"file_size_units\":{\"B\":\"B\",\"KiB\":\"KiB\",\"MiB\":\"MiB\",\"GiB\":\"GiB\",\"TiB\":\"TiB\"}}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/en.json\n// module id = 437\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Babilejo\"},\"features_panel\":{\"chat\":\"Babilejo\",\"gopher\":\"Gopher\",\"media_proxy\":\"Aŭdvidaĵa prokurilo\",\"scope_options\":\"Agordoj de amplekso\",\"text_limit\":\"Teksta limo\",\"title\":\"Funkcioj\",\"who_to_follow\":\"Kiun aboni\"},\"finder\":{\"error_fetching_user\":\"Eraro alportante uzanton\",\"find_user\":\"Trovi uzanton\"},\"general\":{\"apply\":\"Apliki\",\"submit\":\"Sendi\",\"more\":\"Pli\",\"generic_error\":\"Eraro okazis\",\"optional\":\"Malnepra\"},\"image_cropper\":{\"crop_picture\":\"Tondi bildon\",\"save\":\"Konservi\",\"cancel\":\"Nuligi\"},\"login\":{\"login\":\"Saluti\",\"description\":\"Saluti per OAuth\",\"logout\":\"Adiaŭi\",\"password\":\"Pasvorto\",\"placeholder\":\"ekz. lain\",\"register\":\"Registriĝi\",\"username\":\"Salutnomo\",\"hint\":\"Salutu por partopreni la diskutadon\"},\"media_modal\":{\"previous\":\"Antaŭa\",\"next\":\"Sekva\"},\"nav\":{\"about\":\"Pri\",\"back\":\"Reen\",\"chat\":\"Loka babilejo\",\"friend_requests\":\"Abonaj petoj\",\"mentions\":\"Mencioj\",\"dms\":\"Rektaj mesaĝoj\",\"public_tl\":\"Publika tempolinio\",\"timeline\":\"Tempolinio\",\"twkn\":\"La tuta konata reto\",\"user_search\":\"Serĉi uzantojn\",\"who_to_follow\":\"Kiun aboni\",\"preferences\":\"Agordoj\"},\"notifications\":{\"broken_favorite\":\"Nekonata stato, serĉante ĝin…\",\"favorited_you\":\"ŝatis vian staton\",\"followed_you\":\"ekabonis vin\",\"load_older\":\"Enlegi pli malnovajn sciigojn\",\"notifications\":\"Sciigoj\",\"read\":\"Legite!\",\"repeated_you\":\"ripetis vian staton\",\"no_more_notifications\":\"Neniuj pliaj sciigoj\"},\"post_status\":{\"new_status\":\"Afiŝi novan staton\",\"account_not_locked_warning\":\"Via konto ne estas {0}. Iu ajn povas vin aboni por vidi viajn afiŝoj nur por abonantoj.\",\"account_not_locked_warning_link\":\"ŝlosita\",\"attachments_sensitive\":\"Marki kunsendaĵojn kiel konsternajn\",\"content_type\":{\"plain_text\":\"Plata teksto\"},\"content_warning\":\"Temo (malnepra)\",\"default\":\"Ĵus alvenis al la Universala Kongreso!\",\"direct_warning\":\"Ĉi tiu afiŝo estos videbla nur por ĉiuj menciitaj uzantoj.\",\"posting\":\"Afiŝante\",\"scope\":{\"direct\":\"Rekta – Afiŝi nur al menciitaj uzantoj\",\"private\":\"Nur abonantoj – Afiŝi nur al abonantoj\",\"public\":\"Publika – Afiŝi al publikaj tempolinioj\",\"unlisted\":\"Nelistigita – Ne afiŝi al publikaj tempolinioj\"}},\"registration\":{\"bio\":\"Priskribo\",\"email\":\"Retpoŝtadreso\",\"fullname\":\"Vidiga nomo\",\"password_confirm\":\"Konfirmo de pasvorto\",\"registration\":\"Registriĝo\",\"token\":\"Invita ĵetono\",\"captcha\":\"TESTO DE HOMECO\",\"new_captcha\":\"Alklaku la bildon por akiri novan teston\",\"username_placeholder\":\"ekz. lain\",\"fullname_placeholder\":\"ekz. Lain Iwakura\",\"bio_placeholder\":\"ekz.\\nSaluton, mi estas Lain\\nMi estas animea knabino vivante en Japanujo. Eble vi konas min de la retejo « Wired ».\",\"validations\":{\"username_required\":\"ne povas resti malplena\",\"fullname_required\":\"ne povas resti malplena\",\"email_required\":\"ne povas resti malplena\",\"password_required\":\"ne povas resti malplena\",\"password_confirmation_required\":\"ne povas resti malplena\",\"password_confirmation_match\":\"samu la pasvorton\"}},\"settings\":{\"app_name\":\"Nomo de aplikaĵo\",\"attachmentRadius\":\"Kunsendaĵoj\",\"attachments\":\"Kunsendaĵoj\",\"autoload\":\"Ŝalti memfaran enlegadon ĉe subo de paĝo\",\"avatar\":\"Profilbildo\",\"avatarAltRadius\":\"Profilbildoj (sciigoj)\",\"avatarRadius\":\"Profilbildoj\",\"background\":\"Fono\",\"bio\":\"Priskribo\",\"blocks_tab\":\"Baroj\",\"btnRadius\":\"Butonoj\",\"cBlue\":\"Blua (Respondo, abono)\",\"cGreen\":\"Verda (Kunhavigo)\",\"cOrange\":\"Oranĝa (Ŝato)\",\"cRed\":\"Ruĝa (Nuligo)\",\"change_password\":\"Ŝanĝi pasvorton\",\"change_password_error\":\"Okazis eraro dum ŝanĝo de via pasvorto.\",\"changed_password\":\"Pasvorto sukcese ŝanĝiĝis!\",\"collapse_subject\":\"Maletendi afiŝojn kun temoj\",\"composing\":\"Verkante\",\"confirm_new_password\":\"Konfirmu novan pasvorton\",\"current_avatar\":\"Via nuna profilbildo\",\"current_password\":\"Nuna pasvorto\",\"current_profile_banner\":\"Via nuna profila rubando\",\"data_import_export_tab\":\"Enporto / Elporto de datenoj\",\"default_vis\":\"Implicita videbleca amplekso\",\"delete_account\":\"Forigi konton\",\"delete_account_description\":\"Por ĉiam forigi vian konton kaj ĉiujn viajn mesaĝojn\",\"delete_account_error\":\"Okazis eraro dum forigo de via kanto. Se tio daŭre okazados, bonvolu kontakti la administranton de via nodo.\",\"delete_account_instructions\":\"Entajpu sube vian pasvorton por konfirmi forigon de konto.\",\"avatar_size_instruction\":\"La rekomendata malpleja grando de profilbildoj estas 150×150 bilderoj.\",\"export_theme\":\"Konservi antaŭagordon\",\"filtering\":\"Filtrado\",\"filtering_explanation\":\"Ĉiuj statoj kun tiuj ĉi vortoj silentiĝos, po unu linio\",\"follow_export\":\"Abona elporto\",\"follow_export_button\":\"Elporti viajn abonojn al CSV-dosiero\",\"follow_export_processing\":\"Traktante; baldaŭ vi ricevos peton elŝuti la dosieron\",\"follow_import\":\"Abona enporto\",\"follow_import_error\":\"Eraro enportante abonojn\",\"follows_imported\":\"Abonoj enportiĝis! Traktado daŭros iom.\",\"foreground\":\"Malfono\",\"general\":\"Ĝenerala\",\"hide_attachments_in_convo\":\"Kaŝi kunsendaĵojn en interparoloj\",\"hide_attachments_in_tl\":\"Kaŝi kunsendaĵojn en tempolinio\",\"max_thumbnails\":\"Plej multa nombro da bildetoj po afiŝo\",\"hide_isp\":\"Kaŝi nodo-propran breton\",\"preload_images\":\"Antaŭ-enlegi bildojn\",\"use_one_click_nsfw\":\"Malfermi konsternajn kunsendaĵojn per nur unu klako\",\"hide_post_stats\":\"Kaŝi statistikon de afiŝoj (ekz. nombron da ŝatoj)\",\"hide_user_stats\":\"Kaŝi statistikon de uzantoj (ekz. nombron da abonantoj)\",\"hide_filtered_statuses\":\"Kaŝi filtritajn statojn\",\"import_followers_from_a_csv_file\":\"Enporti abonojn el CSV-dosiero\",\"import_theme\":\"Enlegi antaŭagordojn\",\"inputRadius\":\"Enigaj kampoj\",\"checkboxRadius\":\"Markbutonoj\",\"instance_default\":\"(implicita: {value})\",\"instance_default_simple\":\"(implicita)\",\"interface\":\"Fasado\",\"interfaceLanguage\":\"Lingvo de fasado\",\"invalid_theme_imported\":\"La elektita dosiero ne estas subtenata haŭto de Pleromo. Neniuj ŝanĝoj al via haŭto okazis.\",\"limited_availability\":\"Nehavebla en via foliumilo\",\"links\":\"Ligiloj\",\"lock_account_description\":\"Limigi vian konton al nur abonantoj aprobitaj\",\"loop_video\":\"Ripetadi filmojn\",\"loop_video_silent_only\":\"Ripetadi nur filmojn sen sono (ekz. la \\\"GIF-ojn\\\" de Mastodon)\",\"mutes_tab\":\"Silentigoj\",\"play_videos_in_modal\":\"Ludi filmojn rekte en la aŭdvidaĵa spektilo\",\"use_contain_fit\":\"Ne tondi la kunsendaĵon en bildetoj\",\"name\":\"Nomo\",\"name_bio\":\"Nomo kaj priskribo\",\"new_password\":\"Nova pasvorto\",\"notification_visibility\":\"Montrotaj specoj de sciigoj\",\"notification_visibility_follows\":\"Abonoj\",\"notification_visibility_likes\":\"Ŝatoj\",\"notification_visibility_mentions\":\"Mencioj\",\"notification_visibility_repeats\":\"Ripetoj\",\"no_rich_text_description\":\"Forigi riĉtekstajn formojn de ĉiuj afiŝoj\",\"no_blocks\":\"Neniuj baroj\",\"no_mutes\":\"Neniuj silentigoj\",\"hide_follows_description\":\"Ne montri kiun mi sekvas\",\"hide_followers_description\":\"Ne montri kiu min sekvas\",\"show_admin_badge\":\"Montri la insignon de administranto en mia profilo\",\"show_moderator_badge\":\"Montri la insignon de kontrolanto en mia profilo\",\"nsfw_clickthrough\":\"Ŝalti traklakan kaŝon de konsternaj kunsendaĵoj\",\"oauth_tokens\":\"Ĵetonoj de OAuth\",\"token\":\"Ĵetono\",\"refresh_token\":\"Ĵetono de novigo\",\"valid_until\":\"Valida ĝis\",\"revoke_token\":\"Senvalidigi\",\"panelRadius\":\"Bretoj\",\"pause_on_unfocused\":\"Paŭzigi elsendfluon kiam langeto ne estas fokusata\",\"presets\":\"Antaŭagordoj\",\"profile_background\":\"Profila fono\",\"profile_banner\":\"Profila rubando\",\"profile_tab\":\"Profilo\",\"radii_help\":\"Agordi fasadan rondigon de randoj (bildere)\",\"replies_in_timeline\":\"Respondoj en tempolinio\",\"reply_link_preview\":\"Ŝalti respond-ligilan antaŭvidon dum musa ŝvebo\",\"reply_visibility_all\":\"Montri ĉiujn respondojn\",\"reply_visibility_following\":\"Montri nur respondojn por mi aŭ miaj abonatoj\",\"reply_visibility_self\":\"Montri nur respondojn por mi\",\"saving_err\":\"Eraro dum konservo de agordoj\",\"saving_ok\":\"Agordoj konserviĝis\",\"security_tab\":\"Sekureco\",\"scope_copy\":\"Kopii amplekson por respondo (rektaj mesaĝoj ĉiam kopiiĝas)\",\"set_new_avatar\":\"Agordi novan profilbildon\",\"set_new_profile_background\":\"Agordi novan profilan fonon\",\"set_new_profile_banner\":\"Agordi novan profilan rubandon\",\"settings\":\"Agordoj\",\"subject_input_always_show\":\"Ĉiam montri teman kampon\",\"subject_line_behavior\":\"Kopii temon por respondo\",\"subject_line_email\":\"Kiel retpoŝto: \\\"re: temo\\\"\",\"subject_line_mastodon\":\"Kiel Mastodon: kopii senŝanĝe\",\"subject_line_noop\":\"Ne kopii\",\"post_status_content_type\":\"Afiŝi specon de la enhavo de la stato\",\"stop_gifs\":\"Movi GIF-bildojn dum musa ŝvebo\",\"streaming\":\"Ŝalti memfaran fluigon de novaj afiŝoj ĉe la supro de la paĝo\",\"text\":\"Teksto\",\"theme\":\"Haŭto\",\"theme_help\":\"Uzu deksesumajn kolorkodojn (#rrvvbb) por adapti vian koloran haŭton.\",\"theme_help_v2_1\":\"Vi ankaŭ povas superagordi la kolorojn kaj travideblecon de kelkaj eroj per marko de la markbutono; uzu la butonon \\\"Vakigi ĉion\\\" por forigi ĉîujn superagordojn.\",\"theme_help_v2_2\":\"Bildsimboloj sub kelkaj eroj estas indikiloj de kontrasto inter fono kaj teksto; muse ŝvebu por detalaj informoj. Bonvolu memori, ke la indikilo montras la plej malbonan okazeblon dum sia uzo.\",\"tooltipRadius\":\"Ŝpruchelpiloj/avertoj\",\"upload_a_photo\":\"Alŝuti foton\",\"user_settings\":\"Agordoj de uzanto\",\"values\":{\"false\":\"ne\",\"true\":\"jes\"},\"notifications\":\"Sciigoj\",\"enable_web_push_notifications\":\"Ŝalti retajn puŝajn sciigojn\",\"style\":{\"switcher\":{\"keep_color\":\"Konservi kolorojn\",\"keep_shadows\":\"Konservi ombrojn\",\"keep_opacity\":\"Konservi maltravideblecon\",\"keep_roundness\":\"Konservi rondecon\",\"keep_fonts\":\"Konservi tiparojn\",\"save_load_hint\":\"Elektebloj de \\\"konservi\\\" konservas la nuntempajn agordojn dum elektado aŭ enlegado de haŭtoj. Ĝi ankaŭ konservas tiujn agordojn dum elportado de haŭto. Kun ĉiuj markbutonoj nemarkitaj, elporto de la haŭto ĉion konservos.\",\"reset\":\"Restarigi\",\"clear_all\":\"Vakigi ĉion\",\"clear_opacity\":\"Vakigi maltravideblecon\"},\"common\":{\"color\":\"Koloro\",\"opacity\":\"Maltravidebleco\",\"contrast\":{\"hint\":\"Proporcio de kontrasto estas {ratio}, ĝi {level} {context}\",\"level\":{\"aa\":\"plenumas la gvidilon je nivelo AA (malpleja)\",\"aaa\":\"plenumas la gvidilon je nivela AAA (rekomendita)\",\"bad\":\"plenumas neniujn faciluzajn gvidilojn\"},\"context\":{\"18pt\":\"por granda (18pt+) teksto\",\"text\":\"por teksto\"}}},\"common_colors\":{\"_tab_label\":\"Komunaj\",\"main\":\"Komunaj koloroj\",\"foreground_hint\":\"Vidu langeton \\\"Specialaj\\\" por pli detalaj agordoj\",\"rgbo\":\"Bildsimboloj, emfazoj, insignoj\"},\"advanced_colors\":{\"_tab_label\":\"Specialaj\",\"alert\":\"Averta fono\",\"alert_error\":\"Eraro\",\"badge\":\"Insigna fono\",\"badge_notification\":\"Sciigo\",\"panel_header\":\"Kapo de breto\",\"top_bar\":\"Supra breto\",\"borders\":\"Limoj\",\"buttons\":\"Butonoj\",\"inputs\":\"Enigaj kampoj\",\"faint_text\":\"Malvigla teksto\"},\"radii\":{\"_tab_label\":\"Rondeco\"},\"shadows\":{\"_tab_label\":\"Ombro kaj lumo\",\"component\":\"Ero\",\"override\":\"Transpasi\",\"shadow_id\":\"Ombro #{value}\",\"blur\":\"Malklarigo\",\"spread\":\"Vastigo\",\"inset\":\"Internigo\",\"hint\":\"Por ombroj vi ankaŭ povas uzi --variable kiel koloran valoron, por uzi variantojn de CSS3. Bonvolu rimarki, ke tiuokaze agordoj de maltravidebleco ne funkcios.\",\"filter_hint\":{\"always_drop_shadow\":\"Averto: ĉi tiu ombro ĉiam uzas {0} kiam la foliumilo ĝin subtenas.\",\"drop_shadow_syntax\":\"{0} ne subtenas parametron {1} kaj ŝlosilvorton {2}.\",\"avatar_inset\":\"Bonvolu rimarki, ke agordi ambaŭ internajn kaj eksterajn ombrojn por profilbildoj povas redoni neatenditajn rezultojn ĉe profilbildoj travideblaj.\",\"spread_zero\":\"Ombroj kun vastigo > 0 aperos kvazaŭ ĝi estus fakte nulo\",\"inset_classic\":\"Internaj ombroj uzos {0}\"},\"components\":{\"panel\":\"Breto\",\"panelHeader\":\"Kapo de breto\",\"topBar\":\"Supra breto\",\"avatar\":\"Profilbildo de uzanto (en profila vido)\",\"avatarStatus\":\"Profilbildo de uzanto (en afiŝa vido)\",\"popup\":\"Ŝprucaĵoj\",\"button\":\"Butono\",\"buttonHover\":\"Butono (je ŝvebo)\",\"buttonPressed\":\"Butono (premita)\",\"buttonPressedHover\":\"Butono (premita je ŝvebo)\",\"input\":\"Eniga kampo\"}},\"fonts\":{\"_tab_label\":\"Tiparoj\",\"help\":\"Elektu tiparon uzotan por eroj de la fasado. Por \\\"propra\\\" vi devas enigi la precizan nomon de tiparo tiel, kiel ĝi aperas en la sistemo\",\"components\":{\"interface\":\"Fasado\",\"input\":\"Enigaj kampoj\",\"post\":\"Teksto de afiŝo\",\"postCode\":\"Egallarĝa teksto en afiŝo (riĉteksto)\"},\"family\":\"Nomo de tiparo\",\"size\":\"Grando (en bilderoj)\",\"weight\":\"Pezo (graseco)\",\"custom\":\"Propra\"},\"preview\":{\"header\":\"Antaŭrigardo\",\"content\":\"Enhavo\",\"error\":\"Ekzempla eraro\",\"button\":\"Butono\",\"text\":\"Kelko da pliaj {0} kaj {1}\",\"mono\":\"enhavo\",\"input\":\"Ĵus alvenis al la Universala Kongreso!\",\"faint_link\":\"helpan manlibron\",\"fine_print\":\"Legu nian {0} por nenion utilan ekscii!\",\"header_faint\":\"Tio estas en ordo\",\"checkbox\":\"Mi legetis la kondiĉojn de uzado\",\"link\":\"bela eta ligil’\"}}},\"timeline\":{\"collapse\":\"Maletendi\",\"conversation\":\"Interparolo\",\"error_fetching\":\"Eraro dum ĝisdatigo\",\"load_older\":\"Montri pli malnovajn statojn\",\"no_retweet_hint\":\"Afiŝo estas markita kiel rekta aŭ nur por abonantoj, kaj ne eblas ĝin ripeti\",\"repeated\":\"ripetita\",\"show_new\":\"Montri novajn\",\"up_to_date\":\"Ĝisdata\",\"no_more_statuses\":\"Neniuj pliaj statoj\",\"no_statuses\":\"Neniuj statoj\"},\"user_card\":{\"approve\":\"Aprobi\",\"block\":\"Bari\",\"blocked\":\"Barita!\",\"deny\":\"Rifuzi\",\"favorites\":\"Ŝatataj\",\"follow\":\"Aboni\",\"follow_sent\":\"Peto sendiĝis!\",\"follow_progress\":\"Petanta…\",\"follow_again\":\"Ĉu sendi peton denove?\",\"follow_unfollow\":\"Malaboni\",\"followees\":\"Abonatoj\",\"followers\":\"Abonantoj\",\"following\":\"Abonanta!\",\"follows_you\":\"Abonas vin!\",\"its_you\":\"Tio estas vi!\",\"media\":\"Aŭdvidaĵoj\",\"mute\":\"Silentigi\",\"muted\":\"Silentigitaj\",\"per_day\":\"tage\",\"remote_follow\":\"Fore aboni\",\"statuses\":\"Statoj\",\"unblock\":\"Malbari\",\"unblock_progress\":\"Malbaranta…\",\"block_progress\":\"Baranta…\",\"unmute\":\"Malsilentigi\",\"unmute_progress\":\"Malsilentiganta…\",\"mute_progress\":\"Silentiganta…\"},\"user_profile\":{\"timeline_title\":\"Uzanta tempolinio\",\"profile_does_not_exist\":\"Pardonu, ĉi tiu profilo ne ekzistas.\",\"profile_loading_error\":\"Pardonu, eraro okazis dum enlegado de ĉi tiu profilo.\"},\"who_to_follow\":{\"more\":\"Pli\",\"who_to_follow\":\"Kiun aboni\"},\"tool_tip\":{\"media_upload\":\"Alŝuti aŭdvidaĵon\",\"repeat\":\"Ripeti\",\"reply\":\"Respondi\",\"favorite\":\"Ŝati\",\"user_settings\":\"Agordoj de uzanto\"},\"upload\":{\"error\":{\"base\":\"Alŝuto malsukcesis.\",\"file_too_big\":\"Dosiero estas tro granda [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"Reprovu pli poste\"},\"file_size_units\":{\"B\":\"B\",\"KiB\":\"KiB\",\"MiB\":\"MiB\",\"GiB\":\"GiB\",\"TiB\":\"TiB\"}}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/eo.json\n// module id = 438\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Chat\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Media proxy\",\"scope_options\":\"Opciones del alcance de la visibilidad\",\"text_limit\":\"Límite de carácteres\",\"title\":\"Características\",\"who_to_follow\":\"A quién seguir\"},\"finder\":{\"error_fetching_user\":\"Error al buscar usuario\",\"find_user\":\"Encontrar usuario\"},\"general\":{\"apply\":\"Aplicar\",\"submit\":\"Enviar\",\"more\":\"Más\",\"generic_error\":\"Ha ocurrido un error\"},\"login\":{\"login\":\"Identificación\",\"description\":\"Identificación con OAuth\",\"logout\":\"Salir\",\"password\":\"Contraseña\",\"placeholder\":\"p.ej. lain\",\"register\":\"Registrar\",\"username\":\"Usuario\",\"hint\":\"Inicia sesión para unirte a la discusión\"},\"nav\":{\"about\":\"Sobre\",\"back\":\"Volver\",\"chat\":\"Chat Local\",\"friend_requests\":\"Solicitudes de amistad\",\"mentions\":\"Menciones\",\"dms\":\"Mensajes Directo\",\"public_tl\":\"Línea Temporal Pública\",\"timeline\":\"Línea Temporal\",\"twkn\":\"Toda La Red Conocida\",\"user_search\":\"Búsqueda de Usuarios\",\"who_to_follow\":\"A quién seguir\",\"preferences\":\"Preferencias\"},\"notifications\":{\"broken_favorite\":\"Estado desconocido, buscándolo...\",\"favorited_you\":\"le gusta tu estado\",\"followed_you\":\"empezó a seguirte\",\"load_older\":\"Cargar notificaciones antiguas\",\"notifications\":\"Notificaciones\",\"read\":\"¡Leído!\",\"repeated_you\":\"repite tu estado\",\"no_more_notifications\":\"No hay más notificaciones\"},\"post_status\":{\"new_status\":\"Publicar un nuevo estado\",\"account_not_locked_warning\":\"Tu cuenta no está {0}. Cualquiera puede seguirte y leer las entradas para Solo-Seguidores.\",\"account_not_locked_warning_link\":\"bloqueada\",\"attachments_sensitive\":\"Contenido sensible\",\"content_type\":{\"plain_text\":\"Texto Plano\"},\"content_warning\":\"Tema (opcional)\",\"default\":\"Acabo de aterrizar en L.A.\",\"direct_warning\":\"Esta entrada solo será visible para los usuarios mencionados.\",\"posting\":\"Publicando\",\"scope\":{\"direct\":\"Directo - Solo para los usuarios mencionados.\",\"private\":\"Solo-Seguidores - Solo tus seguidores leeran la entrada\",\"public\":\"Público - Entradas visibles en las Líneas Temporales Públicas\",\"unlisted\":\"Sin Listar - Entradas no visibles en las Líneas Temporales Públicas\"}},\"registration\":{\"bio\":\"Biografía\",\"email\":\"Correo electrónico\",\"fullname\":\"Nombre a mostrar\",\"password_confirm\":\"Confirmación de contraseña\",\"registration\":\"Registro\",\"token\":\"Token de invitación\",\"captcha\":\"CAPTCHA\",\"new_captcha\":\"Click en la imagen para obtener un nuevo captca\",\"validations\":{\"username_required\":\"no puede estar vacío\",\"fullname_required\":\"no puede estar vacío\",\"email_required\":\"no puede estar vacío\",\"password_required\":\"no puede estar vacío\",\"password_confirmation_required\":\"no puede estar vacío\",\"password_confirmation_match\":\"la contraseña no coincide\"}},\"settings\":{\"attachmentRadius\":\"Adjuntos\",\"attachments\":\"Adjuntos\",\"autoload\":\"Activar carga automática al llegar al final de la página\",\"avatar\":\"Avatar\",\"avatarAltRadius\":\"Avatares (Notificaciones)\",\"avatarRadius\":\"Avatares\",\"background\":\"Fondo\",\"bio\":\"Biografía\",\"btnRadius\":\"Botones\",\"cBlue\":\"Azul (Responder, seguir)\",\"cGreen\":\"Verde (Retweet)\",\"cOrange\":\"Naranja (Favorito)\",\"cRed\":\"Rojo (Cancelar)\",\"change_password\":\"Cambiar contraseña\",\"change_password_error\":\"Hubo un problema cambiando la contraseña.\",\"changed_password\":\"Contraseña cambiada correctamente!\",\"collapse_subject\":\"Colapsar entradas con tema\",\"composing\":\"Redactando\",\"confirm_new_password\":\"Confirmar la nueva contraseña\",\"current_avatar\":\"Tu avatar actual\",\"current_password\":\"Contraseña actual\",\"current_profile_banner\":\"Tu cabecera actual\",\"data_import_export_tab\":\"Importar / Exportar Datos\",\"default_vis\":\"Alcance de visibilidad por defecto\",\"delete_account\":\"Eliminar la cuenta\",\"delete_account_description\":\"Eliminar para siempre la cuenta y todos los mensajes.\",\"delete_account_error\":\"Hubo un error al eliminar tu cuenta. Si el fallo persiste, ponte en contacto con el administrador de tu instancia.\",\"delete_account_instructions\":\"Escribe tu contraseña para confirmar la eliminación de tu cuenta.\",\"avatar_size_instruction\":\"El tamaño mínimo recomendado para el avatar es de 150X150 píxeles.\",\"export_theme\":\"Exportar tema\",\"filtering\":\"Filtros\",\"filtering_explanation\":\"Todos los estados que contengan estas palabras serán silenciados, una por línea\",\"follow_export\":\"Exportar personas que tú sigues\",\"follow_export_button\":\"Exporta tus seguidores a un archivo csv\",\"follow_export_processing\":\"Procesando, en breve se te preguntará para guardar el archivo\",\"follow_import\":\"Importar personas que tú sigues\",\"follow_import_error\":\"Error al importal el archivo\",\"follows_imported\":\"¡Importado! Procesarlos llevará tiempo.\",\"foreground\":\"Primer plano\",\"general\":\"General\",\"hide_attachments_in_convo\":\"Ocultar adjuntos en las conversaciones\",\"hide_attachments_in_tl\":\"Ocultar adjuntos en la línea temporal\",\"hide_isp\":\"Ocultar el panel específico de la instancia\",\"preload_images\":\"Precargar las imágenes\",\"use_one_click_nsfw\":\"Abrir los adjuntos NSFW con un solo click.\",\"hide_post_stats\":\"Ocultar las estadísticas de las entradas (p.ej. el número de favoritos)\",\"hide_user_stats\":\"Ocultar las estadísticas del usuario (p.ej. el número de seguidores)\",\"hide_filtered_statuses\":\"Ocultar estados filtrados\",\"import_followers_from_a_csv_file\":\"Importar personas que tú sigues a partir de un archivo csv\",\"import_theme\":\"Importar tema\",\"inputRadius\":\"Campos de entrada\",\"checkboxRadius\":\"Casillas de verificación\",\"instance_default\":\"(por defecto: {value})\",\"instance_default_simple\":\"(por defecto)\",\"interface\":\"Interfaz\",\"interfaceLanguage\":\"Idioma\",\"invalid_theme_imported\":\"El archivo importado no es un tema válido de Pleroma. No se han realizado cambios.\",\"limited_availability\":\"No disponible en tu navegador\",\"links\":\"Enlaces\",\"lock_account_description\":\"Restringir el acceso a tu cuenta solo a seguidores admitidos\",\"loop_video\":\"Vídeos en bucle\",\"loop_video_silent_only\":\"Bucle solo en vídeos sin sonido (p.ej. \\\"gifs\\\" de Mastodon)\",\"play_videos_in_modal\":\"Reproducir los vídeos directamente en el visor de medios\",\"use_contain_fit\":\"No recortar los adjuntos en miniaturas\",\"name\":\"Nombre\",\"name_bio\":\"Nombre y Biografía\",\"new_password\":\"Nueva contraseña\",\"notification_visibility\":\"Tipos de notificaciones a mostrar\",\"notification_visibility_follows\":\"Nuevos seguidores\",\"notification_visibility_likes\":\"Me gustan (Likes)\",\"notification_visibility_mentions\":\"Menciones\",\"notification_visibility_repeats\":\"Repeticiones (Repeats)\",\"no_rich_text_description\":\"Eliminar el formato de texto enriquecido de todas las entradas\",\"hide_follows_description\":\"No mostrar a quién sigo\",\"hide_followers_description\":\"No mostrar quién me sigue\",\"show_admin_badge\":\"Mostrar la placa de administrador en mi perfil\",\"show_moderator_badge\":\"Mostrar la placa de moderador en mi perfil\",\"nsfw_clickthrough\":\"Activar el clic para ocultar los adjuntos NSFW\",\"oauth_tokens\":\"Tokens de OAuth\",\"token\":\"Token\",\"refresh_token\":\"Actualizar el token\",\"valid_until\":\"Válido hasta\",\"revoke_token\":\"Revocar\",\"panelRadius\":\"Paneles\",\"pause_on_unfocused\":\"Parar la transmisión cuando no estés en foco.\",\"presets\":\"Por defecto\",\"profile_background\":\"Fondo del Perfil\",\"profile_banner\":\"Cabecera del Perfil\",\"profile_tab\":\"Perfil\",\"radii_help\":\"Estable el redondeo de las esquinas del interfaz (en píxeles)\",\"replies_in_timeline\":\"Réplicas en la línea temporal\",\"reply_link_preview\":\"Activar la previsualización del enlace de responder al pasar el ratón por encim\",\"reply_visibility_all\":\"Mostrar todas las réplicas\",\"reply_visibility_following\":\"Solo mostrar réplicas para mí o usuarios a los que sigo\",\"reply_visibility_self\":\"Solo mostrar réplicas para mí\",\"saving_err\":\"Error al guardar los ajustes\",\"saving_ok\":\"Ajustes guardados\",\"security_tab\":\"Seguridad\",\"scope_copy\":\"Copiar la visibilidad cuando contestamos (En los mensajes directos (MDs) siempre se copia)\",\"set_new_avatar\":\"Cambiar avatar\",\"set_new_profile_background\":\"Cambiar fondo del perfil\",\"set_new_profile_banner\":\"Cambiar cabecera del perfil\",\"settings\":\"Ajustes\",\"subject_input_always_show\":\"Mostrar siempre el campo del tema\",\"subject_line_behavior\":\"Copiar el tema en las contestaciones\",\"subject_line_email\":\"Tipo email: \\\"re: tema\\\"\",\"subject_line_mastodon\":\"Tipo mastodon: copiar como es\",\"subject_line_noop\":\"No copiar\",\"post_status_content_type\":\"Formato de publicación\",\"stop_gifs\":\"Iniciar GIFs al pasar el ratón\",\"streaming\":\"Habilite la transmisión automática de nuevas publicaciones cuando se desplaza hacia la parte superior\",\"text\":\"Texto\",\"theme\":\"Tema\",\"theme_help\":\"Use códigos de color hexadecimales (#rrggbb) para personalizar su tema de colores.\",\"theme_help_v2_1\":\"También puede invalidar los colores y la opacidad de ciertos componentes si activa la casilla de verificación, use el botón \\\"Borrar todo\\\" para deshacer los cambios.\",\"theme_help_v2_2\":\"Los iconos debajo de algunas entradas son indicadores de contraste de fondo/texto, desplace el ratón para obtener información detallada. Tenga en cuenta que cuando se utilizan indicadores de contraste de transparencia se muestra el peor caso posible.\",\"tooltipRadius\":\"Información/alertas\",\"user_settings\":\"Ajustes de Usuario\",\"values\":{\"false\":\"no\",\"true\":\"sí\"},\"notifications\":\"Notificaciones\",\"enable_web_push_notifications\":\"Habilitar las notificiaciones en el navegador\",\"style\":{\"switcher\":{\"keep_color\":\"Mantener colores\",\"keep_shadows\":\"Mantener sombras\",\"keep_opacity\":\"Mantener opacidad\",\"keep_roundness\":\"Mantener redondeces\",\"keep_fonts\":\"Mantener fuentes\",\"save_load_hint\":\"Las opciones \\\"Mantener\\\" conservan las opciones configuradas actualmente al seleccionar o cargar temas, también almacena dichas opciones al exportar un tema. Cuando se desactiven todas las casillas de verificación, el tema de exportación lo guardará todo.\",\"reset\":\"Reiniciar\",\"clear_all\":\"Limpiar todo\",\"clear_opacity\":\"Limpiar opacidad\"},\"common\":{\"color\":\"Color\",\"opacity\":\"Opacidad\",\"contrast\":{\"hint\":\"El ratio de contraste es {ratio}. {level} {context}\",\"level\":{\"aa\":\"Cumple con la pauta de nivel AA (mínimo)\",\"aaa\":\"Cumple con la pauta de nivel AAA (recomendado)\",\"bad\":\"No cumple con las pautas de accesibilidad\"},\"context\":{\"18pt\":\"para textos grandes (+18pt)\",\"text\":\"para textos\"}}},\"common_colors\":{\"_tab_label\":\"Común\",\"main\":\"Colores comunes\",\"foreground_hint\":\"Vea la pestaña \\\"Avanzado\\\" para un control más detallado\",\"rgbo\":\"Iconos, acentos, insignias\"},\"advanced_colors\":{\"_tab_label\":\"Avanzado\",\"alert\":\"Fondo de Alertas\",\"alert_error\":\"Error\",\"badge\":\"Fondo de Insignias\",\"badge_notification\":\"Notificaciones\",\"panel_header\":\"Cabecera del panel\",\"top_bar\":\"Barra superior\",\"borders\":\"Bordes\",\"buttons\":\"Botones\",\"inputs\":\"Campos de entrada\",\"faint_text\":\"Texto desvanecido\"},\"radii\":{\"_tab_label\":\"Redondez\"},\"shadows\":{\"_tab_label\":\"Sombra e iluminación\",\"component\":\"Componente\",\"override\":\"Sobreescribir\",\"shadow_id\":\"Sombra #{value}\",\"blur\":\"Difuminar\",\"spread\":\"Cantidad\",\"inset\":\"Insertada\",\"hint\":\"Para las sombras, también puede usar --variable como un valor de color para usar las variables CSS3. Tenga en cuenta que establecer la opacidad no funcionará en este caso.\",\"filter_hint\":{\"always_drop_shadow\":\"Advertencia, esta sombra siempre usa {0} cuando el navegador lo soporta.\",\"drop_shadow_syntax\":\"{0} no soporta el parámetro {1} y la palabra clave {2}.\",\"avatar_inset\":\"Tenga en cuenta que la combinación de sombras insertadas como no-insertadas en los avatares, puede dar resultados inesperados con los avatares transparentes.\",\"spread_zero\":\"Sombras con una cantidad > 0 aparecerá como si estuviera puesto a cero\",\"inset_classic\":\"Las sombras insertadas estarán usando {0}\"},\"components\":{\"panel\":\"Panel\",\"panelHeader\":\"Cabecera del panel\",\"topBar\":\"Barra superior\",\"avatar\":\"Avatar del usuario (en la vista del perfil)\",\"avatarStatus\":\"Avatar del usuario (en la vista de la entrada)\",\"popup\":\"Ventanas y textos emergentes (popups & tooltips)\",\"button\":\"Botones\",\"buttonHover\":\"Botón (encima)\",\"buttonPressed\":\"Botón (presionado)\",\"buttonPressedHover\":\"Botón (presionado+encima)\",\"input\":\"Campo de entrada\"}},\"fonts\":{\"_tab_label\":\"Fuentes\",\"help\":\"Seleccione la fuente para utilizar para los elementos de la interfaz de usuario. Para \\\"personalizado\\\", debe ingresar el nombre exacto de la fuente tal como aparece en el sistema.\",\"components\":{\"interface\":\"Interfaz\",\"input\":\"Campos de entrada\",\"post\":\"Texto de publicaciones\",\"postCode\":\"Texto monoespaciado en publicación (texto enriquecido)\"},\"family\":\"Nombre de la fuente\",\"size\":\"Tamaño (en px)\",\"weight\":\"Peso (negrita)\",\"custom\":\"Personalizado\"},\"preview\":{\"header\":\"Vista previa\",\"content\":\"Contenido\",\"error\":\"Ejemplo de error\",\"button\":\"Botón\",\"text\":\"Un montón de {0} y {1}\",\"mono\":\"contenido\",\"input\":\"Acaba de aterrizar en L.A.\",\"faint_link\":\"manual útil\",\"fine_print\":\"¡Lea nuestro {0} para aprender nada útil!\",\"header_faint\":\"Esto está bien\",\"checkbox\":\"He revisado los términos y condiciones\",\"link\":\"un bonito enlace\"}}},\"timeline\":{\"collapse\":\"Colapsar\",\"conversation\":\"Conversación\",\"error_fetching\":\"Error al cargar las actualizaciones\",\"load_older\":\"Cargar actualizaciones anteriores\",\"no_retweet_hint\":\"La publicación está marcada como solo para seguidores o directa y no se puede repetir\",\"repeated\":\"repetida\",\"show_new\":\"Mostrar lo nuevo\",\"up_to_date\":\"Actualizado\",\"no_more_statuses\":\"No hay más estados\"},\"user_card\":{\"approve\":\"Aprovar\",\"block\":\"Bloquear\",\"blocked\":\"¡Bloqueado!\",\"deny\":\"Denegar\",\"favorites\":\"Favoritos\",\"follow\":\"Seguir\",\"follow_sent\":\"¡Solicitud enviada!\",\"follow_progress\":\"Solicitando…\",\"follow_again\":\"¿Enviar solicitud de nuevo?\",\"follow_unfollow\":\"Dejar de seguir\",\"followees\":\"Siguiendo\",\"followers\":\"Seguidores\",\"following\":\"¡Siguiendo!\",\"follows_you\":\"¡Te sigue!\",\"its_you\":\"¡Eres tú!\",\"media\":\"Media\",\"mute\":\"Silenciar\",\"muted\":\"Silenciado\",\"per_day\":\"por día\",\"remote_follow\":\"Seguir\",\"statuses\":\"Estados\"},\"user_profile\":{\"timeline_title\":\"Linea temporal del usuario\"},\"who_to_follow\":{\"more\":\"Más\",\"who_to_follow\":\"A quién seguir\"},\"tool_tip\":{\"media_upload\":\"Subir Medios\",\"repeat\":\"Repetir\",\"reply\":\"Contestar\",\"favorite\":\"Favorito\",\"user_settings\":\"Ajustes de usuario\"},\"upload\":{\"error\":{\"base\":\"Subida fallida.\",\"file_too_big\":\"Archivo demasiado grande [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"Inténtalo más tarde\"},\"file_size_units\":{\"B\":\"B\",\"KiB\":\"KiB\",\"MiB\":\"MiB\",\"GiB\":\"GiB\",\"TiB\":\"TiB\"}}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/es.json\n// module id = 439\n// module chunks = 2","module.exports = {\"finder\":{\"error_fetching_user\":\"Viga kasutaja leidmisel\",\"find_user\":\"Otsi kasutajaid\"},\"general\":{\"submit\":\"Postita\"},\"login\":{\"login\":\"Logi sisse\",\"logout\":\"Logi välja\",\"password\":\"Parool\",\"placeholder\":\"nt lain\",\"register\":\"Registreeru\",\"username\":\"Kasutajanimi\"},\"nav\":{\"mentions\":\"Mainimised\",\"public_tl\":\"Avalik Ajajoon\",\"timeline\":\"Ajajoon\",\"twkn\":\"Kogu Teadaolev Võrgustik\"},\"notifications\":{\"followed_you\":\"alustas sinu jälgimist\",\"notifications\":\"Teavitused\",\"read\":\"Loe!\"},\"post_status\":{\"default\":\"Just sõitsin elektrirongiga Tallinnast Pääskülla.\",\"posting\":\"Postitan\"},\"registration\":{\"bio\":\"Bio\",\"email\":\"E-post\",\"fullname\":\"Kuvatav nimi\",\"password_confirm\":\"Parooli kinnitamine\",\"registration\":\"Registreerimine\"},\"settings\":{\"attachments\":\"Manused\",\"autoload\":\"Luba ajajoone automaatne uuendamine kui ajajoon on põhja keritud\",\"avatar\":\"Profiilipilt\",\"bio\":\"Bio\",\"current_avatar\":\"Sinu praegune profiilipilt\",\"current_profile_banner\":\"Praegune profiilibänner\",\"filtering\":\"Sisu filtreerimine\",\"filtering_explanation\":\"Kõiki staatuseid, mis sisaldavad neid sõnu, ei kuvata. Üks sõna reale.\",\"hide_attachments_in_convo\":\"Peida manused vastlustes\",\"hide_attachments_in_tl\":\"Peida manused ajajoonel\",\"name\":\"Nimi\",\"name_bio\":\"Nimi ja Bio\",\"nsfw_clickthrough\":\"Peida tööks-mittesobivad(NSFW) manuste hiireklõpsu taha\",\"profile_background\":\"Profiilitaust\",\"profile_banner\":\"Profiilibänner\",\"reply_link_preview\":\"Luba algpostituse kuvamine vastustes\",\"set_new_avatar\":\"Vali uus profiilipilt\",\"set_new_profile_background\":\"Vali uus profiilitaust\",\"set_new_profile_banner\":\"Vali uus profiilibänner\",\"settings\":\"Sätted\",\"theme\":\"Teema\",\"user_settings\":\"Kasutaja sätted\"},\"timeline\":{\"conversation\":\"Vestlus\",\"error_fetching\":\"Viga uuenduste laadimisel\",\"load_older\":\"Kuva vanemaid staatuseid\",\"show_new\":\"Näita uusi\",\"up_to_date\":\"Uuendatud\"},\"user_card\":{\"block\":\"Blokeeri\",\"blocked\":\"Blokeeritud!\",\"follow\":\"Jälgi\",\"followees\":\"Jälgitavaid\",\"followers\":\"Jälgijaid\",\"following\":\"Jälgin!\",\"follows_you\":\"Jälgib sind!\",\"mute\":\"Vaigista\",\"muted\":\"Vaigistatud\",\"per_day\":\"päevas\",\"statuses\":\"Staatuseid\"}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/et.json\n// module id = 440\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Chat\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Media-välityspalvelin\",\"scope_options\":\"Näkyvyyden rajaus\",\"text_limit\":\"Tekstin pituusraja\",\"title\":\"Ominaisuudet\",\"who_to_follow\":\"Seurausehdotukset\"},\"finder\":{\"error_fetching_user\":\"Virhe hakiessa käyttäjää\",\"find_user\":\"Hae käyttäjä\"},\"general\":{\"apply\":\"Aseta\",\"submit\":\"Lähetä\",\"more\":\"Lisää\",\"generic_error\":\"Virhe tapahtui\"},\"login\":{\"login\":\"Kirjaudu sisään\",\"description\":\"Kirjaudu sisään OAuthilla\",\"logout\":\"Kirjaudu ulos\",\"password\":\"Salasana\",\"placeholder\":\"esim. Seppo\",\"register\":\"Rekisteröidy\",\"username\":\"Käyttäjänimi\"},\"nav\":{\"about\":\"Tietoja\",\"back\":\"Takaisin\",\"chat\":\"Paikallinen Chat\",\"friend_requests\":\"Seurauspyynnöt\",\"mentions\":\"Maininnat\",\"dms\":\"Yksityisviestit\",\"public_tl\":\"Julkinen Aikajana\",\"timeline\":\"Aikajana\",\"twkn\":\"Koko Tunnettu Verkosto\",\"user_search\":\"Käyttäjähaku\",\"who_to_follow\":\"Seurausehdotukset\",\"preferences\":\"Asetukset\"},\"notifications\":{\"broken_favorite\":\"Viestiä ei löydetty...\",\"favorited_you\":\"tykkäsi viestistäsi\",\"followed_you\":\"seuraa sinua\",\"load_older\":\"Lataa vanhempia ilmoituksia\",\"notifications\":\"Ilmoitukset\",\"read\":\"Lue!\",\"repeated_you\":\"toisti viestisi\",\"no_more_notifications\":\"Ei enempää ilmoituksia\"},\"post_status\":{\"new_status\":\"Uusi viesti\",\"account_not_locked_warning\":\"Tilisi ei ole {0}. Kuka vain voi seurata sinua nähdäksesi 'vain-seuraajille' -viestisi\",\"account_not_locked_warning_link\":\"lukittu\",\"attachments_sensitive\":\"Merkkaa liitteet arkaluonteisiksi\",\"content_type\":{\"plain_text\":\"Tavallinen teksti\"},\"content_warning\":\"Aihe (valinnainen)\",\"default\":\"Tulin juuri saunasta.\",\"direct_warning\":\"Tämä viesti näkyy vain mainituille käyttäjille.\",\"posting\":\"Lähetetään\",\"scope\":{\"direct\":\"Yksityisviesti - Näkyy vain mainituille käyttäjille\",\"private\":\"Vain-seuraajille - Näkyy vain seuraajillesi\",\"public\":\"Julkinen - Näkyy julkisilla aikajanoilla\",\"unlisted\":\"Listaamaton - Ei näy julkisilla aikajanoilla\"}},\"registration\":{\"bio\":\"Kuvaus\",\"email\":\"Sähköposti\",\"fullname\":\"Koko nimi\",\"password_confirm\":\"Salasanan vahvistaminen\",\"registration\":\"Rekisteröityminen\",\"token\":\"Kutsuvaltuus\",\"captcha\":\"Varmenne\",\"new_captcha\":\"Paina kuvaa saadaksesi uuden varmenteen\",\"validations\":{\"username_required\":\"ei voi olla tyhjä\",\"fullname_required\":\"ei voi olla tyhjä\",\"email_required\":\"ei voi olla tyhjä\",\"password_required\":\"ei voi olla tyhjä\",\"password_confirmation_required\":\"ei voi olla tyhjä\",\"password_confirmation_match\":\"pitää vastata salasanaa\"}},\"settings\":{\"attachmentRadius\":\"Liitteet\",\"attachments\":\"Liitteet\",\"autoload\":\"Lataa vanhempia viestejä automaattisesti ruudun pohjalla\",\"avatar\":\"Profiilikuva\",\"avatarAltRadius\":\"Profiilikuvat (ilmoitukset)\",\"avatarRadius\":\"Profiilikuvat\",\"background\":\"Tausta\",\"bio\":\"Kuvaus\",\"btnRadius\":\"Napit\",\"cBlue\":\"Sininen (Vastaukset, seuraukset)\",\"cGreen\":\"Vihreä (Toistot)\",\"cOrange\":\"Oranssi (Tykkäykset)\",\"cRed\":\"Punainen (Peruminen)\",\"change_password\":\"Vaihda salasana\",\"change_password_error\":\"Virhe vaihtaessa salasanaa.\",\"changed_password\":\"Salasana vaihdettu!\",\"collapse_subject\":\"Minimoi viestit, joille on asetettu aihe\",\"composing\":\"Viestien laatiminen\",\"confirm_new_password\":\"Vahvista uusi salasana\",\"current_avatar\":\"Nykyinen profiilikuvasi\",\"current_password\":\"Nykyinen salasana\",\"current_profile_banner\":\"Nykyinen julisteesi\",\"data_import_export_tab\":\"Tietojen tuonti / vienti\",\"default_vis\":\"Oletusnäkyvyysrajaus\",\"delete_account\":\"Poista tili\",\"delete_account_description\":\"Poista tilisi ja viestisi pysyvästi.\",\"delete_account_error\":\"Virhe poistaessa tiliäsi. Jos virhe jatkuu, ota yhteyttä palvelimesi ylläpitoon.\",\"delete_account_instructions\":\"Syötä salasanasi vahvistaaksesi tilin poiston.\",\"export_theme\":\"Tallenna teema\",\"filtering\":\"Suodatus\",\"filtering_explanation\":\"Kaikki viestit, jotka sisältävät näitä sanoja, suodatetaan. Yksi sana per rivi.\",\"follow_export\":\"Seurausten vienti\",\"follow_export_button\":\"Vie seurauksesi CSV-tiedostoon\",\"follow_export_processing\":\"Käsitellään, sinua pyydetään lataamaan tiedosto hetken päästä\",\"follow_import\":\"Seurausten tuonti\",\"follow_import_error\":\"Virhe tuodessa seuraksia\",\"follows_imported\":\"Seuraukset tuotu! Niiden käsittely vie hetken.\",\"foreground\":\"Korostus\",\"general\":\"Yleinen\",\"hide_attachments_in_convo\":\"Piilota liitteet keskusteluissa\",\"hide_attachments_in_tl\":\"Piilota liitteet aikajanalla\",\"max_thumbnails\":\"Suurin sallittu määrä liitteitä esikatselussa\",\"hide_isp\":\"Piilota palvelimenkohtainen ruutu\",\"preload_images\":\"Esilataa kuvat\",\"use_one_click_nsfw\":\"Avaa NSFW-liitteet yhdellä painalluksella\",\"hide_post_stats\":\"Piilota viestien statistiikka (esim. tykkäysten määrä)\",\"hide_user_stats\":\"Piilota käyttäjien statistiikka (esim. seuraajien määrä)\",\"import_followers_from_a_csv_file\":\"Tuo seuraukset CSV-tiedostosta\",\"import_theme\":\"Tuo tallennettu teema\",\"inputRadius\":\"Syöttökentät\",\"checkboxRadius\":\"Valintalaatikot\",\"instance_default\":\"(oletus: {value})\",\"instance_default_simple\":\"(oletus)\",\"interface\":\"Käyttöliittymä\",\"interfaceLanguage\":\"Käyttöliittymän kieli\",\"invalid_theme_imported\":\"Tuotu tallennettu teema on epäkelpo, muutoksia ei tehty nykyiseen teemaasi.\",\"limited_availability\":\"Ei saatavilla selaimessasi\",\"links\":\"Linkit\",\"lock_account_description\":\"Vain erikseen hyväksytyt käyttäjät voivat seurata tiliäsi\",\"loop_video\":\"Uudelleentoista videot\",\"loop_video_silent_only\":\"Uudelleentoista ainoastaan äänettömät videot (Video-\\\"giffit\\\")\",\"play_videos_in_modal\":\"Toista videot modaalissa\",\"use_contain_fit\":\"Älä rajaa liitteitä esikatselussa\",\"name\":\"Nimi\",\"name_bio\":\"Nimi ja kuvaus\",\"new_password\":\"Uusi salasana\",\"notification_visibility\":\"Ilmoitusten näkyvyys\",\"notification_visibility_follows\":\"Seuraukset\",\"notification_visibility_likes\":\"Tykkäykset\",\"notification_visibility_mentions\":\"Maininnat\",\"notification_visibility_repeats\":\"Toistot\",\"no_rich_text_description\":\"Älä näytä tekstin muotoilua.\",\"hide_network_description\":\"Älä näytä seurauksiani tai seuraajiani\",\"nsfw_clickthrough\":\"Piilota NSFW liitteet klikkauksen taakse\",\"oauth_tokens\":\"OAuth-merkit\",\"token\":\"Token\",\"refresh_token\":\"Päivitä token\",\"valid_until\":\"Voimassa asti\",\"revoke_token\":\"Peruuttaa\",\"panelRadius\":\"Ruudut\",\"pause_on_unfocused\":\"Pysäytä automaattinen viestien näyttö välilehden ollessa pois fokuksesta\",\"presets\":\"Valmiit teemat\",\"profile_background\":\"Taustakuva\",\"profile_banner\":\"Juliste\",\"profile_tab\":\"Profiili\",\"radii_help\":\"Aseta reunojen pyöristys (pikseleinä)\",\"replies_in_timeline\":\"Keskustelut aikajanalla\",\"reply_link_preview\":\"Keskusteluiden vastauslinkkien esikatselu\",\"reply_visibility_all\":\"Näytä kaikki vastaukset\",\"reply_visibility_following\":\"Näytä vain vastaukset minulle tai seuraamilleni käyttäjille\",\"reply_visibility_self\":\"Näytä vain vastaukset minulle\",\"saving_err\":\"Virhe tallentaessa asetuksia\",\"saving_ok\":\"Asetukset tallennettu\",\"security_tab\":\"Tietoturva\",\"scope_copy\":\"Kopioi näkyvyysrajaus vastatessa (Yksityisviestit aina kopioivat)\",\"set_new_avatar\":\"Aseta uusi profiilikuva\",\"set_new_profile_background\":\"Aseta uusi taustakuva\",\"set_new_profile_banner\":\"Aseta uusi juliste\",\"settings\":\"Asetukset\",\"subject_input_always_show\":\"Näytä aihe-kenttä\",\"subject_line_behavior\":\"Aihe-kentän kopiointi\",\"subject_line_email\":\"Kuten sähköposti: \\\"re: aihe\\\"\",\"subject_line_mastodon\":\"Kopioi sellaisenaan\",\"subject_line_noop\":\"Älä kopioi\",\"stop_gifs\":\"Toista giffit vain kohdistaessa\",\"streaming\":\"Näytä uudet viestit automaattisesti ollessasi ruudun huipulla\",\"text\":\"Teksti\",\"theme\":\"Teema\",\"theme_help\":\"Käytä heksadesimaalivärejä muokataksesi väriteemaasi.\",\"theme_help_v2_1\":\"Voit asettaa tiettyjen osien värin tai läpinäkyvyyden täyttämällä valintalaatikon, käytä \\\"Tyhjennä kaikki\\\"-nappia tyhjentääksesi kaiken.\",\"theme_help_v2_2\":\"Ikonit kenttien alla ovat kontrasti-indikaattoreita, lisätietoa kohdistamalla. Käyttäessä läpinäkyvyyttä ne näyttävät pahimman skenaarion.\",\"tooltipRadius\":\"Ohje- tai huomioviestit\",\"user_settings\":\"Käyttäjän asetukset\",\"values\":{\"false\":\"pois päältä\",\"true\":\"päällä\"}},\"timeline\":{\"collapse\":\"Sulje\",\"conversation\":\"Keskustelu\",\"error_fetching\":\"Virhe ladatessa viestejä\",\"load_older\":\"Lataa vanhempia viestejä\",\"no_retweet_hint\":\"Viesti ei ole julkinen, eikä sitä voi toistaa\",\"repeated\":\"toisti\",\"show_new\":\"Näytä uudet\",\"up_to_date\":\"Ajantasalla\",\"no_more_statuses\":\"Ei enempää viestejä\"},\"status\":{\"reply_to\":\"Vastaus\",\"replies_list\":\"Vastaukset:\"},\"user_card\":{\"approve\":\"Hyväksy\",\"block\":\"Estä\",\"blocked\":\"Estetty!\",\"deny\":\"Älä hyväksy\",\"follow\":\"Seuraa\",\"follow_sent\":\"Pyyntö lähetetty!\",\"follow_progress\":\"Pyydetään...\",\"follow_again\":\"Lähetä pyyntö uudestaan\",\"follow_unfollow\":\"Älä seuraa\",\"followees\":\"Seuraa\",\"followers\":\"Seuraajat\",\"following\":\"Seuraat!\",\"follows_you\":\"Seuraa sinua!\",\"its_you\":\"Sinun tili!\",\"mute\":\"Hiljennä\",\"muted\":\"Hiljennetty\",\"per_day\":\"päivässä\",\"remote_follow\":\"Seuraa muualta\",\"statuses\":\"Viestit\"},\"user_profile\":{\"timeline_title\":\"Käyttäjän aikajana\"},\"who_to_follow\":{\"more\":\"Lisää\",\"who_to_follow\":\"Seurausehdotukset\"},\"tool_tip\":{\"media_upload\":\"Lataa tiedosto\",\"repeat\":\"Toista\",\"reply\":\"Vastaa\",\"favorite\":\"Tykkää\",\"user_settings\":\"Käyttäjäasetukset\"},\"upload\":{\"error\":{\"base\":\"Lataus epäonnistui.\",\"file_too_big\":\"Tiedosto liian suuri [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"Yritä uudestaan myöhemmin\"},\"file_size_units\":{\"B\":\"tavua\",\"KiB\":\"kt\",\"MiB\":\"Mt\",\"GiB\":\"Gt\",\"TiB\":\"Tt\"}}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/fi.json\n// module id = 441\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Chat\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Proxy média\",\"scope_options\":\"Options de visibilité\",\"text_limit\":\"Limite du texte\",\"title\":\"Caractéristiques\",\"who_to_follow\":\"Qui s'abonner\"},\"finder\":{\"error_fetching_user\":\"Erreur lors de la recherche de l'utilisateur\",\"find_user\":\"Chercher un utilisateur\"},\"general\":{\"apply\":\"Appliquer\",\"submit\":\"Envoyer\"},\"login\":{\"login\":\"Connexion\",\"description\":\"Connexion avec OAuth\",\"logout\":\"Déconnexion\",\"password\":\"Mot de passe\",\"placeholder\":\"p.e. lain\",\"register\":\"S'inscrire\",\"username\":\"Identifiant\"},\"nav\":{\"chat\":\"Chat local\",\"friend_requests\":\"Demandes d'ami\",\"dms\":\"Messages adressés\",\"mentions\":\"Notifications\",\"public_tl\":\"Statuts locaux\",\"timeline\":\"Journal\",\"twkn\":\"Le réseau connu\"},\"notifications\":{\"broken_favorite\":\"Chargement d'un message inconnu ...\",\"favorited_you\":\"a aimé votre statut\",\"followed_you\":\"a commencé à vous suivre\",\"load_older\":\"Charger les notifications précédentes\",\"notifications\":\"Notifications\",\"read\":\"Lu !\",\"repeated_you\":\"a partagé votre statut\"},\"post_status\":{\"account_not_locked_warning\":\"Votre compte n'est pas {0}. N'importe qui peut vous suivre pour voir vos billets en Abonné·e·s uniquement.\",\"account_not_locked_warning_link\":\"verrouillé\",\"attachments_sensitive\":\"Marquer le média comme sensible\",\"content_type\":{\"plain_text\":\"Texte brut\"},\"content_warning\":\"Sujet (optionnel)\",\"default\":\"Écrivez ici votre prochain statut.\",\"direct_warning\":\"Ce message sera visible à toutes les personnes mentionnées.\",\"posting\":\"Envoi en cours\",\"scope\":{\"direct\":\"Direct - N'envoyer qu'aux personnes mentionnées\",\"private\":\"Abonné·e·s uniquement - Seul·e·s vos abonné·e·s verront vos billets\",\"public\":\"Publique - Afficher dans les fils publics\",\"unlisted\":\"Non-Listé - Ne pas afficher dans les fils publics\"}},\"registration\":{\"bio\":\"Biographie\",\"email\":\"Adresse email\",\"fullname\":\"Pseudonyme\",\"password_confirm\":\"Confirmation du mot de passe\",\"registration\":\"Inscription\",\"token\":\"Jeton d'invitation\"},\"settings\":{\"attachmentRadius\":\"Pièces jointes\",\"attachments\":\"Pièces jointes\",\"autoload\":\"Charger la suite automatiquement une fois le bas de la page atteint\",\"avatar\":\"Avatar\",\"avatarAltRadius\":\"Avatars (Notifications)\",\"avatarRadius\":\"Avatars\",\"background\":\"Arrière-plan\",\"bio\":\"Biographie\",\"btnRadius\":\"Boutons\",\"cBlue\":\"Bleu (Répondre, suivre)\",\"cGreen\":\"Vert (Partager)\",\"cOrange\":\"Orange (Aimer)\",\"cRed\":\"Rouge (Annuler)\",\"change_password\":\"Changez votre mot de passe\",\"change_password_error\":\"Il y a eu un problème pour changer votre mot de passe.\",\"changed_password\":\"Mot de passe modifié avec succès !\",\"collapse_subject\":\"Réduire les messages avec des sujets\",\"confirm_new_password\":\"Confirmation du nouveau mot de passe\",\"current_avatar\":\"Avatar actuel\",\"current_password\":\"Mot de passe actuel\",\"current_profile_banner\":\"Bannière de profil actuelle\",\"data_import_export_tab\":\"Import / Export des Données\",\"default_vis\":\"Portée de visibilité par défaut\",\"delete_account\":\"Supprimer le compte\",\"delete_account_description\":\"Supprimer définitivement votre compte et tous vos statuts.\",\"delete_account_error\":\"Il y a eu un problème lors de la tentative de suppression de votre compte. Si le problème persiste, contactez l'administrateur de cette instance.\",\"delete_account_instructions\":\"Indiquez votre mot de passe ci-dessous pour confirmer la suppression de votre compte.\",\"export_theme\":\"Enregistrer le thème\",\"filtering\":\"Filtre\",\"filtering_explanation\":\"Tous les statuts contenant ces mots seront masqués. Un mot par ligne\",\"follow_export\":\"Exporter les abonnements\",\"follow_export_button\":\"Exporter les abonnements en csv\",\"follow_export_processing\":\"Exportation en cours…\",\"follow_import\":\"Importer des abonnements\",\"follow_import_error\":\"Erreur lors de l'importation des abonnements\",\"follows_imported\":\"Abonnements importés ! Le traitement peut prendre un moment.\",\"foreground\":\"Premier plan\",\"general\":\"Général\",\"hide_attachments_in_convo\":\"Masquer les pièces jointes dans les conversations\",\"hide_attachments_in_tl\":\"Masquer les pièces jointes dans le journal\",\"hide_post_stats\":\"Masquer les statistiques de publication (le nombre de favoris)\",\"hide_user_stats\":\"Masquer les statistiques de profil (le nombre d'amis)\",\"import_followers_from_a_csv_file\":\"Importer des abonnements depuis un fichier csv\",\"import_theme\":\"Charger le thème\",\"inputRadius\":\"Champs de texte\",\"instance_default\":\"(default: {value})\",\"instance_default_simple\":\"(default)\",\"interfaceLanguage\":\"Langue de l'interface\",\"invalid_theme_imported\":\"Le fichier sélectionné n'est pas un thème Pleroma pris en charge. Aucun changement n'a été apporté à votre thème.\",\"limited_availability\":\"Non disponible dans votre navigateur\",\"links\":\"Liens\",\"lock_account_description\":\"Limitez votre compte aux abonnés acceptés uniquement\",\"loop_video\":\"Vidéos en boucle\",\"loop_video_silent_only\":\"Boucle uniquement les vidéos sans le son (les «gifs» de Mastodon)\",\"name\":\"Nom\",\"name_bio\":\"Nom & Bio\",\"new_password\":\"Nouveau mot de passe\",\"no_rich_text_description\":\"Ne formatez pas le texte\",\"notification_visibility\":\"Types de notifications à afficher\",\"notification_visibility_follows\":\"Abonnements\",\"notification_visibility_likes\":\"J’aime\",\"notification_visibility_mentions\":\"Mentionnés\",\"notification_visibility_repeats\":\"Partages\",\"nsfw_clickthrough\":\"Masquer les images marquées comme contenu adulte ou sensible\",\"oauth_tokens\":\"Jetons OAuth\",\"token\":\"Jeton\",\"refresh_token\":\"Refresh Token\",\"valid_until\":\"Valable jusque\",\"revoke_token\":\"Révoquer\",\"panelRadius\":\"Fenêtres\",\"pause_on_unfocused\":\"Suspendre le streaming lorsque l'onglet n'est pas centré\",\"presets\":\"Thèmes prédéfinis\",\"profile_background\":\"Image de fond\",\"profile_banner\":\"Bannière de profil\",\"profile_tab\":\"Profil\",\"radii_help\":\"Vous pouvez ici choisir le niveau d'arrondi des angles de l'interface (en pixels)\",\"replies_in_timeline\":\"Réponses au journal\",\"reply_link_preview\":\"Afficher un aperçu lors du survol de liens vers une réponse\",\"reply_visibility_all\":\"Montrer toutes les réponses\",\"reply_visibility_following\":\"Afficher uniquement les réponses adressées à moi ou aux utilisateurs que je suis\",\"reply_visibility_self\":\"Afficher uniquement les réponses adressées à moi\",\"saving_err\":\"Erreur lors de l'enregistrement des paramètres\",\"saving_ok\":\"Paramètres enregistrés\",\"security_tab\":\"Sécurité\",\"set_new_avatar\":\"Changer d'avatar\",\"set_new_profile_background\":\"Changer d'image de fond\",\"set_new_profile_banner\":\"Changer de bannière\",\"settings\":\"Paramètres\",\"stop_gifs\":\"N'animer les GIFS que lors du survol du curseur de la souris\",\"streaming\":\"Charger automatiquement les nouveaux statuts lorsque vous êtes au haut de la page\",\"text\":\"Texte\",\"theme\":\"Thème\",\"theme_help\":\"Spécifiez des codes couleur hexadécimaux (#rrvvbb) pour personnaliser les couleurs du thème.\",\"tooltipRadius\":\"Info-bulles/alertes\",\"user_settings\":\"Paramètres utilisateur\",\"values\":{\"false\":\"non\",\"true\":\"oui\"}},\"timeline\":{\"collapse\":\"Fermer\",\"conversation\":\"Conversation\",\"error_fetching\":\"Erreur en cherchant les mises à jour\",\"load_older\":\"Afficher plus\",\"no_retweet_hint\":\"Le message est marqué en abonnés-seulement ou direct et ne peut pas être répété\",\"repeated\":\"a partagé\",\"show_new\":\"Afficher plus\",\"up_to_date\":\"À jour\"},\"user_card\":{\"approve\":\"Accepter\",\"block\":\"Bloquer\",\"blocked\":\"Bloqué !\",\"deny\":\"Rejeter\",\"follow\":\"Suivre\",\"followees\":\"Suivis\",\"followers\":\"Vous suivent\",\"following\":\"Suivi !\",\"follows_you\":\"Vous suit !\",\"mute\":\"Masquer\",\"muted\":\"Masqué\",\"per_day\":\"par jour\",\"remote_follow\":\"Suivre d'une autre instance\",\"statuses\":\"Statuts\"},\"user_profile\":{\"timeline_title\":\"Journal de l'utilisateur\"},\"who_to_follow\":{\"more\":\"Plus\",\"who_to_follow\":\"Qui s'abonner\"}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/fr.json\n// module id = 442\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Comhrá\"},\"features_panel\":{\"chat\":\"Comhrá\",\"gopher\":\"Gófar\",\"media_proxy\":\"Seachfhreastalaí meáin\",\"scope_options\":\"Rogha scóip\",\"text_limit\":\"Teorainn Téacs\",\"title\":\"Gnéithe\",\"who_to_follow\":\"Daoine le leanúint\"},\"finder\":{\"error_fetching_user\":\"Earráid a aimsiú d'úsáideoir\",\"find_user\":\"Aimsigh úsáideoir\"},\"general\":{\"apply\":\"Feidhmigh\",\"submit\":\"Deimhnigh\"},\"login\":{\"login\":\"Logáil isteach\",\"logout\":\"Logáil amach\",\"password\":\"Pasfhocal\",\"placeholder\":\"m.sh. Daire\",\"register\":\"Clárú\",\"username\":\"Ainm Úsáideora\"},\"nav\":{\"chat\":\"Comhrá Áitiúil\",\"friend_requests\":\"Iarratas ar Cairdeas\",\"mentions\":\"Tagairt\",\"public_tl\":\"Amlíne Poiblí\",\"timeline\":\"Amlíne\",\"twkn\":\"An Líonra Iomlán\"},\"notifications\":{\"broken_favorite\":\"Post anaithnid. Cuardach dó...\",\"favorited_you\":\"toghadh le do phost\",\"followed_you\":\"lean tú\",\"load_older\":\"Luchtaigh fógraí aosta\",\"notifications\":\"Fógraí\",\"read\":\"Léigh!\",\"repeated_you\":\"athphostáil tú\"},\"post_status\":{\"account_not_locked_warning\":\"Níl do chuntas {0}. Is féidir le duine ar bith a leanúint leat chun do phoist leantacha amháin a fheiceáil.\",\"account_not_locked_warning_link\":\"faoi glas\",\"attachments_sensitive\":\"Marcáil ceangaltán mar íogair\",\"content_type\":{\"plain_text\":\"Gnáth-théacs\"},\"content_warning\":\"Teideal (roghnach)\",\"default\":\"Lá iontach anseo i nGaillimh\",\"direct_warning\":\"Ní bheidh an post seo le feiceáil ach amháin do na húsáideoirí atá luaite.\",\"posting\":\"Post nua\",\"scope\":{\"direct\":\"Díreach - Post chuig úsáideoirí luaite amháin\",\"private\":\"Leanúna amháin - Post chuig lucht leanúna amháin\",\"public\":\"Poiblí - Post chuig amlínte poiblí\",\"unlisted\":\"Neamhliostaithe - Ná cuir post chuig amlínte poiblí\"}},\"registration\":{\"bio\":\"Scéal saoil\",\"email\":\"Ríomhphost\",\"fullname\":\"Ainm taispeána'\",\"password_confirm\":\"Deimhnigh do pasfhocal\",\"registration\":\"Clárú\",\"token\":\"Cód cuireadh\"},\"settings\":{\"attachmentRadius\":\"Ceangaltáin\",\"attachments\":\"Ceangaltáin\",\"autoload\":\"Cumasaigh luchtú uathoibríoch nuair a scrollaítear go bun\",\"avatar\":\"Phictúir phrófíle\",\"avatarAltRadius\":\"Phictúirí phrófíle (Fograí)\",\"avatarRadius\":\"Phictúirí phrófíle\",\"background\":\"Cúlra\",\"bio\":\"Scéal saoil\",\"btnRadius\":\"Cnaipí\",\"cBlue\":\"Gorm (Freagra, lean)\",\"cGreen\":\"Glas (Athphóstail)\",\"cOrange\":\"Oráiste (Cosúil)\",\"cRed\":\"Dearg (Cealaigh)\",\"change_password\":\"Athraigh do pasfhocal\",\"change_password_error\":\"Bhí fadhb ann ag athrú do pasfhocail\",\"changed_password\":\"Athraigh an pasfhocal go rathúil!\",\"collapse_subject\":\"Poist a chosc le teidil\",\"confirm_new_password\":\"Deimhnigh do pasfhocal nua\",\"current_avatar\":\"Phictúir phrófíle\",\"current_password\":\"Pasfhocal reatha\",\"current_profile_banner\":\"Phictúir ceanntáisc\",\"data_import_export_tab\":\"Iompórtáil / Easpórtáil Sonraí\",\"default_vis\":\"Scóip infheicthe réamhshocraithe\",\"delete_account\":\"Scrios cuntas\",\"delete_account_description\":\"Do chuntas agus do chuid teachtaireachtaí go léir a scriosadh go buan.\",\"delete_account_error\":\"Bhí fadhb ann a scriosadh do chuntas. Má leanann sé seo, téigh i dteagmháil le do riarthóir.\",\"delete_account_instructions\":\"Scríobh do phasfhocal san ionchur thíos chun deimhniú a scriosadh.\",\"export_theme\":\"Sábháil Téama\",\"filtering\":\"Scagadh\",\"filtering_explanation\":\"Beidh gach post ina bhfuil na focail seo i bhfolach, ceann in aghaidh an líne\",\"follow_export\":\"Easpórtáil do leanann\",\"follow_export_button\":\"Easpórtáil do leanann chuig comhad csv\",\"follow_export_processing\":\"Próiseáil. Iarrtar ort go luath an comhad a íoslódáil.\",\"follow_import\":\"Iompórtáil do leanann\",\"follow_import_error\":\"Earráid agus do leanann a iompórtáil\",\"follows_imported\":\"Do leanann iompórtáil! Tógfaidh an próiseas iad le tamall.\",\"foreground\":\"Tulra\",\"general\":\"Ginearálta\",\"hide_attachments_in_convo\":\"Folaigh ceangaltáin i comhráite\",\"hide_attachments_in_tl\":\"Folaigh ceangaltáin sa amlíne\",\"hide_post_stats\":\"Folaigh staitisticí na bpost (m.sh. líon na n-athrá)\",\"hide_user_stats\":\"Folaigh na staitisticí úsáideora (m.sh. líon na leantóiri)\",\"import_followers_from_a_csv_file\":\"Iompórtáil leanann ó chomhad csv\",\"import_theme\":\"Luchtaigh Téama\",\"inputRadius\":\"Limistéar iontrála\",\"instance_default\":\"(Réamhshocrú: {value})\",\"interfaceLanguage\":\"Teanga comhéadain\",\"invalid_theme_imported\":\"Ní téama bailí é an comhad dícheangailte. Níor rinneadh aon athruithe.\",\"limited_availability\":\"Níl sé ar fáil i do bhrabhsálaí\",\"links\":\"Naisc\",\"lock_account_description\":\"Srian a chur ar do chuntas le lucht leanúna ceadaithe amháin\",\"loop_video\":\"Lúb físeáin\",\"loop_video_silent_only\":\"Lúb físeáin amháin gan fuaim (i.e. Mastodon's \\\"gifs\\\")\",\"name\":\"Ainm\",\"name_bio\":\"Ainm ⁊ Scéal\",\"new_password\":\"Pasfhocal nua'\",\"notification_visibility\":\"Cineálacha fógraí a thaispeáint\",\"notification_visibility_follows\":\"Leana\",\"notification_visibility_likes\":\"Thaithin\",\"notification_visibility_mentions\":\"Tagairt\",\"notification_visibility_repeats\":\"Atphostáil\",\"no_rich_text_description\":\"Bain formáidiú téacs saibhir ó gach post\",\"nsfw_clickthrough\":\"Cumasaigh an ceangaltán NSFW cliceáil ar an gcnaipe\",\"oauth_tokens\":\"Tocanna OAuth\",\"token\":\"Token\",\"refresh_token\":\"Athnuachan Comórtas\",\"valid_until\":\"Bailí Go dtí\",\"revoke_token\":\"Athghairm\",\"panelRadius\":\"Painéil\",\"pause_on_unfocused\":\"Sruthú ar sos nuair a bhíonn an fócas caillte\",\"presets\":\"Réamhshocruithe\",\"profile_background\":\"Cúlra Próifíl\",\"profile_banner\":\"Phictúir Ceanntáisc\",\"profile_tab\":\"Próifíl\",\"radii_help\":\"Cruinniú imeall comhéadan a chumrú (i bpicteilíní)\",\"replies_in_timeline\":\"Freagraí sa amlíne\",\"reply_link_preview\":\"Cumasaigh réamhamharc nasc freagartha ar chlár na luiche\",\"reply_visibility_all\":\"Taispeáin gach freagra\",\"reply_visibility_following\":\"Taispeáin freagraí amháin atá dírithe ar mise nó ar úsáideoirí atá mé ag leanúint\",\"reply_visibility_self\":\"Taispeáin freagraí amháin atá dírithe ar mise\",\"saving_err\":\"Earráid socruithe a shábháil\",\"saving_ok\":\"Socruithe sábháilte\",\"security_tab\":\"Slándáil\",\"set_new_avatar\":\"Athraigh do phictúir phrófíle\",\"set_new_profile_background\":\"Athraigh do cúlra próifíl\",\"set_new_profile_banner\":\"Athraigh do phictúir ceanntáisc\",\"settings\":\"Socruithe\",\"stop_gifs\":\"Seinn GIFs ar an scáileán\",\"streaming\":\"Cumasaigh post nua a shruthú uathoibríoch nuair a scrollaítear go barr an leathanaigh\",\"text\":\"Téacs\",\"theme\":\"Téama\",\"theme_help\":\"Úsáid cód daith hex (#rrggbb) chun do schéim a saincheapadh\",\"tooltipRadius\":\"Bileoga eolais\",\"user_settings\":\"Socruithe úsáideora\",\"values\":{\"false\":\"níl\",\"true\":\"tá\"}},\"timeline\":{\"collapse\":\"Folaigh\",\"conversation\":\"Cómhra\",\"error_fetching\":\"Earráid a thabhairt cothrom le dáta\",\"load_older\":\"Luchtaigh níos mó\",\"no_retweet_hint\":\"Tá an post seo marcáilte mar lucht leanúna amháin nó díreach agus ní féidir é a athphostáil\",\"repeated\":\"athphostáil\",\"show_new\":\"Taispeáin nua\",\"up_to_date\":\"Nuashonraithe\"},\"user_card\":{\"approve\":\"Údaraigh\",\"block\":\"Cosc\",\"blocked\":\"Cuireadh coisc!\",\"deny\":\"Diúltaigh\",\"follow\":\"Lean\",\"followees\":\"Leantóirí\",\"followers\":\"Á Leanúint\",\"following\":\"Á Leanúint\",\"follows_you\":\"Leanann tú\",\"mute\":\"Cuir i mód ciúin\",\"muted\":\"Mód ciúin\",\"per_day\":\"laethúil\",\"remote_follow\":\"Leaníunt iargúlta\",\"statuses\":\"Poist\"},\"user_profile\":{\"timeline_title\":\"Amlíne úsáideora\"},\"who_to_follow\":{\"more\":\"Feach uile\",\"who_to_follow\":\"Daoine le leanúint\"}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/ga.json\n// module id = 443\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"צ'אט\"},\"features_panel\":{\"chat\":\"צ'אט\",\"gopher\":\"גופר\",\"media_proxy\":\"מדיה פרוקסי\",\"scope_options\":\"אפשרויות טווח\",\"text_limit\":\"מגבלת טקסט\",\"title\":\"מאפיינים\",\"who_to_follow\":\"אחרי מי לעקוב\"},\"finder\":{\"error_fetching_user\":\"שגיאה במציאת משתמש\",\"find_user\":\"מציאת משתמש\"},\"general\":{\"apply\":\"החל\",\"submit\":\"שלח\"},\"login\":{\"login\":\"התחבר\",\"logout\":\"התנתק\",\"password\":\"סיסמה\",\"placeholder\":\"למשל lain\",\"register\":\"הירשם\",\"username\":\"שם המשתמש\"},\"nav\":{\"chat\":\"צ'אט מקומי\",\"friend_requests\":\"בקשות עקיבה\",\"mentions\":\"אזכורים\",\"public_tl\":\"ציר הזמן הציבורי\",\"timeline\":\"ציר הזמן\",\"twkn\":\"כל הרשת הידועה\"},\"notifications\":{\"broken_favorite\":\"סטאטוס לא ידוע, מחפש...\",\"favorited_you\":\"אהב את הסטטוס שלך\",\"followed_you\":\"עקב אחריך!\",\"load_older\":\"טען התראות ישנות\",\"notifications\":\"התראות\",\"read\":\"קרא!\",\"repeated_you\":\"חזר על הסטטוס שלך\"},\"post_status\":{\"account_not_locked_warning\":\"המשתמש שלך אינו {0}. כל אחד יכול לעקוב אחריך ולראות את ההודעות לעוקבים-בלבד שלך.\",\"account_not_locked_warning_link\":\"נעול\",\"attachments_sensitive\":\"סמן מסמכים מצורפים כלא בטוחים לצפייה\",\"content_type\":{\"plain_text\":\"טקסט פשוט\"},\"content_warning\":\"נושא (נתון לבחירה)\",\"default\":\"הרגע נחת ב-ל.א.\",\"direct_warning\":\"הודעה זו תהיה זמינה רק לאנשים המוזכרים.\",\"posting\":\"מפרסם\",\"scope\":{\"direct\":\"ישיר - שלח לאנשים המוזכרים בלבד\",\"private\":\"עוקבים-בלבד - שלח לעוקבים בלבד\",\"public\":\"ציבורי - שלח לציר הזמן הציבורי\",\"unlisted\":\"מחוץ לרשימה - אל תשלח לציר הזמן הציבורי\"}},\"registration\":{\"bio\":\"אודות\",\"email\":\"אימייל\",\"fullname\":\"שם תצוגה\",\"password_confirm\":\"אישור סיסמה\",\"registration\":\"הרשמה\",\"token\":\"טוקן הזמנה\"},\"settings\":{\"attachmentRadius\":\"צירופים\",\"attachments\":\"צירופים\",\"autoload\":\"החל טעינה אוטומטית בגלילה לתחתית הדף\",\"avatar\":\"תמונת פרופיל\",\"avatarAltRadius\":\"תמונות פרופיל (התראות)\",\"avatarRadius\":\"תמונות פרופיל\",\"background\":\"רקע\",\"bio\":\"אודות\",\"btnRadius\":\"כפתורים\",\"cBlue\":\"כחול (תגובה, עקיבה)\",\"cGreen\":\"ירוק (חזרה)\",\"cOrange\":\"כתום (לייק)\",\"cRed\":\"אדום (ביטול)\",\"change_password\":\"שנה סיסמה\",\"change_password_error\":\"הייתה בעיה בשינוי סיסמתך.\",\"changed_password\":\"סיסמה שונתה בהצלחה!\",\"collapse_subject\":\"מזער הודעות עם נושאים\",\"confirm_new_password\":\"אשר סיסמה\",\"current_avatar\":\"תמונת הפרופיל הנוכחית שלך\",\"current_password\":\"סיסמה נוכחית\",\"current_profile_banner\":\"כרזת הפרופיל הנוכחית שלך\",\"data_import_export_tab\":\"ייבוא או ייצוא מידע\",\"default_vis\":\"ברירת מחדל לטווח הנראות\",\"delete_account\":\"מחק משתמש\",\"delete_account_description\":\"מחק לצמיתות את המשתמש שלך ואת כל הודעותיך.\",\"delete_account_error\":\"הייתה בעיה במחיקת המשתמש. אם זה ממשיך, אנא עדכן את מנהל השרת שלך.\",\"delete_account_instructions\":\"הכנס את סיסמתך בקלט למטה על מנת לאשר מחיקת משתמש.\",\"export_theme\":\"שמור ערכים\",\"filtering\":\"סינון\",\"filtering_explanation\":\"כל הסטטוסים הכוללים את המילים הללו יושתקו, אחד לשורה\",\"follow_export\":\"יצוא עקיבות\",\"follow_export_button\":\"ייצא את הנעקבים שלך לקובץ csv\",\"follow_export_processing\":\"טוען. בקרוב תתבקש להוריד את הקובץ את הקובץ שלך\",\"follow_import\":\"יבוא עקיבות\",\"follow_import_error\":\"שגיאה בייבוא נעקבים.\",\"follows_imported\":\"נעקבים יובאו! ייקח זמן מה לעבד אותם.\",\"foreground\":\"חזית\",\"hide_attachments_in_convo\":\"החבא צירופים בשיחות\",\"hide_attachments_in_tl\":\"החבא צירופים בציר הזמן\",\"import_followers_from_a_csv_file\":\"ייבא את הנעקבים שלך מקובץ csv\",\"import_theme\":\"טען ערכים\",\"inputRadius\":\"שדות קלט\",\"interfaceLanguage\":\"שפת הממשק\",\"invalid_theme_imported\":\"הקובץ הנבחר אינו תמה הנתמכת ע\\\"י פלרומה. שום שינויים לא נעשו לתמה שלך.\",\"limited_availability\":\"לא זמין בדפדפן שלך\",\"links\":\"לינקים\",\"lock_account_description\":\"הגבל את המשתמש לעוקבים מאושרים בלבד\",\"loop_video\":\"נגן סרטונים ללא הפסקה\",\"loop_video_silent_only\":\"נגן רק סרטונים חסרי קול ללא הפסקה\",\"name\":\"שם\",\"name_bio\":\"שם ואודות\",\"new_password\":\"סיסמה חדשה\",\"notification_visibility\":\"סוג ההתראות שתרצו לראות\",\"notification_visibility_follows\":\"עקיבות\",\"notification_visibility_likes\":\"לייקים\",\"notification_visibility_mentions\":\"אזכורים\",\"notification_visibility_repeats\":\"חזרות\",\"nsfw_clickthrough\":\"החל החבאת צירופים לא בטוחים לצפיה בעת עבודה בעזרת לחיצת עכבר\",\"oauth_tokens\":\"אסימוני OAuth\",\"token\":\"אסימון\",\"refresh_token\":\"רענון האסימון\",\"valid_until\":\"בתוקף עד\",\"revoke_token\":\"בטל\",\"panelRadius\":\"פאנלים\",\"pause_on_unfocused\":\"השהה זרימת הודעות כשהחלון לא בפוקוס\",\"presets\":\"ערכים קבועים מראש\",\"profile_background\":\"רקע הפרופיל\",\"profile_banner\":\"כרזת הפרופיל\",\"profile_tab\":\"פרופיל\",\"radii_help\":\"קבע מראש עיגול פינות לממשק (בפיקסלים)\",\"replies_in_timeline\":\"תגובות בציר הזמן\",\"reply_link_preview\":\"החל תצוגה מקדימה של לינק-תגובה בעת ריחוף עם העכבר\",\"reply_visibility_all\":\"הראה את כל התגובות\",\"reply_visibility_following\":\"הראה תגובות שמופנות אליי או לעקובים שלי בלבד\",\"reply_visibility_self\":\"הראה תגובות שמופנות אליי בלבד\",\"security_tab\":\"ביטחון\",\"set_new_avatar\":\"קבע תמונת פרופיל חדשה\",\"set_new_profile_background\":\"קבע רקע פרופיל חדש\",\"set_new_profile_banner\":\"קבע כרזת פרופיל חדשה\",\"settings\":\"הגדרות\",\"stop_gifs\":\"נגן-בעת-ריחוף GIFs\",\"streaming\":\"החל זרימת הודעות אוטומטית בעת גלילה למעלה הדף\",\"text\":\"טקסט\",\"theme\":\"תמה\",\"theme_help\":\"השתמש בקודי צבע הקס (#אדום-אדום-ירוק-ירוק-כחול-כחול) על מנת להתאים אישית את תמת הצבע שלך.\",\"tooltipRadius\":\"טולטיפ \\\\ התראות\",\"user_settings\":\"הגדרות משתמש\"},\"timeline\":{\"collapse\":\"מוטט\",\"conversation\":\"שיחה\",\"error_fetching\":\"שגיאה בהבאת הודעות\",\"load_older\":\"טען סטטוסים חדשים\",\"no_retweet_hint\":\"ההודעה מסומנת כ\\\"לעוקבים-בלבד\\\" ולא ניתן לחזור עליה\",\"repeated\":\"חזר\",\"show_new\":\"הראה חדש\",\"up_to_date\":\"עדכני\"},\"user_card\":{\"approve\":\"אשר\",\"block\":\"חסימה\",\"blocked\":\"חסום!\",\"deny\":\"דחה\",\"follow\":\"עקוב\",\"followees\":\"נעקבים\",\"followers\":\"עוקבים\",\"following\":\"עוקב!\",\"follows_you\":\"עוקב אחריך!\",\"mute\":\"השתק\",\"muted\":\"מושתק\",\"per_day\":\"ליום\",\"remote_follow\":\"עקיבה מרחוק\",\"statuses\":\"סטטוסים\"},\"user_profile\":{\"timeline_title\":\"ציר זמן המשתמש\"},\"who_to_follow\":{\"more\":\"עוד\",\"who_to_follow\":\"אחרי מי לעקוב\"}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/he.json\n// module id = 444\n// module chunks = 2","module.exports = {\"finder\":{\"error_fetching_user\":\"Hiba felhasználó beszerzésével\",\"find_user\":\"Felhasználó keresése\"},\"general\":{\"submit\":\"Elküld\"},\"login\":{\"login\":\"Bejelentkezés\",\"logout\":\"Kijelentkezés\",\"password\":\"Jelszó\",\"placeholder\":\"e.g. lain\",\"register\":\"Feliratkozás\",\"username\":\"Felhasználó név\"},\"nav\":{\"mentions\":\"Említéseim\",\"public_tl\":\"Publikus Idővonal\",\"timeline\":\"Idővonal\",\"twkn\":\"Az Egész Ismert Hálózat\"},\"notifications\":{\"followed_you\":\"követ téged\",\"notifications\":\"Értesítések\",\"read\":\"Olvasva!\"},\"post_status\":{\"default\":\"Most érkeztem L.A.-be\",\"posting\":\"Küldés folyamatban\"},\"registration\":{\"bio\":\"Bio\",\"email\":\"Email\",\"fullname\":\"Teljes név\",\"password_confirm\":\"Jelszó megerősítése\",\"registration\":\"Feliratkozás\"},\"settings\":{\"attachments\":\"Csatolmányok\",\"autoload\":\"Autoatikus betöltés engedélyezése lap aljára görgetéskor\",\"avatar\":\"Avatár\",\"bio\":\"Bio\",\"current_avatar\":\"Jelenlegi avatár\",\"current_profile_banner\":\"Jelenlegi profil banner\",\"filtering\":\"Szűrés\",\"filtering_explanation\":\"Minden tartalom mely ezen szavakat tartalmazza némítva lesz, soronként egy\",\"hide_attachments_in_convo\":\"Csatolmányok elrejtése a társalgásokban\",\"hide_attachments_in_tl\":\"Csatolmányok elrejtése az idővonalon\",\"name\":\"Név\",\"name_bio\":\"Név és Bio\",\"nsfw_clickthrough\":\"NSFW átkattintási tartalom elrejtésének engedélyezése\",\"profile_background\":\"Profil háttérkép\",\"profile_banner\":\"Profil Banner\",\"reply_link_preview\":\"Válasz-link előzetes mutatása egér rátételkor\",\"set_new_avatar\":\"Új avatár\",\"set_new_profile_background\":\"Új profil háttér beállítása\",\"set_new_profile_banner\":\"Új profil banner\",\"settings\":\"Beállítások\",\"theme\":\"Téma\",\"user_settings\":\"Felhasználói beállítások\"},\"timeline\":{\"conversation\":\"Társalgás\",\"error_fetching\":\"Hiba a frissítések beszerzésénél\",\"load_older\":\"Régebbi állapotok betöltése\",\"show_new\":\"Újak mutatása\",\"up_to_date\":\"Naprakész\"},\"user_card\":{\"block\":\"Letilt\",\"blocked\":\"Letiltva!\",\"follow\":\"Követ\",\"followees\":\"Követettek\",\"followers\":\"Követők\",\"following\":\"Követve!\",\"follows_you\":\"Követ téged!\",\"mute\":\"Némít\",\"muted\":\"Némított\",\"per_day\":\"naponta\",\"statuses\":\"Állapotok\"}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/hu.json\n// module id = 445\n// module chunks = 2","module.exports = {\"general\":{\"submit\":\"Invia\",\"apply\":\"Applica\"},\"nav\":{\"mentions\":\"Menzioni\",\"public_tl\":\"Sequenza temporale pubblica\",\"timeline\":\"Sequenza temporale\",\"twkn\":\"L'intera rete conosciuta\",\"chat\":\"Chat Locale\",\"friend_requests\":\"Richieste di Seguirti\"},\"notifications\":{\"followed_you\":\"ti segue\",\"notifications\":\"Notifiche\",\"read\":\"Leggi!\",\"broken_favorite\":\"Stato sconosciuto, lo sto cercando...\",\"favorited_you\":\"ha messo mi piace al tuo stato\",\"load_older\":\"Carica notifiche più vecchie\",\"repeated_you\":\"ha condiviso il tuo stato\"},\"settings\":{\"attachments\":\"Allegati\",\"autoload\":\"Abilita caricamento automatico quando si raggiunge fondo pagina\",\"avatar\":\"Avatar\",\"bio\":\"Introduzione\",\"current_avatar\":\"Il tuo avatar attuale\",\"current_profile_banner\":\"Il tuo banner attuale\",\"filtering\":\"Filtri\",\"filtering_explanation\":\"Tutti i post contenenti queste parole saranno silenziati, uno per linea\",\"hide_attachments_in_convo\":\"Nascondi gli allegati presenti nelle conversazioni\",\"hide_attachments_in_tl\":\"Nascondi gli allegati presenti nella sequenza temporale\",\"name\":\"Nome\",\"name_bio\":\"Nome & Introduzione\",\"nsfw_clickthrough\":\"Abilita il click per visualizzare gli allegati segnati come NSFW\",\"profile_background\":\"Sfondo della tua pagina\",\"profile_banner\":\"Banner del tuo profilo\",\"reply_link_preview\":\"Abilita il link per la risposta al passaggio del mouse\",\"set_new_avatar\":\"Scegli un nuovo avatar\",\"set_new_profile_background\":\"Scegli un nuovo sfondo per la tua pagina\",\"set_new_profile_banner\":\"Scegli un nuovo banner per il tuo profilo\",\"settings\":\"Impostazioni\",\"theme\":\"Tema\",\"user_settings\":\"Impostazioni Utente\",\"attachmentRadius\":\"Allegati\",\"avatarAltRadius\":\"Avatar (Notifiche)\",\"avatarRadius\":\"Avatar\",\"background\":\"Sfondo\",\"btnRadius\":\"Pulsanti\",\"cBlue\":\"Blu (Rispondere, seguire)\",\"cGreen\":\"Verde (Condividi)\",\"cOrange\":\"Arancio (Mi piace)\",\"cRed\":\"Rosso (Annulla)\",\"change_password\":\"Cambia Password\",\"change_password_error\":\"C'è stato un problema durante il cambiamento della password.\",\"changed_password\":\"Password cambiata correttamente!\",\"collapse_subject\":\"Riduci post che hanno un oggetto\",\"confirm_new_password\":\"Conferma la nuova password\",\"current_password\":\"Password attuale\",\"data_import_export_tab\":\"Importa / Esporta Dati\",\"default_vis\":\"Visibilità predefinita dei post\",\"delete_account\":\"Elimina Account\",\"delete_account_description\":\"Elimina definitivamente il tuo account e tutti i tuoi messaggi.\",\"delete_account_error\":\"C'è stato un problema durante l'eliminazione del tuo account. Se il problema persiste contatta l'amministratore della tua istanza.\",\"delete_account_instructions\":\"Digita la tua password nel campo sottostante per confermare l'eliminazione dell'account.\",\"export_theme\":\"Salva settaggi\",\"follow_export\":\"Esporta la lista di chi segui\",\"follow_export_button\":\"Esporta la lista di chi segui in un file csv\",\"follow_export_processing\":\"Sto elaborando, presto ti sarà chiesto di scaricare il tuo file\",\"follow_import\":\"Importa la lista di chi segui\",\"follow_import_error\":\"Errore nell'importazione della lista di chi segui\",\"follows_imported\":\"Importazione riuscita! L'elaborazione richiederà un po' di tempo.\",\"foreground\":\"In primo piano\",\"general\":\"Generale\",\"hide_post_stats\":\"Nascondi statistiche dei post (es. il numero di mi piace)\",\"hide_user_stats\":\"Nascondi statistiche dell'utente (es. il numero di chi ti segue)\",\"import_followers_from_a_csv_file\":\"Importa una lista di chi segui da un file csv\",\"import_theme\":\"Carica settaggi\",\"inputRadius\":\"Campi di testo\",\"instance_default\":\"(predefinito: {value})\",\"interfaceLanguage\":\"Linguaggio dell'interfaccia\",\"invalid_theme_imported\":\"Il file selezionato non è un file di tema per Pleroma supportato. Il tuo tema non è stato modificato.\",\"limited_availability\":\"Non disponibile nel tuo browser\",\"links\":\"Collegamenti\",\"lock_account_description\":\"Limita il tuo account solo per contatti approvati\",\"loop_video\":\"Riproduci video in ciclo continuo\",\"loop_video_silent_only\":\"Riproduci solo video senza audio in ciclo continuo (es. le gif di Mastodon)\",\"new_password\":\"Nuova password\",\"notification_visibility\":\"Tipi di notifiche da mostrare\",\"notification_visibility_follows\":\"Nuove persone ti seguono\",\"notification_visibility_likes\":\"Mi piace\",\"notification_visibility_mentions\":\"Menzioni\",\"notification_visibility_repeats\":\"Condivisioni\",\"no_rich_text_description\":\"Togli la formattazione del testo da tutti i post\",\"oauth_tokens\":\"Token OAuth\",\"token\":\"Token\",\"refresh_token\":\"Aggiorna token\",\"valid_until\":\"Valido fino a\",\"revoke_token\":\"Revocare\",\"panelRadius\":\"Pannelli\",\"pause_on_unfocused\":\"Metti in pausa l'aggiornamento continuo quando la scheda non è in primo piano\",\"presets\":\"Valori predefiniti\",\"profile_tab\":\"Profilo\",\"radii_help\":\"Imposta l'arrotondamento dei bordi (in pixel)\",\"replies_in_timeline\":\"Risposte nella sequenza temporale\",\"reply_visibility_all\":\"Mostra tutte le risposte\",\"reply_visibility_following\":\"Mostra solo le risposte dirette a me o agli utenti che seguo\",\"reply_visibility_self\":\"Mostra solo risposte dirette a me\",\"saving_err\":\"Errore nel salvataggio delle impostazioni\",\"saving_ok\":\"Impostazioni salvate\",\"security_tab\":\"Sicurezza\",\"stop_gifs\":\"Riproduci GIF al passaggio del cursore del mouse\",\"streaming\":\"Abilita aggiornamento automatico dei nuovi post quando si è in alto alla pagina\",\"text\":\"Testo\",\"theme_help\":\"Usa codici colore esadecimali (#rrggbb) per personalizzare il tuo schema di colori.\",\"tooltipRadius\":\"Descrizioni/avvisi\",\"values\":{\"false\":\"no\",\"true\":\"si\"}},\"timeline\":{\"error_fetching\":\"Errore nel prelievo aggiornamenti\",\"load_older\":\"Carica messaggi più vecchi\",\"show_new\":\"Mostra nuovi\",\"up_to_date\":\"Aggiornato\",\"collapse\":\"Riduci\",\"conversation\":\"Conversazione\",\"no_retweet_hint\":\"La visibilità del post è impostata solo per chi ti segue o messaggio diretto e non può essere condiviso\",\"repeated\":\"condiviso\"},\"user_card\":{\"follow\":\"Segui\",\"followees\":\"Chi stai seguendo\",\"followers\":\"Chi ti segue\",\"following\":\"Lo stai seguendo!\",\"follows_you\":\"Ti segue!\",\"mute\":\"Silenzia\",\"muted\":\"Silenziato\",\"per_day\":\"al giorno\",\"statuses\":\"Messaggi\",\"approve\":\"Approva\",\"block\":\"Blocca\",\"blocked\":\"Bloccato!\",\"deny\":\"Nega\",\"remote_follow\":\"Segui da remoto\"},\"chat\":{\"title\":\"Chat\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Media proxy\",\"scope_options\":\"Opzioni di visibilità\",\"text_limit\":\"Lunghezza limite\",\"title\":\"Caratteristiche\",\"who_to_follow\":\"Chi seguire\"},\"finder\":{\"error_fetching_user\":\"Errore nel recupero dell'utente\",\"find_user\":\"Trova utente\"},\"login\":{\"login\":\"Accedi\",\"logout\":\"Disconnettiti\",\"password\":\"Password\",\"placeholder\":\"es. lain\",\"register\":\"Registrati\",\"username\":\"Nome utente\"},\"post_status\":{\"account_not_locked_warning\":\"Il tuo account non è {0}. Chiunque può seguirti e vedere i tuoi post riservati a chi ti segue.\",\"account_not_locked_warning_link\":\"bloccato\",\"attachments_sensitive\":\"Segna allegati come sensibili\",\"content_type\":{\"plain_text\":\"Testo normale\"},\"content_warning\":\"Oggetto (facoltativo)\",\"default\":\"Appena atterrato in L.A.\",\"direct_warning\":\"Questo post sarà visibile solo dagli utenti menzionati.\",\"posting\":\"Pubblica\",\"scope\":{\"direct\":\"Diretto - Pubblicato solo per gli utenti menzionati\",\"private\":\"Solo per chi ti segue - Visibile solo da chi ti segue\",\"public\":\"Pubblico - Visibile sulla sequenza temporale pubblica\",\"unlisted\":\"Non elencato - Non visibile sulla sequenza temporale pubblica\"}},\"registration\":{\"bio\":\"Introduzione\",\"email\":\"Email\",\"fullname\":\"Nome visualizzato\",\"password_confirm\":\"Conferma password\",\"registration\":\"Registrazione\",\"token\":\"Codice d'invito\"},\"user_profile\":{\"timeline_title\":\"Sequenza Temporale dell'Utente\"},\"who_to_follow\":{\"more\":\"Più\",\"who_to_follow\":\"Chi seguire\"}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/it.json\n// module id = 446\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"チャット\"},\"features_panel\":{\"chat\":\"チャット\",\"gopher\":\"Gopher\",\"media_proxy\":\"メディアプロクシ\",\"scope_options\":\"こうかいはんいせんたく\",\"text_limit\":\"もじのかず\",\"title\":\"ゆうこうなきのう\",\"who_to_follow\":\"おすすめユーザー\"},\"finder\":{\"error_fetching_user\":\"ユーザーけんさくがエラーになりました。\",\"find_user\":\"ユーザーをさがす\"},\"general\":{\"apply\":\"てきよう\",\"submit\":\"そうしん\",\"more\":\"つづき\",\"generic_error\":\"エラーになりました\"},\"login\":{\"login\":\"ログイン\",\"description\":\"OAuthでログイン\",\"logout\":\"ログアウト\",\"password\":\"パスワード\",\"placeholder\":\"れい: lain\",\"register\":\"はじめる\",\"username\":\"ユーザーめい\",\"hint\":\"はなしあいにくわわるには、ログインしてください\"},\"nav\":{\"about\":\"これはなに?\",\"back\":\"もどる\",\"chat\":\"ローカルチャット\",\"friend_requests\":\"フォローリクエスト\",\"mentions\":\"メンション\",\"dms\":\"ダイレクトメッセージ\",\"public_tl\":\"パブリックタイムライン\",\"timeline\":\"タイムライン\",\"twkn\":\"つながっているすべてのネットワーク\",\"user_search\":\"ユーザーをさがす\",\"who_to_follow\":\"おすすめユーザー\",\"preferences\":\"せってい\"},\"notifications\":{\"broken_favorite\":\"ステータスがみつかりません。さがしています...\",\"favorited_you\":\"あなたのステータスがおきにいりされました\",\"followed_you\":\"フォローされました\",\"load_older\":\"ふるいつうちをみる\",\"notifications\":\"つうち\",\"read\":\"よんだ!\",\"repeated_you\":\"あなたのステータスがリピートされました\",\"no_more_notifications\":\"つうちはありません\"},\"post_status\":{\"new_status\":\"とうこうする\",\"account_not_locked_warning\":\"あなたのアカウントは {0} ではありません。あなたをフォローすれば、だれでも、フォロワーげんていのステータスをよむことができます。\",\"account_not_locked_warning_link\":\"ロックされたアカウント\",\"attachments_sensitive\":\"ファイルをNSFWにする\",\"content_type\":{\"plain_text\":\"プレーンテキスト\"},\"content_warning\":\"せつめい (かかなくてもよい)\",\"default\":\"はねだくうこうに、つきました。\",\"direct_warning\":\"このステータスは、メンションされたユーザーだけが、よむことができます。\",\"posting\":\"とうこう\",\"scope\":{\"direct\":\"ダイレクト: メンションされたユーザーのみにとどきます。\",\"private\":\"フォロワーげんてい: フォロワーのみにとどきます。\",\"public\":\"パブリック: パブリックタイムラインにとどきます。\",\"unlisted\":\"アンリステッド: パブリックタイムラインにとどきません。\"}},\"registration\":{\"bio\":\"プロフィール\",\"email\":\"Eメール\",\"fullname\":\"スクリーンネーム\",\"password_confirm\":\"パスワードのかくにん\",\"registration\":\"はじめる\",\"token\":\"しょうたいトークン\",\"captcha\":\"CAPTCHA\",\"new_captcha\":\"もじがよめないときは、がぞうをクリックすると、あたらしいがぞうになります\",\"validations\":{\"username_required\":\"なにかかいてください\",\"fullname_required\":\"なにかかいてください\",\"email_required\":\"なにかかいてください\",\"password_required\":\"なにかかいてください\",\"password_confirmation_required\":\"なにかかいてください\",\"password_confirmation_match\":\"パスワードがちがいます\"}},\"settings\":{\"attachmentRadius\":\"ファイル\",\"attachments\":\"ファイル\",\"autoload\":\"したにスクロールしたとき、じどうてきによみこむ。\",\"avatar\":\"アバター\",\"avatarAltRadius\":\"つうちのアバター\",\"avatarRadius\":\"アバター\",\"background\":\"バックグラウンド\",\"bio\":\"プロフィール\",\"btnRadius\":\"ボタン\",\"cBlue\":\"リプライとフォロー\",\"cGreen\":\"リピート\",\"cOrange\":\"おきにいり\",\"cRed\":\"キャンセル\",\"change_password\":\"パスワードをかえる\",\"change_password_error\":\"パスワードをかえることが、できなかったかもしれません。\",\"changed_password\":\"パスワードが、かわりました!\",\"collapse_subject\":\"せつめいのあるとうこうをたたむ\",\"composing\":\"とうこう\",\"confirm_new_password\":\"あたらしいパスワードのかくにん\",\"current_avatar\":\"いまのアバター\",\"current_password\":\"いまのパスワード\",\"current_profile_banner\":\"いまのプロフィールバナー\",\"data_import_export_tab\":\"インポートとエクスポート\",\"default_vis\":\"デフォルトのこうかいはんい\",\"delete_account\":\"アカウントをけす\",\"delete_account_description\":\"あなたのアカウントとメッセージが、きえます。\",\"delete_account_error\":\"アカウントをけすことが、できなかったかもしれません。インスタンスのかんりしゃに、れんらくしてください。\",\"delete_account_instructions\":\"ほんとうにアカウントをけしてもいいなら、パスワードをかいてください。\",\"avatar_size_instruction\":\"アバターのおおきさは、150×150ピクセルか、それよりもおおきくするといいです。\",\"export_theme\":\"セーブ\",\"filtering\":\"フィルタリング\",\"filtering_explanation\":\"これらのことばをふくむすべてのものがミュートされます。1ぎょうに1つのことばをかいてください。\",\"follow_export\":\"フォローのエクスポート\",\"follow_export_button\":\"エクスポート\",\"follow_export_processing\":\"おまちください。まもなくファイルをダウンロードできます。\",\"follow_import\":\"フォローインポート\",\"follow_import_error\":\"フォローのインポートがエラーになりました。\",\"follows_imported\":\"フォローがインポートされました! すこしじかんがかかるかもしれません。\",\"foreground\":\"フォアグラウンド\",\"general\":\"ぜんぱん\",\"hide_attachments_in_convo\":\"スレッドのファイルをかくす\",\"hide_attachments_in_tl\":\"タイムラインのファイルをかくす\",\"hide_isp\":\"インスタンススペシフィックパネルをかくす\",\"preload_images\":\"がぞうをさきよみする\",\"use_one_click_nsfw\":\"NSFWなファイルを1クリックでひらく\",\"hide_post_stats\":\"とうこうのとうけいをかくす (れい: おきにいりのかず)\",\"hide_user_stats\":\"ユーザーのとうけいをかくす (れい: フォロワーのかず)\",\"hide_filtered_statuses\":\"フィルターされたとうこうをかくす\",\"import_followers_from_a_csv_file\":\"CSVファイルからフォローをインポートする\",\"import_theme\":\"ロード\",\"inputRadius\":\"インプットフィールド\",\"checkboxRadius\":\"チェックボックス\",\"instance_default\":\"(デフォルト: {value})\",\"instance_default_simple\":\"(デフォルト)\",\"interface\":\"インターフェース\",\"interfaceLanguage\":\"インターフェースのことば\",\"invalid_theme_imported\":\"このファイルはPleromaのテーマではありません。テーマはへんこうされませんでした。\",\"limited_availability\":\"あなたのブラウザではできません\",\"links\":\"リンク\",\"lock_account_description\":\"あなたがみとめたひとだけ、あなたのアカウントをフォローできる\",\"loop_video\":\"ビデオをくりかえす\",\"loop_video_silent_only\":\"おとのないビデオだけくりかえす\",\"play_videos_in_modal\":\"ビデオをメディアビューアーでみる\",\"use_contain_fit\":\"がぞうのサムネイルを、きりぬかない\",\"name\":\"なまえ\",\"name_bio\":\"なまえとプロフィール\",\"new_password\":\"あたらしいパスワード\",\"notification_visibility\":\"ひょうじするつうち\",\"notification_visibility_follows\":\"フォロー\",\"notification_visibility_likes\":\"おきにいり\",\"notification_visibility_mentions\":\"メンション\",\"notification_visibility_repeats\":\"リピート\",\"no_rich_text_description\":\"リッチテキストをつかわない\",\"hide_follows_description\":\"フォローしているひとをみせない\",\"hide_followers_description\":\"フォロワーをみせない\",\"show_admin_badge\":\"アドミンのしるしをみる\",\"show_moderator_badge\":\"モデレーターのしるしをみる\",\"nsfw_clickthrough\":\"NSFWなファイルをかくす\",\"oauth_tokens\":\"OAuthトークン\",\"token\":\"トークン\",\"refresh_token\":\"トークンを更新\",\"valid_until\":\"まで有効\",\"revoke_token\":\"取り消す\",\"panelRadius\":\"パネル\",\"pause_on_unfocused\":\"タブにフォーカスがないときストリーミングをとめる\",\"presets\":\"プリセット\",\"profile_background\":\"プロフィールのバックグラウンド\",\"profile_banner\":\"プロフィールバナー\",\"profile_tab\":\"プロフィール\",\"radii_help\":\"インターフェースのまるさをせっていする。\",\"replies_in_timeline\":\"タイムラインのリプライ\",\"reply_link_preview\":\"カーソルをかさねたとき、リプライのプレビューをみる\",\"reply_visibility_all\":\"すべてのリプライをみる\",\"reply_visibility_following\":\"わたしにあてられたリプライと、フォローしているひとからのリプライをみる\",\"reply_visibility_self\":\"わたしにあてられたリプライをみる\",\"saving_err\":\"せっていをセーブできませんでした\",\"saving_ok\":\"せっていをセーブしました\",\"security_tab\":\"セキュリティ\",\"scope_copy\":\"リプライするとき、こうかいはんいをコピーする (DMのこうかいはんいは、つねにコピーされます)\",\"set_new_avatar\":\"あたらしいアバターをせっていする\",\"set_new_profile_background\":\"あたらしいプロフィールのバックグラウンドをせっていする\",\"set_new_profile_banner\":\"あたらしいプロフィールバナーを設定する\",\"settings\":\"せってい\",\"subject_input_always_show\":\"サブジェクトフィールドをいつでもひょうじする\",\"subject_line_behavior\":\"リプライするときサブジェクトをコピーする\",\"subject_line_email\":\"メールふう: \\\"re: サブジェクト\\\"\",\"subject_line_mastodon\":\"マストドンふう: そのままコピー\",\"subject_line_noop\":\"コピーしない\",\"post_status_content_type\":\"とうこうのコンテントタイプ\",\"stop_gifs\":\"カーソルをかさねたとき、GIFをうごかす\",\"streaming\":\"うえまでスクロールしたとき、じどうてきにストリーミングする\",\"text\":\"もじ\",\"theme\":\"テーマ\",\"theme_help\":\"カラーテーマをカスタマイズできます\",\"theme_help_v2_1\":\"チェックボックスをONにすると、コンポーネントごとに、いろと、とうめいどを、オーバーライドできます。「すべてクリア」ボタンをおすと、すべてのオーバーライドを、やめます。\",\"theme_help_v2_2\":\"バックグラウンドとテキストのコントラストをあらわすアイコンがあります。マウスをホバーすると、くわしいせつめいがでます。とうめいないろをつかっているときは、もっともわるいばあいのコントラストがしめされます。\",\"tooltipRadius\":\"ツールチップとアラート\",\"user_settings\":\"ユーザーせってい\",\"values\":{\"false\":\"いいえ\",\"true\":\"はい\"},\"notifications\":\"つうち\",\"enable_web_push_notifications\":\"ウェブプッシュつうちをゆるす\",\"style\":{\"switcher\":{\"keep_color\":\"いろをのこす\",\"keep_shadows\":\"かげをのこす\",\"keep_opacity\":\"とうめいどをのこす\",\"keep_roundness\":\"まるさをのこす\",\"keep_fonts\":\"フォントをのこす\",\"save_load_hint\":\"「のこす」オプションをONにすると、テーマをえらんだときとロードしたとき、いまのせっていをのこします。また、テーマをエクスポートするとき、これらのオプションをストアします。すべてのチェックボックスをOFFにすると、テーマをエクスポートしたとき、すべてのせっていをセーブします。\",\"reset\":\"リセット\",\"clear_all\":\"すべてクリア\",\"clear_opacity\":\"とうめいどをクリア\"},\"common\":{\"color\":\"いろ\",\"opacity\":\"とうめいど\",\"contrast\":{\"hint\":\"コントラストは {ratio} です。{level}。({context})\",\"level\":{\"aa\":\"AAレベルガイドライン (ミニマル) をみたします\",\"aaa\":\"AAAレベルガイドライン (レコメンデッド) をみたします。\",\"bad\":\"ガイドラインをみたしません。\"},\"context\":{\"18pt\":\"おおきい (18ポイントいじょう) テキスト\",\"text\":\"テキスト\"}}},\"common_colors\":{\"_tab_label\":\"きょうつう\",\"main\":\"きょうつうのいろ\",\"foreground_hint\":\"「くわしく」タブで、もっとこまかくせっていできます\",\"rgbo\":\"アイコンとアクセントとバッジ\"},\"advanced_colors\":{\"_tab_label\":\"くわしく\",\"alert\":\"アラートのバックグラウンド\",\"alert_error\":\"エラー\",\"badge\":\"バッジのバックグラウンド\",\"badge_notification\":\"つうち\",\"panel_header\":\"パネルヘッダー\",\"top_bar\":\"トップバー\",\"borders\":\"さかいめ\",\"buttons\":\"ボタン\",\"inputs\":\"インプットフィールド\",\"faint_text\":\"うすいテキスト\"},\"radii\":{\"_tab_label\":\"まるさ\"},\"shadows\":{\"_tab_label\":\"ひかりとかげ\",\"component\":\"コンポーネント\",\"override\":\"オーバーライド\",\"shadow_id\":\"かげ #{value}\",\"blur\":\"ぼかし\",\"spread\":\"ひろがり\",\"inset\":\"うちがわ\",\"hint\":\"かげのせっていでは、いろのあたいとして --variable をつかうことができます。これはCSS3へんすうです。ただし、とうめいどのせっていは、きかなくなります。\",\"filter_hint\":{\"always_drop_shadow\":\"ブラウザーがサポートしていれば、つねに {0} がつかわれます。\",\"drop_shadow_syntax\":\"{0} は、{1} パラメーターと {2} キーワードをサポートしていません。\",\"avatar_inset\":\"うちがわのかげと、そとがわのかげを、いっしょにつかうと、とうめいなアバターが、へんなみためになります。\",\"spread_zero\":\"ひろがりが 0 よりもおおきなかげは、0 とおなじです。\",\"inset_classic\":\"うちがわのかげは {0} をつかいます。\"},\"components\":{\"panel\":\"パネル\",\"panelHeader\":\"パネルヘッダー\",\"topBar\":\"トップバー\",\"avatar\":\"ユーザーアバター (プロフィール)\",\"avatarStatus\":\"ユーザーアバター (とうこう)\",\"popup\":\"ポップアップとツールチップ\",\"button\":\"ボタン\",\"buttonHover\":\"ボタン (ホバー)\",\"buttonPressed\":\"ボタン (おされているとき)\",\"buttonPressedHover\":\"ボタン (ホバー、かつ、おされているとき)\",\"input\":\"インプットフィールド\"}},\"fonts\":{\"_tab_label\":\"フォント\",\"help\":\"「カスタム」をえらんだときは、システムにあるフォントのなまえを、ただしくにゅうりょくしてください。\",\"components\":{\"interface\":\"インターフェース\",\"input\":\"インプットフィールド\",\"post\":\"とうこう\",\"postCode\":\"モノスペース (とうこうがリッチテキストであるとき)\"},\"family\":\"フォントめい\",\"size\":\"おおきさ (px)\",\"weight\":\"ふとさ\",\"custom\":\"カスタム\"},\"preview\":{\"header\":\"プレビュー\",\"content\":\"ほんぶん\",\"error\":\"エラーのれい\",\"button\":\"ボタン\",\"text\":\"これは{0}と{1}のれいです。\",\"mono\":\"monospace\",\"input\":\"はねだくうこうに、つきました。\",\"faint_link\":\"とてもたすけになるマニュアル\",\"fine_print\":\"わたしたちの{0}を、よまないでください!\",\"header_faint\":\"エラーではありません\",\"checkbox\":\"りようきやくを、よみました\",\"link\":\"ハイパーリンク\"}}},\"timeline\":{\"collapse\":\"たたむ\",\"conversation\":\"スレッド\",\"error_fetching\":\"よみこみがエラーになりました\",\"load_older\":\"ふるいステータス\",\"no_retweet_hint\":\"とうこうを「フォロワーのみ」または「ダイレクト」にすると、リピートできなくなります\",\"repeated\":\"リピート\",\"show_new\":\"よみこみ\",\"up_to_date\":\"さいしん\",\"no_more_statuses\":\"これでおわりです\"},\"user_card\":{\"approve\":\"うけいれ\",\"block\":\"ブロック\",\"blocked\":\"ブロックしています!\",\"deny\":\"おことわり\",\"favorites\":\"おきにいり\",\"follow\":\"フォロー\",\"follow_sent\":\"リクエストを、おくりました!\",\"follow_progress\":\"リクエストしています…\",\"follow_again\":\"ふたたびリクエストをおくりますか?\",\"follow_unfollow\":\"フォローをやめる\",\"followees\":\"フォロー\",\"followers\":\"フォロワー\",\"following\":\"フォローしています!\",\"follows_you\":\"フォローされました!\",\"its_you\":\"これはあなたです!\",\"media\":\"メディア\",\"mute\":\"ミュート\",\"muted\":\"ミュートしています!\",\"per_day\":\"/日\",\"remote_follow\":\"リモートフォロー\",\"statuses\":\"ステータス\"},\"user_profile\":{\"timeline_title\":\"ユーザータイムライン\"},\"who_to_follow\":{\"more\":\"くわしく\",\"who_to_follow\":\"おすすめユーザー\"},\"tool_tip\":{\"media_upload\":\"メディアをアップロード\",\"repeat\":\"リピート\",\"reply\":\"リプライ\",\"favorite\":\"おきにいり\",\"user_settings\":\"ユーザーせってい\"},\"upload\":{\"error\":{\"base\":\"アップロードにしっぱいしました。\",\"file_too_big\":\"ファイルがおおきすぎます [{filesize} {filesizeunit} / {allowedsize} {allowedsizeunit}]\",\"default\":\"しばらくしてから、ためしてください\"},\"file_size_units\":{\"B\":\"B\",\"KiB\":\"KiB\",\"MiB\":\"MiB\",\"GiB\":\"GiB\",\"TiB\":\"TiB\"}}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/ja.json\n// module id = 447\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"챗\"},\"features_panel\":{\"chat\":\"챗\",\"gopher\":\"고퍼\",\"media_proxy\":\"미디어 프록시\",\"scope_options\":\"범위 옵션\",\"text_limit\":\"텍스트 제한\",\"title\":\"기능\",\"who_to_follow\":\"팔로우 추천\"},\"finder\":{\"error_fetching_user\":\"사용자 정보 불러오기 실패\",\"find_user\":\"사용자 찾기\"},\"general\":{\"apply\":\"적용\",\"submit\":\"보내기\"},\"login\":{\"login\":\"로그인\",\"description\":\"OAuth로 로그인\",\"logout\":\"로그아웃\",\"password\":\"암호\",\"placeholder\":\"예시: lain\",\"register\":\"가입\",\"username\":\"사용자 이름\"},\"nav\":{\"about\":\"About\",\"back\":\"뒤로\",\"chat\":\"로컬 챗\",\"friend_requests\":\"팔로우 요청\",\"mentions\":\"멘션\",\"dms\":\"다이렉트 메시지\",\"public_tl\":\"공개 타임라인\",\"timeline\":\"타임라인\",\"twkn\":\"모든 알려진 네트워크\",\"user_search\":\"사용자 검색\",\"preferences\":\"환경설정\"},\"notifications\":{\"broken_favorite\":\"알 수 없는 게시물입니다, 검색 합니다...\",\"favorited_you\":\"당신의 게시물을 즐겨찾기\",\"followed_you\":\"당신을 팔로우\",\"load_older\":\"오래 된 알림 불러오기\",\"notifications\":\"알림\",\"read\":\"읽음!\",\"repeated_you\":\"당신의 게시물을 리핏\"},\"post_status\":{\"new_status\":\"새 게시물 게시\",\"account_not_locked_warning\":\"당신의 계정은 {0} 상태가 아닙니다. 누구나 당신을 팔로우 하고 팔로워 전용 게시물을 볼 수 있습니다.\",\"account_not_locked_warning_link\":\"잠김\",\"attachments_sensitive\":\"첨부물을 민감함으로 설정\",\"content_type\":{\"plain_text\":\"평문\"},\"content_warning\":\"주제 (필수 아님)\",\"default\":\"LA에 도착!\",\"direct_warning\":\"이 게시물을 멘션 된 사용자들에게만 보여집니다\",\"posting\":\"게시\",\"scope\":{\"direct\":\"다이렉트 - 멘션 된 사용자들에게만\",\"private\":\"팔로워 전용 - 팔로워들에게만\",\"public\":\"공개 - 공개 타임라인으로\",\"unlisted\":\"비공개 - 공개 타임라인에 게시 안 함\"}},\"registration\":{\"bio\":\"소개\",\"email\":\"이메일\",\"fullname\":\"표시 되는 이름\",\"password_confirm\":\"암호 확인\",\"registration\":\"가입하기\",\"token\":\"초대 토큰\",\"captcha\":\"캡차\",\"new_captcha\":\"이미지를 클릭해서 새로운 캡차\",\"validations\":{\"username_required\":\"공백으로 둘 수 없습니다\",\"fullname_required\":\"공백으로 둘 수 없습니다\",\"email_required\":\"공백으로 둘 수 없습니다\",\"password_required\":\"공백으로 둘 수 없습니다\",\"password_confirmation_required\":\"공백으로 둘 수 없습니다\",\"password_confirmation_match\":\"패스워드와 일치해야 합니다\"}},\"settings\":{\"attachmentRadius\":\"첨부물\",\"attachments\":\"첨부물\",\"autoload\":\"최하단에 도착하면 자동으로 로드 활성화\",\"avatar\":\"아바타\",\"avatarAltRadius\":\"아바타 (알림)\",\"avatarRadius\":\"아바타\",\"background\":\"배경\",\"bio\":\"소개\",\"btnRadius\":\"버튼\",\"cBlue\":\"파랑 (답글, 팔로우)\",\"cGreen\":\"초록 (리트윗)\",\"cOrange\":\"주황 (즐겨찾기)\",\"cRed\":\"빨강 (취소)\",\"change_password\":\"암호 바꾸기\",\"change_password_error\":\"암호를 바꾸는 데 몇 가지 문제가 있습니다.\",\"changed_password\":\"암호를 바꾸었습니다!\",\"collapse_subject\":\"주제를 가진 게시물 접기\",\"composing\":\"작성\",\"confirm_new_password\":\"새 패스워드 확인\",\"current_avatar\":\"현재 아바타\",\"current_password\":\"현재 패스워드\",\"current_profile_banner\":\"현재 프로필 배너\",\"data_import_export_tab\":\"데이터 불러오기 / 내보내기\",\"default_vis\":\"기본 공개 범위\",\"delete_account\":\"계정 삭제\",\"delete_account_description\":\"계정과 메시지를 영구히 삭제.\",\"delete_account_error\":\"계정을 삭제하는데 문제가 있습니다. 계속 발생한다면 인스턴스 관리자에게 문의하세요.\",\"delete_account_instructions\":\"계정 삭제를 확인하기 위해 아래에 패스워드 입력.\",\"export_theme\":\"프리셋 저장\",\"filtering\":\"필터링\",\"filtering_explanation\":\"아래의 단어를 가진 게시물들은 뮤트 됩니다, 한 줄에 하나씩 적으세요\",\"follow_export\":\"팔로우 내보내기\",\"follow_export_button\":\"팔로우 목록을 csv로 내보내기\",\"follow_export_processing\":\"진행 중입니다, 곧 다운로드 가능해 질 것입니다\",\"follow_import\":\"팔로우 불러오기\",\"follow_import_error\":\"팔로우 불러오기 실패\",\"follows_imported\":\"팔로우 목록을 불러왔습니다! 처리에는 시간이 걸립니다.\",\"foreground\":\"전경\",\"general\":\"일반\",\"hide_attachments_in_convo\":\"대화의 첨부물 숨기기\",\"hide_attachments_in_tl\":\"타임라인의 첨부물 숨기기\",\"hide_isp\":\"인스턴스 전용 패널 숨기기\",\"preload_images\":\"이미지 미리 불러오기\",\"hide_post_stats\":\"게시물 통계 숨기기 (즐겨찾기 수 등)\",\"hide_user_stats\":\"사용자 통계 숨기기 (팔로워 수 등)\",\"import_followers_from_a_csv_file\":\"csv 파일에서 팔로우 목록 불러오기\",\"import_theme\":\"프리셋 불러오기\",\"inputRadius\":\"입력 칸\",\"checkboxRadius\":\"체크박스\",\"instance_default\":\"(기본: {value})\",\"instance_default_simple\":\"(기본)\",\"interface\":\"인터페이스\",\"interfaceLanguage\":\"인터페이스 언어\",\"invalid_theme_imported\":\"선택한 파일은 지원하는 플레로마 테마가 아닙니다. 아무런 변경도 일어나지 않았습니다.\",\"limited_availability\":\"이 브라우저에서 사용 불가\",\"links\":\"링크\",\"lock_account_description\":\"계정을 승인 된 팔로워들로 제한\",\"loop_video\":\"비디오 반복재생\",\"loop_video_silent_only\":\"소리가 없는 비디오만 반복 재생 (마스토돈의 \\\"gifs\\\" 같은 것들)\",\"name\":\"이름\",\"name_bio\":\"이름 & 소개\",\"new_password\":\"새 암호\",\"notification_visibility\":\"보여 줄 알림 종류\",\"notification_visibility_follows\":\"팔로우\",\"notification_visibility_likes\":\"좋아함\",\"notification_visibility_mentions\":\"멘션\",\"notification_visibility_repeats\":\"반복\",\"no_rich_text_description\":\"모든 게시물의 서식을 지우기\",\"hide_follows_description\":\"내가 팔로우하는 사람을 표시하지 않음\",\"hide_followers_description\":\"나를 따르는 사람을 보여주지 마라.\",\"nsfw_clickthrough\":\"NSFW 이미지 \\\"클릭해서 보이기\\\"를 활성화\",\"oauth_tokens\":\"OAuth 토큰\",\"token\":\"토큰\",\"refresh_token\":\"토큰 새로 고침\",\"valid_until\":\"까지 유효하다\",\"revoke_token\":\"취소\",\"panelRadius\":\"패널\",\"pause_on_unfocused\":\"탭이 활성 상태가 아닐 때 스트리밍 멈추기\",\"presets\":\"프리셋\",\"profile_background\":\"프로필 배경\",\"profile_banner\":\"프로필 배너\",\"profile_tab\":\"프로필\",\"radii_help\":\"인터페이스 모서리 둥글기 (픽셀 단위)\",\"replies_in_timeline\":\"답글을 타임라인에\",\"reply_link_preview\":\"마우스를 올려서 답글 링크 미리보기 활성화\",\"reply_visibility_all\":\"모든 답글 보기\",\"reply_visibility_following\":\"나에게 직접 오는 답글이나 내가 팔로우 중인 사람에게서 오는 답글만 표시\",\"reply_visibility_self\":\"나에게 직접 전송 된 답글만 보이기\",\"saving_err\":\"설정 저장 실패\",\"saving_ok\":\"설정 저장 됨\",\"security_tab\":\"보안\",\"scope_copy\":\"답글을 달 때 공개 범위 따라가리 (다이렉트 메시지는 언제나 따라감)\",\"set_new_avatar\":\"새 아바타 설정\",\"set_new_profile_background\":\"새 프로필 배경 설정\",\"set_new_profile_banner\":\"새 프로필 배너 설정\",\"settings\":\"설정\",\"subject_input_always_show\":\"항상 주제 칸 보이기\",\"subject_line_behavior\":\"답글을 달 때 주제 복사하기\",\"subject_line_email\":\"이메일처럼: \\\"re: 주제\\\"\",\"subject_line_mastodon\":\"마스토돈처럼: 그대로 복사\",\"subject_line_noop\":\"복사 안 함\",\"stop_gifs\":\"GIF파일에 마우스를 올려서 재생\",\"streaming\":\"최상단에 도달하면 자동으로 새 게시물 스트리밍\",\"text\":\"텍스트\",\"theme\":\"테마\",\"theme_help\":\"16진수 색상코드(#rrggbb)를 사용해 색상 테마를 커스터마이즈.\",\"theme_help_v2_1\":\"체크박스를 통해 몇몇 컴포넌트의 색상과 불투명도를 조절 가능, \\\"모두 지우기\\\" 버튼으로 덮어 씌운 것을 모두 취소.\",\"theme_help_v2_2\":\"몇몇 입력칸 밑의 아이콘은 전경/배경 대비 관련 표시등입니다, 마우스를 올려 자세한 정보를 볼 수 있습니다. 투명도 대비 표시등이 가장 최악의 경우를 나타낸다는 것을 유의하세요.\",\"tooltipRadius\":\"툴팁/경고\",\"user_settings\":\"사용자 설정\",\"values\":{\"false\":\"아니오\",\"true\":\"네\"},\"notifications\":\"알림\",\"enable_web_push_notifications\":\"웹 푸시 알림 활성화\",\"style\":{\"switcher\":{\"keep_color\":\"색상 유지\",\"keep_shadows\":\"그림자 유지\",\"keep_opacity\":\"불투명도 유지\",\"keep_roundness\":\"둥글기 유지\",\"keep_fonts\":\"글자체 유지\",\"save_load_hint\":\"\\\"유지\\\" 옵션들은 다른 테마를 고르거나 불러 올 때 현재 설정 된 옵션들을 건드리지 않게 합니다, 테마를 내보내기 할 때도 이 옵션에 따라 저장합니다. 아무 것도 체크 되지 않았다면 모든 설정을 내보냅니다.\",\"reset\":\"초기화\",\"clear_all\":\"모두 지우기\",\"clear_opacity\":\"불투명도 지우기\"},\"common\":{\"color\":\"색상\",\"opacity\":\"불투명도\",\"contrast\":{\"hint\":\"대비율이 {ratio}입니다, 이것은 {context} {level}\",\"level\":{\"aa\":\"AA등급 가이드라인에 부합합니다 (최소한도)\",\"aaa\":\"AAA등급 가이드라인에 부합합니다 (권장)\",\"bad\":\"아무런 가이드라인 등급에도 미치지 못합니다\"},\"context\":{\"18pt\":\"큰 (18pt 이상) 텍스트에 대해\",\"text\":\"텍스트에 대해\"}}},\"common_colors\":{\"_tab_label\":\"일반\",\"main\":\"일반 색상\",\"foreground_hint\":\"\\\"고급\\\" 탭에서 더 자세한 설정이 가능합니다\",\"rgbo\":\"아이콘, 강조, 배지\"},\"advanced_colors\":{\"_tab_label\":\"고급\",\"alert\":\"주의 배경\",\"alert_error\":\"에러\",\"badge\":\"배지 배경\",\"badge_notification\":\"알림\",\"panel_header\":\"패널 헤더\",\"top_bar\":\"상단 바\",\"borders\":\"테두리\",\"buttons\":\"버튼\",\"inputs\":\"입력칸\",\"faint_text\":\"흐려진 텍스트\"},\"radii\":{\"_tab_label\":\"둥글기\"},\"shadows\":{\"_tab_label\":\"그림자와 빛\",\"component\":\"컴포넌트\",\"override\":\"덮어쓰기\",\"shadow_id\":\"그림자 #{value}\",\"blur\":\"흐리기\",\"spread\":\"퍼지기\",\"inset\":\"안쪽으로\",\"hint\":\"그림자에는 CSS3 변수를 --variable을 통해 색상 값으로 사용할 수 있습니다. 불투명도에는 적용 되지 않습니다.\",\"filter_hint\":{\"always_drop_shadow\":\"경고, 이 그림자는 브라우저가 지원하는 경우 항상 {0}을 사용합니다.\",\"drop_shadow_syntax\":\"{0}는 {1} 파라미터와 {2} 키워드를 지원하지 않습니다.\",\"avatar_inset\":\"안쪽과 안쪽이 아닌 그림자를 모두 설정하는 경우 투명 아바타에서 예상치 못 한 결과가 나올 수 있다는 것에 주의해 주세요.\",\"spread_zero\":\"퍼지기가 0보다 큰 그림자는 0으로 설정한 것과 동일하게 보여집니다\",\"inset_classic\":\"안쪽 그림자는 {0}를 사용합니다\"},\"components\":{\"panel\":\"패널\",\"panelHeader\":\"패널 헤더\",\"topBar\":\"상단 바\",\"avatar\":\"사용자 아바타 (프로필 뷰에서)\",\"avatarStatus\":\"사용자 아바타 (게시물에서)\",\"popup\":\"팝업과 툴팁\",\"button\":\"버튼\",\"buttonHover\":\"버튼 (마우스 올렸을 때)\",\"buttonPressed\":\"버튼 (눌렸을 때)\",\"buttonPressedHover\":\"Button (마우스 올림 + 눌림)\",\"input\":\"입력칸\"}},\"fonts\":{\"_tab_label\":\"글자체\",\"help\":\"인터페이스의 요소에 사용 될 글자체를 고르세요. \\\"커스텀\\\"은 시스템에 있는 폰트 이름을 정확히 입력해야 합니다.\",\"components\":{\"interface\":\"인터페이스\",\"input\":\"입력칸\",\"post\":\"게시물 텍스트\",\"postCode\":\"게시물의 고정폭 텍스트 (서식 있는 텍스트)\"},\"family\":\"글자체 이름\",\"size\":\"크기 (px 단위)\",\"weight\":\"굵기\",\"custom\":\"커스텀\"},\"preview\":{\"header\":\"미리보기\",\"content\":\"내용\",\"error\":\"에러 예시\",\"button\":\"버튼\",\"text\":\"더 많은 {0} 그리고 {1}\",\"mono\":\"내용\",\"input\":\"LA에 막 도착!\",\"faint_link\":\"도움 되는 설명서\",\"fine_print\":\"우리의 {0} 를 읽고 도움 되지 않는 것들을 배우자!\",\"header_faint\":\"이건 괜찮아\",\"checkbox\":\"나는 약관을 대충 훑어보았습니다\",\"link\":\"작고 귀여운 링크\"}}},\"timeline\":{\"collapse\":\"접기\",\"conversation\":\"대화\",\"error_fetching\":\"업데이트 불러오기 실패\",\"load_older\":\"더 오래 된 게시물 불러오기\",\"no_retweet_hint\":\"팔로워 전용, 다이렉트 메시지는 반복할 수 없습니다\",\"repeated\":\"반복 됨\",\"show_new\":\"새로운 것 보기\",\"up_to_date\":\"최신 상태\"},\"user_card\":{\"approve\":\"승인\",\"block\":\"차단\",\"blocked\":\"차단 됨!\",\"deny\":\"거부\",\"follow\":\"팔로우\",\"follow_sent\":\"요청 보내짐!\",\"follow_progress\":\"요청 중…\",\"follow_again\":\"요청을 다시 보낼까요?\",\"follow_unfollow\":\"팔로우 중지\",\"followees\":\"팔로우 중\",\"followers\":\"팔로워\",\"following\":\"팔로우 중!\",\"follows_you\":\"당신을 팔로우 합니다!\",\"its_you\":\"당신입니다!\",\"mute\":\"침묵\",\"muted\":\"침묵 됨\",\"per_day\":\" / 하루\",\"remote_follow\":\"원격 팔로우\",\"statuses\":\"게시물\"},\"user_profile\":{\"timeline_title\":\"사용자 타임라인\"},\"who_to_follow\":{\"more\":\"더 보기\",\"who_to_follow\":\"팔로우 추천\"},\"tool_tip\":{\"media_upload\":\"미디어 업로드\",\"repeat\":\"반복\",\"reply\":\"답글\",\"favorite\":\"즐겨찾기\",\"user_settings\":\"사용자 설정\"},\"upload\":{\"error\":{\"base\":\"업로드 실패.\",\"file_too_big\":\"파일이 너무 커요 [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"잠시 후에 다시 시도해 보세요\"},\"file_size_units\":{\"B\":\"바이트\",\"KiB\":\"키비바이트\",\"MiB\":\"메비바이트\",\"GiB\":\"기비바이트\",\"TiB\":\"테비바이트\"}}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/ko.json\n// module id = 448\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Nettprat\"},\"features_panel\":{\"chat\":\"Nettprat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Media proxy\",\"scope_options\":\"Velg mottakere\",\"text_limit\":\"Tekst-grense\",\"title\":\"Egenskaper\",\"who_to_follow\":\"Hvem å følge\"},\"finder\":{\"error_fetching_user\":\"Feil ved henting av bruker\",\"find_user\":\"Finn bruker\"},\"general\":{\"apply\":\"Bruk\",\"submit\":\"Send\"},\"login\":{\"login\":\"Logg inn\",\"logout\":\"Logg ut\",\"password\":\"Passord\",\"placeholder\":\"f. eks lain\",\"register\":\"Registrer\",\"username\":\"Brukernavn\"},\"nav\":{\"chat\":\"Lokal nettprat\",\"friend_requests\":\"Følgeforespørsler\",\"mentions\":\"Nevnt\",\"public_tl\":\"Offentlig Tidslinje\",\"timeline\":\"Tidslinje\",\"twkn\":\"Det hele kjente nettverket\"},\"notifications\":{\"broken_favorite\":\"Ukjent status, leter etter den...\",\"favorited_you\":\"likte din status\",\"followed_you\":\"fulgte deg\",\"load_older\":\"Last eldre varsler\",\"notifications\":\"Varslinger\",\"read\":\"Les!\",\"repeated_you\":\"Gjentok din status\"},\"post_status\":{\"account_not_locked_warning\":\"Kontoen din er ikke {0}. Hvem som helst kan følge deg for å se dine statuser til følgere\",\"account_not_locked_warning_link\":\"låst\",\"attachments_sensitive\":\"Merk vedlegg som sensitive\",\"content_type\":{\"plain_text\":\"Klar tekst\"},\"content_warning\":\"Tema (valgfritt)\",\"default\":\"Landet akkurat i L.A.\",\"direct_warning\":\"Denne statusen vil kun bli sett av nevnte brukere\",\"posting\":\"Publiserer\",\"scope\":{\"direct\":\"Direkte, publiser bare til nevnte brukere\",\"private\":\"Bare følgere, publiser bare til brukere som følger deg\",\"public\":\"Offentlig, publiser til offentlige tidslinjer\",\"unlisted\":\"Uoppført, ikke publiser til offentlige tidslinjer\"}},\"registration\":{\"bio\":\"Biografi\",\"email\":\"Epost-adresse\",\"fullname\":\"Visningsnavn\",\"password_confirm\":\"Bekreft passord\",\"registration\":\"Registrering\",\"token\":\"Invitasjons-bevis\"},\"settings\":{\"attachmentRadius\":\"Vedlegg\",\"attachments\":\"Vedlegg\",\"autoload\":\"Automatisk lasting når du blar ned til bunnen\",\"avatar\":\"Profilbilde\",\"avatarAltRadius\":\"Profilbilde (Varslinger)\",\"avatarRadius\":\"Profilbilde\",\"background\":\"Bakgrunn\",\"bio\":\"Biografi\",\"btnRadius\":\"Knapper\",\"cBlue\":\"Blå (Svar, følg)\",\"cGreen\":\"Grønn (Gjenta)\",\"cOrange\":\"Oransje (Lik)\",\"cRed\":\"Rød (Avbryt)\",\"change_password\":\"Endre passord\",\"change_password_error\":\"Feil ved endring av passord\",\"changed_password\":\"Passord endret\",\"collapse_subject\":\"Sammenfold statuser med tema\",\"confirm_new_password\":\"Bekreft nytt passord\",\"current_avatar\":\"Ditt nåværende profilbilde\",\"current_password\":\"Nåværende passord\",\"current_profile_banner\":\"Din nåværende profil-banner\",\"data_import_export_tab\":\"Data import / eksport\",\"default_vis\":\"Standard visnings-omfang\",\"delete_account\":\"Slett konto\",\"delete_account_description\":\"Slett din konto og alle dine statuser\",\"delete_account_error\":\"Det oppsto et problem ved sletting av kontoen din, hvis dette problemet forblir kontakt din administrator\",\"delete_account_instructions\":\"Skriv inn ditt passord i feltet nedenfor for å bekrefte sletting av konto\",\"export_theme\":\"Lagre tema\",\"filtering\":\"Filtrering\",\"filtering_explanation\":\"Alle statuser som inneholder disse ordene vil bli dempet, en kombinasjon av tegn per linje\",\"follow_export\":\"Eksporter følginger\",\"follow_export_button\":\"Eksporter følgingene dine til en .csv fil\",\"follow_export_processing\":\"Jobber, du vil snart bli spurt om å laste ned filen din.\",\"follow_import\":\"Importer følginger\",\"follow_import_error\":\"Feil ved importering av følginger.\",\"follows_imported\":\"Følginger importert! Behandling vil ta litt tid.\",\"foreground\":\"Forgrunn\",\"general\":\"Generell\",\"hide_attachments_in_convo\":\"Gjem vedlegg i samtaler\",\"hide_attachments_in_tl\":\"Gjem vedlegg på tidslinje\",\"import_followers_from_a_csv_file\":\"Importer følginger fra en csv fil\",\"import_theme\":\"Last tema\",\"inputRadius\":\"Input felt\",\"instance_default\":\"(standard: {value})\",\"interfaceLanguage\":\"Grensesnitt-språk\",\"invalid_theme_imported\":\"Den valgte filen er ikke ett støttet Pleroma-tema, ingen endringer til ditt tema ble gjort\",\"limited_availability\":\"Ikke tilgjengelig i din nettleser\",\"links\":\"Linker\",\"lock_account_description\":\"Begrens din konto til bare godkjente følgere\",\"loop_video\":\"Gjenta videoer\",\"loop_video_silent_only\":\"Gjenta bare videoer uten lyd, (for eksempel Mastodon sine \\\"gifs\\\")\",\"name\":\"Navn\",\"name_bio\":\"Navn & Biografi\",\"new_password\":\"Nytt passord\",\"notification_visibility\":\"Typer varsler som skal vises\",\"notification_visibility_follows\":\"Følginger\",\"notification_visibility_likes\":\"Likes\",\"notification_visibility_mentions\":\"Nevnt\",\"notification_visibility_repeats\":\"Gjentakelser\",\"no_rich_text_description\":\"Fjern all formatering fra statuser\",\"nsfw_clickthrough\":\"Krev trykk for å vise statuser som kan være upassende\",\"oauth_tokens\":\"OAuth Tokens\",\"token\":\"Pollett\",\"refresh_token\":\"Refresh Token\",\"valid_until\":\"Gyldig til\",\"revoke_token\":\"Tilbakekall\",\"panelRadius\":\"Panel\",\"pause_on_unfocused\":\"Stopp henting av poster når vinduet ikke er i fokus\",\"presets\":\"Forhåndsdefinerte tema\",\"profile_background\":\"Profil-bakgrunn\",\"profile_banner\":\"Profil-banner\",\"profile_tab\":\"Profil\",\"radii_help\":\"Bestem hvor runde hjørnene i brukergrensesnittet skal være (i piksler)\",\"replies_in_timeline\":\"Svar på tidslinje\",\"reply_link_preview\":\"Vis en forhåndsvisning når du holder musen over svar til en status\",\"reply_visibility_all\":\"Vis alle svar\",\"reply_visibility_following\":\"Vis bare svar som er til meg eller folk jeg følger\",\"reply_visibility_self\":\"Vis bare svar som er til meg\",\"saving_err\":\"Feil ved lagring av innstillinger\",\"saving_ok\":\"Innstillinger lagret\",\"security_tab\":\"Sikkerhet\",\"set_new_avatar\":\"Rediger profilbilde\",\"set_new_profile_background\":\"Rediger profil-bakgrunn\",\"set_new_profile_banner\":\"Sett ny profil-banner\",\"settings\":\"Innstillinger\",\"stop_gifs\":\"Spill av GIFs når du holder over dem\",\"streaming\":\"Automatisk strømming av nye statuser når du har bladd til toppen\",\"text\":\"Tekst\",\"theme\":\"Tema\",\"theme_help\":\"Bruk heksadesimale fargekoder (#rrggbb) til å endre farge-temaet ditt.\",\"tooltipRadius\":\"Verktøytips/advarsler\",\"user_settings\":\"Brukerinstillinger\",\"values\":{\"false\":\"nei\",\"true\":\"ja\"}},\"timeline\":{\"collapse\":\"Sammenfold\",\"conversation\":\"Samtale\",\"error_fetching\":\"Feil ved henting av oppdateringer\",\"load_older\":\"Last eldre statuser\",\"no_retweet_hint\":\"Status er markert som bare til følgere eller direkte og kan ikke gjentas\",\"repeated\":\"gjentok\",\"show_new\":\"Vis nye\",\"up_to_date\":\"Oppdatert\"},\"user_card\":{\"approve\":\"Godkjenn\",\"block\":\"Blokker\",\"blocked\":\"Blokkert!\",\"deny\":\"Avslå\",\"follow\":\"Følg\",\"followees\":\"Følger\",\"followers\":\"Følgere\",\"following\":\"Følger!\",\"follows_you\":\"Følger deg!\",\"mute\":\"Demp\",\"muted\":\"Dempet\",\"per_day\":\"per dag\",\"remote_follow\":\"Følg eksternt\",\"statuses\":\"Statuser\"},\"user_profile\":{\"timeline_title\":\"Bruker-tidslinje\"},\"who_to_follow\":{\"more\":\"Mer\",\"who_to_follow\":\"Hvem å følge\"}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/nb.json\n// module id = 449\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Chat\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Media proxy\",\"scope_options\":\"Zichtbaarheidsopties\",\"text_limit\":\"Tekst limiet\",\"title\":\"Features\",\"who_to_follow\":\"Wie te volgen\"},\"finder\":{\"error_fetching_user\":\"Fout tijdens ophalen gebruiker\",\"find_user\":\"Gebruiker zoeken\"},\"general\":{\"apply\":\"toepassen\",\"submit\":\"Verzend\"},\"login\":{\"login\":\"Log in\",\"description\":\"Log in met OAuth\",\"logout\":\"Log uit\",\"password\":\"Wachtwoord\",\"placeholder\":\"bv. lain\",\"register\":\"Registreer\",\"username\":\"Gebruikersnaam\"},\"nav\":{\"about\":\"Over\",\"back\":\"Terug\",\"chat\":\"Locale Chat\",\"friend_requests\":\"Volgverzoek\",\"mentions\":\"Vermeldingen\",\"dms\":\"Directe Berichten\",\"public_tl\":\"Publieke Tijdlijn\",\"timeline\":\"Tijdlijn\",\"twkn\":\"Het Geheel Gekende Netwerk\",\"user_search\":\"Zoek Gebruiker\",\"who_to_follow\":\"Wie te volgen\",\"preferences\":\"Voorkeuren\"},\"notifications\":{\"broken_favorite\":\"Onbekende status, aan het zoeken...\",\"favorited_you\":\"vond je status leuk\",\"followed_you\":\"volgt jou\",\"load_older\":\"Laad oudere meldingen\",\"notifications\":\"Meldingen\",\"read\":\"Gelezen!\",\"repeated_you\":\"Herhaalde je status\"},\"post_status\":{\"new_status\":\"Post nieuwe status\",\"account_not_locked_warning\":\"Je account is niet {0}. Iedereen die je volgt kan enkel-volgers posts lezen.\",\"account_not_locked_warning_link\":\"gesloten\",\"attachments_sensitive\":\"Markeer bijlage als gevoelig\",\"content_type\":{\"plain_text\":\"Gewone tekst\"},\"content_warning\":\"Onderwerp (optioneel)\",\"default\":\"Tijd voor een pauze!\",\"direct_warning\":\"Deze post zal enkel zichtbaar zijn voor de personen die genoemd zijn.\",\"posting\":\"Plaatsen\",\"scope\":{\"direct\":\"Direct - Post enkel naar genoemde gebruikers\",\"private\":\"Enkel volgers - Post enkel naar volgers\",\"public\":\"Publiek - Post op publieke tijdlijnen\",\"unlisted\":\"Unlisted - Toon niet op publieke tijdlijnen\"}},\"registration\":{\"bio\":\"Bio\",\"email\":\"Email\",\"fullname\":\"Weergave naam\",\"password_confirm\":\"Wachtwoord bevestiging\",\"registration\":\"Registratie\",\"token\":\"Uitnodigingstoken\",\"captcha\":\"CAPTCHA\",\"new_captcha\":\"Klik op de afbeelding voor een nieuwe captcha\",\"validations\":{\"username_required\":\"moet ingevuld zijn\",\"fullname_required\":\"moet ingevuld zijn\",\"email_required\":\"moet ingevuld zijn\",\"password_required\":\"moet ingevuld zijn\",\"password_confirmation_required\":\"moet ingevuld zijn\",\"password_confirmation_match\":\"komt niet overeen met het wachtwoord\"}},\"settings\":{\"attachmentRadius\":\"Bijlages\",\"attachments\":\"Bijlages\",\"autoload\":\"Automatisch laden wanneer tot de bodem gescrold inschakelen\",\"avatar\":\"Avatar\",\"avatarAltRadius\":\"Avatars (Meldingen)\",\"avatarRadius\":\"Avatars\",\"background\":\"Achtergrond\",\"bio\":\"Bio\",\"btnRadius\":\"Knoppen\",\"cBlue\":\"Blauw (Antwoord, volgen)\",\"cGreen\":\"Groen (Herhaal)\",\"cOrange\":\"Oranje (Vind ik leuk)\",\"cRed\":\"Rood (Annuleer)\",\"change_password\":\"Verander Wachtwoord\",\"change_password_error\":\"Er was een probleem bij het aanpassen van je wachtwoord.\",\"changed_password\":\"Wachtwoord succesvol aangepast!\",\"collapse_subject\":\"Klap posts met onderwerp in\",\"composing\":\"Samenstellen\",\"confirm_new_password\":\"Bevestig nieuw wachtwoord\",\"current_avatar\":\"Je huidige avatar\",\"current_password\":\"Huidig wachtwoord\",\"current_profile_banner\":\"Je huidige profiel banner\",\"data_import_export_tab\":\"Data Import / Export\",\"default_vis\":\"Standaard zichtbaarheidsscope\",\"delete_account\":\"Verwijder Account\",\"delete_account_description\":\"Verwijder je account en berichten permanent.\",\"delete_account_error\":\"Er was een probleem bij het verwijderen van je account. Indien dit probleem blijft, gelieve de administratie van deze instantie te verwittigen.\",\"delete_account_instructions\":\"Typ je wachtwoord in de input hieronder om het verwijderen van je account te bevestigen.\",\"export_theme\":\"Sla preset op\",\"filtering\":\"Filtering\",\"filtering_explanation\":\"Alle statussen die deze woorden bevatten worden genegeerd, één filter per lijn.\",\"follow_export\":\"Volgers export\",\"follow_export_button\":\"Exporteer je volgers naar een csv file\",\"follow_export_processing\":\"Aan het verwerken, binnen enkele ogenblikken wordt je gevraagd je bestand te downloaden\",\"follow_import\":\"Volgers import\",\"follow_import_error\":\"Fout bij importeren volgers\",\"follows_imported\":\"Volgers geïmporteerd! Het kan even duren om ze allemaal te verwerken.\",\"foreground\":\"Voorgrond\",\"general\":\"Algemeen\",\"hide_attachments_in_convo\":\"Verberg bijlages in conversaties\",\"hide_attachments_in_tl\":\"Verberg bijlages in de tijdlijn\",\"hide_isp\":\"Verberg instantie-specifiek paneel\",\"preload_images\":\"Afbeeldingen voorladen\",\"hide_post_stats\":\"Verberg post statistieken (bv. het aantal vind-ik-leuks)\",\"hide_user_stats\":\"Verberg post statistieken (bv. het aantal volgers)\",\"import_followers_from_a_csv_file\":\"Importeer volgers uit een csv file\",\"import_theme\":\"Laad preset\",\"inputRadius\":\"Invoer velden\",\"checkboxRadius\":\"Checkboxen\",\"instance_default\":\"(standaard: {value})\",\"instance_default_simple\":\"(standaard)\",\"interface\":\"Interface\",\"interfaceLanguage\":\"Interface taal\",\"invalid_theme_imported\":\"Het geselecteerde thema is geen door Pleroma ondersteund thema. Er zijn geen aanpassingen gedaan.\",\"limited_availability\":\"Onbeschikbaar in je browser\",\"links\":\"Links\",\"lock_account_description\":\"Laat volgers enkel toe na expliciete toestemming\",\"loop_video\":\"Speel videos af in een lus\",\"loop_video_silent_only\":\"Speel enkel videos zonder geluid af in een lus (bv. Mastodon's \\\"gifs\\\")\",\"name\":\"Naam\",\"name_bio\":\"Naam & Bio\",\"new_password\":\"Nieuw wachtwoord\",\"notification_visibility\":\"Type meldingen die getoond worden\",\"notification_visibility_follows\":\"Volgers\",\"notification_visibility_likes\":\"Vind-ik-leuks\",\"notification_visibility_mentions\":\"Vermeldingen\",\"notification_visibility_repeats\":\"Herhalingen\",\"no_rich_text_description\":\"Strip rich text formattering van alle posts\",\"hide_network_description\":\"Toon niet wie mij volgt en wie ik volg.\",\"nsfw_clickthrough\":\"Schakel doorklikbaar verbergen van NSFW bijlages in\",\"oauth_tokens\":\"OAuth-tokens\",\"token\":\"Token\",\"refresh_token\":\"Token vernieuwen\",\"valid_until\":\"Geldig tot\",\"revoke_token\":\"Intrekken\",\"panelRadius\":\"Panelen\",\"pause_on_unfocused\":\"Pauzeer streamen wanneer de tab niet gefocused is\",\"presets\":\"Presets\",\"profile_background\":\"Profiel Achtergrond\",\"profile_banner\":\"Profiel Banner\",\"profile_tab\":\"Profiel\",\"radii_help\":\"Stel afronding van hoeken in de interface in (in pixels)\",\"replies_in_timeline\":\"Antwoorden in tijdlijn\",\"reply_link_preview\":\"Schakel antwoordlink preview in bij over zweven met muisaanwijzer\",\"reply_visibility_all\":\"Toon alle antwoorden\",\"reply_visibility_following\":\"Toon enkel antwoorden naar mij of andere gebruikers gericht\",\"reply_visibility_self\":\"Toon enkel antwoorden naar mij gericht\",\"saving_err\":\"Fout tijdens opslaan van instellingen\",\"saving_ok\":\"Instellingen opgeslagen\",\"security_tab\":\"Veiligheid\",\"scope_copy\":\"Neem scope over bij antwoorden (Directe Berichten blijven altijd Direct)\",\"set_new_avatar\":\"Zet nieuwe avatar\",\"set_new_profile_background\":\"Zet nieuwe profiel achtergrond\",\"set_new_profile_banner\":\"Zet nieuwe profiel banner\",\"settings\":\"Instellingen\",\"subject_input_always_show\":\"Maak onderwerpveld altijd zichtbaar\",\"subject_line_behavior\":\"Kopieer onderwerp bij antwoorden\",\"subject_line_email\":\"Zoals email: \\\"re: onderwerp\\\"\",\"subject_line_mastodon\":\"Zoals Mastodon: kopieer zoals het is\",\"subject_line_noop\":\"Kopieer niet\",\"stop_gifs\":\"Speel GIFs af bij zweven\",\"streaming\":\"Schakel automatisch streamen van posts in wanneer tot boven gescrold.\",\"text\":\"Tekst\",\"theme\":\"Thema\",\"theme_help\":\"Gebruik hex color codes (#rrggbb) om je kleurschema te wijzigen.\",\"theme_help_v2_1\":\"Je kan ook de kleur en transparantie van bepaalde componenten overschrijven door de checkbox aan te vinken, gebruik de \\\"Wis alles\\\" knop om alle overschrijvingen te annuleren.\",\"theme_help_v2_2\":\"Iconen onder sommige items zijn achtergrond/tekst contrast indicators, zweef er over voor gedetailleerde info. Hou er rekening mee dat bij doorzichtigheid de ergst mogelijke situatie wordt weer gegeven.\",\"tooltipRadius\":\"Gereedschapstips/alarmen\",\"user_settings\":\"Gebruikers Instellingen\",\"values\":{\"false\":\"nee\",\"true\":\"ja\"},\"notifications\":\"Meldingen\",\"enable_web_push_notifications\":\"Schakel web push meldingen in\",\"style\":{\"switcher\":{\"keep_color\":\"Behoud kleuren\",\"keep_shadows\":\"Behoud schaduwen\",\"keep_opacity\":\"Behoud transparantie\",\"keep_roundness\":\"Behoud afrondingen\",\"keep_fonts\":\"Behoud lettertypes\",\"save_load_hint\":\"\\\"Behoud\\\" opties behouden de momenteel ingestelde opties bij het selecteren of laden van thema's, maar slaan ook de genoemde opties op bij het exporteren van een thema. Wanneer alle selectievakjes zijn uitgeschakeld, zal het exporteren van thema's alles opslaan.\",\"reset\":\"Reset\",\"clear_all\":\"Wis alles\",\"clear_opacity\":\"Wis transparantie\"},\"common\":{\"color\":\"Kleur\",\"opacity\":\"Transparantie\",\"contrast\":{\"hint\":\"Contrast ratio is {ratio}, {level} {context}\",\"level\":{\"aa\":\"voldoet aan de richtlijn van niveau AA (minimum)\",\"aaa\":\"voldoet aan de richtlijn van niveau AAA (aangeraden)\",\"bad\":\"voldoet aan geen enkele toegankelijkheidsrichtlijn\"},\"context\":{\"18pt\":\"voor grote (18pt+) tekst\",\"text\":\"voor tekst\"}}},\"common_colors\":{\"_tab_label\":\"Gemeenschappelijk\",\"main\":\"Gemeenschappelijke kleuren\",\"foreground_hint\":\"Zie \\\"Geavanceerd\\\" tab voor meer gedetailleerde controle\",\"rgbo\":\"Iconen, accenten, badges\"},\"advanced_colors\":{\"_tab_label\":\"Geavanceerd\",\"alert\":\"Alarm achtergrond\",\"alert_error\":\"Fout\",\"badge\":\"Badge achtergrond\",\"badge_notification\":\"Meldingen\",\"panel_header\":\"Paneel hoofding\",\"top_bar\":\"Top bar\",\"borders\":\"Randen\",\"buttons\":\"Knoppen\",\"inputs\":\"Invoervelden\",\"faint_text\":\"Vervaagde tekst\"},\"radii\":{\"_tab_label\":\"Rondheid\"},\"shadows\":{\"_tab_label\":\"Schaduw en belichting\",\"component\":\"Component\",\"override\":\"Overschrijven\",\"shadow_id\":\"Schaduw #{value}\",\"blur\":\"Vervagen\",\"spread\":\"Spreid\",\"inset\":\"Inzet\",\"hint\":\"Voor schaduw kan je ook --variable gebruiken als een kleur waarde om CSS3 variabelen te gebruiken. Houd er rekening mee dat het instellen van opaciteit in dit geval niet werkt.\",\"filter_hint\":{\"always_drop_shadow\":\"Waarschuwing, deze schaduw gebruikt altijd {0} als de browser dit ondersteund.\",\"drop_shadow_syntax\":\"{0} ondersteund niet de {1} parameter en {2} sleutelwoord.\",\"avatar_inset\":\"Houd er rekening mee dat het combineren van zowel inzet and niet-inzet schaduwen op transparante avatars onverwachte resultaten kan opleveren.\",\"spread_zero\":\"Schaduw met spreiding > 0 worden weergegeven alsof ze op nul staan\",\"inset_classic\":\"Inzet schaduw zal {0} gebruiken\"},\"components\":{\"panel\":\"Paneel\",\"panelHeader\":\"Paneel hoofding\",\"topBar\":\"Top bar\",\"avatar\":\"Gebruiker avatar (in profiel weergave)\",\"avatarStatus\":\"Gebruiker avatar (in post weergave)\",\"popup\":\"Popups en gereedschapstips\",\"button\":\"Knop\",\"buttonHover\":\"Knop (zweven)\",\"buttonPressed\":\"Knop (ingedrukt)\",\"buttonPressedHover\":\"Knop (ingedrukt+zweven)\",\"input\":\"Invoerveld\"}},\"fonts\":{\"_tab_label\":\"Lettertypes\",\"help\":\"Selecteer het lettertype om te gebruiken voor elementen van de UI.Voor \\\"aangepast\\\" moet je de exacte naam van het lettertype invoeren zoals die in het systeem wordt weergegeven.\",\"components\":{\"interface\":\"Interface\",\"input\":\"Invoervelden\",\"post\":\"Post tekst\",\"postCode\":\"Monospaced tekst in een post (rich text)\"},\"family\":\"Naam lettertype\",\"size\":\"Grootte (in px)\",\"weight\":\"Gewicht (vetheid)\",\"custom\":\"Aangepast\"},\"preview\":{\"header\":\"Voorvertoning\",\"content\":\"Inhoud\",\"error\":\"Voorbeeld fout\",\"button\":\"Knop\",\"text\":\"Nog een boel andere {0} en {1}\",\"mono\":\"inhoud\",\"input\":\"Tijd voor een pauze!\",\"faint_link\":\"handige gebruikershandleiding\",\"fine_print\":\"Lees onze {0} om niets nuttig te leren!\",\"header_faint\":\"Alles komt goed\",\"checkbox\":\"Ik heb de gebruikersvoorwaarden eens van ver bekeken\",\"link\":\"een link\"}}},\"timeline\":{\"collapse\":\"Inklappen\",\"conversation\":\"Conversatie\",\"error_fetching\":\"Fout bij ophalen van updates\",\"load_older\":\"Laad oudere Statussen\",\"no_retweet_hint\":\"Post is gemarkeerd als enkel volgers of direct en kan niet worden herhaald\",\"repeated\":\"herhaalde\",\"show_new\":\"Toon nieuwe\",\"up_to_date\":\"Up-to-date\"},\"user_card\":{\"approve\":\"Goedkeuren\",\"block\":\"Blokkeren\",\"blocked\":\"Geblokkeerd!\",\"deny\":\"Ontzeggen\",\"favorites\":\"Vind-ik-leuks\",\"follow\":\"Volgen\",\"follow_sent\":\"Aanvraag verzonden!\",\"follow_progress\":\"Aanvragen…\",\"follow_again\":\"Aanvraag opnieuw zenden?\",\"follow_unfollow\":\"Stop volgen\",\"followees\":\"Aan het volgen\",\"followers\":\"Volgers\",\"following\":\"Aan het volgen!\",\"follows_you\":\"Volgt jou!\",\"its_you\":\"'t is jij!\",\"mute\":\"Dempen\",\"muted\":\"Gedempt\",\"per_day\":\"per dag\",\"remote_follow\":\"Volg vanop afstand\",\"statuses\":\"Statussen\"},\"user_profile\":{\"timeline_title\":\"Gebruikers Tijdlijn\"},\"who_to_follow\":{\"more\":\"Meer\",\"who_to_follow\":\"Wie te volgen\"},\"tool_tip\":{\"media_upload\":\"Upload Media\",\"repeat\":\"Herhaal\",\"reply\":\"Antwoord\",\"favorite\":\"Vind-ik-leuk\",\"user_settings\":\"Gebruikers Instellingen\"},\"upload\":{\"error\":{\"base\":\"Upload gefaald.\",\"file_too_big\":\"Bestand is te groot [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"Probeer later opnieuw\"},\"file_size_units\":{\"B\":\"B\",\"KiB\":\"KiB\",\"MiB\":\"MiB\",\"GiB\":\"GiB\",\"TiB\":\"TiB\"}}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/nl.json\n// module id = 450\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Messatjariá\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Servidor mandatari mèdia\",\"scope_options\":\"Nivèls de confidencialitat\",\"text_limit\":\"Limita de tèxte\",\"title\":\"Foncionalitats\",\"who_to_follow\":\"Qual seguir\"},\"finder\":{\"error_fetching_user\":\"Error pendent la cèrca d’un utilizaire\",\"find_user\":\"Cercar un utilizaire\"},\"general\":{\"apply\":\"Aplicar\",\"submit\":\"Mandar\",\"more\":\"Mai\",\"generic_error\":\"Una error s’es producha\",\"optional\":\"opcional\"},\"image_cropper\":{\"crop_picture\":\"Talhar l’imatge\",\"save\":\"Salvar\",\"cancel\":\"Anullar\"},\"login\":{\"login\":\"Connexion\",\"description\":\"Connexion via OAuth\",\"logout\":\"Desconnexion\",\"password\":\"Senhal\",\"placeholder\":\"e.g. lain\",\"register\":\"Se marcar\",\"username\":\"Nom d’utilizaire\",\"hint\":\"Connectatz-vos per participar a la discutida\"},\"media_modal\":{\"previous\":\"Precedent\",\"next\":\"Seguent\"},\"nav\":{\"about\":\"A prepaus\",\"back\":\"Tornar\",\"chat\":\"Chat local\",\"friend_requests\":\"Demandas de seguiment\",\"mentions\":\"Notificacions\",\"dms\":\"Messatges privats\",\"public_tl\":\"Estatuts locals\",\"timeline\":\"Flux d’actualitat\",\"twkn\":\"Lo malhum conegut\",\"user_search\":\"Cèrca d’utilizaires\",\"who_to_follow\":\"Qual seguir\",\"preferences\":\"Preferéncias\"},\"notifications\":{\"broken_favorite\":\"Estatut desconegut, sèm a lo cercar...\",\"favorited_you\":\"a aimat vòstre estatut\",\"followed_you\":\"vos a seguit\",\"load_older\":\"Cargar las notificaciones mai ancianas\",\"notifications\":\"Notficacions\",\"read\":\"Legit !\",\"repeated_you\":\"a repetit vòstre estatut\",\"no_more_notifications\":\"Pas mai de notificacions\"},\"post_status\":{\"new_status\":\"Publicar d’estatuts novèls\",\"account_not_locked_warning\":\"Vòstre compte es pas {0}. Qual que siá pòt vos seguir per veire vòstras publicacions destinadas pas qu'a vòstres seguidors.\",\"account_not_locked_warning_link\":\"clavat\",\"attachments_sensitive\":\"Marcar las pèças juntas coma sensiblas\",\"content_type\":{\"plain_text\":\"Tèxte brut\"},\"content_warning\":\"Avís de contengut (opcional)\",\"default\":\"Escrivètz aquí vòstre estatut.\",\"direct_warning\":\"Aquesta publicacion serà pas que visibla pels utilizaires mencionats.\",\"posting\":\"Mandadís\",\"scope\":{\"direct\":\"Dirècte - Publicar pels utilizaires mencionats solament\",\"private\":\"Seguidors solament - Publicar pels sols seguidors\",\"public\":\"Public - Publicar pel flux d’actualitat public\",\"unlisted\":\"Pas listat - Publicar pas pel flux public\"}},\"registration\":{\"bio\":\"Biografia\",\"email\":\"Adreça de corrièl\",\"fullname\":\"Nom complèt\",\"password_confirm\":\"Confirmar lo senhal\",\"registration\":\"Inscripcion\",\"token\":\"Geton de convidat\",\"captcha\":\"CAPTCHA\",\"new_captcha\":\"Clicatz l’imatge per obténer una nòva captcha\",\"username_placeholder\":\"e.g. lain\",\"fullname_placeholder\":\"e.g. Lain Iwakura\",\"bio_placeholder\":\"e.g.\\nHi, Soi lo Lain\\nSoi afocada d’animes e vivi al Japan. Benlèu que me coneissètz de the Wired.\",\"validations\":{\"username_required\":\"pòt pas èsser void\",\"fullname_required\":\"pòt pas èsser void\",\"email_required\":\"pòt pas èsser void\",\"password_required\":\"pòt pas èsser void\",\"password_confirmation_required\":\"pòt pas èsser void\",\"password_confirmation_match\":\"deu èsser lo meteis senhal\"}},\"settings\":{\"app_name\":\"Nom de l’aplicacion\",\"attachmentRadius\":\"Pèças juntas\",\"attachments\":\"Pèças juntas\",\"autoload\":\"Activar lo cargament automatic un còp arribat al cap de la pagina\",\"avatar\":\"Avatar\",\"avatarAltRadius\":\"Avatars (Notificacions)\",\"avatarRadius\":\"Avatars\",\"background\":\"Rèire plan\",\"bio\":\"Biografia\",\"blocks_tab\":\"Blocatges\",\"btnRadius\":\"Botons\",\"cBlue\":\"Blau (Respondre, seguir)\",\"cGreen\":\"Verd (Repartajar)\",\"cOrange\":\"Irange (Aimar)\",\"cRed\":\"Roge (Anullar)\",\"change_password\":\"Cambiar lo senhal\",\"change_password_error\":\"Una error s’es producha en cambiant lo senhal.\",\"changed_password\":\"Senhal corrèctament cambiat !\",\"collapse_subject\":\"Replegar las publicacions amb de subjèctes\",\"composing\":\"Escritura\",\"confirm_new_password\":\"Confirmatz lo nòu senhal\",\"current_avatar\":\"Vòstre avatar actual\",\"current_password\":\"Senhal actual\",\"current_profile_banner\":\"Bandièra actuala del perfil\",\"data_import_export_tab\":\"Importar / Exportar las donadas\",\"default_vis\":\"Nivèl de visibilitat per defaut\",\"delete_account\":\"Suprimir lo compte\",\"delete_account_description\":\"Suprimir vòstre compte e los messatges per sempre.\",\"delete_account_error\":\"Una error s’es producha en suprimir lo compte. S’aquò ten d’arribar mercés de contactar vòstre administrador d’instància.\",\"delete_account_instructions\":\"Picatz vòstre senhal dins lo camp tèxte çai-jos per confirmar la supression del compte.\",\"avatar_size_instruction\":\"La talha minimum recomandada pels imatges d’avatar es 150x150 pixèls.\",\"export_theme\":\"Enregistrar la preconfiguracion\",\"filtering\":\"Filtratge\",\"filtering_explanation\":\"Totes los estatuts amb aqueles mots seràn en silenci, un mot per linha\",\"follow_export\":\"Exportar los abonaments\",\"follow_export_button\":\"Exportar vòstres abonaments dins un fichièr csv\",\"follow_export_processing\":\"Tractament, vos demandarem lèu de telecargar lo fichièr\",\"follow_import\":\"Importar los abonaments\",\"follow_import_error\":\"Error en important los seguidors\",\"follows_imported\":\"Seguidors importats. Lo tractament pòt trigar una estona.\",\"foreground\":\"Endavant\",\"general\":\"General\",\"hide_attachments_in_convo\":\"Rescondre las pèças juntas dins las conversacions\",\"hide_attachments_in_tl\":\"Rescondre las pèças juntas\",\"max_thumbnails\":\"Nombre maximum de vinhetas per publicacion\",\"hide_isp\":\"Amagar lo panèl especial instància\",\"preload_images\":\"Precargar los imatges\",\"use_one_click_nsfw\":\"Dobrir las pèças juntas NSFW amb un clic\",\"hide_post_stats\":\"Amagar los estatistics de publicacion (ex. lo ombre de favorits)\",\"hide_user_stats\":\"Amagar las estatisticas de l’utilizaire (ex. lo nombre de seguidors)\",\"hide_filtered_statuses\":\"Amagar los estatuts filtrats\",\"import_followers_from_a_csv_file\":\"Importar los seguidors d’un fichièr csv\",\"import_theme\":\"Cargar un tèma\",\"inputRadius\":\"Camps tèxte\",\"checkboxRadius\":\"Casas de marcar\",\"instance_default\":\"(defaut : {value})\",\"instance_default_simple\":\"(defaut)\",\"interface\":\"Interfàcia\",\"interfaceLanguage\":\"Lenga de l’interfàcia\",\"invalid_theme_imported\":\"Lo fichièr seleccionat es pas un tèma Pleroma valid. Cap de cambiament es estat fach a vòstre tèma.\",\"limited_availability\":\"Pas disponible per vòstre navigador\",\"links\":\"Ligams\",\"lock_account_description\":\"Limitar vòstre compte als seguidors acceptats solament\",\"loop_video\":\"Bocla vidèo\",\"loop_video_silent_only\":\"Legir en bocla solament las vidèos sens son (coma los « Gifs » de Mastodon)\",\"mutes_tab\":\"Agamats\",\"play_videos_in_modal\":\"Legir las vidèoas dirèctament dins la visualizaira mèdia\",\"use_contain_fit\":\"Talhar pas las pèças juntas per las vinhetas\",\"name\":\"Nom\",\"name_bio\":\"Nom & Bio\",\"new_password\":\"Nòu senhal\",\"notification_visibility_follows\":\"Abonaments\",\"notification_visibility_likes\":\"Aimar\",\"notification_visibility_mentions\":\"Mencions\",\"notification_visibility_repeats\":\"Repeticions\",\"notification_visibility\":\"Tipes de notificacion de mostrar\",\"no_rich_text_description\":\"Netejar lo format tèxte de totas las publicacions\",\"no_blocks\":\"Cap de blocatge\",\"no_mutes\":\"Cap d’amagat\",\"hide_follows_description\":\"Mostrar pas qual seguissi\",\"hide_followers_description\":\"Mostrar pas qual me seguisson\",\"show_admin_badge\":\"Mostrar lo badge Admin badge al perfil meu\",\"show_moderator_badge\":\"Mostrar lo badge Moderator al perfil meu\",\"nsfw_clickthrough\":\"Activar lo clic per mostrar los imatges marcats coma pels adults o sensibles\",\"oauth_tokens\":\"Listats OAuth\",\"token\":\"Geton\",\"refresh_token\":\"Actualizar lo geton\",\"valid_until\":\"Valid fins a\",\"revoke_token\":\"Revocar\",\"panelRadius\":\"Panèls\",\"pause_on_unfocused\":\"Pausar la difusion quand l’onglet es pas seleccionat\",\"presets\":\"Pre-enregistrats\",\"profile_background\":\"Imatge de fons\",\"profile_banner\":\"Bandièra del perfil\",\"profile_tab\":\"Perfil\",\"radii_help\":\"Configurar los caires arredondits de l’interfàcia (en pixèls)\",\"replies_in_timeline\":\"Responsas del flux\",\"reply_link_preview\":\"Activar l’apercebut en passar la mirga\",\"reply_visibility_all\":\"Mostrar totas las responsas\",\"reply_visibility_following\":\"Mostrar pas que las responsas que me son destinada a ieu o un utilizaire que seguissi\",\"reply_visibility_self\":\"Mostrar pas que las responsas que me son destinadas\",\"saving_err\":\"Error en enregistrant los paramètres\",\"saving_ok\":\"Paramètres enregistrats\",\"scope_copy\":\"Copiar lo nivèl de confidencialitat per las responsas (Totjorn aissí pels Messatges Dirèctes)\",\"security_tab\":\"Seguretat\",\"set_new_avatar\":\"Definir un nòu avatar\",\"set_new_profile_background\":\"Definir un nòu fons de perfil\",\"set_new_profile_banner\":\"Definir una nòva bandièra de perfil\",\"settings\":\"Paramètres\",\"subject_input_always_show\":\"Totjorn mostrar lo camp de subjècte\",\"subject_line_behavior\":\"Copiar lo subjècte per las responsas\",\"subject_line_email\":\"Coma los corrièls : \\\"re: subjècte\\\"\",\"subject_line_mastodon\":\"Coma mastodon : copiar tal coma es\",\"subject_line_noop\":\"Copiar pas\",\"post_status_content_type\":\"Publicar lo tipe de contengut dels estatuts\",\"stop_gifs\":\"Lançar los GIFs al subrevòl\",\"streaming\":\"Activar lo cargament automatic dels novèls estatus en anar amont\",\"text\":\"Tèxt\",\"theme\":\"Tèma\",\"theme_help_v2_1\":\"You can also override certain component's colors and opacity by toggling the checkbox, use \\\"Clear all\\\" button to clear all overrides.\",\"theme_help_v2_2\":\"Icons underneath some entries are background/text contrast indicators, hover over for detailed info. Please keep in mind that when using transparency contrast indicators show the worst possible case.\",\"theme_help\":\"Emplegatz los còdis de color hex (#rrggbb) per personalizar vòstre tèma de color.\",\"tooltipRadius\":\"Astúcias/alèrtas\",\"upload_a_photo\":\"Enviar una fotografia\",\"user_settings\":\"Paramètres utilizaire\",\"values\":{\"false\":\"non\",\"true\":\"òc\"}},\"timeline\":{\"collapse\":\"Tampar\",\"conversation\":\"Conversacion\",\"error_fetching\":\"Error en cercant de mesas a jorn\",\"load_older\":\"Ne veire mai\",\"repeated\":\"repetit\",\"show_new\":\"Ne veire mai\",\"up_to_date\":\"A jorn\",\"no_retweet_hint\":\"La publicacion marcada coma pels seguidors solament o dirècte pòt pas èsser repetida\"},\"status\":{\"reply_to\":\"Respondre à\",\"replies_list\":\"Responsas :\"},\"user_card\":{\"approve\":\"Validar\",\"block\":\"Blocar\",\"blocked\":\"Blocat !\",\"deny\":\"Refusar\",\"favorites\":\"Favorits\",\"follow\":\"Seguir\",\"follow_sent\":\"Demanda enviada !\",\"follow_progress\":\"Demanda…\",\"follow_again\":\"Tornar enviar la demanda ?\",\"follow_unfollow\":\"Quitar de seguir\",\"followees\":\"Abonaments\",\"followers\":\"Seguidors\",\"following\":\"Seguit !\",\"follows_you\":\"Vos sèc !\",\"its_you\":\"Sètz vos !\",\"media\":\"Mèdia\",\"mute\":\"Amagar\",\"muted\":\"Amagat\",\"per_day\":\"per jorn\",\"remote_follow\":\"Seguir a distància\",\"statuses\":\"Estatuts\",\"unblock\":\"Desblocar\",\"unblock_progress\":\"Desblocatge...\",\"block_progress\":\"Blocatge...\",\"unmute\":\"Tornar mostrar\",\"unmute_progress\":\"Afichatge...\",\"mute_progress\":\"A amagar...\"},\"user_profile\":{\"timeline_title\":\"Flux utilizaire\",\"profile_does_not_exist\":\"Aqueste perfil existís pas.\",\"profile_loading_error\":\"Una error s’es producha en cargant aqueste perfil.\"},\"who_to_follow\":{\"more\":\"Mai\",\"who_to_follow\":\"Qual seguir\"},\"tool_tip\":{\"media_upload\":\"Enviar un mèdia\",\"repeat\":\"Repetir\",\"reply\":\"Respondre\",\"favorite\":\"aimar\",\"user_settings\":\"Paramètres utilizaire\"},\"upload\":{\"error\":{\"base\":\"Mandadís fracassat.\",\"file_too_big\":\"Fichièr tròp grand [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"Tornatz ensajar mai tard\"},\"file_size_units\":{\"B\":\"o\",\"KiB\":\"Kio\",\"MiB\":\"Mio\",\"GiB\":\"Gio\",\"TiB\":\"Tio\"}}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/oc.json\n// module id = 451\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Czat\"},\"finder\":{\"error_fetching_user\":\"Błąd przy pobieraniu profilu\",\"find_user\":\"Znajdź użytkownika\"},\"general\":{\"apply\":\"Zastosuj\",\"submit\":\"Wyślij\"},\"login\":{\"login\":\"Zaloguj\",\"logout\":\"Wyloguj\",\"password\":\"Hasło\",\"placeholder\":\"n.p. lain\",\"register\":\"Zarejestruj\",\"username\":\"Użytkownik\"},\"nav\":{\"chat\":\"Lokalny czat\",\"mentions\":\"Wzmianki\",\"public_tl\":\"Publiczna oś czasu\",\"timeline\":\"Oś czasu\",\"twkn\":\"Cała znana sieć\"},\"notifications\":{\"favorited_you\":\"dodał twój status do ulubionych\",\"followed_you\":\"obserwuje cię\",\"notifications\":\"Powiadomienia\",\"read\":\"Przeczytane!\",\"repeated_you\":\"powtórzył twój status\"},\"post_status\":{\"default\":\"Właśnie wróciłem z kościoła\",\"posting\":\"Wysyłanie\"},\"registration\":{\"bio\":\"Bio\",\"email\":\"Email\",\"fullname\":\"Wyświetlana nazwa profilu\",\"password_confirm\":\"Potwierdzenie hasła\",\"registration\":\"Rejestracja\"},\"settings\":{\"attachmentRadius\":\"Załączniki\",\"attachments\":\"Załączniki\",\"autoload\":\"Włącz automatyczne ładowanie po przewinięciu do końca strony\",\"avatar\":\"Awatar\",\"avatarAltRadius\":\"Awatary (powiadomienia)\",\"avatarRadius\":\"Awatary\",\"background\":\"Tło\",\"bio\":\"Bio\",\"btnRadius\":\"Przyciski\",\"cBlue\":\"Niebieski (odpowiedz, obserwuj)\",\"cGreen\":\"Zielony (powtórzenia)\",\"cOrange\":\"Pomarańczowy (ulubione)\",\"cRed\":\"Czerwony (anuluj)\",\"change_password\":\"Zmień hasło\",\"change_password_error\":\"Podczas zmiany hasła wystąpił problem.\",\"changed_password\":\"Hasło zmienione poprawnie!\",\"confirm_new_password\":\"Potwierdź nowe hasło\",\"current_avatar\":\"Twój obecny awatar\",\"current_password\":\"Obecne hasło\",\"current_profile_banner\":\"Twój obecny banner profilu\",\"delete_account\":\"Usuń konto\",\"delete_account_description\":\"Trwale usuń konto i wszystkie posty.\",\"delete_account_error\":\"Wystąpił problem z usuwaniem twojego konta. Jeżeli problem powtarza się, poinformuj administratora swojej instancji.\",\"delete_account_instructions\":\"Wprowadź swoje hasło w poniższe pole aby potwierdzić usunięcie konta.\",\"filtering\":\"Filtrowanie\",\"filtering_explanation\":\"Wszystkie statusy zawierające te słowa będą wyciszone. Jedno słowo na linijkę.\",\"follow_export\":\"Eksport obserwowanych\",\"follow_export_button\":\"Eksportuj swoją listę obserwowanych do pliku CSV\",\"follow_export_processing\":\"Przetwarzanie, wkrótce twój plik zacznie się ściągać.\",\"follow_import\":\"Import obserwowanych\",\"follow_import_error\":\"Błąd przy importowaniu obserwowanych\",\"follows_imported\":\"Obserwowani zaimportowani! Przetwarzanie może trochę potrwać.\",\"foreground\":\"Pierwszy plan\",\"hide_attachments_in_convo\":\"Ukryj załączniki w rozmowach\",\"hide_attachments_in_tl\":\"Ukryj załączniki w osi czasu\",\"import_followers_from_a_csv_file\":\"Importuj obserwowanych z pliku CSV\",\"inputRadius\":\"Pola tekstowe\",\"links\":\"Łącza\",\"name\":\"Imię\",\"name_bio\":\"Imię i bio\",\"new_password\":\"Nowe hasło\",\"nsfw_clickthrough\":\"Włącz domyślne ukrywanie załączników o treści nieprzyzwoitej (NSFW)\",\"oauth_tokens\":\"Tokeny OAuth\",\"token\":\"Token\",\"refresh_token\":\"Odśwież token\",\"valid_until\":\"Ważne do\",\"revoke_token\":\"Odwołać\",\"panelRadius\":\"Panele\",\"presets\":\"Gotowe motywy\",\"profile_background\":\"Tło profilu\",\"profile_banner\":\"Banner profilu\",\"radii_help\":\"Ustaw zaokrąglenie krawędzi interfejsu (w pikselach)\",\"reply_link_preview\":\"Włącz dymek z podglądem postu po najechaniu na znak odpowiedzi\",\"set_new_avatar\":\"Ustaw nowy awatar\",\"set_new_profile_background\":\"Ustaw nowe tło profilu\",\"set_new_profile_banner\":\"Ustaw nowy banner profilu\",\"settings\":\"Ustawienia\",\"stop_gifs\":\"Odtwarzaj GIFy po najechaniu kursorem\",\"streaming\":\"Włącz automatycznie strumieniowanie nowych postów gdy na początku strony\",\"text\":\"Tekst\",\"theme\":\"Motyw\",\"theme_help\":\"Użyj kolorów w notacji szesnastkowej (#rrggbb), by stworzyć swój motyw.\",\"tooltipRadius\":\"Etykiety/alerty\",\"user_settings\":\"Ustawienia użytkownika\"},\"timeline\":{\"collapse\":\"Zwiń\",\"conversation\":\"Rozmowa\",\"error_fetching\":\"Błąd pobierania\",\"load_older\":\"Załaduj starsze statusy\",\"repeated\":\"powtórzono\",\"show_new\":\"Pokaż nowe\",\"up_to_date\":\"Na bieżąco\"},\"user_card\":{\"block\":\"Zablokuj\",\"blocked\":\"Zablokowany!\",\"follow\":\"Obserwuj\",\"followees\":\"Obserwowani\",\"followers\":\"Obserwujący\",\"following\":\"Obserwowany!\",\"follows_you\":\"Obserwuje cię!\",\"mute\":\"Wycisz\",\"muted\":\"Wyciszony\",\"per_day\":\"dziennie\",\"remote_follow\":\"Zdalna obserwacja\",\"statuses\":\"Statusy\"},\"user_profile\":{\"timeline_title\":\"Oś czasu użytkownika\"}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/pl.json\n// module id = 452\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Chat\"},\"features_panel\":{\"chat\":\"Chat\",\"gopher\":\"Gopher\",\"media_proxy\":\"Proxy de mídia\",\"scope_options\":\"Opções de privacidade\",\"text_limit\":\"Limite de caracteres\",\"title\":\"Funções\",\"who_to_follow\":\"Quem seguir\"},\"finder\":{\"error_fetching_user\":\"Erro ao procurar usuário\",\"find_user\":\"Buscar usuário\"},\"general\":{\"apply\":\"Aplicar\",\"submit\":\"Enviar\",\"more\":\"Mais\",\"generic_error\":\"Houve um erro\",\"optional\":\"opcional\"},\"image_cropper\":{\"crop_picture\":\"Cortar imagem\",\"save\":\"Salvar\",\"cancel\":\"Cancelar\"},\"login\":{\"login\":\"Entrar\",\"description\":\"Entrar com OAuth\",\"logout\":\"Sair\",\"password\":\"Senha\",\"placeholder\":\"p.e. lain\",\"register\":\"Registrar\",\"username\":\"Usuário\",\"hint\":\"Entre para participar da discussão\"},\"media_modal\":{\"previous\":\"Anterior\",\"next\":\"Próximo\"},\"nav\":{\"about\":\"Sobre\",\"back\":\"Voltar\",\"chat\":\"Chat local\",\"friend_requests\":\"Solicitações de seguidores\",\"mentions\":\"Menções\",\"dms\":\"Mensagens diretas\",\"public_tl\":\"Linha do tempo pública\",\"timeline\":\"Linha do tempo\",\"twkn\":\"Toda a rede conhecida\",\"user_search\":\"Busca de usuário\",\"who_to_follow\":\"Quem seguir\",\"preferences\":\"Preferências\"},\"notifications\":{\"broken_favorite\":\"Status desconhecido, buscando...\",\"favorited_you\":\"favoritou sua postagem\",\"followed_you\":\"seguiu você\",\"load_older\":\"Carregar notificações antigas\",\"notifications\":\"Notificações\",\"read\":\"Lido!\",\"repeated_you\":\"repetiu sua postagem\",\"no_more_notifications\":\"Mais nenhuma notificação\"},\"post_status\":{\"new_status\":\"Postar novo status\",\"account_not_locked_warning\":\"Sua conta não está {0}. Qualquer pessoa pode te seguir para ver seus posts restritos.\",\"account_not_locked_warning_link\":\"fechada\",\"attachments_sensitive\":\"Marcar anexos como sensíveis\",\"content_type\":{\"plain_text\":\"Texto puro\"},\"content_warning\":\"Assunto (opcional)\",\"default\":\"Acabei de chegar no Rio!\",\"direct_warning\":\"Este post será visível apenas para os usuários mencionados.\",\"posting\":\"Publicando\",\"scope\":{\"direct\":\"Direto - Enviar somente aos usuários mencionados\",\"private\":\"Apenas para seguidores - Enviar apenas para seguidores\",\"public\":\"Público - Enviar a linhas do tempo públicas\",\"unlisted\":\"Não listado - Não enviar a linhas do tempo públicas\"}},\"registration\":{\"bio\":\"Biografia\",\"email\":\"Correio eletrônico\",\"fullname\":\"Nome para exibição\",\"password_confirm\":\"Confirmação de senha\",\"registration\":\"Registro\",\"token\":\"Código do convite\",\"captcha\":\"CAPTCHA\",\"new_captcha\":\"Clique na imagem para carregar um novo captcha\",\"username_placeholder\":\"p. ex. lain\",\"fullname_placeholder\":\"p. ex. Lain Iwakura\",\"bio_placeholder\":\"e.g.\\nOi, sou Lain\\nSou uma garota que vive no subúrbio do Japão. Você deve me conhecer da Rede.\",\"validations\":{\"username_required\":\"não pode ser deixado em branco\",\"fullname_required\":\"não pode ser deixado em branco\",\"email_required\":\"não pode ser deixado em branco\",\"password_required\":\"não pode ser deixado em branco\",\"password_confirmation_required\":\"não pode ser deixado em branco\",\"password_confirmation_match\":\"deve ser idêntica à senha\"}},\"settings\":{\"app_name\":\"Nome do aplicativo\",\"attachmentRadius\":\"Anexos\",\"attachments\":\"Anexos\",\"autoload\":\"Habilitar carregamento automático quando a rolagem chegar ao fim.\",\"avatar\":\"Avatar\",\"avatarAltRadius\":\"Avatares (Notificações)\",\"avatarRadius\":\"Avatares\",\"background\":\"Pano de Fundo\",\"bio\":\"Biografia\",\"blocks_tab\":\"Blocos\",\"btnRadius\":\"Botões\",\"cBlue\":\"Azul (Responder, seguir)\",\"cGreen\":\"Verde (Repetir)\",\"cOrange\":\"Laranja (Favoritar)\",\"cRed\":\"Vermelho (Cancelar)\",\"change_password\":\"Mudar senha\",\"change_password_error\":\"Houve um erro ao modificar sua senha.\",\"changed_password\":\"Senha modificada com sucesso!\",\"collapse_subject\":\"Esconder posts com assunto\",\"composing\":\"Escrevendo\",\"confirm_new_password\":\"Confirmar nova senha\",\"current_avatar\":\"Seu avatar atual\",\"current_password\":\"Sua senha atual\",\"current_profile_banner\":\"Sua capa de perfil atual\",\"data_import_export_tab\":\"Importação/exportação de dados\",\"default_vis\":\"Opção de privacidade padrão\",\"delete_account\":\"Deletar conta\",\"delete_account_description\":\"Deletar sua conta e mensagens permanentemente.\",\"delete_account_error\":\"Houve um problema ao deletar sua conta. Se ele persistir, por favor entre em contato com o/a administrador/a da instância.\",\"delete_account_instructions\":\"Digite sua senha no campo abaixo para confirmar a exclusão da conta.\",\"avatar_size_instruction\":\"O tamanho mínimo recomendado para imagens de avatar é 150x150 pixels.\",\"export_theme\":\"Salvar predefinições\",\"filtering\":\"Filtragem\",\"filtering_explanation\":\"Todas as postagens contendo estas palavras serão silenciadas, uma por linha.\",\"follow_export\":\"Exportar quem você segue\",\"follow_export_button\":\"Exportar quem você segue para um arquivo CSV\",\"follow_export_processing\":\"Processando. Em breve você receberá a solicitação de download do arquivo\",\"follow_import\":\"Importar quem você segue\",\"follow_import_error\":\"Erro ao importar seguidores\",\"follows_imported\":\"Seguidores importados! O processamento pode demorar um pouco.\",\"foreground\":\"Primeiro Plano\",\"general\":\"Geral\",\"hide_attachments_in_convo\":\"Ocultar anexos em conversas\",\"hide_attachments_in_tl\":\"Ocultar anexos na linha do tempo.\",\"max_thumbnails\":\"Número máximo de miniaturas por post\",\"hide_isp\":\"Esconder painel específico da instância\",\"preload_images\":\"Pré-carregar imagens\",\"use_one_click_nsfw\":\"Abrir anexos sensíveis com um clique\",\"hide_post_stats\":\"Esconder estatísticas de posts (p. ex. número de favoritos)\",\"hide_user_stats\":\"Esconder estatísticas do usuário (p. ex. número de seguidores)\",\"hide_filtered_statuses\":\"Esconder posts filtrados\",\"import_followers_from_a_csv_file\":\"Importe seguidores a partir de um arquivo CSV\",\"import_theme\":\"Carregar pré-definição\",\"inputRadius\":\"Campos de entrada\",\"checkboxRadius\":\"Checkboxes\",\"instance_default\":\"(padrão: {value})\",\"instance_default_simple\":\"(padrão)\",\"interface\":\"Interface\",\"interfaceLanguage\":\"Idioma da interface\",\"invalid_theme_imported\":\"O arquivo selecionado não é um tema compatível com o Pleroma. Nenhuma mudança no tema foi feita.\",\"limited_availability\":\"Indisponível para seu navegador\",\"links\":\"Links\",\"lock_account_description\":\"Restringir sua conta a seguidores aprovados\",\"loop_video\":\"Repetir vídeos\",\"loop_video_silent_only\":\"Repetir apenas vídeos sem som (como os \\\"gifs\\\" do Mastodon)\",\"mutes_tab\":\"Silenciados\",\"play_videos_in_modal\":\"Tocar vídeos diretamente no visualizador de mídia\",\"use_contain_fit\":\"Não cortar o anexo na miniatura\",\"name\":\"Nome\",\"name_bio\":\"Nome & Biografia\",\"new_password\":\"Nova senha\",\"notification_visibility\":\"Tipos de notificação para mostrar\",\"notification_visibility_follows\":\"Seguidos\",\"notification_visibility_likes\":\"Favoritos\",\"notification_visibility_mentions\":\"Menções\",\"notification_visibility_repeats\":\"Repetições\",\"no_rich_text_description\":\"Remover formatação de todos os posts\",\"no_blocks\":\"Sem bloqueios\",\"no_mutes\":\"Sem silenciados\",\"hide_follows_description\":\"Não mostrar quem estou seguindo\",\"hide_followers_description\":\"Não mostrar quem me segue\",\"show_admin_badge\":\"Mostrar distintivo de Administrador em meu perfil\",\"show_moderator_badge\":\"Mostrar título de Moderador em meu perfil\",\"nsfw_clickthrough\":\"Habilitar clique para ocultar anexos sensíveis\",\"oauth_tokens\":\"Token OAuth\",\"token\":\"Token\",\"refresh_token\":\"Atualizar Token\",\"valid_until\":\"Válido até\",\"revoke_token\":\"Revogar\",\"panelRadius\":\"Paineis\",\"pause_on_unfocused\":\"Parar transmissão quando a aba não estiver em primeiro plano\",\"presets\":\"Predefinições\",\"profile_background\":\"Pano de fundo de perfil\",\"profile_banner\":\"Capa de perfil\",\"profile_tab\":\"Perfil\",\"radii_help\":\"Arredondar arestas da interface (em píxeis)\",\"replies_in_timeline\":\"Respostas na linha do tempo\",\"reply_link_preview\":\"Habilitar a pré-visualização de link de respostas ao passar o mouse.\",\"reply_visibility_all\":\"Mostrar todas as respostas\",\"reply_visibility_following\":\"Só mostrar respostas direcionadas a mim ou a usuários que sigo\",\"reply_visibility_self\":\"Só mostrar respostas direcionadas a mim\",\"saving_err\":\"Erro ao salvar configurações\",\"saving_ok\":\"Configurações salvas\",\"security_tab\":\"Segurança\",\"scope_copy\":\"Copiar opções de privacidade ao responder (Mensagens diretas sempre copiam)\",\"set_new_avatar\":\"Alterar avatar\",\"set_new_profile_background\":\"Alterar o plano de fundo de perfil\",\"set_new_profile_banner\":\"Alterar capa de perfil\",\"settings\":\"Configurações\",\"subject_input_always_show\":\"Sempre mostrar campo de assunto\",\"subject_line_behavior\":\"Copiar assunto ao responder\",\"subject_line_email\":\"Como em email: \\\"re: assunto\\\"\",\"subject_line_mastodon\":\"Como o Mastodon: copiar como está\",\"subject_line_noop\":\"Não copiar\",\"post_status_content_type\":\"Postar tipo de conteúdo do status\",\"stop_gifs\":\"Reproduzir GIFs ao passar o cursor em cima\",\"streaming\":\"Habilitar o fluxo automático de postagens quando ao topo da página\",\"text\":\"Texto\",\"theme\":\"Tema\",\"theme_help\":\"Use cores em código hexadecimal (#rrggbb) para personalizar seu esquema de cores.\",\"theme_help_v2_1\":\"Você também pode sobrescrever as cores e opacidade de alguns componentes ao modificar o checkbox, use \\\"Limpar todos\\\" para limpar todas as modificações.\",\"theme_help_v2_2\":\"Alguns ícones sob registros são indicadores de fundo/contraste de textos, passe por cima para informações detalhadas. Tenha ciência de que os indicadores de contraste não funcionam muito bem com transparência.\",\"tooltipRadius\":\"Dicas/alertas\",\"upload_a_photo\":\"Enviar uma foto\",\"user_settings\":\"Configurações de Usuário\",\"values\":{\"false\":\"não\",\"true\":\"sim\"},\"notifications\":\"Notifications\",\"enable_web_push_notifications\":\"Habilitar notificações web push\",\"style\":{\"switcher\":{\"keep_color\":\"Manter cores\",\"keep_shadows\":\"Manter sombras\",\"keep_opacity\":\"Manter opacidade\",\"keep_roundness\":\"Manter arredondado\",\"keep_fonts\":\"Manter fontes\",\"save_load_hint\":\"Manter as opções preserva as opções atuais ao selecionar ou carregar temas; também salva as opções ao exportar um tempo. Quanto todos os campos estiverem desmarcados, tudo será salvo ao exportar o tema.\",\"reset\":\"Voltar ao padrão\",\"clear_all\":\"Limpar tudo\",\"clear_opacity\":\"Limpar opacidade\"},\"common\":{\"color\":\"Cor\",\"opacity\":\"Opacidade\",\"contrast\":{\"hint\":\"A taxa de contraste é {ratio}, {level} {context}\",\"level\":{\"aa\":\"padrão Nível AA (mínimo)\",\"aaa\":\"padrão Nível AAA (recomendado)\",\"bad\":\"nenhum padrão de acessibilidade\"},\"context\":{\"18pt\":\"para textos longos (18pt+)\",\"text\":\"para texto\"}}},\"common_colors\":{\"_tab_label\":\"Comum\",\"main\":\"Cores Comuns\",\"foreground_hint\":\"Configurações mais detalhadas na aba\\\"Avançado\\\"\",\"rgbo\":\"Ícones, acentuação, distintivos\"},\"advanced_colors\":{\"_tab_label\":\"Avançado\",\"alert\":\"Fundo de alerta\",\"alert_error\":\"Erro\",\"badge\":\"Fundo do distintivo\",\"badge_notification\":\"Notificação\",\"panel_header\":\"Topo do painel\",\"top_bar\":\"Barra do topo\",\"borders\":\"Bordas\",\"buttons\":\"Botões\",\"inputs\":\"Caixas de entrada\",\"faint_text\":\"Texto esmaecido\"},\"radii\":{\"_tab_label\":\"Arredondado\"},\"shadows\":{\"_tab_label\":\"Luz e sombra\",\"component\":\"Componente\",\"override\":\"Sobrescrever\",\"shadow_id\":\"Sombra #{value}\",\"blur\":\"Borrado\",\"spread\":\"Difusão\",\"inset\":\"Inserção\",\"hint\":\"Para as sombras você também pode usar --variável como valor de cor para utilizar variáveis do CSS3. Tenha em mente que configurar a opacidade não será possível neste caso.\",\"filter_hint\":{\"always_drop_shadow\":\"Atenção, esta sombra sempre utiliza {0} quando compatível com o navegador.\",\"drop_shadow_syntax\":\"{0} não é compatível com o parâmetro {1} e a palavra-chave {2}.\",\"avatar_inset\":\"Tenha em mente que combinar as sombras de inserção e a não-inserção em avatares pode causar resultados inesperados em avatares transparentes.\",\"spread_zero\":\"Sombras com uma difusão > 0 aparecerão como se fossem definidas como 0.\",\"inset_classic\":\"Sombras de inserção utilizarão {0}\"},\"components\":{\"panel\":\"Painel\",\"panelHeader\":\"Topo do painel\",\"topBar\":\"Barra do topo\",\"avatar\":\"Avatar do usuário (na visualização do perfil)\",\"avatarStatus\":\"Avatar do usuário (na exibição de posts)\",\"popup\":\"Dicas e notificações\",\"button\":\"Botão\",\"buttonHover\":\"Botão (em cima)\",\"buttonPressed\":\"Botão (pressionado)\",\"buttonPressedHover\":\"Botão (pressionado+em cima)\",\"input\":\"Campo de entrada\"}},\"fonts\":{\"_tab_label\":\"Fontes\",\"help\":\"Selecionar fonte dos elementos da interface. Para fonte \\\"personalizada\\\" você deve entrar exatamente o nome da fonte no sistema.\",\"components\":{\"interface\":\"Interface\",\"input\":\"Campo de entrada\",\"post\":\"Postar texto\",\"postCode\":\"Texto monoespaçado em post (formatação rica)\"},\"family\":\"Nome da fonte\",\"size\":\"Tamanho (em px)\",\"weight\":\"Peso\",\"custom\":\"Personalizada\"},\"preview\":{\"header\":\"Pré-visualizar\",\"content\":\"Conteúdo\",\"error\":\"Erro de exemplo\",\"button\":\"Botão\",\"text\":\"Vários {0} e {1}\",\"mono\":\"conteúdo\",\"input\":\"Acabei de chegar no Rio!\",\"faint_link\":\"manual útil\",\"fine_print\":\"Leia nosso {0} para não aprender nada!\",\"header_faint\":\"Está ok!\",\"checkbox\":\"Li os termos e condições\",\"link\":\"um belo link\"}}},\"timeline\":{\"collapse\":\"Esconder\",\"conversation\":\"Conversa\",\"error_fetching\":\"Erro ao buscar atualizações\",\"load_older\":\"Carregar postagens antigas\",\"no_retweet_hint\":\"Posts apenas para seguidores ou diretos não podem ser repetidos\",\"repeated\":\"Repetido\",\"show_new\":\"Mostrar novas\",\"up_to_date\":\"Atualizado\",\"no_more_statuses\":\"Sem mais posts\",\"no_statuses\":\"Sem posts\"},\"status\":{\"reply_to\":\"Responder a\",\"replies_list\":\"Respostas:\"},\"user_card\":{\"approve\":\"Aprovar\",\"block\":\"Bloquear\",\"blocked\":\"Bloqueado!\",\"deny\":\"Negar\",\"favorites\":\"Favoritos\",\"follow\":\"Seguir\",\"follow_sent\":\"Pedido enviado!\",\"follow_progress\":\"Enviando…\",\"follow_again\":\"Enviar solicitação novamente?\",\"follow_unfollow\":\"Deixar de seguir\",\"followees\":\"Seguindo\",\"followers\":\"Seguidores\",\"following\":\"Seguindo!\",\"follows_you\":\"Segue você!\",\"its_you\":\"É você!\",\"media\":\"Mídia\",\"mute\":\"Silenciar\",\"muted\":\"Silenciado\",\"per_day\":\"por dia\",\"remote_follow\":\"Seguidor Remoto\",\"statuses\":\"Postagens\",\"unblock\":\"Desbloquear\",\"unblock_progress\":\"Desbloqueando...\",\"block_progress\":\"Bloqueando...\",\"unmute\":\"Retirar silêncio\",\"unmute_progress\":\"Retirando silêncio...\",\"mute_progress\":\"Silenciando...\"},\"user_profile\":{\"timeline_title\":\"Linha do tempo do usuário\",\"profile_does_not_exist\":\"Desculpe, este perfil não existe.\",\"profile_loading_error\":\"Desculpe, houve um erro ao carregar este perfil.\"},\"who_to_follow\":{\"more\":\"Mais\",\"who_to_follow\":\"Quem seguir\"},\"tool_tip\":{\"media_upload\":\"Envio de mídia\",\"repeat\":\"Repetir\",\"reply\":\"Responder\",\"favorite\":\"Favoritar\",\"user_settings\":\"Configurações do usuário\"},\"upload\":{\"error\":{\"base\":\"Falha no envio.\",\"file_too_big\":\"Arquivo grande demais [{filesize}{filesizeunit} / {allowedsize}{allowedsizeunit}]\",\"default\":\"Tente novamente mais tarde\"},\"file_size_units\":{\"B\":\"B\",\"KiB\":\"KiB\",\"MiB\":\"MiB\",\"GiB\":\"GiB\",\"TiB\":\"TiB\"}}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/pt.json\n// module id = 453\n// module chunks = 2","module.exports = {\"finder\":{\"error_fetching_user\":\"Eroare la preluarea utilizatorului\",\"find_user\":\"Găsește utilizator\"},\"general\":{\"submit\":\"trimite\"},\"login\":{\"login\":\"Loghează\",\"logout\":\"Deloghează\",\"password\":\"Parolă\",\"placeholder\":\"d.e. lain\",\"register\":\"Înregistrare\",\"username\":\"Nume utilizator\"},\"nav\":{\"mentions\":\"Menționări\",\"public_tl\":\"Cronologie Publică\",\"timeline\":\"Cronologie\",\"twkn\":\"Toată Reșeaua Cunoscută\"},\"notifications\":{\"followed_you\":\"te-a urmărit\",\"notifications\":\"Notificări\",\"read\":\"Citit!\"},\"post_status\":{\"default\":\"Nu de mult am aterizat în L.A.\",\"posting\":\"Postează\"},\"registration\":{\"bio\":\"Bio\",\"email\":\"Email\",\"fullname\":\"Numele întreg\",\"password_confirm\":\"Cofirmă parola\",\"registration\":\"Îregistrare\"},\"settings\":{\"attachments\":\"Atașamente\",\"autoload\":\"Permite încărcarea automată când scrolat la capăt\",\"avatar\":\"Avatar\",\"bio\":\"Bio\",\"current_avatar\":\"Avatarul curent\",\"current_profile_banner\":\"Bannerul curent al profilului\",\"filtering\":\"Filtru\",\"filtering_explanation\":\"Toate stările care conțin aceste cuvinte vor fi puse pe mut, una pe linie\",\"hide_attachments_in_convo\":\"Ascunde atașamentele în conversații\",\"hide_attachments_in_tl\":\"Ascunde atașamentele în cronologie\",\"name\":\"Nume\",\"name_bio\":\"Nume și Bio\",\"nsfw_clickthrough\":\"Permite ascunderea al atașamentelor NSFW\",\"profile_background\":\"Fundalul de profil\",\"profile_banner\":\"Banner de profil\",\"reply_link_preview\":\"Permite previzualizarea linkului de răspuns la planarea de mouse\",\"set_new_avatar\":\"Setează avatar nou\",\"set_new_profile_background\":\"Setează fundal nou\",\"set_new_profile_banner\":\"Setează banner nou la profil\",\"settings\":\"Setări\",\"theme\":\"Temă\",\"user_settings\":\"Setările utilizatorului\"},\"timeline\":{\"conversation\":\"Conversație\",\"error_fetching\":\"Erare la preluarea actualizărilor\",\"load_older\":\"Încarcă stări mai vechi\",\"show_new\":\"Arată cele noi\",\"up_to_date\":\"La zi\"},\"user_card\":{\"block\":\"Blochează\",\"blocked\":\"Blocat!\",\"follow\":\"Urmărește\",\"followees\":\"Urmărește\",\"followers\":\"Următori\",\"following\":\"Urmărit!\",\"follows_you\":\"Te urmărește!\",\"mute\":\"Pune pe mut\",\"muted\":\"Pus pe mut\",\"per_day\":\"pe zi\",\"statuses\":\"Stări\"}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/ro.json\n// module id = 454\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"Чат\"},\"finder\":{\"error_fetching_user\":\"Пользователь не найден\",\"find_user\":\"Найти пользователя\"},\"general\":{\"apply\":\"Применить\",\"submit\":\"Отправить\"},\"login\":{\"login\":\"Войти\",\"logout\":\"Выйти\",\"password\":\"Пароль\",\"placeholder\":\"e.c. lain\",\"register\":\"Зарегистрироваться\",\"username\":\"Имя пользователя\"},\"nav\":{\"back\":\"Назад\",\"chat\":\"Локальный чат\",\"mentions\":\"Упоминания\",\"public_tl\":\"Публичная лента\",\"timeline\":\"Лента\",\"twkn\":\"Федеративная лента\"},\"notifications\":{\"broken_favorite\":\"Неизвестный статус, ищем...\",\"favorited_you\":\"нравится ваш статус\",\"followed_you\":\"начал(а) читать вас\",\"load_older\":\"Загрузить старые уведомления\",\"notifications\":\"Уведомления\",\"read\":\"Прочесть\",\"repeated_you\":\"повторил(а) ваш статус\"},\"post_status\":{\"account_not_locked_warning\":\"Ваш аккаунт не {0}. Кто угодно может зафоловить вас чтобы прочитать посты только для подписчиков\",\"account_not_locked_warning_link\":\"залочен\",\"attachments_sensitive\":\"Вложения содержат чувствительный контент\",\"content_warning\":\"Тема (не обязательно)\",\"default\":\"Что нового?\",\"direct_warning\":\"Этот пост будет видет только упомянутым пользователям\",\"posting\":\"Отправляется\",\"scope\":{\"direct\":\"Личное - этот пост видят только те кто в нём упомянут\",\"private\":\"Для подписчиков - этот пост видят только подписчики\",\"public\":\"Публичный - этот пост виден всем\",\"unlisted\":\"Непубличный - этот пост не виден на публичных лентах\"}},\"registration\":{\"bio\":\"Описание\",\"email\":\"Email\",\"fullname\":\"Отображаемое имя\",\"password_confirm\":\"Подтверждение пароля\",\"registration\":\"Регистрация\",\"token\":\"Код приглашения\",\"validations\":{\"username_required\":\"не должно быть пустым\",\"fullname_required\":\"не должно быть пустым\",\"email_required\":\"не должен быть пустым\",\"password_required\":\"не должен быть пустым\",\"password_confirmation_required\":\"не должно быть пустым\",\"password_confirmation_match\":\"должно совпадать с паролем\"}},\"settings\":{\"attachmentRadius\":\"Прикреплённые файлы\",\"attachments\":\"Вложения\",\"autoload\":\"Включить автоматическую загрузку при прокрутке вниз\",\"avatar\":\"Аватар\",\"avatarAltRadius\":\"Аватары в уведомлениях\",\"avatarRadius\":\"Аватары\",\"background\":\"Фон\",\"bio\":\"Описание\",\"btnRadius\":\"Кнопки\",\"cBlue\":\"Ответить, читать\",\"cGreen\":\"Повторить\",\"cOrange\":\"Нравится\",\"cRed\":\"Отменить\",\"change_password\":\"Сменить пароль\",\"change_password_error\":\"Произошла ошибка при попытке изменить пароль.\",\"changed_password\":\"Пароль изменён успешно.\",\"collapse_subject\":\"Сворачивать посты с темой\",\"confirm_new_password\":\"Подтверждение нового пароля\",\"current_avatar\":\"Текущий аватар\",\"current_password\":\"Текущий пароль\",\"current_profile_banner\":\"Текущий баннер профиля\",\"data_import_export_tab\":\"Импорт / Экспорт данных\",\"delete_account\":\"Удалить аккаунт\",\"delete_account_description\":\"Удалить ваш аккаунт и все ваши сообщения.\",\"delete_account_error\":\"Возникла ошибка в процессе удаления вашего аккаунта. Если это повторяется, свяжитесь с администратором вашего сервера.\",\"delete_account_instructions\":\"Введите ваш пароль в поле ниже для подтверждения удаления.\",\"export_theme\":\"Сохранить Тему\",\"filtering\":\"Фильтрация\",\"filtering_explanation\":\"Все статусы, содержащие данные слова, будут игнорироваться, по одному в строке\",\"follow_export\":\"Экспортировать читаемых\",\"follow_export_button\":\"Экспортировать читаемых в файл .csv\",\"follow_export_processing\":\"Ведётся обработка, скоро вам будет предложено загрузить файл\",\"follow_import\":\"Импортировать читаемых\",\"follow_import_error\":\"Ошибка при импортировании читаемых.\",\"follows_imported\":\"Список читаемых импортирован. Обработка займёт некоторое время..\",\"foreground\":\"Передний план\",\"general\":\"Общие\",\"hide_attachments_in_convo\":\"Прятать вложения в разговорах\",\"hide_attachments_in_tl\":\"Прятать вложения в ленте\",\"hide_isp\":\"Скрыть серверную панель\",\"import_followers_from_a_csv_file\":\"Импортировать читаемых из файла .csv\",\"import_theme\":\"Загрузить Тему\",\"inputRadius\":\"Поля ввода\",\"checkboxRadius\":\"Чекбоксы\",\"interface\":\"Интерфейс\",\"interfaceLanguage\":\"Язык интерфейса\",\"limited_availability\":\"Не доступно в вашем браузере\",\"links\":\"Ссылки\",\"lock_account_description\":\"Аккаунт доступен только подтверждённым подписчикам\",\"loop_video\":\"Зациливать видео\",\"loop_video_silent_only\":\"Зацикливать только беззвучные видео (т.е. \\\"гифки\\\" с Mastodon)\",\"name\":\"Имя\",\"name_bio\":\"Имя и описание\",\"new_password\":\"Новый пароль\",\"notification_visibility\":\"Показывать уведомления\",\"notification_visibility_follows\":\"Подписки\",\"notification_visibility_likes\":\"Лайки\",\"notification_visibility_mentions\":\"Упоминания\",\"notification_visibility_repeats\":\"Повторы\",\"no_rich_text_description\":\"Убрать форматирование из всех постов\",\"hide_follows_description\":\"Не показывать кого я читаю\",\"hide_followers_description\":\"Не показывать кто читает меня\",\"show_admin_badge\":\"Показывать значок администратора в моем профиле\",\"show_moderator_badge\":\"Показывать значок модератора в моем профиле\",\"nsfw_clickthrough\":\"Включить скрытие NSFW вложений\",\"oauth_tokens\":\"OAuth токены\",\"token\":\"Токен\",\"refresh_token\":\"Рефреш токен\",\"valid_until\":\"Годен до\",\"revoke_token\":\"Удалить\",\"panelRadius\":\"Панели\",\"pause_on_unfocused\":\"Приостановить загрузку когда вкладка не в фокусе\",\"presets\":\"Пресеты\",\"profile_background\":\"Фон профиля\",\"profile_banner\":\"Баннер профиля\",\"profile_tab\":\"Профиль\",\"radii_help\":\"Скругление углов элементов интерфейса (в пикселях)\",\"replies_in_timeline\":\"Ответы в ленте\",\"reply_link_preview\":\"Включить предварительный просмотр ответа при наведении мыши\",\"reply_visibility_all\":\"Показывать все ответы\",\"reply_visibility_following\":\"Показывать только ответы мне и тех на кого я подписан\",\"reply_visibility_self\":\"Показывать только ответы мне\",\"security_tab\":\"Безопасность\",\"set_new_avatar\":\"Загрузить новый аватар\",\"set_new_profile_background\":\"Загрузить новый фон профиля\",\"set_new_profile_banner\":\"Загрузить новый баннер профиля\",\"settings\":\"Настройки\",\"subject_input_always_show\":\"Всегда показывать поле ввода темы\",\"stop_gifs\":\"Проигрывать GIF анимации только при наведении\",\"streaming\":\"Включить автоматическую загрузку новых сообщений при прокрутке вверх\",\"text\":\"Текст\",\"theme\":\"Тема\",\"theme_help\":\"Используйте шестнадцатеричные коды цветов (#rrggbb) для настройки темы.\",\"theme_help_v2_1\":\"Вы так же можете перепоределить цвета определенных компонентов нажав соотв. галочку. Используйте кнопку \\\"Очистить всё\\\" чтобы снять все переопределения\",\"theme_help_v2_2\":\"Под некоторыми полями ввода это идикаторы контрастности, наведите на них мышью чтобы узнать больше. Приспользовании прозрачности контраст расчитывается для наихудшего варианта.\",\"tooltipRadius\":\"Всплывающие подсказки/уведомления\",\"user_settings\":\"Настройки пользователя\",\"style\":{\"switcher\":{\"keep_color\":\"Оставить цвета\",\"keep_shadows\":\"Оставить тени\",\"keep_opacity\":\"Оставить прозрачность\",\"keep_roundness\":\"Оставить скругление\",\"keep_fonts\":\"Оставить шрифты\",\"save_load_hint\":\"Опции \\\"оставить...\\\" позволяют сохранить текущие настройки при выборе другой темы или импорта её из файла. Так же они влияют на то какие компоненты будут сохранены при экспорте темы. Когда все галочки сняты все компоненты будут экспортированы.\",\"reset\":\"Сбросить\",\"clear_all\":\"Очистить всё\",\"clear_opacity\":\"Очистить прозрачность\"},\"common\":{\"color\":\"Цвет\",\"opacity\":\"Прозрачность\",\"contrast\":{\"hint\":\"Уровень контраста: {ratio}, что {level} {context}\",\"level\":{\"aa\":\"соответствует гайдлайну Level AA (минимальный)\",\"aaa\":\"соответствует гайдлайну Level AAA (рекомендуемый)\",\"bad\":\"не соответствует каким либо гайдлайнам\"},\"context\":{\"18pt\":\"для крупного (18pt+) текста\",\"text\":\"для текста\"}}},\"common_colors\":{\"_tab_label\":\"Общие\",\"main\":\"Общие цвета\",\"foreground_hint\":\"См. вкладку \\\"Дополнительно\\\" для более детального контроля\",\"rgbo\":\"Иконки, акценты, ярылки\"},\"advanced_colors\":{\"_tab_label\":\"Дополнительно\",\"alert\":\"Фон уведомлений\",\"alert_error\":\"Ошибки\",\"badge\":\"Фон значков\",\"badge_notification\":\"Уведомления\",\"panel_header\":\"Заголовок панели\",\"top_bar\":\"Верняя полоска\",\"borders\":\"Границы\",\"buttons\":\"Кнопки\",\"inputs\":\"Поля ввода\",\"faint_text\":\"Маловажный текст\"},\"radii\":{\"_tab_label\":\"Скругление\"},\"shadows\":{\"_tab_label\":\"Светотень\",\"component\":\"Компонент\",\"override\":\"Переопределить\",\"shadow_id\":\"Тень №{value}\",\"blur\":\"Размытие\",\"spread\":\"Разброс\",\"inset\":\"Внутренняя\",\"hint\":\"Для теней вы так же можете использовать --variable в качестве цвета чтобы использовать CSS3-переменные. В таком случае прозрачность работать не будет.\",\"filter_hint\":{\"always_drop_shadow\":\"Внимание, эта тень всегда использует {0} когда браузер поддерживает это\",\"drop_shadow_syntax\":\"{0} не поддерживает параметр {1} и ключевое слово {2}\",\"avatar_inset\":\"Одновременное использование внутренних и внешних теней на (прозрачных) аватарках может дать не те результаты что вы ожидаете\",\"spread_zero\":\"Тени с разбросом > 0 будут выглядеть как если бы разброс установлен в 0\",\"inset_classic\":\"Внутренние тени будут использовать {0}\"},\"components\":{\"panel\":\"Панель\",\"panelHeader\":\"Заголовок панели\",\"topBar\":\"Верхняя полоска\",\"avatar\":\"Аватарка (профиль)\",\"avatarStatus\":\"Аватарка (в ленте)\",\"popup\":\"Всплывающие подсказки\",\"button\":\"Кнопки\",\"buttonHover\":\"Кнопки (наведен курсор)\",\"buttonPressed\":\"Кнопки (нажата)\",\"buttonPressedHover\":\"Кнопки (нажата+наведен курсор)\",\"input\":\"Поля ввода\"}},\"fonts\":{\"_tab_label\":\"Шрифты\",\"help\":\"Выберите тип шрифта для использования в интерфейсе. При выборе варианта \\\"другой\\\" надо ввести название шрифта в точности как он называется в системе.\",\"components\":{\"interface\":\"Интерфейс\",\"input\":\"Поля ввода\",\"post\":\"Текст постов\",\"postCode\":\"Моноширинный текст в посте (форматирование)\"},\"family\":\"Шрифт\",\"size\":\"Размер (в пикселях)\",\"weight\":\"Ширина\",\"custom\":\"Другой\"},\"preview\":{\"header\":\"Пример\",\"content\":\"Контент\",\"error\":\"Ошибка стоп 000\",\"button\":\"Кнопка\",\"text\":\"Еще немного {0} и масенькая {1}\",\"mono\":\"контента\",\"input\":\"Что нового?\",\"faint_link\":\"Его придется убрать\",\"fine_print\":\"Если проблемы остались — ваш гуртовщик мыши плохо стоит. {0}.\",\"header_faint\":\"Все идет по плану\",\"checkbox\":\"Я подтверждаю что не было ни единого разрыва\",\"link\":\"ссылка\"}}},\"timeline\":{\"collapse\":\"Свернуть\",\"conversation\":\"Разговор\",\"error_fetching\":\"Ошибка при обновлении\",\"load_older\":\"Загрузить старые статусы\",\"no_retweet_hint\":\"Пост помечен как \\\"только для подписчиков\\\" или \\\"личное\\\" и поэтому не может быть повторён\",\"repeated\":\"повторил(а)\",\"show_new\":\"Показать новые\",\"up_to_date\":\"Обновлено\"},\"user_card\":{\"block\":\"Заблокировать\",\"blocked\":\"Заблокирован\",\"favorites\":\"Понравившиеся\",\"follow\":\"Читать\",\"follow_sent\":\"Запрос отправлен!\",\"follow_progress\":\"Запрашиваем…\",\"follow_again\":\"Запросить еще заново?\",\"follow_unfollow\":\"Перестать читать\",\"followees\":\"Читаемые\",\"followers\":\"Читатели\",\"following\":\"Читаю\",\"follows_you\":\"Читает вас\",\"mute\":\"Игнорировать\",\"muted\":\"Игнорирую\",\"per_day\":\"в день\",\"remote_follow\":\"Читать удалённо\",\"statuses\":\"Статусы\"},\"user_profile\":{\"timeline_title\":\"Лента пользователя\"}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/ru.json\n// module id = 455\n// module chunks = 2","module.exports = {\"chat\":{\"title\":\"聊天\"},\"features_panel\":{\"chat\":\"聊天\",\"gopher\":\"Gopher\",\"media_proxy\":\"媒体代理\",\"scope_options\":\"可见范围设置\",\"text_limit\":\"文本长度限制\",\"title\":\"功能\",\"who_to_follow\":\"推荐关注\"},\"finder\":{\"error_fetching_user\":\"获取用户时发生错误\",\"find_user\":\"寻找用户\"},\"general\":{\"apply\":\"应用\",\"submit\":\"提交\"},\"login\":{\"login\":\"登录\",\"logout\":\"登出\",\"password\":\"密码\",\"placeholder\":\"例如:lain\",\"register\":\"注册\",\"username\":\"用户名\"},\"nav\":{\"chat\":\"本地聊天\",\"friend_requests\":\"关注请求\",\"mentions\":\"提及\",\"public_tl\":\"公共时间线\",\"timeline\":\"时间线\",\"twkn\":\"所有已知网络\"},\"notifications\":{\"broken_favorite\":\"未知的状态,正在搜索中...\",\"favorited_you\":\"收藏了你的状态\",\"followed_you\":\"关注了你\",\"load_older\":\"加载更早的通知\",\"notifications\":\"通知\",\"read\":\"阅读!\",\"repeated_you\":\"转发了你的状态\"},\"post_status\":{\"account_not_locked_warning\":\"你的帐号没有 {0}。任何人都可以关注你并浏览你的上锁内容。\",\"account_not_locked_warning_link\":\"上锁\",\"attachments_sensitive\":\"标记附件为敏感内容\",\"content_type\":{\"plain_text\":\"纯文本\"},\"content_warning\":\"主题(可选)\",\"default\":\"刚刚抵达上海\",\"direct_warning\":\"本条内容只有被提及的用户能够看到。\",\"posting\":\"发送\",\"scope\":{\"direct\":\"私信 - 只发送给被提及的用户\",\"private\":\"仅关注者 - 只有关注了你的人能看到\",\"public\":\"公共 - 发送到公共时间轴\",\"unlisted\":\"不公开 - 所有人可见,但不会发送到公共时间轴\"}},\"registration\":{\"bio\":\"简介\",\"email\":\"电子邮箱\",\"fullname\":\"全名\",\"password_confirm\":\"确认密码\",\"registration\":\"注册\",\"token\":\"邀请码\"},\"settings\":{\"attachmentRadius\":\"附件\",\"attachments\":\"附件\",\"autoload\":\"启用滚动到底部时的自动加载\",\"avatar\":\"头像\",\"avatarAltRadius\":\"头像(通知)\",\"avatarRadius\":\"头像\",\"background\":\"背景\",\"bio\":\"简介\",\"btnRadius\":\"按钮\",\"cBlue\":\"蓝色(回复,关注)\",\"cGreen\":\"绿色(转发)\",\"cOrange\":\"橙色(收藏)\",\"cRed\":\"红色(取消)\",\"change_password\":\"修改密码\",\"change_password_error\":\"修改密码的时候出了点问题。\",\"changed_password\":\"成功修改了密码!\",\"collapse_subject\":\"折叠带主题的内容\",\"confirm_new_password\":\"确认新密码\",\"current_avatar\":\"当前头像\",\"current_password\":\"当前密码\",\"current_profile_banner\":\"您当前的横幅图片\",\"data_import_export_tab\":\"数据导入/导出\",\"default_vis\":\"默认可见范围\",\"delete_account\":\"删除账户\",\"delete_account_description\":\"永久删除你的帐号和所有消息。\",\"delete_account_error\":\"删除账户时发生错误,如果一直删除不了,请联系实例管理员。\",\"delete_account_instructions\":\"在下面输入你的密码来确认删除账户\",\"export_theme\":\"导出预置主题\",\"filtering\":\"过滤器\",\"filtering_explanation\":\"所有包含以下词汇的内容都会被隐藏,一行一个\",\"follow_export\":\"导出关注\",\"follow_export_button\":\"将关注导出成 csv 文件\",\"follow_export_processing\":\"正在处理,过一会儿就可以下载你的文件了\",\"follow_import\":\"导入关注\",\"follow_import_error\":\"导入关注时错误\",\"follows_imported\":\"关注已导入!尚需要一些时间来处理。\",\"foreground\":\"前景\",\"general\":\"通用\",\"hide_attachments_in_convo\":\"在对话中隐藏附件\",\"hide_attachments_in_tl\":\"在时间线上隐藏附件\",\"hide_post_stats\":\"隐藏推文相关的统计数据(例如:收藏的次数)\",\"hide_user_stats\":\"隐藏用户的统计数据(例如:关注者的数量)\",\"import_followers_from_a_csv_file\":\"从 csv 文件中导入关注\",\"import_theme\":\"导入预置主题\",\"inputRadius\":\"输入框\",\"instance_default\":\"(默认:{value})\",\"interfaceLanguage\":\"界面语言\",\"invalid_theme_imported\":\"您所选择的主题文件不被 Pleroma 支持,因此主题未被修改。\",\"limited_availability\":\"在您的浏览器中无法使用\",\"links\":\"链接\",\"lock_account_description\":\"你需要手动审核关注请求\",\"loop_video\":\"循环视频\",\"loop_video_silent_only\":\"只循环没有声音的视频(例如:Mastodon 里的“GIF”)\",\"name\":\"名字\",\"name_bio\":\"名字及简介\",\"new_password\":\"新密码\",\"notification_visibility\":\"要显示的通知类型\",\"notification_visibility_follows\":\"关注\",\"notification_visibility_likes\":\"点赞\",\"notification_visibility_mentions\":\"提及\",\"notification_visibility_repeats\":\"转发\",\"no_rich_text_description\":\"不显示富文本格式\",\"nsfw_clickthrough\":\"将不和谐附件隐藏,点击才能打开\",\"oauth_tokens\":\"OAuth令牌\",\"token\":\"代币\",\"refresh_token\":\"刷新令牌\",\"valid_until\":\"有效期至\",\"revoke_token\":\"撤消\",\"panelRadius\":\"面板\",\"pause_on_unfocused\":\"在离开页面时暂停时间线推送\",\"presets\":\"预置\",\"profile_background\":\"个人资料背景图\",\"profile_banner\":\"横幅图片\",\"profile_tab\":\"个人资料\",\"radii_help\":\"设置界面边缘的圆角 (单位:像素)\",\"replies_in_timeline\":\"时间线中的回复\",\"reply_link_preview\":\"启用鼠标悬停时预览回复链接\",\"reply_visibility_all\":\"显示所有回复\",\"reply_visibility_following\":\"只显示发送给我的回复/发送给我关注的用户的回复\",\"reply_visibility_self\":\"只显示发送给我的回复\",\"saving_err\":\"保存设置时发生错误\",\"saving_ok\":\"设置已保存\",\"security_tab\":\"安全\",\"set_new_avatar\":\"设置新头像\",\"set_new_profile_background\":\"设置新的个人资料背景\",\"set_new_profile_banner\":\"设置新的横幅图片\",\"settings\":\"设置\",\"stop_gifs\":\"鼠标悬停时播放GIF\",\"streaming\":\"开启滚动到顶部时的自动推送\",\"text\":\"文本\",\"theme\":\"主题\",\"theme_help\":\"使用十六进制代码(#rrggbb)来设置主题颜色。\",\"tooltipRadius\":\"提醒\",\"user_settings\":\"用户设置\",\"values\":{\"false\":\"否\",\"true\":\"是\"}},\"timeline\":{\"collapse\":\"折叠\",\"conversation\":\"对话\",\"error_fetching\":\"获取更新时发生错误\",\"load_older\":\"加载更早的状态\",\"no_retweet_hint\":\"这条内容仅关注者可见,或者是私信,因此不能转发。\",\"repeated\":\"已转发\",\"show_new\":\"显示新内容\",\"up_to_date\":\"已是最新\"},\"user_card\":{\"approve\":\"允许\",\"block\":\"屏蔽\",\"blocked\":\"已屏蔽!\",\"deny\":\"拒绝\",\"follow\":\"关注\",\"followees\":\"正在关注\",\"followers\":\"关注者\",\"following\":\"正在关注!\",\"follows_you\":\"关注了你!\",\"mute\":\"隐藏\",\"muted\":\"已隐藏\",\"per_day\":\"每天\",\"remote_follow\":\"跨站关注\",\"statuses\":\"状态\"},\"user_profile\":{\"timeline_title\":\"用户时间线\"},\"who_to_follow\":{\"more\":\"更多\",\"who_to_follow\":\"推荐关注\"}}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/i18n/zh.json\n// module id = 456\n// module chunks = 2","module.exports = [\"teď\",[\"%s s\",\"%s s\"],[\"%s min\",\"%s min\"],[\"%s h\",\"%s h\"],[\"%s d\",\"%s d\"],[\"%s týd\",\"%s týd\"],[\"%s měs\",\"%s měs\"],[\"%s r\",\"%s l\"]]\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./static/timeago-cs.json\n// module id = 457\n// module chunks = 2","module.exports = [\"now\",[\"%ss\",\"%ss\"],[\"%smin\",\"%smin\"],[\"%sh\",\"%sh\"],[\"%sd\",\"%sd\"],[\"%sw\",\"%sw\"],[\"%smo\",\"%smo\"],[\"%sy\",\"%sy\"]]\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./static/timeago-en.json\n// module id = 458\n// module chunks = 2","module.exports = [\"たった今\",\"%s 秒前\",\"%s 分前\",\"%s 時間前\",\"%s 日前\",\"%s 週間前\",\"%s ヶ月前\",\"%s 年前\"]\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./static/timeago-ja.json\n// module id = 459\n// module chunks = 2","module.exports = __webpack_public_path__ + \"static/img/nsfw.74818f9.png\";\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/assets/nsfw.png\n// module id = 629\n// module chunks = 2","\n/* styles */\nrequire(\"!!../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-4c17cd72\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!./App.scss\")\n\nvar Component = require(\"!../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./App.js\"),\n /* template */\n require(\"!!../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-4c17cd72\\\"}!../node_modules/vue-loader/lib/selector?type=template&index=0!./App.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/App.vue\n// module id = 633\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-519c4ebc\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./about.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./about.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-519c4ebc\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./about.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/about/about.vue\n// module id = 634\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-5370e1c0\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./block_card.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./block_card.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-5370e1c0\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./block_card.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/block_card/block_card.vue\n// module id = 635\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-205b4e20\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./contrast_ratio.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!../../../node_modules/vue-loader/lib/selector?type=script&index=0!./contrast_ratio.vue\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-205b4e20\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./contrast_ratio.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/contrast_ratio/contrast_ratio.vue\n// module id = 636\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./conversation-page.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-6d354bd4\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./conversation-page.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/conversation-page/conversation-page.vue\n// module id = 637\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-ab5f3124\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./delete_button.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./delete_button.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-ab5f3124\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./delete_button.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/delete_button/delete_button.vue\n// module id = 638\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./dm_timeline.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-55994110\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./dm_timeline.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/dm_timeline/dm_timeline.vue\n// module id = 639\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-e5bdcefc\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./export_import.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!../../../node_modules/vue-loader/lib/selector?type=script&index=0!./export_import.vue\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-e5bdcefc\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./export_import.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/export_import/export_import.vue\n// module id = 640\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-bd666be8\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./favorite_button.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./favorite_button.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-bd666be8\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./favorite_button.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/favorite_button/favorite_button.vue\n// module id = 641\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-3937d93e\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./follow_request_card.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./follow_request_card.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-3937d93e\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./follow_request_card.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/follow_request_card/follow_request_card.vue\n// module id = 642\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./follow_requests.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-06c79474\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./follow_requests.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/follow_requests/follow_requests.vue\n// module id = 643\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-4bc1e940\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./font_control.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./font_control.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-4bc1e940\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./font_control.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/font_control/font_control.vue\n// module id = 644\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./friends_timeline.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-938aba00\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./friends_timeline.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/friends_timeline/friends_timeline.vue\n// module id = 645\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-d4665f74\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./gallery.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./gallery.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-d4665f74\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./gallery.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/gallery/gallery.vue\n// module id = 646\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-8fcb0418\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./image_cropper.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./image_cropper.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-8fcb0418\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./image_cropper.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/image_cropper/image_cropper.vue\n// module id = 647\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!../../../node_modules/vue-loader/lib/selector?type=script&index=0!./interface_language_switcher.vue\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-3de351e6\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./interface_language_switcher.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/interface_language_switcher/interface_language_switcher.vue\n// module id = 648\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-6efb6640\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./link-preview.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./link-preview.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-6efb6640\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./link-preview.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/link-preview/link-preview.vue\n// module id = 649\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-556eb774\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./media_modal.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./media_modal.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-556eb774\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./media_modal.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/media_modal/media_modal.vue\n// module id = 650\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-546891a0\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./media_upload.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./media_upload.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-546891a0\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./media_upload.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/media_upload/media_upload.vue\n// module id = 651\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./mentions.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-2b4a7ac0\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./mentions.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/mentions/mentions.vue\n// module id = 652\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-001adce0\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./mobile_post_status_modal.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./mobile_post_status_modal.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-001adce0\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./mobile_post_status_modal.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/mobile_post_status_modal/mobile_post_status_modal.vue\n// module id = 653\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./mute_card.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-29a81a4e\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./mute_card.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/mute_card/mute_card.vue\n// module id = 654\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-d306a29c\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./nav_panel.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./nav_panel.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-d306a29c\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./nav_panel.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/nav_panel/nav_panel.vue\n// module id = 655\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./notification.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-68f32600\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./notification.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/notification/notification.vue\n// module id = 656\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./oauth_callback.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-410c9440\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./oauth_callback.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/oauth_callback/oauth_callback.vue\n// module id = 657\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./public_and_external_timeline.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-2dd59500\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./public_and_external_timeline.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/public_and_external_timeline/public_and_external_timeline.vue\n// module id = 658\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./public_timeline.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-63335050\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./public_timeline.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/public_timeline/public_timeline.vue\n// module id = 659\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!../../../node_modules/vue-loader/lib/selector?type=script&index=0!./range_input.vue\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-6553acb2\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./range_input.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/range_input/range_input.vue\n// module id = 660\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-45f064c0\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./registration.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./registration.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-45f064c0\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./registration.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/registration/registration.vue\n// module id = 661\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-1ca01100\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./retweet_button.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./retweet_button.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-1ca01100\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./retweet_button.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/retweet_button/retweet_button.vue\n// module id = 662\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-cd51c000\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./settings.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./settings.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-cd51c000\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./settings.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/settings/settings.vue\n// module id = 663\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-6a1c4fc0\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./shadow_control.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./shadow_control.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-6a1c4fc0\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./shadow_control.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/shadow_control/shadow_control.vue\n// module id = 664\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-69918754\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./side_drawer.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./side_drawer.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-69918754\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./side_drawer.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/side_drawer/side_drawer.vue\n// module id = 665\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-42b0f6a0\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./status_or_conversation.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./status_or_conversation.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-42b0f6a0\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./status_or_conversation.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/status_or_conversation/status_or_conversation.vue\n// module id = 666\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n null,\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-b5c96572\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./preview.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/style_switcher/preview.vue\n// module id = 667\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./tag_timeline.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-1555bc40\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./tag_timeline.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/tag_timeline/tag_timeline.vue\n// module id = 668\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-1faeb7a0\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./terms_of_service_panel.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./terms_of_service_panel.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-1faeb7a0\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./terms_of_service_panel.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/terms_of_service_panel/terms_of_service_panel.vue\n// module id = 669\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-3e9fe956\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./user_finder.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./user_finder.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-3e9fe956\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./user_finder.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/user_finder/user_finder.vue\n// module id = 670\n// module chunks = 2","var Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./user_panel.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-eda04b40\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./user_panel.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/user_panel/user_panel.vue\n// module id = 671\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-48484e40\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./user_profile.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./user_profile.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-48484e40\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./user_profile.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/user_profile/user_profile.vue\n// module id = 672\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-5e33ef5a\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./user_search.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./user_search.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-5e33ef5a\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./user_search.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/user_search/user_search.vue\n// module id = 673\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-93ac3f60\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./user_settings.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./user_settings.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-93ac3f60\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./user_settings.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/user_settings/user_settings.vue\n// module id = 674\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-1a7865ca\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./who_to_follow.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./who_to_follow.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-1a7865ca\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./who_to_follow.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/who_to_follow/who_to_follow.vue\n// module id = 675\n// module chunks = 2","\n/* styles */\nrequire(\"!!../../../node_modules/extract-text-webpack-plugin/loader.js?{\\\"omit\\\":1,\\\"extract\\\":true,\\\"remove\\\":true}!vue-style-loader!css-loader?sourceMap!../../../node_modules/vue-loader/lib/style-compiler/index?{\\\"id\\\":\\\"data-v-d8fd69d8\\\",\\\"scoped\\\":false,\\\"hasInlineConfig\\\":false}!sass-loader?sourceMap!../../../node_modules/vue-loader/lib/selector?type=styles&index=0!./who_to_follow_panel.vue\")\n\nvar Component = require(\"!../../../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!./who_to_follow_panel.js\"),\n /* template */\n require(\"!!../../../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-d8fd69d8\\\"}!../../../node_modules/vue-loader/lib/selector?type=template&index=0!./who_to_follow_panel.vue\"),\n /* scopeId */\n null,\n /* cssModules */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/components/who_to_follow_panel/who_to_follow_panel.vue\n// module id = 676\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"notifications\"\n }, [_c('div', {\n staticClass: \"panel panel-default\"\n }, [_c('div', {\n staticClass: \"panel-heading\"\n }, [_c('div', {\n staticClass: \"title\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('notifications.notifications')) + \"\\n \"), (_vm.unseenCount) ? _c('span', {\n staticClass: \"badge badge-notification unseen-count\"\n }, [_vm._v(_vm._s(_vm.unseenCount))]) : _vm._e()]), _vm._v(\" \"), (_vm.error) ? _c('div', {\n staticClass: \"loadmore-error alert error\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('timeline.error_fetching')) + \"\\n \")]) : _vm._e(), _vm._v(\" \"), (_vm.unseenCount) ? _c('button', {\n staticClass: \"read-button\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.markAsSeen($event)\n }\n }\n }, [_vm._v(_vm._s(_vm.$t('notifications.read')))]) : _vm._e()]), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-body\"\n }, _vm._l((_vm.visibleNotifications), function(notification) {\n return _c('div', {\n key: notification.action.id,\n staticClass: \"notification\",\n class: {\n \"unseen\": !notification.seen\n }\n }, [_c('div', {\n staticClass: \"notification-overlay\"\n }), _vm._v(\" \"), _c('notification', {\n attrs: {\n \"notification\": notification\n }\n })], 1)\n }), 0), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-footer\"\n }, [(_vm.bottomedOut) ? _c('div', {\n staticClass: \"new-status-notification text-center panel-footer faint\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('notifications.no_more_notifications')) + \"\\n \")]) : (!_vm.loading) ? _c('a', {\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n _vm.fetchOlderNotifications()\n }\n }\n }, [_c('div', {\n staticClass: \"new-status-notification text-center panel-footer\"\n }, [_vm._v(_vm._s(_vm.$t('notifications.load_older')))])]) : _c('div', {\n staticClass: \"new-status-notification text-center panel-footer\"\n }, [_c('i', {\n staticClass: \"icon-spin3 animate-spin\"\n })])])])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-00135b32\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/notifications/notifications.vue\n// module id = 677\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return (_vm.currentUser) ? _c('div', [_c('div', {\n directives: [{\n name: \"show\",\n rawName: \"v-show\",\n value: (_vm.postFormOpen),\n expression: \"postFormOpen\"\n }],\n staticClass: \"post-form-modal-view modal-view\",\n on: {\n \"click\": _vm.closePostForm\n }\n }, [_c('div', {\n staticClass: \"post-form-modal-panel panel\",\n on: {\n \"click\": function($event) {\n $event.stopPropagation();\n }\n }\n }, [_c('div', {\n staticClass: \"panel-heading\"\n }, [_vm._v(_vm._s(_vm.$t('post_status.new_status')))]), _vm._v(\" \"), _c('PostStatusForm', {\n staticClass: \"panel-body\",\n on: {\n \"posted\": _vm.closePostForm\n }\n })], 1)]), _vm._v(\" \"), _c('button', {\n staticClass: \"new-status-button\",\n class: {\n 'hidden': _vm.isHidden\n },\n on: {\n \"click\": _vm.openPostForm\n }\n }, [_c('i', {\n staticClass: \"icon-edit\"\n })])]) : _vm._e()\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-001adce0\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/mobile_post_status_modal/mobile_post_status_modal.vue\n// module id = 678\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n class: _vm.classes.root\n }, [_c('div', {\n class: _vm.classes.header\n }, [_c('div', {\n staticClass: \"title\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.title) + \"\\n \")]), _vm._v(\" \"), (_vm.timelineError) ? _c('div', {\n staticClass: \"loadmore-error alert error\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('timeline.error_fetching')) + \"\\n \")]) : _vm._e(), _vm._v(\" \"), (_vm.timeline.newStatusCount > 0 && !_vm.timelineError) ? _c('button', {\n staticClass: \"loadmore-button\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.showNewStatuses($event)\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('timeline.show_new')) + _vm._s(_vm.newStatusCountStr) + \"\\n \")]) : _vm._e(), _vm._v(\" \"), (!_vm.timeline.newStatusCount > 0 && !_vm.timelineError) ? _c('div', {\n staticClass: \"loadmore-text faint\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('timeline.up_to_date')) + \"\\n \")]) : _vm._e()]), _vm._v(\" \"), _c('div', {\n class: _vm.classes.body\n }, [_c('div', {\n staticClass: \"timeline\"\n }, _vm._l((_vm.timeline.visibleStatuses), function(status) {\n return _c('status-or-conversation', {\n key: status.id,\n staticClass: \"status-fadein\",\n attrs: {\n \"statusoid\": status\n }\n })\n }), 1)]), _vm._v(\" \"), _c('div', {\n class: _vm.classes.footer\n }, [(_vm.count === 0) ? _c('div', {\n staticClass: \"new-status-notification text-center panel-footer faint\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('timeline.no_statuses')) + \"\\n \")]) : (_vm.bottomedOut) ? _c('div', {\n staticClass: \"new-status-notification text-center panel-footer faint\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('timeline.no_more_statuses')) + \"\\n \")]) : (!_vm.timeline.loading) ? _c('a', {\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n _vm.fetchOlderStatuses()\n }\n }\n }, [_c('div', {\n staticClass: \"new-status-notification text-center panel-footer\"\n }, [_vm._v(_vm._s(_vm.$t('timeline.load_older')))])]) : _c('div', {\n staticClass: \"new-status-notification text-center panel-footer\"\n }, [_c('i', {\n staticClass: \"icon-spin3 animate-spin\"\n })])])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-0652fc80\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/timeline/timeline.vue\n// module id = 679\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"settings panel panel-default\"\n }, [_c('div', {\n staticClass: \"panel-heading\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('nav.friend_requests')) + \"\\n \")]), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-body\"\n }, _vm._l((_vm.requests), function(request) {\n return _c('FollowRequestCard', {\n key: request.id,\n attrs: {\n \"user\": request\n }\n })\n }), 1)])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-06c79474\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/follow_requests/follow_requests.vue\n// module id = 680\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('StillImage', {\n staticClass: \"avatar\",\n class: {\n 'avatar-compact': _vm.compact, 'better-shadow': _vm.betterShadow\n },\n attrs: {\n \"src\": _vm.imgSrc,\n \"imageLoadError\": _vm.imageLoadError\n }\n })\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-0a19e43c\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/user_avatar/user_avatar.vue\n// module id = 681\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"post-status-form\"\n }, [_c('form', {\n on: {\n \"submit\": function($event) {\n $event.preventDefault();\n _vm.postStatus(_vm.newStatus)\n }\n }\n }, [_c('div', {\n staticClass: \"form-group\"\n }, [(!this.$store.state.users.currentUser.locked && this.newStatus.visibility == 'private') ? _c('i18n', {\n staticClass: \"visibility-notice\",\n attrs: {\n \"path\": \"post_status.account_not_locked_warning\",\n \"tag\": \"p\"\n }\n }, [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'user-settings'\n }\n }\n }, [_vm._v(_vm._s(_vm.$t('post_status.account_not_locked_warning_link')))])], 1) : _vm._e(), _vm._v(\" \"), (this.newStatus.visibility == 'direct') ? _c('p', {\n staticClass: \"visibility-notice\"\n }, [_vm._v(_vm._s(_vm.$t('post_status.direct_warning')))]) : _vm._e(), _vm._v(\" \"), (_vm.newStatus.spoilerText || _vm.alwaysShowSubject) ? _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.newStatus.spoilerText),\n expression: \"newStatus.spoilerText\"\n }],\n staticClass: \"form-cw\",\n attrs: {\n \"type\": \"text\",\n \"placeholder\": _vm.$t('post_status.content_warning')\n },\n domProps: {\n \"value\": (_vm.newStatus.spoilerText)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.newStatus, \"spoilerText\", $event.target.value)\n }\n }\n }) : _vm._e(), _vm._v(\" \"), _c('textarea', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.newStatus.status),\n expression: \"newStatus.status\"\n }],\n ref: \"textarea\",\n staticClass: \"form-control\",\n attrs: {\n \"placeholder\": _vm.$t('post_status.default'),\n \"rows\": \"1\",\n \"disabled\": _vm.posting\n },\n domProps: {\n \"value\": (_vm.newStatus.status)\n },\n on: {\n \"click\": _vm.setCaret,\n \"keyup\": [_vm.setCaret, function($event) {\n if (!('button' in $event) && _vm._k($event.keyCode, \"enter\", 13, $event.key, \"Enter\")) { return null; }\n if (!$event.ctrlKey) { return null; }\n _vm.postStatus(_vm.newStatus)\n }],\n \"keydown\": [_vm.onKeydown, function($event) {\n if (!('button' in $event) && _vm._k($event.keyCode, \"down\", 40, $event.key, [\"Down\", \"ArrowDown\"])) { return null; }\n return _vm.cycleForward($event)\n }, function($event) {\n if (!('button' in $event) && _vm._k($event.keyCode, \"up\", 38, $event.key, [\"Up\", \"ArrowUp\"])) { return null; }\n return _vm.cycleBackward($event)\n }, function($event) {\n if (!('button' in $event) && _vm._k($event.keyCode, \"tab\", 9, $event.key, \"Tab\")) { return null; }\n if (!$event.shiftKey) { return null; }\n return _vm.cycleBackward($event)\n }, function($event) {\n if (!('button' in $event) && _vm._k($event.keyCode, \"tab\", 9, $event.key, \"Tab\")) { return null; }\n return _vm.cycleForward($event)\n }, function($event) {\n if (!('button' in $event) && _vm._k($event.keyCode, \"enter\", 13, $event.key, \"Enter\")) { return null; }\n return _vm.replaceCandidate($event)\n }, function($event) {\n if (!('button' in $event) && _vm._k($event.keyCode, \"enter\", 13, $event.key, \"Enter\")) { return null; }\n if (!$event.metaKey) { return null; }\n _vm.postStatus(_vm.newStatus)\n }],\n \"drop\": _vm.fileDrop,\n \"dragover\": function($event) {\n $event.preventDefault();\n return _vm.fileDrag($event)\n },\n \"input\": [function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.newStatus, \"status\", $event.target.value)\n }, _vm.resize],\n \"paste\": _vm.paste\n }\n }), _vm._v(\" \"), _c('div', {\n staticClass: \"visibility-tray\"\n }, [(_vm.formattingOptionsEnabled) ? _c('span', {\n staticClass: \"text-format\"\n }, [_c('label', {\n staticClass: \"select\",\n attrs: {\n \"for\": \"post-content-type\"\n }\n }, [_c('select', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.newStatus.contentType),\n expression: \"newStatus.contentType\"\n }],\n staticClass: \"form-control\",\n attrs: {\n \"id\": \"post-content-type\"\n },\n on: {\n \"change\": function($event) {\n var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n return o.selected\n }).map(function(o) {\n var val = \"_value\" in o ? o._value : o.value;\n return val\n });\n _vm.$set(_vm.newStatus, \"contentType\", $event.target.multiple ? $$selectedVal : $$selectedVal[0])\n }\n }\n }, _vm._l((_vm.postFormats), function(postFormat) {\n return _c('option', {\n key: postFormat,\n domProps: {\n \"value\": postFormat\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t((\"post_status.content_type[\\\"\" + postFormat + \"\\\"]\"))) + \"\\n \")])\n }), 0), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-down-open\"\n })])]) : _vm._e(), _vm._v(\" \"), (_vm.scopeOptionsEnabled) ? _c('div', [_c('i', {\n staticClass: \"icon-mail-alt\",\n class: _vm.vis.direct,\n attrs: {\n \"title\": _vm.$t('post_status.scope.direct')\n },\n on: {\n \"click\": function($event) {\n _vm.changeVis('direct')\n }\n }\n }), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-lock\",\n class: _vm.vis.private,\n attrs: {\n \"title\": _vm.$t('post_status.scope.private')\n },\n on: {\n \"click\": function($event) {\n _vm.changeVis('private')\n }\n }\n }), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-lock-open-alt\",\n class: _vm.vis.unlisted,\n attrs: {\n \"title\": _vm.$t('post_status.scope.unlisted')\n },\n on: {\n \"click\": function($event) {\n _vm.changeVis('unlisted')\n }\n }\n }), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-globe\",\n class: _vm.vis.public,\n attrs: {\n \"title\": _vm.$t('post_status.scope.public')\n },\n on: {\n \"click\": function($event) {\n _vm.changeVis('public')\n }\n }\n })]) : _vm._e()])], 1), _vm._v(\" \"), (_vm.candidates) ? _c('div', {\n staticStyle: {\n \"position\": \"relative\"\n }\n }, [_c('div', {\n staticClass: \"autocomplete-panel\"\n }, _vm._l((_vm.candidates), function(candidate) {\n return _c('div', {\n on: {\n \"click\": function($event) {\n _vm.replace(candidate.utf || (candidate.screen_name + ' '))\n }\n }\n }, [_c('div', {\n staticClass: \"autocomplete\",\n class: {\n highlighted: candidate.highlighted\n }\n }, [(candidate.img) ? _c('span', [_c('img', {\n attrs: {\n \"src\": candidate.img\n }\n })]) : _c('span', [_vm._v(_vm._s(candidate.utf))]), _vm._v(\" \"), _c('span', [_vm._v(_vm._s(candidate.screen_name)), _c('small', [_vm._v(_vm._s(candidate.name))])])])])\n }), 0)]) : _vm._e(), _vm._v(\" \"), _c('div', {\n staticClass: \"form-bottom\"\n }, [_c('media-upload', {\n ref: \"mediaUpload\",\n attrs: {\n \"drop-files\": _vm.dropFiles\n },\n on: {\n \"uploading\": _vm.disableSubmit,\n \"uploaded\": _vm.addMediaFile,\n \"upload-failed\": _vm.uploadFailed\n }\n }), _vm._v(\" \"), (_vm.isOverLengthLimit) ? _c('p', {\n staticClass: \"error\"\n }, [_vm._v(_vm._s(_vm.charactersLeft))]) : (_vm.hasStatusLengthLimit) ? _c('p', {\n staticClass: \"faint\"\n }, [_vm._v(_vm._s(_vm.charactersLeft))]) : _vm._e(), _vm._v(\" \"), (_vm.posting) ? _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": \"\"\n }\n }, [_vm._v(_vm._s(_vm.$t('post_status.posting')))]) : (_vm.isOverLengthLimit) ? _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": \"\"\n }\n }, [_vm._v(_vm._s(_vm.$t('general.submit')))]) : _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": _vm.submitDisabled,\n \"type\": \"submit\"\n }\n }, [_vm._v(_vm._s(_vm.$t('general.submit')))])], 1), _vm._v(\" \"), (_vm.error) ? _c('div', {\n staticClass: \"alert error\"\n }, [_vm._v(\"\\n Error: \" + _vm._s(_vm.error) + \"\\n \"), _c('i', {\n staticClass: \"button-icon icon-cancel\",\n on: {\n \"click\": _vm.clearError\n }\n })]) : _vm._e(), _vm._v(\" \"), _c('div', {\n staticClass: \"attachments\"\n }, _vm._l((_vm.newStatus.files), function(file) {\n return _c('div', {\n staticClass: \"media-upload-wrapper\"\n }, [_c('i', {\n staticClass: \"fa button-icon icon-cancel\",\n on: {\n \"click\": function($event) {\n _vm.removeMediaFile(file)\n }\n }\n }), _vm._v(\" \"), _c('div', {\n staticClass: \"media-upload-container attachment\"\n }, [(_vm.type(file) === 'image') ? _c('img', {\n staticClass: \"thumbnail media-upload\",\n attrs: {\n \"src\": file.image\n }\n }) : _vm._e(), _vm._v(\" \"), (_vm.type(file) === 'video') ? _c('video', {\n attrs: {\n \"src\": file.image,\n \"controls\": \"\"\n }\n }) : _vm._e(), _vm._v(\" \"), (_vm.type(file) === 'audio') ? _c('audio', {\n attrs: {\n \"src\": file.image,\n \"controls\": \"\"\n }\n }) : _vm._e(), _vm._v(\" \"), (_vm.type(file) === 'unknown') ? _c('a', {\n attrs: {\n \"href\": file.image\n }\n }, [_vm._v(_vm._s(file.url))]) : _vm._e()])])\n }), 0), _vm._v(\" \"), (_vm.newStatus.files.length > 0) ? _c('div', {\n staticClass: \"upload_settings\"\n }, [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.newStatus.nsfw),\n expression: \"newStatus.nsfw\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"filesSensitive\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.newStatus.nsfw) ? _vm._i(_vm.newStatus.nsfw, null) > -1 : (_vm.newStatus.nsfw)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.newStatus.nsfw,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.$set(_vm.newStatus, \"nsfw\", $$a.concat([$$v])))\n } else {\n $$i > -1 && (_vm.$set(_vm.newStatus, \"nsfw\", $$a.slice(0, $$i).concat($$a.slice($$i + 1))))\n }\n } else {\n _vm.$set(_vm.newStatus, \"nsfw\", $$c)\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"filesSensitive\"\n }\n }, [_vm._v(_vm._s(_vm.$t('post_status.attachments_sensitive')))])]) : _vm._e()])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-11ada5e0\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/post_status_form/post_status_form.vue\n// module id = 682\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"timeline panel panel-default\"\n }, [_c('div', {\n staticClass: \"panel-heading conversation-heading\"\n }, [_c('span', {\n staticClass: \"title\"\n }, [_vm._v(\" \" + _vm._s(_vm.$t('timeline.conversation')) + \" \")]), _vm._v(\" \"), (_vm.collapsable) ? _c('span', [_c('a', {\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n _vm.$emit('toggleExpanded')\n }\n }\n }, [_vm._v(_vm._s(_vm.$t('timeline.collapse')))])]) : _vm._e()]), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-body\"\n }, [_c('div', {\n staticClass: \"timeline\"\n }, _vm._l((_vm.conversation), function(status) {\n return _c('status', {\n key: status.id,\n staticClass: \"status-fadein\",\n attrs: {\n \"inlineExpanded\": _vm.collapsable,\n \"statusoid\": status,\n \"expandable\": false,\n \"focused\": _vm.focused(status.id),\n \"inConversation\": true,\n \"highlight\": _vm.highlight,\n \"replies\": _vm.getReplies(status.id)\n },\n on: {\n \"goto\": _vm.setHighlight\n }\n })\n }), 1)])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-12838600\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/conversation/conversation.vue\n// module id = 683\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('Timeline', {\n attrs: {\n \"title\": _vm.tag,\n \"timeline\": _vm.timeline,\n \"timeline-name\": 'tag',\n \"tag\": _vm.tag\n }\n })\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-1555bc40\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/tag_timeline/tag_timeline.vue\n// module id = 684\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"panel panel-default\"\n }, [_c('div', {\n staticClass: \"panel-heading\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('who_to_follow.who_to_follow')) + \"\\n \")]), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-body\"\n }, _vm._l((_vm.users), function(user) {\n return _c('FollowCard', {\n key: user.id,\n attrs: {\n \"user\": user\n }\n })\n }), 1)])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-1a7865ca\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/who_to_follow/who_to_follow.vue\n// module id = 685\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return (_vm.loggedIn) ? _c('div', [(_vm.visibility !== 'private' && _vm.visibility !== 'direct') ? [_c('i', {\n staticClass: \"button-icon retweet-button icon-retweet rt-active\",\n class: _vm.classes,\n attrs: {\n \"title\": _vm.$t('tool_tip.repeat')\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n _vm.retweet()\n }\n }\n }), _vm._v(\" \"), (!_vm.hidePostStatsLocal && _vm.status.repeat_num > 0) ? _c('span', [_vm._v(_vm._s(_vm.status.repeat_num))]) : _vm._e()] : [_c('i', {\n staticClass: \"button-icon icon-lock\",\n class: _vm.classes,\n attrs: {\n \"title\": _vm.$t('timeline.no_retweet_hint')\n }\n })]], 2) : (!_vm.loggedIn) ? _c('div', [_c('i', {\n staticClass: \"button-icon icon-retweet\",\n class: _vm.classes,\n attrs: {\n \"title\": _vm.$t('tool_tip.repeat')\n }\n }), _vm._v(\" \"), (!_vm.hidePostStatsLocal && _vm.status.repeat_num > 0) ? _c('span', [_vm._v(_vm._s(_vm.status.repeat_num))]) : _vm._e()]) : _vm._e()\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-1ca01100\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/retweet_button/retweet_button.vue\n// module id = 686\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', [_c('div', {\n staticClass: \"panel panel-default\"\n }, [_c('div', {\n staticClass: \"panel-body\"\n }, [_c('div', {\n staticClass: \"tos-content\",\n domProps: {\n \"innerHTML\": _vm._s(_vm.content)\n }\n })])])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-1faeb7a0\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/terms_of_service_panel/terms_of_service_panel.vue\n// module id = 687\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return (_vm.contrast) ? _c('span', {\n staticClass: \"contrast-ratio\"\n }, [_c('span', {\n staticClass: \"rating\",\n attrs: {\n \"title\": _vm.hint\n }\n }, [(_vm.contrast.aaa) ? _c('span', [_c('i', {\n staticClass: \"icon-thumbs-up-alt\"\n })]) : _vm._e(), _vm._v(\" \"), (!_vm.contrast.aaa && _vm.contrast.aa) ? _c('span', [_c('i', {\n staticClass: \"icon-adjust\"\n })]) : _vm._e(), _vm._v(\" \"), (!_vm.contrast.aaa && !_vm.contrast.aa) ? _c('span', [_c('i', {\n staticClass: \"icon-attention\"\n })]) : _vm._e()]), _vm._v(\" \"), (_vm.contrast && _vm.large) ? _c('span', {\n staticClass: \"rating\",\n attrs: {\n \"title\": _vm.hint_18pt\n }\n }, [(_vm.contrast.laaa) ? _c('span', [_c('i', {\n staticClass: \"icon-thumbs-up-alt\"\n })]) : _vm._e(), _vm._v(\" \"), (!_vm.contrast.laaa && _vm.contrast.laa) ? _c('span', [_c('i', {\n staticClass: \"icon-adjust\"\n })]) : _vm._e(), _vm._v(\" \"), (!_vm.contrast.laaa && !_vm.contrast.laa) ? _c('span', [_c('i', {\n staticClass: \"icon-attention\"\n })]) : _vm._e()]) : _vm._e()]) : _vm._e()\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-205b4e20\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/contrast_ratio/contrast_ratio.vue\n// module id = 688\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('basic-user-card', {\n attrs: {\n \"user\": _vm.user\n }\n }, [_c('div', {\n staticClass: \"follow-card-content-container\"\n }, [(!_vm.noFollowsYou && _vm.user.follows_you) ? _c('span', {\n staticClass: \"faint\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.isMe ? _vm.$t('user_card.its_you') : _vm.$t('user_card.follows_you')) + \"\\n \")]) : _vm._e(), _vm._v(\" \"), (_vm.showFollow) ? _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": _vm.inProgress,\n \"title\": _vm.requestSent ? _vm.$t('user_card.follow_again') : ''\n },\n on: {\n \"click\": _vm.followUser\n }\n }, [(_vm.inProgress) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follow_progress')) + \"\\n \")] : (_vm.requestSent) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follow_sent')) + \"\\n \")] : [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follow')) + \"\\n \")]], 2) : _vm._e(), _vm._v(\" \"), (_vm.following) ? _c('button', {\n staticClass: \"btn btn-default pressed\",\n attrs: {\n \"disabled\": _vm.inProgress\n },\n on: {\n \"click\": _vm.unfollowUser\n }\n }, [(_vm.inProgress) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follow_progress')) + \"\\n \")] : [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follow_unfollow')) + \"\\n \")]], 2) : _vm._e()])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-22921ede\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/follow_card/follow_card.vue\n// module id = 689\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('basic-user-card', {\n attrs: {\n \"user\": _vm.user\n }\n }, [_c('template', {\n slot: \"secondary-area\"\n }, [(_vm.muted) ? _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": _vm.progress\n },\n on: {\n \"click\": _vm.unmuteUser\n }\n }, [(_vm.progress) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.unmute_progress')) + \"\\n \")] : [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.unmute')) + \"\\n \")]], 2) : _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": _vm.progress\n },\n on: {\n \"click\": _vm.muteUser\n }\n }, [(_vm.progress) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.mute_progress')) + \"\\n \")] : [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.mute')) + \"\\n \")]], 2)])], 2)\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-29a81a4e\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/mute_card/mute_card.vue\n// module id = 690\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('Timeline', {\n attrs: {\n \"title\": _vm.$t('nav.mentions'),\n \"timeline\": _vm.timeline,\n \"timeline-name\": 'mentions'\n }\n })\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-2b4a7ac0\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/mentions/mentions.vue\n// module id = 691\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('Timeline', {\n attrs: {\n \"title\": _vm.$t('nav.twkn'),\n \"timeline\": _vm.timeline,\n \"timeline-name\": 'publicAndExternal'\n }\n })\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-2dd59500\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/public_and_external_timeline/public_and_external_timeline.vue\n// module id = 692\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return (!this.collapsed || !this.floating) ? _c('div', {\n staticClass: \"chat-panel\"\n }, [_c('div', {\n staticClass: \"panel panel-default\"\n }, [_c('div', {\n staticClass: \"panel-heading timeline-heading\",\n class: {\n 'chat-heading': _vm.floating\n },\n on: {\n \"click\": function($event) {\n $event.stopPropagation();\n $event.preventDefault();\n return _vm.togglePanel($event)\n }\n }\n }, [_c('div', {\n staticClass: \"title\"\n }, [_c('span', [_vm._v(_vm._s(_vm.$t('chat.title')))]), _vm._v(\" \"), (_vm.floating) ? _c('i', {\n staticClass: \"icon-cancel\"\n }) : _vm._e()])]), _vm._v(\" \"), _c('div', {\n directives: [{\n name: \"chat-scroll\",\n rawName: \"v-chat-scroll\"\n }],\n staticClass: \"chat-window\"\n }, _vm._l((_vm.messages), function(message) {\n return _c('div', {\n key: message.id,\n staticClass: \"chat-message\"\n }, [_c('span', {\n staticClass: \"chat-avatar\"\n }, [_c('img', {\n attrs: {\n \"src\": message.author.avatar\n }\n })]), _vm._v(\" \"), _c('div', {\n staticClass: \"chat-content\"\n }, [_c('router-link', {\n staticClass: \"chat-name\",\n attrs: {\n \"to\": _vm.userProfileLink(message.author)\n }\n }, [_vm._v(\"\\n \" + _vm._s(message.author.username) + \"\\n \")]), _vm._v(\" \"), _c('br'), _vm._v(\" \"), _c('span', {\n staticClass: \"chat-text\"\n }, [_vm._v(\"\\n \" + _vm._s(message.text) + \"\\n \")])], 1)])\n }), 0), _vm._v(\" \"), _c('div', {\n staticClass: \"chat-input\"\n }, [_c('textarea', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.currentMessage),\n expression: \"currentMessage\"\n }],\n staticClass: \"chat-input-textarea\",\n attrs: {\n \"rows\": \"1\"\n },\n domProps: {\n \"value\": (_vm.currentMessage)\n },\n on: {\n \"keyup\": function($event) {\n if (!('button' in $event) && _vm._k($event.keyCode, \"enter\", 13, $event.key, \"Enter\")) { return null; }\n _vm.submit(_vm.currentMessage)\n },\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.currentMessage = $event.target.value\n }\n }\n })])])]) : _c('div', {\n staticClass: \"chat-panel\"\n }, [_c('div', {\n staticClass: \"panel panel-default\"\n }, [_c('div', {\n staticClass: \"panel-heading stub timeline-heading chat-heading\",\n on: {\n \"click\": function($event) {\n $event.stopPropagation();\n $event.preventDefault();\n return _vm.togglePanel($event)\n }\n }\n }, [_c('div', {\n staticClass: \"title\"\n }, [_c('i', {\n staticClass: \"icon-comment-empty\"\n }), _vm._v(\"\\n \" + _vm._s(_vm.$t('chat.title')) + \"\\n \")])])])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-37c7b840\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/chat_panel/chat_panel.vue\n// module id = 693\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('basic-user-card', {\n attrs: {\n \"user\": _vm.user\n }\n }, [_c('div', {\n staticClass: \"follow-request-card-content-container\"\n }, [_c('button', {\n staticClass: \"btn btn-default\",\n on: {\n \"click\": _vm.approveUser\n }\n }, [_vm._v(_vm._s(_vm.$t('user_card.approve')))]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn btn-default\",\n on: {\n \"click\": _vm.denyUser\n }\n }, [_vm._v(_vm._s(_vm.$t('user_card.deny')))])])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-3937d93e\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/follow_request_card/follow_request_card.vue\n// module id = 694\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', [_c('label', {\n attrs: {\n \"for\": \"interface-language-switcher\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.interfaceLanguage')) + \"\\n \")]), _vm._v(\" \"), _c('label', {\n staticClass: \"select\",\n attrs: {\n \"for\": \"interface-language-switcher\"\n }\n }, [_c('select', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.language),\n expression: \"language\"\n }],\n attrs: {\n \"id\": \"interface-language-switcher\"\n },\n on: {\n \"change\": function($event) {\n var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n return o.selected\n }).map(function(o) {\n var val = \"_value\" in o ? o._value : o.value;\n return val\n });\n _vm.language = $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n }\n }\n }, _vm._l((_vm.languageCodes), function(langCode, i) {\n return _c('option', {\n domProps: {\n \"value\": langCode\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.languageNames[i]) + \"\\n \")])\n }), 0), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-down-open\"\n })])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-3de351e6\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/interface_language_switcher/interface_language_switcher.vue\n// module id = 695\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', [_c('div', {\n staticClass: \"user-finder-container\"\n }, [(_vm.loading) ? _c('i', {\n staticClass: \"icon-spin4 user-finder-icon animate-spin-slow\"\n }) : _vm._e(), _vm._v(\" \"), (_vm.hidden) ? _c('a', {\n attrs: {\n \"href\": \"#\",\n \"title\": _vm.$t('finder.find_user')\n }\n }, [_c('i', {\n staticClass: \"icon-user-plus user-finder-icon\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n $event.stopPropagation();\n return _vm.toggleHidden($event)\n }\n }\n })]) : [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.username),\n expression: \"username\"\n }],\n ref: \"userSearchInput\",\n staticClass: \"user-finder-input\",\n attrs: {\n \"placeholder\": _vm.$t('finder.find_user'),\n \"id\": \"user-finder-input\",\n \"type\": \"text\"\n },\n domProps: {\n \"value\": (_vm.username)\n },\n on: {\n \"keyup\": function($event) {\n if (!('button' in $event) && _vm._k($event.keyCode, \"enter\", 13, $event.key, \"Enter\")) { return null; }\n _vm.findUser(_vm.username)\n },\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.username = $event.target.value\n }\n }\n }), _vm._v(\" \"), _c('button', {\n staticClass: \"btn search-button\",\n on: {\n \"click\": function($event) {\n _vm.findUser(_vm.username)\n }\n }\n }, [_c('i', {\n staticClass: \"icon-search\"\n })]), _vm._v(\" \"), _c('i', {\n staticClass: \"button-icon icon-cancel user-finder-icon\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n $event.stopPropagation();\n return _vm.toggleHidden($event)\n }\n }\n })]], 2)])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-3e9fe956\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/user_finder/user_finder.vue\n// module id = 696\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('h1', [_vm._v(\"...\")])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-410c9440\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/oauth_callback/oauth_callback.vue\n// module id = 697\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', [(_vm.expanded) ? _c('conversation', {\n attrs: {\n \"collapsable\": true,\n \"statusoid\": _vm.statusoid\n },\n on: {\n \"toggleExpanded\": _vm.toggleExpanded\n }\n }) : _vm._e(), _vm._v(\" \"), (!_vm.expanded) ? _c('status', {\n attrs: {\n \"expandable\": true,\n \"inConversation\": false,\n \"focused\": false,\n \"statusoid\": _vm.statusoid\n },\n on: {\n \"toggleExpanded\": _vm.toggleExpanded\n }\n }) : _vm._e()], 1)\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-42b0f6a0\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/status_or_conversation/status_or_conversation.vue\n// module id = 698\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"login panel panel-default\"\n }, [_c('div', {\n staticClass: \"panel-heading\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('login.login')) + \"\\n \")]), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-body\"\n }, [(_vm.loginMethod == 'password') ? _c('form', {\n staticClass: \"login-form\",\n on: {\n \"submit\": function($event) {\n $event.preventDefault();\n _vm.submit(_vm.user)\n }\n }\n }, [_c('div', {\n staticClass: \"form-group\"\n }, [_c('label', {\n attrs: {\n \"for\": \"username\"\n }\n }, [_vm._v(_vm._s(_vm.$t('login.username')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.user.username),\n expression: \"user.username\"\n }],\n staticClass: \"form-control\",\n attrs: {\n \"disabled\": _vm.loggingIn,\n \"id\": \"username\",\n \"placeholder\": _vm.$t('login.placeholder')\n },\n domProps: {\n \"value\": (_vm.user.username)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.user, \"username\", $event.target.value)\n }\n }\n })]), _vm._v(\" \"), _c('div', {\n staticClass: \"form-group\"\n }, [_c('label', {\n attrs: {\n \"for\": \"password\"\n }\n }, [_vm._v(_vm._s(_vm.$t('login.password')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.user.password),\n expression: \"user.password\"\n }],\n staticClass: \"form-control\",\n attrs: {\n \"disabled\": _vm.loggingIn,\n \"id\": \"password\",\n \"type\": \"password\"\n },\n domProps: {\n \"value\": (_vm.user.password)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.user, \"password\", $event.target.value)\n }\n }\n })]), _vm._v(\" \"), _c('div', {\n staticClass: \"form-group\"\n }, [_c('div', {\n staticClass: \"login-bottom\"\n }, [_c('div', [(_vm.registrationOpen) ? _c('router-link', {\n staticClass: \"register\",\n attrs: {\n \"to\": {\n name: 'registration'\n }\n }\n }, [_vm._v(_vm._s(_vm.$t('login.register')))]) : _vm._e()], 1), _vm._v(\" \"), _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": _vm.loggingIn,\n \"type\": \"submit\"\n }\n }, [_vm._v(_vm._s(_vm.$t('login.login')))])])])]) : _vm._e(), _vm._v(\" \"), (_vm.loginMethod == 'token') ? _c('form', {\n staticClass: \"login-form\",\n on: {\n \"submit\": function($event) {\n $event.preventDefault();\n return _vm.oAuthLogin($event)\n }\n }\n }, [_c('div', {\n staticClass: \"form-group\"\n }, [_c('p', [_vm._v(_vm._s(_vm.$t('login.description')))])]), _vm._v(\" \"), _c('div', {\n staticClass: \"form-group\"\n }, [_c('div', {\n staticClass: \"login-bottom\"\n }, [_c('div', [(_vm.registrationOpen) ? _c('router-link', {\n staticClass: \"register\",\n attrs: {\n \"to\": {\n name: 'registration'\n }\n }\n }, [_vm._v(_vm._s(_vm.$t('login.register')))]) : _vm._e()], 1), _vm._v(\" \"), _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": _vm.loggingIn,\n \"type\": \"submit\"\n }\n }, [_vm._v(_vm._s(_vm.$t('login.login')))])])])]) : _vm._e(), _vm._v(\" \"), (_vm.authError) ? _c('div', {\n staticClass: \"form-group\"\n }, [_c('div', {\n staticClass: \"alert error\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.authError) + \"\\n \"), _c('i', {\n staticClass: \"button-icon icon-cancel\",\n on: {\n \"click\": _vm.clearError\n }\n })])]) : _vm._e()])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-437c2fc0\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/login_form/login_form.vue\n// module id = 699\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"settings panel panel-default\"\n }, [_c('div', {\n staticClass: \"panel-heading\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('registration.registration')) + \"\\n \")]), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-body\"\n }, [_c('form', {\n staticClass: \"registration-form\",\n on: {\n \"submit\": function($event) {\n $event.preventDefault();\n _vm.submit(_vm.user)\n }\n }\n }, [_c('div', {\n staticClass: \"container\"\n }, [_c('div', {\n staticClass: \"text-fields\"\n }, [_c('div', {\n staticClass: \"form-group\",\n class: {\n 'form-group--error': _vm.$v.user.username.$error\n }\n }, [_c('label', {\n staticClass: \"form--label\",\n attrs: {\n \"for\": \"sign-up-username\"\n }\n }, [_vm._v(_vm._s(_vm.$t('login.username')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model.trim\",\n value: (_vm.$v.user.username.$model),\n expression: \"$v.user.username.$model\",\n modifiers: {\n \"trim\": true\n }\n }],\n staticClass: \"form-control\",\n attrs: {\n \"disabled\": _vm.isPending,\n \"id\": \"sign-up-username\",\n \"placeholder\": _vm.$t('registration.username_placeholder')\n },\n domProps: {\n \"value\": (_vm.$v.user.username.$model)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.$v.user.username, \"$model\", $event.target.value.trim())\n },\n \"blur\": function($event) {\n _vm.$forceUpdate()\n }\n }\n })]), _vm._v(\" \"), (_vm.$v.user.username.$dirty) ? _c('div', {\n staticClass: \"form-error\"\n }, [_c('ul', [(!_vm.$v.user.username.required) ? _c('li', [_c('span', [_vm._v(_vm._s(_vm.$t('registration.validations.username_required')))])]) : _vm._e()])]) : _vm._e(), _vm._v(\" \"), _c('div', {\n staticClass: \"form-group\",\n class: {\n 'form-group--error': _vm.$v.user.fullname.$error\n }\n }, [_c('label', {\n staticClass: \"form--label\",\n attrs: {\n \"for\": \"sign-up-fullname\"\n }\n }, [_vm._v(_vm._s(_vm.$t('registration.fullname')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model.trim\",\n value: (_vm.$v.user.fullname.$model),\n expression: \"$v.user.fullname.$model\",\n modifiers: {\n \"trim\": true\n }\n }],\n staticClass: \"form-control\",\n attrs: {\n \"disabled\": _vm.isPending,\n \"id\": \"sign-up-fullname\",\n \"placeholder\": _vm.$t('registration.fullname_placeholder')\n },\n domProps: {\n \"value\": (_vm.$v.user.fullname.$model)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.$v.user.fullname, \"$model\", $event.target.value.trim())\n },\n \"blur\": function($event) {\n _vm.$forceUpdate()\n }\n }\n })]), _vm._v(\" \"), (_vm.$v.user.fullname.$dirty) ? _c('div', {\n staticClass: \"form-error\"\n }, [_c('ul', [(!_vm.$v.user.fullname.required) ? _c('li', [_c('span', [_vm._v(_vm._s(_vm.$t('registration.validations.fullname_required')))])]) : _vm._e()])]) : _vm._e(), _vm._v(\" \"), _c('div', {\n staticClass: \"form-group\",\n class: {\n 'form-group--error': _vm.$v.user.email.$error\n }\n }, [_c('label', {\n staticClass: \"form--label\",\n attrs: {\n \"for\": \"email\"\n }\n }, [_vm._v(_vm._s(_vm.$t('registration.email')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.$v.user.email.$model),\n expression: \"$v.user.email.$model\"\n }],\n staticClass: \"form-control\",\n attrs: {\n \"disabled\": _vm.isPending,\n \"id\": \"email\",\n \"type\": \"email\"\n },\n domProps: {\n \"value\": (_vm.$v.user.email.$model)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.$v.user.email, \"$model\", $event.target.value)\n }\n }\n })]), _vm._v(\" \"), (_vm.$v.user.email.$dirty) ? _c('div', {\n staticClass: \"form-error\"\n }, [_c('ul', [(!_vm.$v.user.email.required) ? _c('li', [_c('span', [_vm._v(_vm._s(_vm.$t('registration.validations.email_required')))])]) : _vm._e()])]) : _vm._e(), _vm._v(\" \"), _c('div', {\n staticClass: \"form-group\"\n }, [_c('label', {\n staticClass: \"form--label\",\n attrs: {\n \"for\": \"bio\"\n }\n }, [_vm._v(_vm._s(_vm.$t('registration.bio')) + \" (\" + _vm._s(_vm.$t('general.optional')) + \")\")]), _vm._v(\" \"), _c('textarea', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.user.bio),\n expression: \"user.bio\"\n }],\n staticClass: \"form-control\",\n attrs: {\n \"disabled\": _vm.isPending,\n \"id\": \"bio\",\n \"placeholder\": _vm.$t('registration.bio_placeholder')\n },\n domProps: {\n \"value\": (_vm.user.bio)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.user, \"bio\", $event.target.value)\n }\n }\n })]), _vm._v(\" \"), _c('div', {\n staticClass: \"form-group\",\n class: {\n 'form-group--error': _vm.$v.user.password.$error\n }\n }, [_c('label', {\n staticClass: \"form--label\",\n attrs: {\n \"for\": \"sign-up-password\"\n }\n }, [_vm._v(_vm._s(_vm.$t('login.password')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.user.password),\n expression: \"user.password\"\n }],\n staticClass: \"form-control\",\n attrs: {\n \"disabled\": _vm.isPending,\n \"id\": \"sign-up-password\",\n \"type\": \"password\"\n },\n domProps: {\n \"value\": (_vm.user.password)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.user, \"password\", $event.target.value)\n }\n }\n })]), _vm._v(\" \"), (_vm.$v.user.password.$dirty) ? _c('div', {\n staticClass: \"form-error\"\n }, [_c('ul', [(!_vm.$v.user.password.required) ? _c('li', [_c('span', [_vm._v(_vm._s(_vm.$t('registration.validations.password_required')))])]) : _vm._e()])]) : _vm._e(), _vm._v(\" \"), _c('div', {\n staticClass: \"form-group\",\n class: {\n 'form-group--error': _vm.$v.user.confirm.$error\n }\n }, [_c('label', {\n staticClass: \"form--label\",\n attrs: {\n \"for\": \"sign-up-password-confirmation\"\n }\n }, [_vm._v(_vm._s(_vm.$t('registration.password_confirm')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.user.confirm),\n expression: \"user.confirm\"\n }],\n staticClass: \"form-control\",\n attrs: {\n \"disabled\": _vm.isPending,\n \"id\": \"sign-up-password-confirmation\",\n \"type\": \"password\"\n },\n domProps: {\n \"value\": (_vm.user.confirm)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.user, \"confirm\", $event.target.value)\n }\n }\n })]), _vm._v(\" \"), (_vm.$v.user.confirm.$dirty) ? _c('div', {\n staticClass: \"form-error\"\n }, [_c('ul', [(!_vm.$v.user.confirm.required) ? _c('li', [_c('span', [_vm._v(_vm._s(_vm.$t('registration.validations.password_confirmation_required')))])]) : _vm._e(), _vm._v(\" \"), (!_vm.$v.user.confirm.sameAsPassword) ? _c('li', [_c('span', [_vm._v(_vm._s(_vm.$t('registration.validations.password_confirmation_match')))])]) : _vm._e()])]) : _vm._e(), _vm._v(\" \"), (_vm.captcha.type != 'none') ? _c('div', {\n staticClass: \"form-group\",\n attrs: {\n \"id\": \"captcha-group\"\n }\n }, [_c('label', {\n staticClass: \"form--label\",\n attrs: {\n \"for\": \"captcha-label\"\n }\n }, [_vm._v(_vm._s(_vm.$t('captcha')))]), _vm._v(\" \"), (_vm.captcha.type == 'kocaptcha') ? [_c('img', {\n attrs: {\n \"src\": _vm.captcha.url\n },\n on: {\n \"click\": _vm.setCaptcha\n }\n }), _vm._v(\" \"), _c('sub', [_vm._v(_vm._s(_vm.$t('registration.new_captcha')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.captcha.solution),\n expression: \"captcha.solution\"\n }],\n staticClass: \"form-control\",\n attrs: {\n \"disabled\": _vm.isPending,\n \"id\": \"captcha-answer\",\n \"type\": \"text\",\n \"autocomplete\": \"off\"\n },\n domProps: {\n \"value\": (_vm.captcha.solution)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.captcha, \"solution\", $event.target.value)\n }\n }\n })] : _vm._e()], 2) : _vm._e(), _vm._v(\" \"), (_vm.token) ? _c('div', {\n staticClass: \"form-group\"\n }, [_c('label', {\n attrs: {\n \"for\": \"token\"\n }\n }, [_vm._v(_vm._s(_vm.$t('registration.token')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.token),\n expression: \"token\"\n }],\n staticClass: \"form-control\",\n attrs: {\n \"disabled\": \"true\",\n \"id\": \"token\",\n \"type\": \"text\"\n },\n domProps: {\n \"value\": (_vm.token)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.token = $event.target.value\n }\n }\n })]) : _vm._e(), _vm._v(\" \"), _c('div', {\n staticClass: \"form-group\"\n }, [_c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": _vm.isPending,\n \"type\": \"submit\"\n }\n }, [_vm._v(_vm._s(_vm.$t('general.submit')))])])]), _vm._v(\" \"), _c('div', {\n staticClass: \"terms-of-service\",\n domProps: {\n \"innerHTML\": _vm._s(_vm.termsOfService)\n }\n })]), _vm._v(\" \"), (_vm.serverValidationErrors.length) ? _c('div', {\n staticClass: \"form-group\"\n }, [_c('div', {\n staticClass: \"alert error\"\n }, _vm._l((_vm.serverValidationErrors), function(error) {\n return _c('span', [_vm._v(_vm._s(error))])\n }), 0)]) : _vm._e()])])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-45f064c0\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/registration/registration.vue\n// module id = 700\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"features-panel\"\n }, [_c('div', {\n staticClass: \"panel panel-default base01-background\"\n }, [_c('div', {\n staticClass: \"panel-heading timeline-heading base02-background base04\"\n }, [_c('div', {\n staticClass: \"title\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('features_panel.title')) + \"\\n \")])]), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-body features-panel\"\n }, [_c('ul', [(_vm.chat) ? _c('li', [_vm._v(_vm._s(_vm.$t('features_panel.chat')))]) : _vm._e(), _vm._v(\" \"), (_vm.gopher) ? _c('li', [_vm._v(_vm._s(_vm.$t('features_panel.gopher')))]) : _vm._e(), _vm._v(\" \"), (_vm.whoToFollow) ? _c('li', [_vm._v(_vm._s(_vm.$t('features_panel.who_to_follow')))]) : _vm._e(), _vm._v(\" \"), (_vm.mediaProxy) ? _c('li', [_vm._v(_vm._s(_vm.$t('features_panel.media_proxy')))]) : _vm._e(), _vm._v(\" \"), (_vm.scopeOptions) ? _c('li', [_vm._v(_vm._s(_vm.$t('features_panel.scope_options')))]) : _vm._e(), _vm._v(\" \"), _c('li', [_vm._v(_vm._s(_vm.$t('features_panel.text_limit')) + \" = \" + _vm._s(_vm.textlimit))])])])])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-46b7c7a0\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/features_panel/features_panel.vue\n// module id = 701\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', [(_vm.user.id) ? _c('div', {\n staticClass: \"user-profile panel panel-default\"\n }, [_c('UserCard', {\n attrs: {\n \"user\": _vm.user,\n \"switcher\": true,\n \"selected\": _vm.timeline.viewing,\n \"rounded\": \"top\"\n }\n }), _vm._v(\" \"), _c('tab-switcher', {\n ref: \"tabSwitcher\",\n attrs: {\n \"renderOnlyFocused\": true\n }\n }, [_c('Timeline', {\n attrs: {\n \"label\": _vm.$t('user_card.statuses'),\n \"disabled\": !_vm.user.statuses_count,\n \"count\": _vm.user.statuses_count,\n \"embedded\": true,\n \"title\": _vm.$t('user_profile.timeline_title'),\n \"timeline\": _vm.timeline,\n \"timeline-name\": 'user',\n \"user-id\": _vm.fetchBy\n }\n }), _vm._v(\" \"), (_vm.followsTabVisible) ? _c('div', {\n attrs: {\n \"label\": _vm.$t('user_card.followees'),\n \"disabled\": !_vm.user.friends_count\n }\n }, [_c('FriendList', {\n attrs: {\n \"userId\": _vm.userId\n }\n })], 1) : _vm._e(), _vm._v(\" \"), (_vm.followersTabVisible) ? _c('div', {\n attrs: {\n \"label\": _vm.$t('user_card.followers'),\n \"disabled\": !_vm.user.followers_count\n }\n }, [_c('FollowerList', {\n attrs: {\n \"userId\": _vm.userId,\n \"entryProps\": {\n noFollowsYou: _vm.isUs\n }\n }\n })], 1) : _vm._e(), _vm._v(\" \"), _c('Timeline', {\n attrs: {\n \"label\": _vm.$t('user_card.media'),\n \"disabled\": !_vm.media.visibleStatuses.length,\n \"embedded\": true,\n \"title\": _vm.$t('user_card.media'),\n \"timeline-name\": \"media\",\n \"timeline\": _vm.media,\n \"user-id\": _vm.fetchBy\n }\n }), _vm._v(\" \"), (_vm.isUs) ? _c('Timeline', {\n attrs: {\n \"label\": _vm.$t('user_card.favorites'),\n \"disabled\": !_vm.favorites.visibleStatuses.length,\n \"embedded\": true,\n \"title\": _vm.$t('user_card.favorites'),\n \"timeline-name\": \"favorites\",\n \"timeline\": _vm.favorites\n }\n }) : _vm._e()], 1)], 1) : _c('div', {\n staticClass: \"panel user-profile-placeholder\"\n }, [_c('div', {\n staticClass: \"panel-heading\"\n }, [_c('div', {\n staticClass: \"title\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.profile_tab')) + \"\\n \")])]), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-body\"\n }, [(_vm.error) ? _c('span', [_vm._v(_vm._s(_vm.error))]) : _c('i', {\n staticClass: \"icon-spin3 animate-spin\"\n })])])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-48484e40\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/user_profile/user_profile.vue\n// module id = 702\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return (_vm.usePlaceHolder) ? _c('div', {\n on: {\n \"click\": _vm.openModal\n }\n }, [(_vm.type !== 'html') ? _c('a', {\n staticClass: \"placeholder\",\n attrs: {\n \"target\": \"_blank\",\n \"href\": _vm.attachment.url\n }\n }, [_vm._v(\"\\n [\" + _vm._s(_vm.nsfw ? \"NSFW/\" : \"\") + _vm._s(_vm.type.toUpperCase()) + \"]\\n \")]) : _vm._e()]) : _c('div', {\n directives: [{\n name: \"show\",\n rawName: \"v-show\",\n value: (!_vm.isEmpty),\n expression: \"!isEmpty\"\n }],\n staticClass: \"attachment\",\n class: ( _obj = {\n loading: _vm.loading,\n 'fullwidth': _vm.fullwidth,\n 'nsfw-placeholder': _vm.hidden\n }, _obj[_vm.type] = true, _obj )\n }, [(_vm.hidden) ? _c('a', {\n staticClass: \"image-attachment\",\n attrs: {\n \"href\": _vm.attachment.url\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.toggleHidden($event)\n }\n }\n }, [_c('img', {\n key: _vm.nsfwImage,\n staticClass: \"nsfw\",\n class: {\n 'small': _vm.isSmall\n },\n attrs: {\n \"src\": _vm.nsfwImage\n }\n }), _vm._v(\" \"), (_vm.type === 'video') ? _c('i', {\n staticClass: \"play-icon icon-play-circled\"\n }) : _vm._e()]) : _vm._e(), _vm._v(\" \"), (_vm.nsfw && _vm.hideNsfwLocal && !_vm.hidden) ? _c('div', {\n staticClass: \"hider\"\n }, [_c('a', {\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.toggleHidden($event)\n }\n }\n }, [_vm._v(\"Hide\")])]) : _vm._e(), _vm._v(\" \"), (_vm.type === 'image' && (!_vm.hidden || _vm.preloadImage)) ? _c('a', {\n staticClass: \"image-attachment\",\n class: {\n 'hidden': _vm.hidden && _vm.preloadImage\n },\n attrs: {\n \"href\": _vm.attachment.url,\n \"target\": \"_blank\",\n \"title\": _vm.attachment.description\n },\n on: {\n \"click\": _vm.openModal\n }\n }, [_c('StillImage', {\n attrs: {\n \"referrerpolicy\": _vm.referrerpolicy,\n \"mimetype\": _vm.attachment.mimetype,\n \"src\": _vm.attachment.large_thumb_url || _vm.attachment.url\n }\n })], 1) : _vm._e(), _vm._v(\" \"), (_vm.type === 'video' && !_vm.hidden) ? _c('a', {\n staticClass: \"video-container\",\n class: {\n 'small': _vm.isSmall\n },\n attrs: {\n \"href\": _vm.allowPlay ? undefined : _vm.attachment.url\n },\n on: {\n \"click\": _vm.openModal\n }\n }, [_c('VideoAttachment', {\n staticClass: \"video\",\n attrs: {\n \"attachment\": _vm.attachment,\n \"controls\": _vm.allowPlay\n }\n }), _vm._v(\" \"), (!_vm.allowPlay) ? _c('i', {\n staticClass: \"play-icon icon-play-circled\"\n }) : _vm._e()], 1) : _vm._e(), _vm._v(\" \"), (_vm.type === 'audio') ? _c('audio', {\n attrs: {\n \"src\": _vm.attachment.url,\n \"controls\": \"\"\n }\n }) : _vm._e(), _vm._v(\" \"), (_vm.type === 'html' && _vm.attachment.oembed) ? _c('div', {\n staticClass: \"oembed\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.linkClicked($event)\n }\n }\n }, [(_vm.attachment.thumb_url) ? _c('div', {\n staticClass: \"image\"\n }, [_c('img', {\n attrs: {\n \"src\": _vm.attachment.thumb_url\n }\n })]) : _vm._e(), _vm._v(\" \"), _c('div', {\n staticClass: \"text\"\n }, [_c('h1', [_c('a', {\n attrs: {\n \"href\": _vm.attachment.url\n }\n }, [_vm._v(_vm._s(_vm.attachment.oembed.title))])]), _vm._v(\" \"), _c('div', {\n domProps: {\n \"innerHTML\": _vm._s(_vm.attachment.oembed.oembedHTML)\n }\n })])]) : _vm._e()])\n var _obj;\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-48d74080\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/attachment/attachment.vue\n// module id = 703\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"font-control style-control\",\n class: {\n custom: _vm.isCustom\n }\n }, [_c('label', {\n staticClass: \"label\",\n attrs: {\n \"for\": _vm.preset === 'custom' ? _vm.name : _vm.name + '-font-switcher'\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.label) + \"\\n \")]), _vm._v(\" \"), (typeof _vm.fallback !== 'undefined') ? _c('input', {\n staticClass: \"opt exlcude-disabled\",\n attrs: {\n \"type\": \"checkbox\",\n \"id\": _vm.name + '-o'\n },\n domProps: {\n \"checked\": _vm.present\n },\n on: {\n \"input\": function($event) {\n _vm.$emit('input', typeof _vm.value === 'undefined' ? _vm.fallback : undefined)\n }\n }\n }) : _vm._e(), _vm._v(\" \"), (typeof _vm.fallback !== 'undefined') ? _c('label', {\n staticClass: \"opt-l\",\n attrs: {\n \"for\": _vm.name + '-o'\n }\n }) : _vm._e(), _vm._v(\" \"), _c('label', {\n staticClass: \"select\",\n attrs: {\n \"for\": _vm.name + '-font-switcher',\n \"disabled\": !_vm.present\n }\n }, [_c('select', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.preset),\n expression: \"preset\"\n }],\n staticClass: \"font-switcher\",\n attrs: {\n \"disabled\": !_vm.present,\n \"id\": _vm.name + '-font-switcher'\n },\n on: {\n \"change\": function($event) {\n var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n return o.selected\n }).map(function(o) {\n var val = \"_value\" in o ? o._value : o.value;\n return val\n });\n _vm.preset = $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n }\n }\n }, _vm._l((_vm.availableOptions), function(option) {\n return _c('option', {\n domProps: {\n \"value\": option\n }\n }, [_vm._v(\"\\n \" + _vm._s(option === 'custom' ? _vm.$t('settings.style.fonts.custom') : option) + \"\\n \")])\n }), 0), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-down-open\"\n })]), _vm._v(\" \"), (_vm.isCustom) ? _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.family),\n expression: \"family\"\n }],\n staticClass: \"custom-font\",\n attrs: {\n \"type\": \"text\",\n \"id\": _vm.name\n },\n domProps: {\n \"value\": (_vm.family)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.family = $event.target.value\n }\n }\n }) : _vm._e()])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-4bc1e940\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/font_control/font_control.vue\n// module id = 704\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n style: (_vm.bgAppStyle),\n attrs: {\n \"id\": \"app\"\n }\n }, [_c('div', {\n staticClass: \"app-bg-wrapper\",\n style: (_vm.bgStyle)\n }), _vm._v(\" \"), _c('nav', {\n staticClass: \"nav-bar container\",\n attrs: {\n \"id\": \"nav\"\n },\n on: {\n \"click\": function($event) {\n _vm.scrollToTop()\n }\n }\n }, [_c('div', {\n staticClass: \"logo\",\n style: (_vm.logoBgStyle)\n }, [_c('div', {\n staticClass: \"mask\",\n style: (_vm.logoMaskStyle)\n }), _vm._v(\" \"), _c('img', {\n style: (_vm.logoStyle),\n attrs: {\n \"src\": _vm.logo\n }\n })]), _vm._v(\" \"), _c('div', {\n staticClass: \"inner-nav\"\n }, [_c('div', {\n staticClass: \"item\"\n }, [_c('a', {\n staticClass: \"menu-button\",\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.stopPropagation();\n $event.preventDefault();\n _vm.toggleMobileSidebar()\n }\n }\n }, [_c('i', {\n staticClass: \"button-icon icon-menu\"\n }), _vm._v(\" \"), (_vm.unseenNotificationsCount) ? _c('div', {\n staticClass: \"alert-dot\"\n }) : _vm._e()]), _vm._v(\" \"), _c('router-link', {\n staticClass: \"site-name\",\n attrs: {\n \"to\": {\n name: 'root'\n },\n \"active-class\": \"home\"\n }\n }, [_vm._v(_vm._s(_vm.sitename))])], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"item right\"\n }, [_c('user-finder', {\n staticClass: \"button-icon nav-icon mobile-hidden\",\n on: {\n \"toggled\": _vm.onFinderToggled\n }\n }), _vm._v(\" \"), _c('router-link', {\n staticClass: \"mobile-hidden\",\n attrs: {\n \"to\": {\n name: 'settings'\n }\n }\n }, [_c('i', {\n staticClass: \"button-icon icon-cog nav-icon\",\n attrs: {\n \"title\": _vm.$t('nav.preferences')\n }\n })]), _vm._v(\" \"), (_vm.currentUser) ? _c('a', {\n staticClass: \"mobile-hidden\",\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.logout($event)\n }\n }\n }, [_c('i', {\n staticClass: \"button-icon icon-logout nav-icon\",\n attrs: {\n \"title\": _vm.$t('login.logout')\n }\n })]) : _vm._e()], 1)])]), _vm._v(\" \"), _c('div', {\n staticClass: \"container\",\n attrs: {\n \"id\": \"content\"\n }\n }, [_c('side-drawer', {\n ref: \"sideDrawer\",\n attrs: {\n \"logout\": _vm.logout\n }\n }), _vm._v(\" \"), _c('div', {\n staticClass: \"sidebar-flexer mobile-hidden\"\n }, [_c('div', {\n staticClass: \"sidebar-bounds\"\n }, [_c('div', {\n staticClass: \"sidebar-scroller\"\n }, [_c('div', {\n staticClass: \"sidebar\"\n }, [_c('user-panel'), _vm._v(\" \"), _c('nav-panel'), _vm._v(\" \"), (_vm.showInstanceSpecificPanel) ? _c('instance-specific-panel') : _vm._e(), _vm._v(\" \"), (!_vm.currentUser && _vm.showFeaturesPanel) ? _c('features-panel') : _vm._e(), _vm._v(\" \"), (_vm.currentUser && _vm.suggestionsEnabled) ? _c('who-to-follow-panel') : _vm._e(), _vm._v(\" \"), (_vm.currentUser) ? _c('notifications') : _vm._e()], 1)])])]), _vm._v(\" \"), _c('div', {\n staticClass: \"main\"\n }, [(!_vm.currentUser) ? _c('div', {\n staticClass: \"login-hint panel panel-default\"\n }, [_c('router-link', {\n staticClass: \"panel-body\",\n attrs: {\n \"to\": {\n name: 'login'\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"login.hint\")) + \"\\n \")])], 1) : _vm._e(), _vm._v(\" \"), _c('transition', {\n attrs: {\n \"name\": \"fade\"\n }\n }, [_c('router-view')], 1)], 1), _vm._v(\" \"), _c('media-modal')], 1), _vm._v(\" \"), (_vm.currentUser && _vm.chat) ? _c('chat-panel', {\n staticClass: \"floating-chat mobile-hidden\",\n attrs: {\n \"floating\": true\n }\n }) : _vm._e(), _vm._v(\" \"), _c('MobilePostStatusModal')], 1)\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-4c17cd72\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/App.vue\n// module id = 705\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"opacity-control style-control\",\n class: {\n disabled: !_vm.present || _vm.disabled\n }\n }, [_c('label', {\n staticClass: \"label\",\n attrs: {\n \"for\": _vm.name\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.common.opacity')) + \"\\n \")]), _vm._v(\" \"), (typeof _vm.fallback !== 'undefined') ? _c('input', {\n staticClass: \"opt exclude-disabled\",\n attrs: {\n \"id\": _vm.name + '-o',\n \"type\": \"checkbox\"\n },\n domProps: {\n \"checked\": _vm.present\n },\n on: {\n \"input\": function($event) {\n _vm.$emit('input', !_vm.present ? _vm.fallback : undefined)\n }\n }\n }) : _vm._e(), _vm._v(\" \"), (typeof _vm.fallback !== 'undefined') ? _c('label', {\n staticClass: \"opt-l\",\n attrs: {\n \"for\": _vm.name + '-o'\n }\n }) : _vm._e(), _vm._v(\" \"), _c('input', {\n staticClass: \"input-number\",\n attrs: {\n \"id\": _vm.name,\n \"type\": \"number\",\n \"disabled\": !_vm.present || _vm.disabled,\n \"max\": \"1\",\n \"min\": \"0\",\n \"step\": \".05\"\n },\n domProps: {\n \"value\": _vm.value || _vm.fallback\n },\n on: {\n \"input\": function($event) {\n _vm.$emit('input', $event.target.value)\n }\n }\n })])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-4cc8580e\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/opacity_input/opacity_input.vue\n// module id = 706\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"sidebar\"\n }, [_c('instance-specific-panel'), _vm._v(\" \"), (_vm.showFeaturesPanel) ? _c('features-panel') : _vm._e(), _vm._v(\" \"), _c('terms-of-service-panel')], 1)\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-519c4ebc\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/about/about.vue\n// module id = 707\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('video', {\n staticClass: \"video\",\n attrs: {\n \"src\": _vm.attachment.url,\n \"loop\": _vm.loopVideo,\n \"controls\": _vm.controls,\n \"playsinline\": \"\"\n },\n on: {\n \"loadeddata\": _vm.onVideoDataLoad\n }\n })\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-526a5280\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/video_attachment/video_attachment.vue\n// module id = 708\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('basic-user-card', {\n attrs: {\n \"user\": _vm.user\n }\n }, [_c('div', {\n staticClass: \"block-card-content-container\"\n }, [(_vm.blocked) ? _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": _vm.progress\n },\n on: {\n \"click\": _vm.unblockUser\n }\n }, [(_vm.progress) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.unblock_progress')) + \"\\n \")] : [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.unblock')) + \"\\n \")]], 2) : _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": _vm.progress\n },\n on: {\n \"click\": _vm.blockUser\n }\n }, [(_vm.progress) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.block_progress')) + \"\\n \")] : [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.block')) + \"\\n \")]], 2)])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-5370e1c0\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/block_card/block_card.vue\n// module id = 709\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"media-upload\",\n on: {\n \"drop\": [function($event) {\n $event.preventDefault();\n }, _vm.fileDrop],\n \"dragover\": function($event) {\n $event.preventDefault();\n return _vm.fileDrag($event)\n }\n }\n }, [_c('label', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"title\": _vm.$t('tool_tip.media_upload')\n }\n }, [(_vm.uploading) ? _c('i', {\n staticClass: \"icon-spin4 animate-spin\"\n }) : _vm._e(), _vm._v(\" \"), (!_vm.uploading) ? _c('i', {\n staticClass: \"icon-upload\"\n }) : _vm._e(), _vm._v(\" \"), (_vm.uploadReady) ? _c('input', {\n staticStyle: {\n \"position\": \"fixed\",\n \"top\": \"-100em\"\n },\n attrs: {\n \"type\": \"file\",\n \"multiple\": \"true\"\n },\n on: {\n \"change\": _vm.change\n }\n }) : _vm._e()])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-546891a0\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/media_upload/media_upload.vue\n// module id = 710\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return (_vm.showing) ? _c('div', {\n staticClass: \"modal-view media-modal-view\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.hide($event)\n }\n }\n }, [(_vm.type === 'image') ? _c('img', {\n staticClass: \"modal-image\",\n attrs: {\n \"src\": _vm.currentMedia.url\n }\n }) : _vm._e(), _vm._v(\" \"), (_vm.type === 'video') ? _c('VideoAttachment', {\n staticClass: \"modal-image\",\n attrs: {\n \"attachment\": _vm.currentMedia,\n \"controls\": true\n },\n nativeOn: {\n \"click\": function($event) {\n $event.stopPropagation();\n }\n }\n }) : _vm._e(), _vm._v(\" \"), (_vm.canNavigate) ? _c('button', {\n staticClass: \"modal-view-button-arrow modal-view-button-arrow--prev\",\n attrs: {\n \"title\": _vm.$t('media_modal.previous')\n },\n on: {\n \"click\": function($event) {\n $event.stopPropagation();\n $event.preventDefault();\n return _vm.goPrev($event)\n }\n }\n }, [_c('i', {\n staticClass: \"icon-left-open arrow-icon\"\n })]) : _vm._e(), _vm._v(\" \"), (_vm.canNavigate) ? _c('button', {\n staticClass: \"modal-view-button-arrow modal-view-button-arrow--next\",\n attrs: {\n \"title\": _vm.$t('media_modal.next')\n },\n on: {\n \"click\": function($event) {\n $event.stopPropagation();\n $event.preventDefault();\n return _vm.goNext($event)\n }\n }\n }, [_c('i', {\n staticClass: \"icon-right-open arrow-icon\"\n })]) : _vm._e()], 1) : _vm._e()\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-556eb774\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/media_modal/media_modal.vue\n// module id = 711\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('Timeline', {\n attrs: {\n \"title\": _vm.$t('nav.dms'),\n \"timeline\": _vm.timeline,\n \"timeline-name\": 'dms'\n }\n })\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-55994110\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/dm_timeline/dm_timeline.vue\n// module id = 712\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"user-search panel panel-default\"\n }, [_c('div', {\n staticClass: \"panel-heading\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('nav.user_search')) + \"\\n \")]), _vm._v(\" \"), _c('div', {\n staticClass: \"user-search-input-container\"\n }, [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.username),\n expression: \"username\"\n }],\n ref: \"userSearchInput\",\n staticClass: \"user-finder-input\",\n attrs: {\n \"placeholder\": _vm.$t('finder.find_user')\n },\n domProps: {\n \"value\": (_vm.username)\n },\n on: {\n \"keyup\": function($event) {\n if (!('button' in $event) && _vm._k($event.keyCode, \"enter\", 13, $event.key, \"Enter\")) { return null; }\n _vm.newQuery(_vm.username)\n },\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.username = $event.target.value\n }\n }\n }), _vm._v(\" \"), _c('button', {\n staticClass: \"btn search-button\",\n on: {\n \"click\": function($event) {\n _vm.newQuery(_vm.username)\n }\n }\n }, [_c('i', {\n staticClass: \"icon-search\"\n })])]), _vm._v(\" \"), (_vm.loading) ? _c('div', {\n staticClass: \"text-center loading-icon\"\n }, [_c('i', {\n staticClass: \"icon-spin3 animate-spin\"\n })]) : _c('div', {\n staticClass: \"panel-body\"\n }, _vm._l((_vm.users), function(user) {\n return _c('FollowCard', {\n key: user.id,\n attrs: {\n \"user\": user\n }\n })\n }), 1)])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-5e33ef5a\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/user_search/user_search.vue\n// module id = 713\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('Timeline', {\n attrs: {\n \"title\": _vm.$t('nav.public_tl'),\n \"timeline\": _vm.timeline,\n \"timeline-name\": 'public'\n }\n })\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-63335050\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/public_timeline/public_timeline.vue\n// module id = 714\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"range-control style-control\",\n class: {\n disabled: !_vm.present || _vm.disabled\n }\n }, [_c('label', {\n staticClass: \"label\",\n attrs: {\n \"for\": _vm.name\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.label) + \"\\n \")]), _vm._v(\" \"), (typeof _vm.fallback !== 'undefined') ? _c('input', {\n staticClass: \"opt exclude-disabled\",\n attrs: {\n \"id\": _vm.name + '-o',\n \"type\": \"checkbox\"\n },\n domProps: {\n \"checked\": _vm.present\n },\n on: {\n \"input\": function($event) {\n _vm.$emit('input', !_vm.present ? _vm.fallback : undefined)\n }\n }\n }) : _vm._e(), _vm._v(\" \"), (typeof _vm.fallback !== 'undefined') ? _c('label', {\n staticClass: \"opt-l\",\n attrs: {\n \"for\": _vm.name + '-o'\n }\n }) : _vm._e(), _vm._v(\" \"), _c('input', {\n staticClass: \"input-number\",\n attrs: {\n \"id\": _vm.name,\n \"type\": \"range\",\n \"disabled\": !_vm.present || _vm.disabled,\n \"max\": _vm.max || _vm.hardMax || 100,\n \"min\": _vm.min || _vm.hardMin || 0,\n \"step\": _vm.step || 1\n },\n domProps: {\n \"value\": _vm.value || _vm.fallback\n },\n on: {\n \"input\": function($event) {\n _vm.$emit('input', $event.target.value)\n }\n }\n }), _vm._v(\" \"), _c('input', {\n staticClass: \"input-number\",\n attrs: {\n \"id\": _vm.name,\n \"type\": \"number\",\n \"disabled\": !_vm.present || _vm.disabled,\n \"max\": _vm.hardMax,\n \"min\": _vm.hardMin,\n \"step\": _vm.step || 1\n },\n domProps: {\n \"value\": _vm.value || _vm.fallback\n },\n on: {\n \"input\": function($event) {\n _vm.$emit('input', $event.target.value)\n }\n }\n })])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-6553acb2\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/range_input/range_input.vue\n// module id = 715\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"basic-user-card\"\n }, [_c('router-link', {\n attrs: {\n \"to\": _vm.userProfileLink(_vm.user)\n }\n }, [_c('UserAvatar', {\n staticClass: \"avatar\",\n attrs: {\n \"src\": _vm.user.profile_image_url\n },\n nativeOn: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.toggleUserExpanded($event)\n }\n }\n })], 1), _vm._v(\" \"), (_vm.userExpanded) ? _c('div', {\n staticClass: \"basic-user-card-expanded-content\"\n }, [_c('UserCard', {\n attrs: {\n \"user\": _vm.user,\n \"rounded\": true,\n \"bordered\": true\n }\n })], 1) : _c('div', {\n staticClass: \"basic-user-card-collapsed-content\"\n }, [_c('div', {\n staticClass: \"basic-user-card-user-name\",\n attrs: {\n \"title\": _vm.user.name\n }\n }, [(_vm.user.name_html) ? _c('span', {\n domProps: {\n \"innerHTML\": _vm._s(_vm.user.name_html)\n }\n }) : _c('span', [_vm._v(_vm._s(_vm.user.name))])]), _vm._v(\" \"), _c('div', [_c('router-link', {\n staticClass: \"basic-user-card-screen-name\",\n attrs: {\n \"to\": _vm.userProfileLink(_vm.user)\n }\n }, [_vm._v(\"\\n @\" + _vm._s(_vm.user.screen_name) + \"\\n \")])], 1), _vm._v(\" \"), _vm._t(\"default\")], 2)], 1)\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-67fc4208\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/basic_user_card/basic_user_card.vue\n// module id = 716\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return (_vm.notification.type === 'mention') ? _c('status', {\n attrs: {\n \"compact\": true,\n \"statusoid\": _vm.notification.status\n }\n }) : _c('div', {\n staticClass: \"non-mention\",\n class: [_vm.userClass, {\n highlighted: _vm.userStyle\n }],\n style: ([_vm.userStyle])\n }, [_c('a', {\n staticClass: \"avatar-container\",\n attrs: {\n \"href\": _vm.notification.action.user.statusnet_profile_url\n },\n on: {\n \"!click\": function($event) {\n $event.stopPropagation();\n $event.preventDefault();\n return _vm.toggleUserExpanded($event)\n }\n }\n }, [_c('UserAvatar', {\n attrs: {\n \"compact\": true,\n \"betterShadow\": _vm.betterShadow,\n \"src\": _vm.notification.action.user.profile_image_url_original\n }\n })], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"notification-right\"\n }, [(_vm.userExpanded) ? _c('UserCard', {\n attrs: {\n \"user\": _vm.notification.action.user,\n \"rounded\": true,\n \"bordered\": true\n }\n }) : _vm._e(), _vm._v(\" \"), _c('span', {\n staticClass: \"notification-details\"\n }, [_c('div', {\n staticClass: \"name-and-action\"\n }, [(!!_vm.notification.action.user.name_html) ? _c('span', {\n staticClass: \"username\",\n attrs: {\n \"title\": '@' + _vm.notification.action.user.screen_name\n },\n domProps: {\n \"innerHTML\": _vm._s(_vm.notification.action.user.name_html)\n }\n }) : _c('span', {\n staticClass: \"username\",\n attrs: {\n \"title\": '@' + _vm.notification.action.user.screen_name\n }\n }, [_vm._v(_vm._s(_vm.notification.action.user.name))]), _vm._v(\" \"), (_vm.notification.type === 'like') ? _c('span', [_c('i', {\n staticClass: \"fa icon-star lit\"\n }), _vm._v(\" \"), _c('small', [_vm._v(_vm._s(_vm.$t('notifications.favorited_you')))])]) : _vm._e(), _vm._v(\" \"), (_vm.notification.type === 'repeat') ? _c('span', [_c('i', {\n staticClass: \"fa icon-retweet lit\",\n attrs: {\n \"title\": _vm.$t('tool_tip.repeat')\n }\n }), _vm._v(\" \"), _c('small', [_vm._v(_vm._s(_vm.$t('notifications.repeated_you')))])]) : _vm._e(), _vm._v(\" \"), (_vm.notification.type === 'follow') ? _c('span', [_c('i', {\n staticClass: \"fa icon-user-plus lit\"\n }), _vm._v(\" \"), _c('small', [_vm._v(_vm._s(_vm.$t('notifications.followed_you')))])]) : _vm._e()]), _vm._v(\" \"), _c('div', {\n staticClass: \"timeago\"\n }, [(_vm.notification.status) ? _c('router-link', {\n staticClass: \"faint-link\",\n attrs: {\n \"to\": {\n name: 'conversation',\n params: {\n id: _vm.notification.status.id\n }\n }\n }\n }, [_c('timeago', {\n attrs: {\n \"since\": _vm.notification.action.created_at,\n \"auto-update\": 240\n }\n })], 1) : _vm._e()], 1)]), _vm._v(\" \"), (_vm.notification.type === 'follow') ? _c('div', {\n staticClass: \"follow-text\"\n }, [_c('router-link', {\n attrs: {\n \"to\": _vm.userProfileLink(_vm.notification.action.user)\n }\n }, [_vm._v(\"\\n @\" + _vm._s(_vm.notification.action.user.screen_name) + \"\\n \")])], 1) : [_c('status', {\n staticClass: \"faint\",\n attrs: {\n \"compact\": true,\n \"statusoid\": _vm.notification.status,\n \"noHeading\": true\n }\n })]], 2)])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-68f32600\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/notification/notification.vue\n// module id = 717\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"side-drawer-container\",\n class: {\n 'side-drawer-container-closed': _vm.closed, 'side-drawer-container-open': !_vm.closed\n }\n }, [_c('div', {\n staticClass: \"side-drawer\",\n class: {\n 'side-drawer-closed': _vm.closed\n },\n on: {\n \"touchstart\": _vm.touchStart,\n \"touchmove\": _vm.touchMove\n }\n }, [_c('div', {\n staticClass: \"side-drawer-heading\",\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [(_vm.currentUser) ? _c('UserCard', {\n attrs: {\n \"user\": _vm.currentUser,\n \"hideBio\": true\n }\n }) : _c('div', {\n staticClass: \"side-drawer-logo-wrapper\"\n }, [_c('img', {\n attrs: {\n \"src\": _vm.logo\n }\n }), _vm._v(\" \"), _c('span', [_vm._v(_vm._s(_vm.sitename))])])], 1), _vm._v(\" \"), _c('ul', [(!_vm.currentUser) ? _c('li', {\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'login'\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"login.login\")) + \"\\n \")])], 1) : _vm._e(), _vm._v(\" \"), (_vm.currentUser) ? _c('li', {\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'notifications',\n params: {\n username: _vm.currentUser.screen_name\n }\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"notifications.notifications\")) + \" \" + _vm._s(_vm.unseenNotificationsCount > 0 ? (\"(\" + _vm.unseenNotificationsCount + \")\") : '') + \"\\n \")])], 1) : _vm._e(), _vm._v(\" \"), (_vm.currentUser) ? _c('li', {\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'dms',\n params: {\n username: _vm.currentUser.screen_name\n }\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.dms\")) + \"\\n \")])], 1) : _vm._e()]), _vm._v(\" \"), _c('ul', [(_vm.currentUser) ? _c('li', {\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'friends'\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.timeline\")) + \"\\n \")])], 1) : _vm._e(), _vm._v(\" \"), (_vm.currentUser && _vm.currentUser.locked) ? _c('li', {\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [_c('router-link', {\n attrs: {\n \"to\": \"/friend-requests\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.friend_requests\")) + \"\\n \"), (_vm.followRequestCount > 0) ? _c('span', {\n staticClass: \"badge follow-request-count\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.followRequestCount) + \"\\n \")]) : _vm._e()])], 1) : _vm._e(), _vm._v(\" \"), _c('li', {\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [_c('router-link', {\n attrs: {\n \"to\": \"/main/public\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.public_tl\")) + \"\\n \")])], 1), _vm._v(\" \"), _c('li', {\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [_c('router-link', {\n attrs: {\n \"to\": \"/main/all\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.twkn\")) + \"\\n \")])], 1), _vm._v(\" \"), (_vm.currentUser && _vm.chat) ? _c('li', {\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'chat'\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.chat\")) + \"\\n \")])], 1) : _vm._e()]), _vm._v(\" \"), _c('ul', [_c('li', {\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'user-search'\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.user_search\")) + \"\\n \")])], 1), _vm._v(\" \"), (_vm.currentUser && _vm.suggestionsEnabled) ? _c('li', {\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'who-to-follow'\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.who_to_follow\")) + \"\\n \")])], 1) : _vm._e(), _vm._v(\" \"), _c('li', {\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'settings'\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"settings.settings\")) + \"\\n \")])], 1), _vm._v(\" \"), _c('li', {\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'about'\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.about\")) + \"\\n \")])], 1), _vm._v(\" \"), (_vm.currentUser) ? _c('li', {\n on: {\n \"click\": _vm.toggleDrawer\n }\n }, [_c('a', {\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": _vm.doLogout\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"login.logout\")) + \"\\n \")])]) : _vm._e()])]), _vm._v(\" \"), _c('div', {\n staticClass: \"side-drawer-click-outside\",\n class: {\n 'side-drawer-click-outside-closed': _vm.closed\n },\n on: {\n \"click\": function($event) {\n $event.stopPropagation();\n $event.preventDefault();\n return _vm.toggleDrawer($event)\n }\n }\n })])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-69918754\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/side_drawer/side_drawer.vue\n// module id = 718\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"shadow-control\",\n class: {\n disabled: !_vm.present\n }\n }, [_c('div', {\n staticClass: \"shadow-preview-container\"\n }, [_c('div', {\n staticClass: \"y-shift-control\",\n attrs: {\n \"disabled\": !_vm.present\n }\n }, [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.selected.y),\n expression: \"selected.y\"\n }],\n staticClass: \"input-number\",\n attrs: {\n \"disabled\": !_vm.present,\n \"type\": \"number\"\n },\n domProps: {\n \"value\": (_vm.selected.y)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.selected, \"y\", $event.target.value)\n }\n }\n }), _vm._v(\" \"), _c('div', {\n staticClass: \"wrap\"\n }, [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.selected.y),\n expression: \"selected.y\"\n }],\n staticClass: \"input-range\",\n attrs: {\n \"disabled\": !_vm.present,\n \"type\": \"range\",\n \"max\": \"20\",\n \"min\": \"-20\"\n },\n domProps: {\n \"value\": (_vm.selected.y)\n },\n on: {\n \"__r\": function($event) {\n _vm.$set(_vm.selected, \"y\", $event.target.value)\n }\n }\n })])]), _vm._v(\" \"), _c('div', {\n staticClass: \"preview-window\"\n }, [_c('div', {\n staticClass: \"preview-block\",\n style: (_vm.style)\n })]), _vm._v(\" \"), _c('div', {\n staticClass: \"x-shift-control\",\n attrs: {\n \"disabled\": !_vm.present\n }\n }, [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.selected.x),\n expression: \"selected.x\"\n }],\n staticClass: \"input-number\",\n attrs: {\n \"disabled\": !_vm.present,\n \"type\": \"number\"\n },\n domProps: {\n \"value\": (_vm.selected.x)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.selected, \"x\", $event.target.value)\n }\n }\n }), _vm._v(\" \"), _c('div', {\n staticClass: \"wrap\"\n }, [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.selected.x),\n expression: \"selected.x\"\n }],\n staticClass: \"input-range\",\n attrs: {\n \"disabled\": !_vm.present,\n \"type\": \"range\",\n \"max\": \"20\",\n \"min\": \"-20\"\n },\n domProps: {\n \"value\": (_vm.selected.x)\n },\n on: {\n \"__r\": function($event) {\n _vm.$set(_vm.selected, \"x\", $event.target.value)\n }\n }\n })])])]), _vm._v(\" \"), _c('div', {\n staticClass: \"shadow-tweak\"\n }, [_c('div', {\n staticClass: \"id-control style-control\",\n attrs: {\n \"disabled\": _vm.usingFallback\n }\n }, [_c('label', {\n staticClass: \"select\",\n attrs: {\n \"for\": \"shadow-switcher\",\n \"disabled\": !_vm.ready || _vm.usingFallback\n }\n }, [_c('select', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.selectedId),\n expression: \"selectedId\"\n }],\n staticClass: \"shadow-switcher\",\n attrs: {\n \"disabled\": !_vm.ready || _vm.usingFallback,\n \"id\": \"shadow-switcher\"\n },\n on: {\n \"change\": function($event) {\n var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n return o.selected\n }).map(function(o) {\n var val = \"_value\" in o ? o._value : o.value;\n return val\n });\n _vm.selectedId = $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n }\n }\n }, _vm._l((_vm.cValue), function(shadow, index) {\n return _c('option', {\n domProps: {\n \"value\": index\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.shadows.shadow_id', {\n value: index\n })) + \"\\n \")])\n }), 0), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-down-open\"\n })]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": !_vm.ready || !_vm.present\n },\n on: {\n \"click\": _vm.del\n }\n }, [_c('i', {\n staticClass: \"icon-cancel\"\n })]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": !_vm.moveUpValid\n },\n on: {\n \"click\": _vm.moveUp\n }\n }, [_c('i', {\n staticClass: \"icon-up-open\"\n })]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": !_vm.moveDnValid\n },\n on: {\n \"click\": _vm.moveDn\n }\n }, [_c('i', {\n staticClass: \"icon-down-open\"\n })]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": _vm.usingFallback\n },\n on: {\n \"click\": _vm.add\n }\n }, [_c('i', {\n staticClass: \"icon-plus\"\n })])]), _vm._v(\" \"), _c('div', {\n staticClass: \"inset-control style-control\",\n attrs: {\n \"disabled\": !_vm.present\n }\n }, [_c('label', {\n staticClass: \"label\",\n attrs: {\n \"for\": \"inset\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.shadows.inset')) + \"\\n \")]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.selected.inset),\n expression: \"selected.inset\"\n }],\n staticClass: \"input-inset\",\n attrs: {\n \"disabled\": !_vm.present,\n \"name\": \"inset\",\n \"id\": \"inset\",\n \"type\": \"checkbox\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.selected.inset) ? _vm._i(_vm.selected.inset, null) > -1 : (_vm.selected.inset)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.selected.inset,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.$set(_vm.selected, \"inset\", $$a.concat([$$v])))\n } else {\n $$i > -1 && (_vm.$set(_vm.selected, \"inset\", $$a.slice(0, $$i).concat($$a.slice($$i + 1))))\n }\n } else {\n _vm.$set(_vm.selected, \"inset\", $$c)\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n staticClass: \"checkbox-label\",\n attrs: {\n \"for\": \"inset\"\n }\n })]), _vm._v(\" \"), _c('div', {\n staticClass: \"blur-control style-control\",\n attrs: {\n \"disabled\": !_vm.present\n }\n }, [_c('label', {\n staticClass: \"label\",\n attrs: {\n \"for\": \"spread\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.shadows.blur')) + \"\\n \")]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.selected.blur),\n expression: \"selected.blur\"\n }],\n staticClass: \"input-range\",\n attrs: {\n \"disabled\": !_vm.present,\n \"name\": \"blur\",\n \"id\": \"blur\",\n \"type\": \"range\",\n \"max\": \"20\",\n \"min\": \"0\"\n },\n domProps: {\n \"value\": (_vm.selected.blur)\n },\n on: {\n \"__r\": function($event) {\n _vm.$set(_vm.selected, \"blur\", $event.target.value)\n }\n }\n }), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.selected.blur),\n expression: \"selected.blur\"\n }],\n staticClass: \"input-number\",\n attrs: {\n \"disabled\": !_vm.present,\n \"type\": \"number\",\n \"min\": \"0\"\n },\n domProps: {\n \"value\": (_vm.selected.blur)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.selected, \"blur\", $event.target.value)\n }\n }\n })]), _vm._v(\" \"), _c('div', {\n staticClass: \"spread-control style-control\",\n attrs: {\n \"disabled\": !_vm.present\n }\n }, [_c('label', {\n staticClass: \"label\",\n attrs: {\n \"for\": \"spread\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.shadows.spread')) + \"\\n \")]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.selected.spread),\n expression: \"selected.spread\"\n }],\n staticClass: \"input-range\",\n attrs: {\n \"disabled\": !_vm.present,\n \"name\": \"spread\",\n \"id\": \"spread\",\n \"type\": \"range\",\n \"max\": \"20\",\n \"min\": \"-20\"\n },\n domProps: {\n \"value\": (_vm.selected.spread)\n },\n on: {\n \"__r\": function($event) {\n _vm.$set(_vm.selected, \"spread\", $event.target.value)\n }\n }\n }), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.selected.spread),\n expression: \"selected.spread\"\n }],\n staticClass: \"input-number\",\n attrs: {\n \"disabled\": !_vm.present,\n \"type\": \"number\"\n },\n domProps: {\n \"value\": (_vm.selected.spread)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.selected, \"spread\", $event.target.value)\n }\n }\n })]), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"disabled\": !_vm.present,\n \"label\": _vm.$t('settings.style.common.color'),\n \"name\": \"shadow\"\n },\n model: {\n value: (_vm.selected.color),\n callback: function($$v) {\n _vm.$set(_vm.selected, \"color\", $$v)\n },\n expression: \"selected.color\"\n }\n }), _vm._v(\" \"), _c('OpacityInput', {\n attrs: {\n \"disabled\": !_vm.present\n },\n model: {\n value: (_vm.selected.alpha),\n callback: function($$v) {\n _vm.$set(_vm.selected, \"alpha\", $$v)\n },\n expression: \"selected.alpha\"\n }\n }), _vm._v(\" \"), _c('p', [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.shadows.hint')) + \"\\n \")])], 1)])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-6a1c4fc0\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/shadow_control/shadow_control.vue\n// module id = 719\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('conversation', {\n attrs: {\n \"collapsable\": false,\n \"statusoid\": _vm.statusoid\n }\n })\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-6d354bd4\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/conversation-page/conversation-page.vue\n// module id = 720\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"still-image\",\n class: {\n animated: _vm.animated\n }\n }, [(_vm.animated) ? _c('canvas', {\n ref: \"canvas\"\n }) : _vm._e(), _vm._v(\" \"), _c('img', {\n ref: \"src\",\n attrs: {\n \"src\": _vm.src,\n \"referrerpolicy\": _vm.referrerpolicy\n },\n on: {\n \"load\": _vm.onLoad,\n \"error\": _vm.onError\n }\n })])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-6ecb31e4\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/still-image/still-image.vue\n// module id = 721\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', [_c('a', {\n staticClass: \"link-preview-card\",\n attrs: {\n \"href\": _vm.card.url,\n \"target\": \"_blank\",\n \"rel\": \"noopener\"\n }\n }, [(_vm.useImage) ? _c('div', {\n staticClass: \"card-image\",\n class: {\n 'small-image': _vm.size === 'small'\n }\n }, [_c('img', {\n attrs: {\n \"src\": _vm.card.image\n }\n })]) : _vm._e(), _vm._v(\" \"), _c('div', {\n staticClass: \"card-content\"\n }, [_c('span', {\n staticClass: \"card-host faint\"\n }, [_vm._v(_vm._s(_vm.card.provider_name))]), _vm._v(\" \"), _c('h4', {\n staticClass: \"card-title\"\n }, [_vm._v(_vm._s(_vm.card.title))]), _vm._v(\" \"), (_vm.useDescription) ? _c('p', {\n staticClass: \"card-description\"\n }, [_vm._v(_vm._s(_vm.card.description))]) : _vm._e()])])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-6efb6640\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/link-preview/link-preview.vue\n// module id = 722\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"color-control style-control\",\n class: {\n disabled: !_vm.present || _vm.disabled\n }\n }, [_c('label', {\n staticClass: \"label\",\n attrs: {\n \"for\": _vm.name\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.label) + \"\\n \")]), _vm._v(\" \"), (typeof _vm.fallback !== 'undefined') ? _c('input', {\n staticClass: \"opt exlcude-disabled\",\n attrs: {\n \"id\": _vm.name + '-o',\n \"type\": \"checkbox\"\n },\n domProps: {\n \"checked\": _vm.present\n },\n on: {\n \"input\": function($event) {\n _vm.$emit('input', typeof _vm.value === 'undefined' ? _vm.fallback : undefined)\n }\n }\n }) : _vm._e(), _vm._v(\" \"), (typeof _vm.fallback !== 'undefined') ? _c('label', {\n staticClass: \"opt-l\",\n attrs: {\n \"for\": _vm.name + '-o'\n }\n }) : _vm._e(), _vm._v(\" \"), _c('input', {\n staticClass: \"color-input\",\n attrs: {\n \"id\": _vm.name,\n \"type\": \"color\",\n \"disabled\": !_vm.present || _vm.disabled\n },\n domProps: {\n \"value\": _vm.value || _vm.fallback\n },\n on: {\n \"input\": function($event) {\n _vm.$emit('input', $event.target.value)\n }\n }\n }), _vm._v(\" \"), _c('input', {\n staticClass: \"text-input\",\n attrs: {\n \"id\": _vm.name + '-t',\n \"type\": \"text\",\n \"disabled\": !_vm.present || _vm.disabled\n },\n domProps: {\n \"value\": _vm.value || _vm.fallback\n },\n on: {\n \"input\": function($event) {\n _vm.$emit('input', $event.target.value)\n }\n }\n })])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-73de3e04\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/color_input/color_input.vue\n// module id = 723\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return (!_vm.hideStatus) ? _c('div', {\n staticClass: \"status-el\",\n class: [{\n 'status-el_focused': _vm.isFocused\n }, {\n 'status-conversation': _vm.inlineExpanded\n }]\n }, [(_vm.muted && !_vm.isPreview) ? [_c('div', {\n staticClass: \"media status container muted\"\n }, [_c('small', [_c('router-link', {\n attrs: {\n \"to\": _vm.userProfileLink\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.status.user.screen_name) + \"\\n \")])], 1), _vm._v(\" \"), _c('small', {\n staticClass: \"muteWords\"\n }, [_vm._v(_vm._s(_vm.muteWordHits.join(', ')))]), _vm._v(\" \"), _c('a', {\n staticClass: \"unmute\",\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.toggleMute($event)\n }\n }\n }, [_c('i', {\n staticClass: \"button-icon icon-eye-off\"\n })])])] : [(_vm.retweet && !_vm.noHeading) ? _c('div', {\n staticClass: \"media container retweet-info\",\n class: [_vm.repeaterClass, {\n highlighted: _vm.repeaterStyle\n }],\n style: ([_vm.repeaterStyle])\n }, [(_vm.retweet) ? _c('UserAvatar', {\n staticClass: \"media-left\",\n attrs: {\n \"betterShadow\": _vm.betterShadow,\n \"src\": _vm.statusoid.user.profile_image_url_original\n }\n }) : _vm._e(), _vm._v(\" \"), _c('div', {\n staticClass: \"media-body faint\"\n }, [_c('span', {\n staticClass: \"user-name\"\n }, [(_vm.retweeterHtml) ? _c('router-link', {\n attrs: {\n \"to\": _vm.retweeterProfileLink\n },\n domProps: {\n \"innerHTML\": _vm._s(_vm.retweeterHtml)\n }\n }) : _c('router-link', {\n attrs: {\n \"to\": _vm.retweeterProfileLink\n }\n }, [_vm._v(_vm._s(_vm.retweeter))])], 1), _vm._v(\" \"), _c('i', {\n staticClass: \"fa icon-retweet retweeted\",\n attrs: {\n \"title\": _vm.$t('tool_tip.repeat')\n }\n }), _vm._v(\"\\n \" + _vm._s(_vm.$t('timeline.repeated')) + \"\\n \")])], 1) : _vm._e(), _vm._v(\" \"), _c('div', {\n staticClass: \"media status\",\n class: [_vm.userClass, {\n highlighted: _vm.userStyle,\n 'is-retweet': _vm.retweet\n }],\n style: ([_vm.userStyle])\n }, [(!_vm.noHeading) ? _c('div', {\n staticClass: \"media-left\"\n }, [_c('router-link', {\n attrs: {\n \"to\": _vm.userProfileLink\n },\n nativeOn: {\n \"!click\": function($event) {\n $event.stopPropagation();\n $event.preventDefault();\n return _vm.toggleUserExpanded($event)\n }\n }\n }, [_c('UserAvatar', {\n attrs: {\n \"compact\": _vm.compact,\n \"betterShadow\": _vm.betterShadow,\n \"src\": _vm.status.user.profile_image_url_original\n }\n })], 1)], 1) : _vm._e(), _vm._v(\" \"), _c('div', {\n staticClass: \"status-body\"\n }, [(_vm.userExpanded) ? _c('UserCard', {\n staticClass: \"status-usercard\",\n attrs: {\n \"user\": _vm.status.user,\n \"rounded\": true,\n \"bordered\": true\n }\n }) : _vm._e(), _vm._v(\" \"), (!_vm.noHeading) ? _c('div', {\n staticClass: \"media-heading\"\n }, [_c('div', {\n staticClass: \"heading-name-row\"\n }, [_c('div', {\n staticClass: \"name-and-account-name\"\n }, [(_vm.status.user.name_html) ? _c('h4', {\n staticClass: \"user-name\",\n domProps: {\n \"innerHTML\": _vm._s(_vm.status.user.name_html)\n }\n }) : _c('h4', {\n staticClass: \"user-name\"\n }, [_vm._v(_vm._s(_vm.status.user.name))]), _vm._v(\" \"), _c('router-link', {\n staticClass: \"account-name\",\n attrs: {\n \"to\": _vm.userProfileLink\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.status.user.screen_name) + \"\\n \")])], 1), _vm._v(\" \"), _c('span', {\n staticClass: \"heading-right\"\n }, [_c('router-link', {\n staticClass: \"timeago faint-link\",\n attrs: {\n \"to\": {\n name: 'conversation',\n params: {\n id: _vm.status.id\n }\n }\n }\n }, [_c('timeago', {\n attrs: {\n \"since\": _vm.status.created_at,\n \"auto-update\": 60\n }\n })], 1), _vm._v(\" \"), (_vm.status.visibility) ? _c('div', {\n staticClass: \"button-icon visibility-icon\"\n }, [_c('i', {\n class: _vm.visibilityIcon(_vm.status.visibility),\n attrs: {\n \"title\": _vm._f(\"capitalize\")(_vm.status.visibility)\n }\n })]) : _vm._e(), _vm._v(\" \"), (!_vm.status.is_local && !_vm.isPreview) ? _c('a', {\n staticClass: \"source_url\",\n attrs: {\n \"href\": _vm.status.external_url,\n \"target\": \"_blank\",\n \"title\": \"Source\"\n }\n }, [_c('i', {\n staticClass: \"button-icon icon-link-ext-alt\"\n })]) : _vm._e(), _vm._v(\" \"), (_vm.expandable && !_vm.isPreview) ? [_c('a', {\n attrs: {\n \"href\": \"#\",\n \"title\": \"Expand\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.toggleExpanded($event)\n }\n }\n }, [_c('i', {\n staticClass: \"button-icon icon-plus-squared\"\n })])] : _vm._e(), _vm._v(\" \"), (_vm.unmuted) ? _c('a', {\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.toggleMute($event)\n }\n }\n }, [_c('i', {\n staticClass: \"button-icon icon-eye-off\"\n })]) : _vm._e()], 2)]), _vm._v(\" \"), _c('div', {\n staticClass: \"heading-reply-row\"\n }, [(_vm.isReply) ? _c('div', {\n staticClass: \"reply-to-and-accountname\"\n }, [_c('a', {\n staticClass: \"reply-to\",\n attrs: {\n \"href\": \"#\",\n \"aria-label\": _vm.$t('tool_tip.reply')\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n _vm.gotoOriginal(_vm.status.in_reply_to_status_id)\n },\n \"mouseenter\": function($event) {\n $event.preventDefault();\n $event.stopPropagation();\n _vm.replyEnter(_vm.status.in_reply_to_status_id, $event)\n },\n \"mouseleave\": function($event) {\n $event.preventDefault();\n $event.stopPropagation();\n _vm.replyLeave()\n }\n }\n }, [(!_vm.isPreview) ? _c('i', {\n staticClass: \"button-icon icon-reply\"\n }) : _vm._e(), _vm._v(\" \"), _c('span', {\n staticClass: \"faint-link reply-to-text\"\n }, [_vm._v(_vm._s(_vm.$t('status.reply_to')))])]), _vm._v(\" \"), _c('router-link', {\n attrs: {\n \"to\": _vm.replyProfileLink\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.replyToName) + \"\\n \")]), _vm._v(\" \"), (_vm.replies && _vm.replies.length) ? _c('span', {\n staticClass: \"faint replies-separator\"\n }, [_vm._v(\"\\n -\\n \")]) : _vm._e()], 1) : _vm._e(), _vm._v(\" \"), (_vm.inConversation && !_vm.isPreview) ? _c('div', {\n staticClass: \"replies\"\n }, [(_vm.replies && _vm.replies.length) ? _c('span', {\n staticClass: \"faint\"\n }, [_vm._v(_vm._s(_vm.$t('status.replies_list')))]) : _vm._e(), _vm._v(\" \"), _vm._l((_vm.replies), function(reply) {\n return (_vm.replies) ? _c('span', {\n staticClass: \"reply-link faint\"\n }, [_c('a', {\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n _vm.gotoOriginal(reply.id)\n },\n \"mouseenter\": function($event) {\n _vm.replyEnter(reply.id, $event)\n },\n \"mouseout\": function($event) {\n _vm.replyLeave()\n }\n }\n }, [_vm._v(_vm._s(reply.name))])]) : _vm._e()\n })], 2) : _vm._e()])]) : _vm._e(), _vm._v(\" \"), (_vm.showPreview) ? _c('div', {\n staticClass: \"status-preview-container\"\n }, [(_vm.preview) ? _c('status', {\n staticClass: \"status-preview\",\n attrs: {\n \"isPreview\": true,\n \"statusoid\": _vm.preview,\n \"compact\": true\n }\n }) : _c('div', {\n staticClass: \"status-preview status-preview-loading\"\n }, [_c('i', {\n staticClass: \"icon-spin4 animate-spin\"\n })])], 1) : _vm._e(), _vm._v(\" \"), (_vm.longSubject) ? _c('div', {\n staticClass: \"status-content-wrapper\",\n class: {\n 'tall-status': !_vm.showingLongSubject\n }\n }, [(!_vm.showingLongSubject) ? _c('a', {\n staticClass: \"tall-status-hider\",\n class: {\n 'tall-status-hider_focused': _vm.isFocused\n },\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n _vm.showingLongSubject = true\n }\n }\n }, [_vm._v(\"Show more\")]) : _vm._e(), _vm._v(\" \"), _c('div', {\n staticClass: \"status-content media-body\",\n domProps: {\n \"innerHTML\": _vm._s(_vm.status.statusnet_html)\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.linkClicked($event)\n }\n }\n }), _vm._v(\" \"), (_vm.showingLongSubject) ? _c('a', {\n staticClass: \"status-unhider\",\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n _vm.showingLongSubject = false\n }\n }\n }, [_vm._v(\"Show less\")]) : _vm._e()]) : _c('div', {\n staticClass: \"status-content-wrapper\",\n class: {\n 'tall-status': _vm.hideTallStatus\n }\n }, [(_vm.hideTallStatus) ? _c('a', {\n staticClass: \"tall-status-hider\",\n class: {\n 'tall-status-hider_focused': _vm.isFocused\n },\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.toggleShowMore($event)\n }\n }\n }, [_vm._v(\"Show more\")]) : _vm._e(), _vm._v(\" \"), (!_vm.hideSubjectStatus) ? _c('div', {\n staticClass: \"status-content media-body\",\n domProps: {\n \"innerHTML\": _vm._s(_vm.status.statusnet_html)\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.linkClicked($event)\n }\n }\n }) : _c('div', {\n staticClass: \"status-content media-body\",\n domProps: {\n \"innerHTML\": _vm._s(_vm.status.summary_html)\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.linkClicked($event)\n }\n }\n }), _vm._v(\" \"), (_vm.hideSubjectStatus) ? _c('a', {\n staticClass: \"cw-status-hider\",\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.toggleShowMore($event)\n }\n }\n }, [_vm._v(\"Show more\")]) : _vm._e(), _vm._v(\" \"), (_vm.showingMore) ? _c('a', {\n staticClass: \"status-unhider\",\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.toggleShowMore($event)\n }\n }\n }, [_vm._v(\"Show less\")]) : _vm._e()]), _vm._v(\" \"), (_vm.status.attachments && (!_vm.hideSubjectStatus || _vm.showingLongSubject)) ? _c('div', {\n staticClass: \"attachments media-body\"\n }, [_vm._l((_vm.nonGalleryAttachments), function(attachment) {\n return _c('attachment', {\n key: attachment.id,\n staticClass: \"non-gallery\",\n attrs: {\n \"size\": _vm.attachmentSize,\n \"nsfw\": _vm.nsfwClickthrough,\n \"attachment\": attachment,\n \"allowPlay\": true,\n \"setMedia\": _vm.setMedia()\n }\n })\n }), _vm._v(\" \"), (_vm.galleryAttachments.length > 0) ? _c('gallery', {\n attrs: {\n \"nsfw\": _vm.nsfwClickthrough,\n \"attachments\": _vm.galleryAttachments,\n \"setMedia\": _vm.setMedia()\n }\n }) : _vm._e()], 2) : _vm._e(), _vm._v(\" \"), (_vm.status.card && !_vm.hideSubjectStatus && !_vm.noHeading) ? _c('div', {\n staticClass: \"link-preview media-body\"\n }, [_c('link-preview', {\n attrs: {\n \"card\": _vm.status.card,\n \"size\": _vm.attachmentSize,\n \"nsfw\": _vm.nsfwClickthrough\n }\n })], 1) : _vm._e(), _vm._v(\" \"), (!_vm.noHeading && !_vm.isPreview) ? _c('div', {\n staticClass: \"status-actions media-body\"\n }, [(_vm.loggedIn) ? _c('div', [_c('a', {\n attrs: {\n \"href\": \"#\",\n \"title\": _vm.$t('tool_tip.reply')\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.toggleReplying($event)\n }\n }\n }, [_c('i', {\n staticClass: \"button-icon icon-reply\",\n class: {\n 'icon-reply-active': _vm.replying\n }\n })])]) : _vm._e(), _vm._v(\" \"), _c('retweet-button', {\n attrs: {\n \"visibility\": _vm.status.visibility,\n \"loggedIn\": _vm.loggedIn,\n \"status\": _vm.status\n }\n }), _vm._v(\" \"), _c('favorite-button', {\n attrs: {\n \"loggedIn\": _vm.loggedIn,\n \"status\": _vm.status\n }\n }), _vm._v(\" \"), _c('delete-button', {\n attrs: {\n \"status\": _vm.status\n }\n })], 1) : _vm._e()], 1)]), _vm._v(\" \"), (_vm.replying) ? _c('div', {\n staticClass: \"container\"\n }, [_c('div', {\n staticClass: \"reply-left\"\n }), _vm._v(\" \"), _c('post-status-form', {\n staticClass: \"reply-body\",\n attrs: {\n \"reply-to\": _vm.status.id,\n \"attentions\": _vm.status.attentions,\n \"repliedUser\": _vm.status.user,\n \"copy-message-scope\": _vm.status.visibility,\n \"subject\": _vm.replySubject\n },\n on: {\n \"posted\": _vm.toggleReplying\n }\n })], 1) : _vm._e()]], 2) : _vm._e()\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-769e38a0\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/status/status.vue\n// module id = 724\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return (_vm.show) ? _c('div', {\n staticClass: \"instance-specific-panel\"\n }, [_c('div', {\n staticClass: \"panel panel-default\"\n }, [_c('div', {\n staticClass: \"panel-body\"\n }, [_c('div', {\n domProps: {\n \"innerHTML\": _vm._s(_vm.instanceSpecificPanelContent)\n }\n })])])]) : _vm._e()\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-8ac93238\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/instance_specific_panel/instance_specific_panel.vue\n// module id = 725\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"image-cropper\"\n }, [(_vm.dataUrl) ? _c('div', [_c('div', {\n staticClass: \"image-cropper-image-container\"\n }, [_c('img', {\n ref: \"img\",\n attrs: {\n \"src\": _vm.dataUrl,\n \"alt\": \"\"\n },\n on: {\n \"load\": function($event) {\n $event.stopPropagation();\n return _vm.createCropper($event)\n }\n }\n })]), _vm._v(\" \"), _c('div', {\n staticClass: \"image-cropper-buttons-wrapper\"\n }, [_c('button', {\n staticClass: \"btn\",\n attrs: {\n \"type\": \"button\",\n \"disabled\": _vm.submitting\n },\n domProps: {\n \"textContent\": _vm._s(_vm.saveText)\n },\n on: {\n \"click\": _vm.submit\n }\n }), _vm._v(\" \"), _c('button', {\n staticClass: \"btn\",\n attrs: {\n \"type\": \"button\",\n \"disabled\": _vm.submitting\n },\n domProps: {\n \"textContent\": _vm._s(_vm.cancelText)\n },\n on: {\n \"click\": _vm.destroy\n }\n }), _vm._v(\" \"), (_vm.submitting) ? _c('i', {\n staticClass: \"icon-spin4 animate-spin\"\n }) : _vm._e()]), _vm._v(\" \"), (_vm.submitError) ? _c('div', {\n staticClass: \"alert error\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.submitErrorMsg) + \"\\n \"), _c('i', {\n staticClass: \"button-icon icon-cancel\",\n on: {\n \"click\": _vm.clearError\n }\n })]) : _vm._e()]) : _vm._e(), _vm._v(\" \"), _c('input', {\n ref: \"input\",\n staticClass: \"image-cropper-img-input\",\n attrs: {\n \"type\": \"file\",\n \"accept\": _vm.mimes\n }\n })])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-8fcb0418\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/image_cropper/image_cropper.vue\n// module id = 726\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('Timeline', {\n attrs: {\n \"title\": _vm.$t('nav.timeline'),\n \"timeline\": _vm.timeline,\n \"timeline-name\": 'friends'\n }\n })\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-938aba00\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/friends_timeline/friends_timeline.vue\n// module id = 727\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"settings panel panel-default\"\n }, [_c('div', {\n staticClass: \"panel-heading\"\n }, [_c('div', {\n staticClass: \"title\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.user_settings')) + \"\\n \")]), _vm._v(\" \"), _c('transition', {\n attrs: {\n \"name\": \"fade\"\n }\n }, [(_vm.currentSaveStateNotice) ? [(_vm.currentSaveStateNotice.error) ? _c('div', {\n staticClass: \"alert error\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.saving_err')) + \"\\n \")]) : _vm._e(), _vm._v(\" \"), (!_vm.currentSaveStateNotice.error) ? _c('div', {\n staticClass: \"alert transparent\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.saving_ok')) + \"\\n \")]) : _vm._e()] : _vm._e()], 2)], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-body profile-edit\"\n }, [_c('tab-switcher', [_c('div', {\n attrs: {\n \"label\": _vm.$t('settings.profile_tab')\n }\n }, [_c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.name_bio')))]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.name')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.newName),\n expression: \"newName\"\n }],\n staticClass: \"name-changer\",\n attrs: {\n \"id\": \"username\"\n },\n domProps: {\n \"value\": (_vm.newName)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.newName = $event.target.value\n }\n }\n }), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.bio')))]), _vm._v(\" \"), _c('textarea', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.newBio),\n expression: \"newBio\"\n }],\n staticClass: \"bio\",\n domProps: {\n \"value\": (_vm.newBio)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.newBio = $event.target.value\n }\n }\n }), _vm._v(\" \"), _c('p', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.newLocked),\n expression: \"newLocked\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"account-locked\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.newLocked) ? _vm._i(_vm.newLocked, null) > -1 : (_vm.newLocked)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.newLocked,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.newLocked = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.newLocked = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.newLocked = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"account-locked\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.lock_account_description')))])]), _vm._v(\" \"), (_vm.scopeOptionsEnabled) ? _c('div', [_c('label', {\n attrs: {\n \"for\": \"default-vis\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.default_vis')))]), _vm._v(\" \"), _c('div', {\n staticClass: \"visibility-tray\",\n attrs: {\n \"id\": \"default-vis\"\n }\n }, [_c('i', {\n staticClass: \"icon-mail-alt\",\n class: _vm.vis.direct,\n attrs: {\n \"title\": _vm.$t('post_status.scope.direct')\n },\n on: {\n \"click\": function($event) {\n _vm.changeVis('direct')\n }\n }\n }), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-lock\",\n class: _vm.vis.private,\n attrs: {\n \"title\": _vm.$t('post_status.scope.private')\n },\n on: {\n \"click\": function($event) {\n _vm.changeVis('private')\n }\n }\n }), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-lock-open-alt\",\n class: _vm.vis.unlisted,\n attrs: {\n \"title\": _vm.$t('post_status.scope.unlisted')\n },\n on: {\n \"click\": function($event) {\n _vm.changeVis('unlisted')\n }\n }\n }), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-globe\",\n class: _vm.vis.public,\n attrs: {\n \"title\": _vm.$t('post_status.scope.public')\n },\n on: {\n \"click\": function($event) {\n _vm.changeVis('public')\n }\n }\n })])]) : _vm._e(), _vm._v(\" \"), _c('p', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.newNoRichText),\n expression: \"newNoRichText\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"account-no-rich-text\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.newNoRichText) ? _vm._i(_vm.newNoRichText, null) > -1 : (_vm.newNoRichText)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.newNoRichText,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.newNoRichText = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.newNoRichText = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.newNoRichText = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"account-no-rich-text\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.no_rich_text_description')))])]), _vm._v(\" \"), _c('p', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.hideFollows),\n expression: \"hideFollows\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"account-hide-follows\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.hideFollows) ? _vm._i(_vm.hideFollows, null) > -1 : (_vm.hideFollows)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.hideFollows,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.hideFollows = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.hideFollows = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.hideFollows = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"account-hide-follows\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.hide_follows_description')))])]), _vm._v(\" \"), _c('p', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.hideFollowers),\n expression: \"hideFollowers\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"account-hide-followers\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.hideFollowers) ? _vm._i(_vm.hideFollowers, null) > -1 : (_vm.hideFollowers)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.hideFollowers,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.hideFollowers = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.hideFollowers = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.hideFollowers = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"account-hide-followers\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.hide_followers_description')))])]), _vm._v(\" \"), _c('p', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.showRole),\n expression: \"showRole\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"account-show-role\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.showRole) ? _vm._i(_vm.showRole, null) > -1 : (_vm.showRole)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.showRole,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.showRole = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.showRole = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.showRole = $$c\n }\n }\n }\n }), _vm._v(\" \"), (_vm.role === 'admin') ? _c('label', {\n attrs: {\n \"for\": \"account-show-role\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.show_admin_badge')))]) : _vm._e(), _vm._v(\" \"), (_vm.role === 'moderator') ? _c('label', {\n attrs: {\n \"for\": \"account-show-role\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.show_moderator_badge')))]) : _vm._e()]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn btn-default\",\n attrs: {\n \"disabled\": _vm.newName && _vm.newName.length === 0\n },\n on: {\n \"click\": _vm.updateProfile\n }\n }, [_vm._v(_vm._s(_vm.$t('general.submit')))])]), _vm._v(\" \"), _c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.avatar')))]), _vm._v(\" \"), _c('p', {\n staticClass: \"visibility-notice\"\n }, [_vm._v(_vm._s(_vm.$t('settings.avatar_size_instruction')))]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.current_avatar')))]), _vm._v(\" \"), _c('img', {\n staticClass: \"current-avatar\",\n attrs: {\n \"src\": _vm.user.profile_image_url_original\n }\n }), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.set_new_avatar')))]), _vm._v(\" \"), _c('button', {\n directives: [{\n name: \"show\",\n rawName: \"v-show\",\n value: (_vm.pickAvatarBtnVisible),\n expression: \"pickAvatarBtnVisible\"\n }],\n staticClass: \"btn\",\n attrs: {\n \"type\": \"button\",\n \"id\": \"pick-avatar\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.upload_a_photo')))]), _vm._v(\" \"), _c('image-cropper', {\n attrs: {\n \"trigger\": \"#pick-avatar\",\n \"submitHandler\": _vm.submitAvatar\n },\n on: {\n \"open\": function($event) {\n _vm.pickAvatarBtnVisible = false\n },\n \"close\": function($event) {\n _vm.pickAvatarBtnVisible = true\n }\n }\n })], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.profile_banner')))]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.current_profile_banner')))]), _vm._v(\" \"), _c('img', {\n staticClass: \"banner\",\n attrs: {\n \"src\": _vm.user.cover_photo\n }\n }), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.set_new_profile_banner')))]), _vm._v(\" \"), (_vm.bannerPreview) ? _c('img', {\n staticClass: \"banner\",\n attrs: {\n \"src\": _vm.bannerPreview\n }\n }) : _vm._e(), _vm._v(\" \"), _c('div', [_c('input', {\n attrs: {\n \"type\": \"file\"\n },\n on: {\n \"change\": function($event) {\n _vm.uploadFile('banner', $event)\n }\n }\n })]), _vm._v(\" \"), (_vm.bannerUploading) ? _c('i', {\n staticClass: \" icon-spin4 animate-spin uploading\"\n }) : (_vm.bannerPreview) ? _c('button', {\n staticClass: \"btn btn-default\",\n on: {\n \"click\": _vm.submitBanner\n }\n }, [_vm._v(_vm._s(_vm.$t('general.submit')))]) : _vm._e(), _vm._v(\" \"), (_vm.bannerUploadError) ? _c('div', {\n staticClass: \"alert error\"\n }, [_vm._v(\"\\n Error: \" + _vm._s(_vm.bannerUploadError) + \"\\n \"), _c('i', {\n staticClass: \"button-icon icon-cancel\",\n on: {\n \"click\": function($event) {\n _vm.clearUploadError('banner')\n }\n }\n })]) : _vm._e()]), _vm._v(\" \"), _c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.profile_background')))]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.set_new_profile_background')))]), _vm._v(\" \"), (_vm.backgroundPreview) ? _c('img', {\n staticClass: \"bg\",\n attrs: {\n \"src\": _vm.backgroundPreview\n }\n }) : _vm._e(), _vm._v(\" \"), _c('div', [_c('input', {\n attrs: {\n \"type\": \"file\"\n },\n on: {\n \"change\": function($event) {\n _vm.uploadFile('background', $event)\n }\n }\n })]), _vm._v(\" \"), (_vm.backgroundUploading) ? _c('i', {\n staticClass: \" icon-spin4 animate-spin uploading\"\n }) : (_vm.backgroundPreview) ? _c('button', {\n staticClass: \"btn btn-default\",\n on: {\n \"click\": _vm.submitBg\n }\n }, [_vm._v(_vm._s(_vm.$t('general.submit')))]) : _vm._e(), _vm._v(\" \"), (_vm.backgroundUploadError) ? _c('div', {\n staticClass: \"alert error\"\n }, [_vm._v(\"\\n Error: \" + _vm._s(_vm.backgroundUploadError) + \"\\n \"), _c('i', {\n staticClass: \"button-icon icon-cancel\",\n on: {\n \"click\": function($event) {\n _vm.clearUploadError('background')\n }\n }\n })]) : _vm._e()])]), _vm._v(\" \"), _c('div', {\n attrs: {\n \"label\": _vm.$t('settings.security_tab')\n }\n }, [_c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.change_password')))]), _vm._v(\" \"), _c('div', [_c('p', [_vm._v(_vm._s(_vm.$t('settings.current_password')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.changePasswordInputs[0]),\n expression: \"changePasswordInputs[0]\"\n }],\n attrs: {\n \"type\": \"password\"\n },\n domProps: {\n \"value\": (_vm.changePasswordInputs[0])\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.changePasswordInputs, 0, $event.target.value)\n }\n }\n })]), _vm._v(\" \"), _c('div', [_c('p', [_vm._v(_vm._s(_vm.$t('settings.new_password')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.changePasswordInputs[1]),\n expression: \"changePasswordInputs[1]\"\n }],\n attrs: {\n \"type\": \"password\"\n },\n domProps: {\n \"value\": (_vm.changePasswordInputs[1])\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.changePasswordInputs, 1, $event.target.value)\n }\n }\n })]), _vm._v(\" \"), _c('div', [_c('p', [_vm._v(_vm._s(_vm.$t('settings.confirm_new_password')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.changePasswordInputs[2]),\n expression: \"changePasswordInputs[2]\"\n }],\n attrs: {\n \"type\": \"password\"\n },\n domProps: {\n \"value\": (_vm.changePasswordInputs[2])\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.$set(_vm.changePasswordInputs, 2, $event.target.value)\n }\n }\n })]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn btn-default\",\n on: {\n \"click\": _vm.changePassword\n }\n }, [_vm._v(_vm._s(_vm.$t('general.submit')))]), _vm._v(\" \"), (_vm.changedPassword) ? _c('p', [_vm._v(_vm._s(_vm.$t('settings.changed_password')))]) : (_vm.changePasswordError !== false) ? _c('p', [_vm._v(_vm._s(_vm.$t('settings.change_password_error')))]) : _vm._e(), _vm._v(\" \"), (_vm.changePasswordError) ? _c('p', [_vm._v(_vm._s(_vm.changePasswordError))]) : _vm._e()]), _vm._v(\" \"), _c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.oauth_tokens')))]), _vm._v(\" \"), _c('table', {\n staticClass: \"oauth-tokens\"\n }, [_c('thead', [_c('tr', [_c('th', [_vm._v(_vm._s(_vm.$t('settings.app_name')))]), _vm._v(\" \"), _c('th', [_vm._v(_vm._s(_vm.$t('settings.valid_until')))]), _vm._v(\" \"), _c('th')])]), _vm._v(\" \"), _c('tbody', _vm._l((_vm.oauthTokens), function(oauthToken) {\n return _c('tr', {\n key: oauthToken.id\n }, [_c('td', [_vm._v(_vm._s(oauthToken.appName))]), _vm._v(\" \"), _c('td', [_vm._v(_vm._s(oauthToken.validUntil))]), _vm._v(\" \"), _c('td', {\n staticClass: \"actions\"\n }, [_c('button', {\n staticClass: \"btn btn-default\",\n on: {\n \"click\": function($event) {\n _vm.revokeToken(oauthToken.id)\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.revoke_token')) + \"\\n \")])])])\n }), 0)])]), _vm._v(\" \"), _c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.delete_account')))]), _vm._v(\" \"), (!_vm.deletingAccount) ? _c('p', [_vm._v(_vm._s(_vm.$t('settings.delete_account_description')))]) : _vm._e(), _vm._v(\" \"), (_vm.deletingAccount) ? _c('div', [_c('p', [_vm._v(_vm._s(_vm.$t('settings.delete_account_instructions')))]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('login.password')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.deleteAccountConfirmPasswordInput),\n expression: \"deleteAccountConfirmPasswordInput\"\n }],\n attrs: {\n \"type\": \"password\"\n },\n domProps: {\n \"value\": (_vm.deleteAccountConfirmPasswordInput)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.deleteAccountConfirmPasswordInput = $event.target.value\n }\n }\n }), _vm._v(\" \"), _c('button', {\n staticClass: \"btn btn-default\",\n on: {\n \"click\": _vm.deleteAccount\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.delete_account')))])]) : _vm._e(), _vm._v(\" \"), (_vm.deleteAccountError !== false) ? _c('p', [_vm._v(_vm._s(_vm.$t('settings.delete_account_error')))]) : _vm._e(), _vm._v(\" \"), (_vm.deleteAccountError) ? _c('p', [_vm._v(_vm._s(_vm.deleteAccountError))]) : _vm._e(), _vm._v(\" \"), (!_vm.deletingAccount) ? _c('button', {\n staticClass: \"btn btn-default\",\n on: {\n \"click\": _vm.confirmDelete\n }\n }, [_vm._v(_vm._s(_vm.$t('general.submit')))]) : _vm._e()])]), _vm._v(\" \"), (_vm.pleromaBackend) ? _c('div', {\n attrs: {\n \"label\": _vm.$t('settings.data_import_export_tab')\n }\n }, [_c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.follow_import')))]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.import_followers_from_a_csv_file')))]), _vm._v(\" \"), _c('form', [_c('input', {\n ref: \"followlist\",\n attrs: {\n \"type\": \"file\"\n },\n on: {\n \"change\": _vm.followListChange\n }\n })]), _vm._v(\" \"), (_vm.followListUploading) ? _c('i', {\n staticClass: \" icon-spin4 animate-spin uploading\"\n }) : _c('button', {\n staticClass: \"btn btn-default\",\n on: {\n \"click\": _vm.importFollows\n }\n }, [_vm._v(_vm._s(_vm.$t('general.submit')))]), _vm._v(\" \"), (_vm.followsImported) ? _c('div', [_c('i', {\n staticClass: \"icon-cross\",\n on: {\n \"click\": _vm.dismissImported\n }\n }), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.follows_imported')))])]) : (_vm.followImportError) ? _c('div', [_c('i', {\n staticClass: \"icon-cross\",\n on: {\n \"click\": _vm.dismissImported\n }\n }), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.follow_import_error')))])]) : _vm._e()]), _vm._v(\" \"), (_vm.enableFollowsExport) ? _c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.follow_export')))]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn btn-default\",\n on: {\n \"click\": _vm.exportFollows\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.follow_export_button')))])]) : _c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.follow_export_processing')))])])]) : _vm._e(), _vm._v(\" \"), _c('div', {\n attrs: {\n \"label\": _vm.$t('settings.blocks_tab')\n }\n }, [_c('block-list', {\n attrs: {\n \"refresh\": true\n }\n }, [_c('template', {\n slot: \"empty\"\n }, [_vm._v(_vm._s(_vm.$t('settings.no_blocks')))])], 2)], 1)])], 1)])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-93ac3f60\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/user_settings/user_settings.vue\n// module id = 728\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return (_vm.canDelete) ? _c('div', [_c('a', {\n attrs: {\n \"href\": \"#\"\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n _vm.deleteStatus()\n }\n }\n }, [_c('i', {\n staticClass: \"button-icon icon-cancel delete-status\"\n })])]) : _vm._e()\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-ab5f3124\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/delete_button/delete_button.vue\n// module id = 729\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"style-switcher\"\n }, [_c('div', {\n staticClass: \"presets-container\"\n }, [_c('div', {\n staticClass: \"save-load\"\n }, [_c('export-import', {\n attrs: {\n \"exportObject\": _vm.exportedTheme,\n \"exportLabel\": _vm.$t(\"settings.export_theme\"),\n \"importLabel\": _vm.$t(\"settings.import_theme\"),\n \"importFailedText\": _vm.$t(\"settings.invalid_theme_imported\"),\n \"onImport\": _vm.onImport,\n \"validator\": _vm.importValidator\n }\n }, [_c('template', {\n slot: \"before\"\n }, [_c('div', {\n staticClass: \"presets\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.presets')) + \"\\n \"), _c('label', {\n staticClass: \"select\",\n attrs: {\n \"for\": \"preset-switcher\"\n }\n }, [_c('select', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.selected),\n expression: \"selected\"\n }],\n staticClass: \"preset-switcher\",\n attrs: {\n \"id\": \"preset-switcher\"\n },\n on: {\n \"change\": function($event) {\n var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n return o.selected\n }).map(function(o) {\n var val = \"_value\" in o ? o._value : o.value;\n return val\n });\n _vm.selected = $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n }\n }\n }, _vm._l((_vm.availableStyles), function(style) {\n return _c('option', {\n style: ({\n backgroundColor: style[1] || style.theme.colors.bg,\n color: style[3] || style.theme.colors.text\n }),\n domProps: {\n \"value\": style\n }\n }, [_vm._v(\"\\n \" + _vm._s(style[0] || style.name) + \"\\n \")])\n }), 0), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-down-open\"\n })])])])], 2)], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"save-load-options\"\n }, [_c('span', {\n staticClass: \"keep-option\"\n }, [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.keepColor),\n expression: \"keepColor\"\n }],\n attrs: {\n \"id\": \"keep-color\",\n \"type\": \"checkbox\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.keepColor) ? _vm._i(_vm.keepColor, null) > -1 : (_vm.keepColor)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.keepColor,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.keepColor = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.keepColor = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.keepColor = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"keep-color\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.keep_color')))])]), _vm._v(\" \"), _c('span', {\n staticClass: \"keep-option\"\n }, [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.keepShadows),\n expression: \"keepShadows\"\n }],\n attrs: {\n \"id\": \"keep-shadows\",\n \"type\": \"checkbox\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.keepShadows) ? _vm._i(_vm.keepShadows, null) > -1 : (_vm.keepShadows)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.keepShadows,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.keepShadows = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.keepShadows = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.keepShadows = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"keep-shadows\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.keep_shadows')))])]), _vm._v(\" \"), _c('span', {\n staticClass: \"keep-option\"\n }, [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.keepOpacity),\n expression: \"keepOpacity\"\n }],\n attrs: {\n \"id\": \"keep-opacity\",\n \"type\": \"checkbox\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.keepOpacity) ? _vm._i(_vm.keepOpacity, null) > -1 : (_vm.keepOpacity)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.keepOpacity,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.keepOpacity = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.keepOpacity = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.keepOpacity = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"keep-opacity\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.keep_opacity')))])]), _vm._v(\" \"), _c('span', {\n staticClass: \"keep-option\"\n }, [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.keepRoundness),\n expression: \"keepRoundness\"\n }],\n attrs: {\n \"id\": \"keep-roundness\",\n \"type\": \"checkbox\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.keepRoundness) ? _vm._i(_vm.keepRoundness, null) > -1 : (_vm.keepRoundness)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.keepRoundness,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.keepRoundness = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.keepRoundness = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.keepRoundness = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"keep-roundness\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.keep_roundness')))])]), _vm._v(\" \"), _c('span', {\n staticClass: \"keep-option\"\n }, [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.keepFonts),\n expression: \"keepFonts\"\n }],\n attrs: {\n \"id\": \"keep-fonts\",\n \"type\": \"checkbox\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.keepFonts) ? _vm._i(_vm.keepFonts, null) > -1 : (_vm.keepFonts)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.keepFonts,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.keepFonts = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.keepFonts = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.keepFonts = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"keep-fonts\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.keep_fonts')))])]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.style.switcher.save_load_hint')))])])]), _vm._v(\" \"), _c('div', {\n staticClass: \"preview-container\"\n }, [_c('preview', {\n style: (_vm.previewRules)\n })], 1), _vm._v(\" \"), _c('keep-alive', [_c('tab-switcher', {\n key: \"style-tweak\"\n }, [_c('div', {\n staticClass: \"color-container\",\n attrs: {\n \"label\": _vm.$t('settings.style.common_colors._tab_label')\n }\n }, [_c('div', {\n staticClass: \"tab-header\"\n }, [_c('p', [_vm._v(_vm._s(_vm.$t('settings.theme_help')))]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn\",\n on: {\n \"click\": _vm.clearOpacity\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.clear_opacity')))]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn\",\n on: {\n \"click\": _vm.clearV1\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.clear_all')))])]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.theme_help_v2_1')))]), _vm._v(\" \"), _c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.common_colors.main')))]), _vm._v(\" \"), _c('div', {\n staticClass: \"color-item\"\n }, [_c('ColorInput', {\n attrs: {\n \"name\": \"bgColor\",\n \"label\": _vm.$t('settings.background')\n },\n model: {\n value: (_vm.bgColorLocal),\n callback: function($$v) {\n _vm.bgColorLocal = $$v\n },\n expression: \"bgColorLocal\"\n }\n }), _vm._v(\" \"), _c('OpacityInput', {\n attrs: {\n \"name\": \"bgOpacity\",\n \"fallback\": _vm.previewTheme.opacity.bg || 1\n },\n model: {\n value: (_vm.bgOpacityLocal),\n callback: function($$v) {\n _vm.bgOpacityLocal = $$v\n },\n expression: \"bgOpacityLocal\"\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"textColor\",\n \"label\": _vm.$t('settings.text')\n },\n model: {\n value: (_vm.textColorLocal),\n callback: function($$v) {\n _vm.textColorLocal = $$v\n },\n expression: \"textColorLocal\"\n }\n }), _vm._v(\" \"), _c('ContrastRatio', {\n attrs: {\n \"contrast\": _vm.previewContrast.bgText\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"linkColor\",\n \"label\": _vm.$t('settings.links')\n },\n model: {\n value: (_vm.linkColorLocal),\n callback: function($$v) {\n _vm.linkColorLocal = $$v\n },\n expression: \"linkColorLocal\"\n }\n }), _vm._v(\" \"), _c('ContrastRatio', {\n attrs: {\n \"contrast\": _vm.previewContrast.bgLink\n }\n })], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"color-item\"\n }, [_c('ColorInput', {\n attrs: {\n \"name\": \"fgColor\",\n \"label\": _vm.$t('settings.foreground')\n },\n model: {\n value: (_vm.fgColorLocal),\n callback: function($$v) {\n _vm.fgColorLocal = $$v\n },\n expression: \"fgColorLocal\"\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"fgTextColor\",\n \"label\": _vm.$t('settings.text'),\n \"fallback\": _vm.previewTheme.colors.fgText\n },\n model: {\n value: (_vm.fgTextColorLocal),\n callback: function($$v) {\n _vm.fgTextColorLocal = $$v\n },\n expression: \"fgTextColorLocal\"\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"fgLinkColor\",\n \"label\": _vm.$t('settings.links'),\n \"fallback\": _vm.previewTheme.colors.fgLink\n },\n model: {\n value: (_vm.fgLinkColorLocal),\n callback: function($$v) {\n _vm.fgLinkColorLocal = $$v\n },\n expression: \"fgLinkColorLocal\"\n }\n }), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.style.common_colors.foreground_hint')))])], 1), _vm._v(\" \"), _c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.common_colors.rgbo')))]), _vm._v(\" \"), _c('div', {\n staticClass: \"color-item\"\n }, [_c('ColorInput', {\n attrs: {\n \"name\": \"cRedColor\",\n \"label\": _vm.$t('settings.cRed')\n },\n model: {\n value: (_vm.cRedColorLocal),\n callback: function($$v) {\n _vm.cRedColorLocal = $$v\n },\n expression: \"cRedColorLocal\"\n }\n }), _vm._v(\" \"), _c('ContrastRatio', {\n attrs: {\n \"contrast\": _vm.previewContrast.bgRed\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"cBlueColor\",\n \"label\": _vm.$t('settings.cBlue')\n },\n model: {\n value: (_vm.cBlueColorLocal),\n callback: function($$v) {\n _vm.cBlueColorLocal = $$v\n },\n expression: \"cBlueColorLocal\"\n }\n }), _vm._v(\" \"), _c('ContrastRatio', {\n attrs: {\n \"contrast\": _vm.previewContrast.bgBlue\n }\n })], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"color-item\"\n }, [_c('ColorInput', {\n attrs: {\n \"name\": \"cGreenColor\",\n \"label\": _vm.$t('settings.cGreen')\n },\n model: {\n value: (_vm.cGreenColorLocal),\n callback: function($$v) {\n _vm.cGreenColorLocal = $$v\n },\n expression: \"cGreenColorLocal\"\n }\n }), _vm._v(\" \"), _c('ContrastRatio', {\n attrs: {\n \"contrast\": _vm.previewContrast.bgGreen\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"cOrangeColor\",\n \"label\": _vm.$t('settings.cOrange')\n },\n model: {\n value: (_vm.cOrangeColorLocal),\n callback: function($$v) {\n _vm.cOrangeColorLocal = $$v\n },\n expression: \"cOrangeColorLocal\"\n }\n }), _vm._v(\" \"), _c('ContrastRatio', {\n attrs: {\n \"contrast\": _vm.previewContrast.bgOrange\n }\n })], 1), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.theme_help_v2_2')))])]), _vm._v(\" \"), _c('div', {\n staticClass: \"color-container\",\n attrs: {\n \"label\": _vm.$t('settings.style.advanced_colors._tab_label')\n }\n }, [_c('div', {\n staticClass: \"tab-header\"\n }, [_c('p', [_vm._v(_vm._s(_vm.$t('settings.theme_help')))]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn\",\n on: {\n \"click\": _vm.clearOpacity\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.clear_opacity')))]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn\",\n on: {\n \"click\": _vm.clearV1\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.clear_all')))])]), _vm._v(\" \"), _c('div', {\n staticClass: \"color-item\"\n }, [_c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.advanced_colors.alert')))]), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"alertError\",\n \"label\": _vm.$t('settings.style.advanced_colors.alert_error'),\n \"fallback\": _vm.previewTheme.colors.alertError\n },\n model: {\n value: (_vm.alertErrorColorLocal),\n callback: function($$v) {\n _vm.alertErrorColorLocal = $$v\n },\n expression: \"alertErrorColorLocal\"\n }\n }), _vm._v(\" \"), _c('ContrastRatio', {\n attrs: {\n \"contrast\": _vm.previewContrast.alertError\n }\n })], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"color-item\"\n }, [_c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.advanced_colors.badge')))]), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"badgeNotification\",\n \"label\": _vm.$t('settings.style.advanced_colors.badge_notification'),\n \"fallback\": _vm.previewTheme.colors.badgeNotification\n },\n model: {\n value: (_vm.badgeNotificationColorLocal),\n callback: function($$v) {\n _vm.badgeNotificationColorLocal = $$v\n },\n expression: \"badgeNotificationColorLocal\"\n }\n })], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"color-item\"\n }, [_c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.advanced_colors.panel_header')))]), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"panelColor\",\n \"fallback\": _vm.fgColorLocal,\n \"label\": _vm.$t('settings.background')\n },\n model: {\n value: (_vm.panelColorLocal),\n callback: function($$v) {\n _vm.panelColorLocal = $$v\n },\n expression: \"panelColorLocal\"\n }\n }), _vm._v(\" \"), _c('OpacityInput', {\n attrs: {\n \"name\": \"panelOpacity\",\n \"fallback\": _vm.previewTheme.opacity.panel || 1\n },\n model: {\n value: (_vm.panelOpacityLocal),\n callback: function($$v) {\n _vm.panelOpacityLocal = $$v\n },\n expression: \"panelOpacityLocal\"\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"panelTextColor\",\n \"fallback\": _vm.previewTheme.colors.panelText,\n \"label\": _vm.$t('settings.text')\n },\n model: {\n value: (_vm.panelTextColorLocal),\n callback: function($$v) {\n _vm.panelTextColorLocal = $$v\n },\n expression: \"panelTextColorLocal\"\n }\n }), _vm._v(\" \"), _c('ContrastRatio', {\n attrs: {\n \"contrast\": _vm.previewContrast.panelText,\n \"large\": \"1\"\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"panelLinkColor\",\n \"fallback\": _vm.previewTheme.colors.panelLink,\n \"label\": _vm.$t('settings.links')\n },\n model: {\n value: (_vm.panelLinkColorLocal),\n callback: function($$v) {\n _vm.panelLinkColorLocal = $$v\n },\n expression: \"panelLinkColorLocal\"\n }\n }), _vm._v(\" \"), _c('ContrastRatio', {\n attrs: {\n \"contrast\": _vm.previewContrast.panelLink,\n \"large\": \"1\"\n }\n })], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"color-item\"\n }, [_c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.advanced_colors.top_bar')))]), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"topBarColor\",\n \"fallback\": _vm.fgColorLocal,\n \"label\": _vm.$t('settings.background')\n },\n model: {\n value: (_vm.topBarColorLocal),\n callback: function($$v) {\n _vm.topBarColorLocal = $$v\n },\n expression: \"topBarColorLocal\"\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"topBarTextColor\",\n \"fallback\": _vm.previewTheme.colors.topBarText,\n \"label\": _vm.$t('settings.text')\n },\n model: {\n value: (_vm.topBarTextColorLocal),\n callback: function($$v) {\n _vm.topBarTextColorLocal = $$v\n },\n expression: \"topBarTextColorLocal\"\n }\n }), _vm._v(\" \"), _c('ContrastRatio', {\n attrs: {\n \"contrast\": _vm.previewContrast.topBarText\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"topBarLinkColor\",\n \"fallback\": _vm.previewTheme.colors.topBarLink,\n \"label\": _vm.$t('settings.links')\n },\n model: {\n value: (_vm.topBarLinkColorLocal),\n callback: function($$v) {\n _vm.topBarLinkColorLocal = $$v\n },\n expression: \"topBarLinkColorLocal\"\n }\n }), _vm._v(\" \"), _c('ContrastRatio', {\n attrs: {\n \"contrast\": _vm.previewContrast.topBarLink\n }\n })], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"color-item\"\n }, [_c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.advanced_colors.inputs')))]), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"inputColor\",\n \"fallback\": _vm.fgColorLocal,\n \"label\": _vm.$t('settings.background')\n },\n model: {\n value: (_vm.inputColorLocal),\n callback: function($$v) {\n _vm.inputColorLocal = $$v\n },\n expression: \"inputColorLocal\"\n }\n }), _vm._v(\" \"), _c('OpacityInput', {\n attrs: {\n \"name\": \"inputOpacity\",\n \"fallback\": _vm.previewTheme.opacity.input || 1\n },\n model: {\n value: (_vm.inputOpacityLocal),\n callback: function($$v) {\n _vm.inputOpacityLocal = $$v\n },\n expression: \"inputOpacityLocal\"\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"inputTextColor\",\n \"fallback\": _vm.previewTheme.colors.inputText,\n \"label\": _vm.$t('settings.text')\n },\n model: {\n value: (_vm.inputTextColorLocal),\n callback: function($$v) {\n _vm.inputTextColorLocal = $$v\n },\n expression: \"inputTextColorLocal\"\n }\n }), _vm._v(\" \"), _c('ContrastRatio', {\n attrs: {\n \"contrast\": _vm.previewContrast.inputText\n }\n })], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"color-item\"\n }, [_c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.advanced_colors.buttons')))]), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"btnColor\",\n \"fallback\": _vm.fgColorLocal,\n \"label\": _vm.$t('settings.background')\n },\n model: {\n value: (_vm.btnColorLocal),\n callback: function($$v) {\n _vm.btnColorLocal = $$v\n },\n expression: \"btnColorLocal\"\n }\n }), _vm._v(\" \"), _c('OpacityInput', {\n attrs: {\n \"name\": \"btnOpacity\",\n \"fallback\": _vm.previewTheme.opacity.btn || 1\n },\n model: {\n value: (_vm.btnOpacityLocal),\n callback: function($$v) {\n _vm.btnOpacityLocal = $$v\n },\n expression: \"btnOpacityLocal\"\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"btnTextColor\",\n \"fallback\": _vm.previewTheme.colors.btnText,\n \"label\": _vm.$t('settings.text')\n },\n model: {\n value: (_vm.btnTextColorLocal),\n callback: function($$v) {\n _vm.btnTextColorLocal = $$v\n },\n expression: \"btnTextColorLocal\"\n }\n }), _vm._v(\" \"), _c('ContrastRatio', {\n attrs: {\n \"contrast\": _vm.previewContrast.btnText\n }\n })], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"color-item\"\n }, [_c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.advanced_colors.borders')))]), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"borderColor\",\n \"fallback\": _vm.previewTheme.colors.border,\n \"label\": _vm.$t('settings.style.common.color')\n },\n model: {\n value: (_vm.borderColorLocal),\n callback: function($$v) {\n _vm.borderColorLocal = $$v\n },\n expression: \"borderColorLocal\"\n }\n }), _vm._v(\" \"), _c('OpacityInput', {\n attrs: {\n \"name\": \"borderOpacity\",\n \"fallback\": _vm.previewTheme.opacity.border || 1\n },\n model: {\n value: (_vm.borderOpacityLocal),\n callback: function($$v) {\n _vm.borderOpacityLocal = $$v\n },\n expression: \"borderOpacityLocal\"\n }\n })], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"color-item\"\n }, [_c('h4', [_vm._v(_vm._s(_vm.$t('settings.style.advanced_colors.faint_text')))]), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"faintColor\",\n \"fallback\": _vm.previewTheme.colors.faint || 1,\n \"label\": _vm.$t('settings.text')\n },\n model: {\n value: (_vm.faintColorLocal),\n callback: function($$v) {\n _vm.faintColorLocal = $$v\n },\n expression: \"faintColorLocal\"\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"faintLinkColor\",\n \"fallback\": _vm.previewTheme.colors.faintLink,\n \"label\": _vm.$t('settings.links')\n },\n model: {\n value: (_vm.faintLinkColorLocal),\n callback: function($$v) {\n _vm.faintLinkColorLocal = $$v\n },\n expression: \"faintLinkColorLocal\"\n }\n }), _vm._v(\" \"), _c('ColorInput', {\n attrs: {\n \"name\": \"panelFaintColor\",\n \"fallback\": _vm.previewTheme.colors.panelFaint,\n \"label\": _vm.$t('settings.style.advanced_colors.panel_header')\n },\n model: {\n value: (_vm.panelFaintColorLocal),\n callback: function($$v) {\n _vm.panelFaintColorLocal = $$v\n },\n expression: \"panelFaintColorLocal\"\n }\n }), _vm._v(\" \"), _c('OpacityInput', {\n attrs: {\n \"name\": \"faintOpacity\",\n \"fallback\": _vm.previewTheme.opacity.faint || 0.5\n },\n model: {\n value: (_vm.faintOpacityLocal),\n callback: function($$v) {\n _vm.faintOpacityLocal = $$v\n },\n expression: \"faintOpacityLocal\"\n }\n })], 1)]), _vm._v(\" \"), _c('div', {\n staticClass: \"radius-container\",\n attrs: {\n \"label\": _vm.$t('settings.style.radii._tab_label')\n }\n }, [_c('div', {\n staticClass: \"tab-header\"\n }, [_c('p', [_vm._v(_vm._s(_vm.$t('settings.radii_help')))]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn\",\n on: {\n \"click\": _vm.clearRoundness\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.clear_all')))])]), _vm._v(\" \"), _c('RangeInput', {\n attrs: {\n \"name\": \"btnRadius\",\n \"label\": _vm.$t('settings.btnRadius'),\n \"fallback\": _vm.previewTheme.radii.btn,\n \"max\": \"16\",\n \"hardMin\": \"0\"\n },\n model: {\n value: (_vm.btnRadiusLocal),\n callback: function($$v) {\n _vm.btnRadiusLocal = $$v\n },\n expression: \"btnRadiusLocal\"\n }\n }), _vm._v(\" \"), _c('RangeInput', {\n attrs: {\n \"name\": \"inputRadius\",\n \"label\": _vm.$t('settings.inputRadius'),\n \"fallback\": _vm.previewTheme.radii.input,\n \"max\": \"9\",\n \"hardMin\": \"0\"\n },\n model: {\n value: (_vm.inputRadiusLocal),\n callback: function($$v) {\n _vm.inputRadiusLocal = $$v\n },\n expression: \"inputRadiusLocal\"\n }\n }), _vm._v(\" \"), _c('RangeInput', {\n attrs: {\n \"name\": \"checkboxRadius\",\n \"label\": _vm.$t('settings.checkboxRadius'),\n \"fallback\": _vm.previewTheme.radii.checkbox,\n \"max\": \"16\",\n \"hardMin\": \"0\"\n },\n model: {\n value: (_vm.checkboxRadiusLocal),\n callback: function($$v) {\n _vm.checkboxRadiusLocal = $$v\n },\n expression: \"checkboxRadiusLocal\"\n }\n }), _vm._v(\" \"), _c('RangeInput', {\n attrs: {\n \"name\": \"panelRadius\",\n \"label\": _vm.$t('settings.panelRadius'),\n \"fallback\": _vm.previewTheme.radii.panel,\n \"max\": \"50\",\n \"hardMin\": \"0\"\n },\n model: {\n value: (_vm.panelRadiusLocal),\n callback: function($$v) {\n _vm.panelRadiusLocal = $$v\n },\n expression: \"panelRadiusLocal\"\n }\n }), _vm._v(\" \"), _c('RangeInput', {\n attrs: {\n \"name\": \"avatarRadius\",\n \"label\": _vm.$t('settings.avatarRadius'),\n \"fallback\": _vm.previewTheme.radii.avatar,\n \"max\": \"28\",\n \"hardMin\": \"0\"\n },\n model: {\n value: (_vm.avatarRadiusLocal),\n callback: function($$v) {\n _vm.avatarRadiusLocal = $$v\n },\n expression: \"avatarRadiusLocal\"\n }\n }), _vm._v(\" \"), _c('RangeInput', {\n attrs: {\n \"name\": \"avatarAltRadius\",\n \"label\": _vm.$t('settings.avatarAltRadius'),\n \"fallback\": _vm.previewTheme.radii.avatarAlt,\n \"max\": \"28\",\n \"hardMin\": \"0\"\n },\n model: {\n value: (_vm.avatarAltRadiusLocal),\n callback: function($$v) {\n _vm.avatarAltRadiusLocal = $$v\n },\n expression: \"avatarAltRadiusLocal\"\n }\n }), _vm._v(\" \"), _c('RangeInput', {\n attrs: {\n \"name\": \"attachmentRadius\",\n \"label\": _vm.$t('settings.attachmentRadius'),\n \"fallback\": _vm.previewTheme.radii.attachment,\n \"max\": \"50\",\n \"hardMin\": \"0\"\n },\n model: {\n value: (_vm.attachmentRadiusLocal),\n callback: function($$v) {\n _vm.attachmentRadiusLocal = $$v\n },\n expression: \"attachmentRadiusLocal\"\n }\n }), _vm._v(\" \"), _c('RangeInput', {\n attrs: {\n \"name\": \"tooltipRadius\",\n \"label\": _vm.$t('settings.tooltipRadius'),\n \"fallback\": _vm.previewTheme.radii.tooltip,\n \"max\": \"50\",\n \"hardMin\": \"0\"\n },\n model: {\n value: (_vm.tooltipRadiusLocal),\n callback: function($$v) {\n _vm.tooltipRadiusLocal = $$v\n },\n expression: \"tooltipRadiusLocal\"\n }\n })], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"shadow-container\",\n attrs: {\n \"label\": _vm.$t('settings.style.shadows._tab_label')\n }\n }, [_c('div', {\n staticClass: \"tab-header shadow-selector\"\n }, [_c('div', {\n staticClass: \"select-container\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.shadows.component')) + \"\\n \"), _c('label', {\n staticClass: \"select\",\n attrs: {\n \"for\": \"shadow-switcher\"\n }\n }, [_c('select', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.shadowSelected),\n expression: \"shadowSelected\"\n }],\n staticClass: \"shadow-switcher\",\n attrs: {\n \"id\": \"shadow-switcher\"\n },\n on: {\n \"change\": function($event) {\n var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n return o.selected\n }).map(function(o) {\n var val = \"_value\" in o ? o._value : o.value;\n return val\n });\n _vm.shadowSelected = $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n }\n }\n }, _vm._l((_vm.shadowsAvailable), function(shadow) {\n return _c('option', {\n domProps: {\n \"value\": shadow\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.shadows.components.' + shadow)) + \"\\n \")])\n }), 0), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-down-open\"\n })])]), _vm._v(\" \"), _c('div', {\n staticClass: \"override\"\n }, [_c('label', {\n staticClass: \"label\",\n attrs: {\n \"for\": \"override\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.shadows.override')) + \"\\n \")]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.currentShadowOverriden),\n expression: \"currentShadowOverriden\"\n }],\n staticClass: \"input-override\",\n attrs: {\n \"name\": \"override\",\n \"id\": \"override\",\n \"type\": \"checkbox\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.currentShadowOverriden) ? _vm._i(_vm.currentShadowOverriden, null) > -1 : (_vm.currentShadowOverriden)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.currentShadowOverriden,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.currentShadowOverriden = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.currentShadowOverriden = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.currentShadowOverriden = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n staticClass: \"checkbox-label\",\n attrs: {\n \"for\": \"override\"\n }\n })]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn\",\n on: {\n \"click\": _vm.clearShadows\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.clear_all')))])]), _vm._v(\" \"), _c('shadow-control', {\n attrs: {\n \"ready\": !!_vm.currentShadowFallback,\n \"fallback\": _vm.currentShadowFallback\n },\n model: {\n value: (_vm.currentShadow),\n callback: function($$v) {\n _vm.currentShadow = $$v\n },\n expression: \"currentShadow\"\n }\n }), _vm._v(\" \"), (_vm.shadowSelected === 'avatar' || _vm.shadowSelected === 'avatarStatus') ? _c('div', [_c('i18n', {\n attrs: {\n \"path\": \"settings.style.shadows.filter_hint.always_drop_shadow\",\n \"tag\": \"p\"\n }\n }, [_c('code', [_vm._v(\"filter: drop-shadow()\")])]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.style.shadows.filter_hint.avatar_inset')))]), _vm._v(\" \"), _c('i18n', {\n attrs: {\n \"path\": \"settings.style.shadows.filter_hint.drop_shadow_syntax\",\n \"tag\": \"p\"\n }\n }, [_c('code', [_vm._v(\"drop-shadow\")]), _vm._v(\" \"), _c('code', [_vm._v(\"spread-radius\")]), _vm._v(\" \"), _c('code', [_vm._v(\"inset\")])]), _vm._v(\" \"), _c('i18n', {\n attrs: {\n \"path\": \"settings.style.shadows.filter_hint.inset_classic\",\n \"tag\": \"p\"\n }\n }, [_c('code', [_vm._v(\"box-shadow\")])]), _vm._v(\" \"), _c('p', [_vm._v(_vm._s(_vm.$t('settings.style.shadows.filter_hint.spread_zero')))])], 1) : _vm._e()], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"fonts-container\",\n attrs: {\n \"label\": _vm.$t('settings.style.fonts._tab_label')\n }\n }, [_c('div', {\n staticClass: \"tab-header\"\n }, [_c('p', [_vm._v(_vm._s(_vm.$t('settings.style.fonts.help')))]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn\",\n on: {\n \"click\": _vm.clearFonts\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.clear_all')))])]), _vm._v(\" \"), _c('FontControl', {\n attrs: {\n \"name\": \"ui\",\n \"label\": _vm.$t('settings.style.fonts.components.interface'),\n \"fallback\": _vm.previewTheme.fonts.interface,\n \"no-inherit\": \"1\"\n },\n model: {\n value: (_vm.fontsLocal.interface),\n callback: function($$v) {\n _vm.$set(_vm.fontsLocal, \"interface\", $$v)\n },\n expression: \"fontsLocal.interface\"\n }\n }), _vm._v(\" \"), _c('FontControl', {\n attrs: {\n \"name\": \"input\",\n \"label\": _vm.$t('settings.style.fonts.components.input'),\n \"fallback\": _vm.previewTheme.fonts.input\n },\n model: {\n value: (_vm.fontsLocal.input),\n callback: function($$v) {\n _vm.$set(_vm.fontsLocal, \"input\", $$v)\n },\n expression: \"fontsLocal.input\"\n }\n }), _vm._v(\" \"), _c('FontControl', {\n attrs: {\n \"name\": \"post\",\n \"label\": _vm.$t('settings.style.fonts.components.post'),\n \"fallback\": _vm.previewTheme.fonts.post\n },\n model: {\n value: (_vm.fontsLocal.post),\n callback: function($$v) {\n _vm.$set(_vm.fontsLocal, \"post\", $$v)\n },\n expression: \"fontsLocal.post\"\n }\n }), _vm._v(\" \"), _c('FontControl', {\n attrs: {\n \"name\": \"postCode\",\n \"label\": _vm.$t('settings.style.fonts.components.postCode'),\n \"fallback\": _vm.previewTheme.fonts.postCode\n },\n model: {\n value: (_vm.fontsLocal.postCode),\n callback: function($$v) {\n _vm.$set(_vm.fontsLocal, \"postCode\", $$v)\n },\n expression: \"fontsLocal.postCode\"\n }\n })], 1)])], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"apply-container\"\n }, [_c('button', {\n staticClass: \"btn submit\",\n attrs: {\n \"disabled\": !_vm.themeValid\n },\n on: {\n \"click\": _vm.setCustomTheme\n }\n }, [_vm._v(_vm._s(_vm.$t('general.apply')))]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn\",\n on: {\n \"click\": _vm.clearAll\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.switcher.reset')))])])], 1)\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-ae8f5000\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/style_switcher/style_switcher.vue\n// module id = 730\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"panel dummy\"\n }, [_c('div', {\n staticClass: \"panel-heading\"\n }, [_c('div', {\n staticClass: \"title\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.header')) + \"\\n \"), _c('span', {\n staticClass: \"badge badge-notification\"\n }, [_vm._v(\"\\n 99\\n \")])]), _vm._v(\" \"), _c('span', {\n staticClass: \"faint\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.header_faint')) + \"\\n \")]), _vm._v(\" \"), _c('span', {\n staticClass: \"alert error\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.error')) + \"\\n \")]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.button')) + \"\\n \")])]), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-body theme-preview-content\"\n }, [_c('div', {\n staticClass: \"post\"\n }, [_c('div', {\n staticClass: \"avatar\"\n }, [_vm._v(\"\\n ( ͡° ͜ʖ ͡°)\\n \")]), _vm._v(\" \"), _c('div', {\n staticClass: \"content\"\n }, [_c('h4', [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.content')) + \"\\n \")]), _vm._v(\" \"), _c('i18n', {\n attrs: {\n \"path\": \"settings.style.preview.text\"\n }\n }, [_c('code', {\n staticStyle: {\n \"font-family\": \"var(--postCodeFont)\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.mono')) + \"\\n \")]), _vm._v(\" \"), _c('a', {\n staticStyle: {\n \"color\": \"var(--link)\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.link')) + \"\\n \")])]), _vm._v(\" \"), _vm._m(0)], 1)]), _vm._v(\" \"), _c('div', {\n staticClass: \"after-post\"\n }, [_c('div', {\n staticClass: \"avatar-alt\"\n }, [_vm._v(\"\\n :^)\\n \")]), _vm._v(\" \"), _c('div', {\n staticClass: \"content\"\n }, [_c('i18n', {\n staticClass: \"faint\",\n attrs: {\n \"path\": \"settings.style.preview.fine_print\",\n \"tag\": \"span\"\n }\n }, [_c('a', {\n staticStyle: {\n \"color\": \"var(--faintLink)\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.faint_link')) + \"\\n \")])])], 1)]), _vm._v(\" \"), _c('div', {\n staticClass: \"separator\"\n }), _vm._v(\" \"), _c('span', {\n staticClass: \"alert error\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.error')) + \"\\n \")]), _vm._v(\" \"), _c('input', {\n attrs: {\n \"type\": \"text\"\n },\n domProps: {\n \"value\": _vm.$t('settings.style.preview.input')\n }\n }), _vm._v(\" \"), _c('div', {\n staticClass: \"actions\"\n }, [_c('span', {\n staticClass: \"checkbox\"\n }, [_c('input', {\n attrs: {\n \"checked\": \"very yes\",\n \"type\": \"checkbox\",\n \"id\": \"preview_checkbox\"\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"preview_checkbox\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.style.preview.checkbox')))])]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.style.preview.button')) + \"\\n \")])])])])\n},staticRenderFns: [function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"icons\"\n }, [_c('i', {\n staticClass: \"button-icon icon-reply\",\n staticStyle: {\n \"color\": \"var(--cBlue)\"\n }\n }), _vm._v(\" \"), _c('i', {\n staticClass: \"button-icon icon-retweet\",\n staticStyle: {\n \"color\": \"var(--cGreen)\"\n }\n }), _vm._v(\" \"), _c('i', {\n staticClass: \"button-icon icon-star\",\n staticStyle: {\n \"color\": \"var(--cOrange)\"\n }\n }), _vm._v(\" \"), _c('i', {\n staticClass: \"button-icon icon-cancel\",\n staticStyle: {\n \"color\": \"var(--cRed)\"\n }\n })])\n}]}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-b5c96572\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/style_switcher/preview.vue\n// module id = 731\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return (_vm.loggedIn) ? _c('div', [_c('i', {\n staticClass: \"button-icon favorite-button fav-active\",\n class: _vm.classes,\n attrs: {\n \"title\": _vm.$t('tool_tip.favorite')\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n _vm.favorite()\n }\n }\n }), _vm._v(\" \"), (!_vm.hidePostStatsLocal && _vm.status.fave_num > 0) ? _c('span', [_vm._v(_vm._s(_vm.status.fave_num))]) : _vm._e()]) : _c('div', [_c('i', {\n staticClass: \"button-icon favorite-button\",\n class: _vm.classes,\n attrs: {\n \"title\": _vm.$t('tool_tip.favorite')\n }\n }), _vm._v(\" \"), (!_vm.hidePostStatsLocal && _vm.status.fave_num > 0) ? _c('span', [_vm._v(_vm._s(_vm.status.fave_num))]) : _vm._e()])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-bd666be8\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/favorite_button/favorite_button.vue\n// module id = 732\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"settings panel panel-default\"\n }, [_c('div', {\n staticClass: \"panel-heading\"\n }, [_c('div', {\n staticClass: \"title\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.settings')) + \"\\n \")]), _vm._v(\" \"), _c('transition', {\n attrs: {\n \"name\": \"fade\"\n }\n }, [(_vm.currentSaveStateNotice) ? [(_vm.currentSaveStateNotice.error) ? _c('div', {\n staticClass: \"alert error\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.saving_err')) + \"\\n \")]) : _vm._e(), _vm._v(\" \"), (!_vm.currentSaveStateNotice.error) ? _c('div', {\n staticClass: \"alert transparent\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.saving_ok')) + \"\\n \")]) : _vm._e()] : _vm._e()], 2)], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-body\"\n }, [_c('keep-alive', [_c('tab-switcher', [_c('div', {\n attrs: {\n \"label\": _vm.$t('settings.general')\n }\n }, [_c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.interface')))]), _vm._v(\" \"), _c('ul', {\n staticClass: \"setting-list\"\n }, [_c('li', [_c('interface-language-switcher')], 1), _vm._v(\" \"), (_vm.instanceSpecificPanelPresent) ? _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.hideISPLocal),\n expression: \"hideISPLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"hideISP\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.hideISPLocal) ? _vm._i(_vm.hideISPLocal, null) > -1 : (_vm.hideISPLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.hideISPLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.hideISPLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.hideISPLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.hideISPLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"hideISP\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.hide_isp')))])]) : _vm._e()])]), _vm._v(\" \"), _c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('nav.timeline')))]), _vm._v(\" \"), _c('ul', {\n staticClass: \"setting-list\"\n }, [_c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.collapseMessageWithSubjectLocal),\n expression: \"collapseMessageWithSubjectLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"collapseMessageWithSubject\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.collapseMessageWithSubjectLocal) ? _vm._i(_vm.collapseMessageWithSubjectLocal, null) > -1 : (_vm.collapseMessageWithSubjectLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.collapseMessageWithSubjectLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.collapseMessageWithSubjectLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.collapseMessageWithSubjectLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.collapseMessageWithSubjectLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"collapseMessageWithSubject\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.collapse_subject')) + \" \" + _vm._s(_vm.$t('settings.instance_default', {\n value: _vm.collapseMessageWithSubjectDefault\n })) + \"\\n \")])]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.streamingLocal),\n expression: \"streamingLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"streaming\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.streamingLocal) ? _vm._i(_vm.streamingLocal, null) > -1 : (_vm.streamingLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.streamingLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.streamingLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.streamingLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.streamingLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"streaming\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.streaming')))]), _vm._v(\" \"), _c('ul', {\n staticClass: \"setting-list suboptions\",\n class: [{\n disabled: !_vm.streamingLocal\n }]\n }, [_c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.pauseOnUnfocusedLocal),\n expression: \"pauseOnUnfocusedLocal\"\n }],\n attrs: {\n \"disabled\": !_vm.streamingLocal,\n \"type\": \"checkbox\",\n \"id\": \"pauseOnUnfocused\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.pauseOnUnfocusedLocal) ? _vm._i(_vm.pauseOnUnfocusedLocal, null) > -1 : (_vm.pauseOnUnfocusedLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.pauseOnUnfocusedLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.pauseOnUnfocusedLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.pauseOnUnfocusedLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.pauseOnUnfocusedLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"pauseOnUnfocused\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.pause_on_unfocused')))])])])]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.autoLoadLocal),\n expression: \"autoLoadLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"autoload\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.autoLoadLocal) ? _vm._i(_vm.autoLoadLocal, null) > -1 : (_vm.autoLoadLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.autoLoadLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.autoLoadLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.autoLoadLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.autoLoadLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"autoload\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.autoload')))])]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.hoverPreviewLocal),\n expression: \"hoverPreviewLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"hoverPreview\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.hoverPreviewLocal) ? _vm._i(_vm.hoverPreviewLocal, null) > -1 : (_vm.hoverPreviewLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.hoverPreviewLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.hoverPreviewLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.hoverPreviewLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.hoverPreviewLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"hoverPreview\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.reply_link_preview')))])])])]), _vm._v(\" \"), _c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.composing')))]), _vm._v(\" \"), _c('ul', {\n staticClass: \"setting-list\"\n }, [_c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.scopeCopyLocal),\n expression: \"scopeCopyLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"scopeCopy\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.scopeCopyLocal) ? _vm._i(_vm.scopeCopyLocal, null) > -1 : (_vm.scopeCopyLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.scopeCopyLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.scopeCopyLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.scopeCopyLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.scopeCopyLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"scopeCopy\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.scope_copy')) + \" \" + _vm._s(_vm.$t('settings.instance_default', {\n value: _vm.scopeCopyDefault\n })) + \"\\n \")])]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.alwaysShowSubjectInputLocal),\n expression: \"alwaysShowSubjectInputLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"subjectHide\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.alwaysShowSubjectInputLocal) ? _vm._i(_vm.alwaysShowSubjectInputLocal, null) > -1 : (_vm.alwaysShowSubjectInputLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.alwaysShowSubjectInputLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.alwaysShowSubjectInputLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.alwaysShowSubjectInputLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.alwaysShowSubjectInputLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"subjectHide\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.subject_input_always_show')) + \" \" + _vm._s(_vm.$t('settings.instance_default', {\n value: _vm.alwaysShowSubjectInputDefault\n })) + \"\\n \")])]), _vm._v(\" \"), _c('li', [_c('div', [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.subject_line_behavior')) + \"\\n \"), _c('label', {\n staticClass: \"select\",\n attrs: {\n \"for\": \"subjectLineBehavior\"\n }\n }, [_c('select', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.subjectLineBehaviorLocal),\n expression: \"subjectLineBehaviorLocal\"\n }],\n attrs: {\n \"id\": \"subjectLineBehavior\"\n },\n on: {\n \"change\": function($event) {\n var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n return o.selected\n }).map(function(o) {\n var val = \"_value\" in o ? o._value : o.value;\n return val\n });\n _vm.subjectLineBehaviorLocal = $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n }\n }\n }, [_c('option', {\n attrs: {\n \"value\": \"email\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.subject_line_email')) + \"\\n \" + _vm._s(_vm.subjectLineBehaviorDefault == 'email' ? _vm.$t('settings.instance_default_simple') : '') + \"\\n \")]), _vm._v(\" \"), _c('option', {\n attrs: {\n \"value\": \"masto\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.subject_line_mastodon')) + \"\\n \" + _vm._s(_vm.subjectLineBehaviorDefault == 'mastodon' ? _vm.$t('settings.instance_default_simple') : '') + \"\\n \")]), _vm._v(\" \"), _c('option', {\n attrs: {\n \"value\": \"noop\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.subject_line_noop')) + \"\\n \" + _vm._s(_vm.subjectLineBehaviorDefault == 'noop' ? _vm.$t('settings.instance_default_simple') : '') + \"\\n \")])]), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-down-open\"\n })])])]), _vm._v(\" \"), _c('li', [_c('div', [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.post_status_content_type')) + \"\\n \"), _c('label', {\n staticClass: \"select\",\n attrs: {\n \"for\": \"postContentType\"\n }\n }, [_c('select', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.postContentTypeLocal),\n expression: \"postContentTypeLocal\"\n }],\n attrs: {\n \"id\": \"postContentType\"\n },\n on: {\n \"change\": function($event) {\n var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n return o.selected\n }).map(function(o) {\n var val = \"_value\" in o ? o._value : o.value;\n return val\n });\n _vm.postContentTypeLocal = $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n }\n }\n }, _vm._l((_vm.postFormats), function(postFormat) {\n return _c('option', {\n key: postFormat,\n domProps: {\n \"value\": postFormat\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t((\"post_status.content_type[\\\"\" + postFormat + \"\\\"]\"))) + \"\\n \" + _vm._s(_vm.postContentTypeDefault === postFormat ? _vm.$t('settings.instance_default_simple') : '') + \"\\n \")])\n }), 0), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-down-open\"\n })])])])])]), _vm._v(\" \"), _c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.attachments')))]), _vm._v(\" \"), _c('ul', {\n staticClass: \"setting-list\"\n }, [_c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.hideAttachmentsLocal),\n expression: \"hideAttachmentsLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"hideAttachments\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.hideAttachmentsLocal) ? _vm._i(_vm.hideAttachmentsLocal, null) > -1 : (_vm.hideAttachmentsLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.hideAttachmentsLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.hideAttachmentsLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.hideAttachmentsLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.hideAttachmentsLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"hideAttachments\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.hide_attachments_in_tl')))])]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.hideAttachmentsInConvLocal),\n expression: \"hideAttachmentsInConvLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"hideAttachmentsInConv\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.hideAttachmentsInConvLocal) ? _vm._i(_vm.hideAttachmentsInConvLocal, null) > -1 : (_vm.hideAttachmentsInConvLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.hideAttachmentsInConvLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.hideAttachmentsInConvLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.hideAttachmentsInConvLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.hideAttachmentsInConvLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"hideAttachmentsInConv\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.hide_attachments_in_convo')))])]), _vm._v(\" \"), _c('li', [_c('label', {\n attrs: {\n \"for\": \"maxThumbnails\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.max_thumbnails')))]), _vm._v(\" \"), _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model.number\",\n value: (_vm.maxThumbnails),\n expression: \"maxThumbnails\",\n modifiers: {\n \"number\": true\n }\n }],\n staticClass: \"number-input\",\n attrs: {\n \"type\": \"number\",\n \"id\": \"maxThumbnails\",\n \"min\": \"0\",\n \"step\": \"1\"\n },\n domProps: {\n \"value\": (_vm.maxThumbnails)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.maxThumbnails = _vm._n($event.target.value)\n },\n \"blur\": function($event) {\n _vm.$forceUpdate()\n }\n }\n })]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.hideNsfwLocal),\n expression: \"hideNsfwLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"hideNsfw\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.hideNsfwLocal) ? _vm._i(_vm.hideNsfwLocal, null) > -1 : (_vm.hideNsfwLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.hideNsfwLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.hideNsfwLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.hideNsfwLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.hideNsfwLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"hideNsfw\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.nsfw_clickthrough')))])]), _vm._v(\" \"), _c('ul', {\n staticClass: \"setting-list suboptions\"\n }, [_c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.preloadImage),\n expression: \"preloadImage\"\n }],\n attrs: {\n \"disabled\": !_vm.hideNsfwLocal,\n \"type\": \"checkbox\",\n \"id\": \"preloadImage\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.preloadImage) ? _vm._i(_vm.preloadImage, null) > -1 : (_vm.preloadImage)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.preloadImage,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.preloadImage = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.preloadImage = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.preloadImage = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"preloadImage\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.preload_images')))])]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.useOneClickNsfw),\n expression: \"useOneClickNsfw\"\n }],\n attrs: {\n \"disabled\": !_vm.hideNsfwLocal,\n \"type\": \"checkbox\",\n \"id\": \"useOneClickNsfw\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.useOneClickNsfw) ? _vm._i(_vm.useOneClickNsfw, null) > -1 : (_vm.useOneClickNsfw)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.useOneClickNsfw,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.useOneClickNsfw = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.useOneClickNsfw = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.useOneClickNsfw = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"useOneClickNsfw\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.use_one_click_nsfw')))])])]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.stopGifs),\n expression: \"stopGifs\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"stopGifs\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.stopGifs) ? _vm._i(_vm.stopGifs, null) > -1 : (_vm.stopGifs)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.stopGifs,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.stopGifs = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.stopGifs = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.stopGifs = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"stopGifs\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.stop_gifs')))])]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.loopVideoLocal),\n expression: \"loopVideoLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"loopVideo\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.loopVideoLocal) ? _vm._i(_vm.loopVideoLocal, null) > -1 : (_vm.loopVideoLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.loopVideoLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.loopVideoLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.loopVideoLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.loopVideoLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"loopVideo\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.loop_video')))]), _vm._v(\" \"), _c('ul', {\n staticClass: \"setting-list suboptions\",\n class: [{\n disabled: !_vm.streamingLocal\n }]\n }, [_c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.loopVideoSilentOnlyLocal),\n expression: \"loopVideoSilentOnlyLocal\"\n }],\n attrs: {\n \"disabled\": !_vm.loopVideoLocal || !_vm.loopSilentAvailable,\n \"type\": \"checkbox\",\n \"id\": \"loopVideoSilentOnly\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.loopVideoSilentOnlyLocal) ? _vm._i(_vm.loopVideoSilentOnlyLocal, null) > -1 : (_vm.loopVideoSilentOnlyLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.loopVideoSilentOnlyLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.loopVideoSilentOnlyLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.loopVideoSilentOnlyLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.loopVideoSilentOnlyLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"loopVideoSilentOnly\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.loop_video_silent_only')))]), _vm._v(\" \"), (!_vm.loopSilentAvailable) ? _c('div', {\n staticClass: \"unavailable\"\n }, [_c('i', {\n staticClass: \"icon-globe\"\n }), _vm._v(\"! \" + _vm._s(_vm.$t('settings.limited_availability')) + \"\\n \")]) : _vm._e()])])]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.playVideosInModal),\n expression: \"playVideosInModal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"playVideosInModal\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.playVideosInModal) ? _vm._i(_vm.playVideosInModal, null) > -1 : (_vm.playVideosInModal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.playVideosInModal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.playVideosInModal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.playVideosInModal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.playVideosInModal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"playVideosInModal\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.play_videos_in_modal')))])]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.useContainFit),\n expression: \"useContainFit\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"useContainFit\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.useContainFit) ? _vm._i(_vm.useContainFit, null) > -1 : (_vm.useContainFit)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.useContainFit,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.useContainFit = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.useContainFit = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.useContainFit = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"useContainFit\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.use_contain_fit')))])])])]), _vm._v(\" \"), _c('div', {\n staticClass: \"setting-item\"\n }, [_c('h2', [_vm._v(_vm._s(_vm.$t('settings.notifications')))]), _vm._v(\" \"), _c('ul', {\n staticClass: \"setting-list\"\n }, [_c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.webPushNotificationsLocal),\n expression: \"webPushNotificationsLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"webPushNotifications\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.webPushNotificationsLocal) ? _vm._i(_vm.webPushNotificationsLocal, null) > -1 : (_vm.webPushNotificationsLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.webPushNotificationsLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.webPushNotificationsLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.webPushNotificationsLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.webPushNotificationsLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"webPushNotifications\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.enable_web_push_notifications')) + \"\\n \")])])])])]), _vm._v(\" \"), _c('div', {\n attrs: {\n \"label\": _vm.$t('settings.theme')\n }\n }, [_c('div', {\n staticClass: \"setting-item\"\n }, [_c('style-switcher')], 1)]), _vm._v(\" \"), _c('div', {\n attrs: {\n \"label\": _vm.$t('settings.filtering')\n }\n }, [_c('div', {\n staticClass: \"setting-item\"\n }, [_c('div', {\n staticClass: \"select-multiple\"\n }, [_c('span', {\n staticClass: \"label\"\n }, [_vm._v(_vm._s(_vm.$t('settings.notification_visibility')))]), _vm._v(\" \"), _c('ul', {\n staticClass: \"option-list\"\n }, [_c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.notificationVisibilityLocal.likes),\n expression: \"notificationVisibilityLocal.likes\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"notification-visibility-likes\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.notificationVisibilityLocal.likes) ? _vm._i(_vm.notificationVisibilityLocal.likes, null) > -1 : (_vm.notificationVisibilityLocal.likes)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.notificationVisibilityLocal.likes,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.$set(_vm.notificationVisibilityLocal, \"likes\", $$a.concat([$$v])))\n } else {\n $$i > -1 && (_vm.$set(_vm.notificationVisibilityLocal, \"likes\", $$a.slice(0, $$i).concat($$a.slice($$i + 1))))\n }\n } else {\n _vm.$set(_vm.notificationVisibilityLocal, \"likes\", $$c)\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"notification-visibility-likes\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.notification_visibility_likes')) + \"\\n \")])]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.notificationVisibilityLocal.repeats),\n expression: \"notificationVisibilityLocal.repeats\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"notification-visibility-repeats\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.notificationVisibilityLocal.repeats) ? _vm._i(_vm.notificationVisibilityLocal.repeats, null) > -1 : (_vm.notificationVisibilityLocal.repeats)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.notificationVisibilityLocal.repeats,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.$set(_vm.notificationVisibilityLocal, \"repeats\", $$a.concat([$$v])))\n } else {\n $$i > -1 && (_vm.$set(_vm.notificationVisibilityLocal, \"repeats\", $$a.slice(0, $$i).concat($$a.slice($$i + 1))))\n }\n } else {\n _vm.$set(_vm.notificationVisibilityLocal, \"repeats\", $$c)\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"notification-visibility-repeats\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.notification_visibility_repeats')) + \"\\n \")])]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.notificationVisibilityLocal.follows),\n expression: \"notificationVisibilityLocal.follows\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"notification-visibility-follows\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.notificationVisibilityLocal.follows) ? _vm._i(_vm.notificationVisibilityLocal.follows, null) > -1 : (_vm.notificationVisibilityLocal.follows)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.notificationVisibilityLocal.follows,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.$set(_vm.notificationVisibilityLocal, \"follows\", $$a.concat([$$v])))\n } else {\n $$i > -1 && (_vm.$set(_vm.notificationVisibilityLocal, \"follows\", $$a.slice(0, $$i).concat($$a.slice($$i + 1))))\n }\n } else {\n _vm.$set(_vm.notificationVisibilityLocal, \"follows\", $$c)\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"notification-visibility-follows\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.notification_visibility_follows')) + \"\\n \")])]), _vm._v(\" \"), _c('li', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.notificationVisibilityLocal.mentions),\n expression: \"notificationVisibilityLocal.mentions\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"notification-visibility-mentions\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.notificationVisibilityLocal.mentions) ? _vm._i(_vm.notificationVisibilityLocal.mentions, null) > -1 : (_vm.notificationVisibilityLocal.mentions)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.notificationVisibilityLocal.mentions,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.$set(_vm.notificationVisibilityLocal, \"mentions\", $$a.concat([$$v])))\n } else {\n $$i > -1 && (_vm.$set(_vm.notificationVisibilityLocal, \"mentions\", $$a.slice(0, $$i).concat($$a.slice($$i + 1))))\n }\n } else {\n _vm.$set(_vm.notificationVisibilityLocal, \"mentions\", $$c)\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"notification-visibility-mentions\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.notification_visibility_mentions')) + \"\\n \")])])])]), _vm._v(\" \"), _c('div', [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.replies_in_timeline')) + \"\\n \"), _c('label', {\n staticClass: \"select\",\n attrs: {\n \"for\": \"replyVisibility\"\n }\n }, [_c('select', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.replyVisibilityLocal),\n expression: \"replyVisibilityLocal\"\n }],\n attrs: {\n \"id\": \"replyVisibility\"\n },\n on: {\n \"change\": function($event) {\n var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n return o.selected\n }).map(function(o) {\n var val = \"_value\" in o ? o._value : o.value;\n return val\n });\n _vm.replyVisibilityLocal = $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n }\n }\n }, [_c('option', {\n attrs: {\n \"value\": \"all\",\n \"selected\": \"\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.reply_visibility_all')))]), _vm._v(\" \"), _c('option', {\n attrs: {\n \"value\": \"following\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.reply_visibility_following')))]), _vm._v(\" \"), _c('option', {\n attrs: {\n \"value\": \"self\"\n }\n }, [_vm._v(_vm._s(_vm.$t('settings.reply_visibility_self')))])]), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-down-open\"\n })])]), _vm._v(\" \"), _c('div', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.hidePostStatsLocal),\n expression: \"hidePostStatsLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"hidePostStats\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.hidePostStatsLocal) ? _vm._i(_vm.hidePostStatsLocal, null) > -1 : (_vm.hidePostStatsLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.hidePostStatsLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.hidePostStatsLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.hidePostStatsLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.hidePostStatsLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"hidePostStats\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.hide_post_stats')) + \" \" + _vm._s(_vm.$t('settings.instance_default', {\n value: _vm.hidePostStatsDefault\n })) + \"\\n \")])]), _vm._v(\" \"), _c('div', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.hideUserStatsLocal),\n expression: \"hideUserStatsLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"hideUserStats\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.hideUserStatsLocal) ? _vm._i(_vm.hideUserStatsLocal, null) > -1 : (_vm.hideUserStatsLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.hideUserStatsLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.hideUserStatsLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.hideUserStatsLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.hideUserStatsLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"hideUserStats\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.hide_user_stats')) + \" \" + _vm._s(_vm.$t('settings.instance_default', {\n value: _vm.hideUserStatsDefault\n })) + \"\\n \")])])]), _vm._v(\" \"), _c('div', {\n staticClass: \"setting-item\"\n }, [_c('div', [_c('p', [_vm._v(_vm._s(_vm.$t('settings.filtering_explanation')))]), _vm._v(\" \"), _c('textarea', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.muteWordsString),\n expression: \"muteWordsString\"\n }],\n attrs: {\n \"id\": \"muteWords\"\n },\n domProps: {\n \"value\": (_vm.muteWordsString)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.muteWordsString = $event.target.value\n }\n }\n })]), _vm._v(\" \"), _c('div', [_c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.hideFilteredStatusesLocal),\n expression: \"hideFilteredStatusesLocal\"\n }],\n attrs: {\n \"type\": \"checkbox\",\n \"id\": \"hideFilteredStatuses\"\n },\n domProps: {\n \"checked\": Array.isArray(_vm.hideFilteredStatusesLocal) ? _vm._i(_vm.hideFilteredStatusesLocal, null) > -1 : (_vm.hideFilteredStatusesLocal)\n },\n on: {\n \"change\": function($event) {\n var $$a = _vm.hideFilteredStatusesLocal,\n $$el = $event.target,\n $$c = $$el.checked ? (true) : (false);\n if (Array.isArray($$a)) {\n var $$v = null,\n $$i = _vm._i($$a, $$v);\n if ($$el.checked) {\n $$i < 0 && (_vm.hideFilteredStatusesLocal = $$a.concat([$$v]))\n } else {\n $$i > -1 && (_vm.hideFilteredStatusesLocal = $$a.slice(0, $$i).concat($$a.slice($$i + 1)))\n }\n } else {\n _vm.hideFilteredStatusesLocal = $$c\n }\n }\n }\n }), _vm._v(\" \"), _c('label', {\n attrs: {\n \"for\": \"hideFilteredStatuses\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('settings.hide_filtered_statuses')) + \" \" + _vm._s(_vm.$t('settings.instance_default', {\n value: _vm.hideFilteredStatusesDefault\n })) + \"\\n \")])])])])])], 1)], 1)])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-cd51c000\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/settings/settings.vue\n// module id = 733\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"nav-panel\"\n }, [_c('div', {\n staticClass: \"panel panel-default\"\n }, [_c('ul', [(_vm.currentUser) ? _c('li', [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'friends'\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.timeline\")) + \"\\n \")])], 1) : _vm._e(), _vm._v(\" \"), (_vm.currentUser) ? _c('li', [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'mentions',\n params: {\n username: _vm.currentUser.screen_name\n }\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.mentions\")) + \"\\n \")])], 1) : _vm._e(), _vm._v(\" \"), (_vm.currentUser) ? _c('li', [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'dms',\n params: {\n username: _vm.currentUser.screen_name\n }\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.dms\")) + \"\\n \")])], 1) : _vm._e(), _vm._v(\" \"), (_vm.currentUser && _vm.currentUser.locked) ? _c('li', [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'friend-requests'\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.friend_requests\")) + \"\\n \"), (_vm.followRequestCount > 0) ? _c('span', {\n staticClass: \"badge follow-request-count\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.followRequestCount) + \"\\n \")]) : _vm._e()])], 1) : _vm._e(), _vm._v(\" \"), _c('li', [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'public-timeline'\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.public_tl\")) + \"\\n \")])], 1), _vm._v(\" \"), _c('li', [_c('router-link', {\n attrs: {\n \"to\": {\n name: 'public-external-timeline'\n }\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t(\"nav.twkn\")) + \"\\n \")])], 1)])])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-d306a29c\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/nav_panel/nav_panel.vue\n// module id = 734\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n ref: \"galleryContainer\",\n staticStyle: {\n \"width\": \"100%\"\n }\n }, _vm._l((_vm.rows), function(row) {\n return _c('div', {\n staticClass: \"gallery-row\",\n class: {\n 'contain-fit': _vm.useContainFit, 'cover-fit': !_vm.useContainFit\n },\n style: (_vm.rowHeight(row.length))\n }, _vm._l((row), function(attachment) {\n return _c('attachment', {\n key: attachment.id,\n attrs: {\n \"setMedia\": _vm.setMedia,\n \"nsfw\": _vm.nsfw,\n \"attachment\": attachment,\n \"allowPlay\": false\n }\n })\n }), 1)\n }), 0)\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-d4665f74\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/gallery/gallery.vue\n// module id = 735\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"who-to-follow-panel\"\n }, [_c('div', {\n staticClass: \"panel panel-default base01-background\"\n }, [_c('div', {\n staticClass: \"panel-heading timeline-heading base02-background base04\"\n }, [_c('div', {\n staticClass: \"title\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('who_to_follow.who_to_follow')) + \"\\n \")])]), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-body who-to-follow\"\n }, [_vm._l((_vm.usersToFollow), function(user) {\n return _c('span', [_c('img', {\n attrs: {\n \"src\": user.img\n }\n }), _vm._v(\" \"), _c('router-link', {\n attrs: {\n \"to\": _vm.userProfileLink(user.id, user.name)\n }\n }, [_vm._v(\"\\n \" + _vm._s(user.name) + \"\\n \")]), _c('br')], 1)\n }), _vm._v(\" \"), _c('img', {\n attrs: {\n \"src\": _vm.$store.state.instance.logo\n }\n }), _vm._v(\" \"), _c('router-link', {\n attrs: {\n \"to\": {\n name: 'who-to-follow'\n }\n }\n }, [_vm._v(_vm._s(_vm.$t('who_to_follow.more')))])], 2)])])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-d8fd69d8\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/who_to_follow_panel/who_to_follow_panel.vue\n// module id = 736\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"import-export-container\"\n }, [_vm._t(\"before\"), _vm._v(\" \"), _c('button', {\n staticClass: \"btn\",\n on: {\n \"click\": _vm.exportData\n }\n }, [_vm._v(_vm._s(_vm.exportLabel))]), _vm._v(\" \"), _c('button', {\n staticClass: \"btn\",\n on: {\n \"click\": _vm.importData\n }\n }, [_vm._v(_vm._s(_vm.importLabel))]), _vm._v(\" \"), _vm._t(\"afterButtons\"), _vm._v(\" \"), (_vm.importFailed) ? _c('p', {\n staticClass: \"alert error\"\n }, [_vm._v(_vm._s(_vm.importFailedText))]) : _vm._e(), _vm._v(\" \"), _vm._t(\"afterError\")], 2)\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-e5bdcefc\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/export_import/export_import.vue\n// module id = 737\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"user-panel\"\n }, [(_vm.user) ? _c('div', {\n staticClass: \"panel panel-default\",\n staticStyle: {\n \"overflow\": \"visible\"\n }\n }, [_c('UserCard', {\n attrs: {\n \"user\": _vm.user,\n \"hideBio\": true,\n \"rounded\": \"top\"\n }\n }), _vm._v(\" \"), _c('div', {\n staticClass: \"panel-footer\"\n }, [(_vm.user) ? _c('post-status-form') : _vm._e()], 1)], 1) : _vm._e(), _vm._v(\" \"), (!_vm.user) ? _c('login-form') : _vm._e()], 1)\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-eda04b40\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/user_panel/user_panel.vue\n// module id = 738\n// module chunks = 2","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n staticClass: \"user-card\",\n class: _vm.classes,\n style: (_vm.style)\n }, [_c('div', {\n staticClass: \"panel-heading\"\n }, [_c('div', {\n staticClass: \"user-info\"\n }, [_c('div', {\n staticClass: \"container\"\n }, [_c('router-link', {\n attrs: {\n \"to\": _vm.userProfileLink(_vm.user)\n }\n }, [_c('UserAvatar', {\n attrs: {\n \"betterShadow\": _vm.betterShadow,\n \"src\": _vm.user.profile_image_url_original\n }\n })], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"name-and-screen-name\"\n }, [_c('div', {\n staticClass: \"top-line\"\n }, [(_vm.user.name_html) ? _c('div', {\n staticClass: \"user-name\",\n attrs: {\n \"title\": _vm.user.name\n },\n domProps: {\n \"innerHTML\": _vm._s(_vm.user.name_html)\n }\n }) : _c('div', {\n staticClass: \"user-name\",\n attrs: {\n \"title\": _vm.user.name\n }\n }, [_vm._v(_vm._s(_vm.user.name))]), _vm._v(\" \"), (!_vm.isOtherUser) ? _c('router-link', {\n attrs: {\n \"to\": {\n name: 'user-settings'\n }\n }\n }, [_c('i', {\n staticClass: \"button-icon icon-pencil usersettings\",\n attrs: {\n \"title\": _vm.$t('tool_tip.user_settings')\n }\n })]) : _vm._e(), _vm._v(\" \"), (_vm.isOtherUser && !_vm.user.is_local) ? _c('a', {\n attrs: {\n \"href\": _vm.user.statusnet_profile_url,\n \"target\": \"_blank\"\n }\n }, [_c('i', {\n staticClass: \"icon-link-ext usersettings\"\n })]) : _vm._e()], 1), _vm._v(\" \"), _c('router-link', {\n staticClass: \"user-screen-name\",\n attrs: {\n \"to\": _vm.userProfileLink(_vm.user)\n }\n }, [_c('span', {\n staticClass: \"handle\"\n }, [_vm._v(\"@\" + _vm._s(_vm.user.screen_name) + \"\\n \"), (!_vm.hideBio && !!_vm.visibleRole) ? _c('span', {\n staticClass: \"alert staff\"\n }, [_vm._v(_vm._s(_vm.visibleRole))]) : _vm._e()]), (_vm.user.locked) ? _c('span', [_c('i', {\n staticClass: \"icon icon-lock\"\n })]) : _vm._e(), _vm._v(\" \"), (!_vm.hideUserStatsLocal && !_vm.hideBio) ? _c('span', {\n staticClass: \"dailyAvg\"\n }, [_vm._v(_vm._s(_vm.dailyAvg) + \" \" + _vm._s(_vm.$t('user_card.per_day')))]) : _vm._e()])], 1)], 1), _vm._v(\" \"), _c('div', {\n staticClass: \"user-meta\"\n }, [(_vm.user.follows_you && _vm.loggedIn && _vm.isOtherUser) ? _c('div', {\n staticClass: \"following\"\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follows_you')) + \"\\n \")]) : _vm._e(), _vm._v(\" \"), (_vm.isOtherUser && (_vm.loggedIn || !_vm.switcher)) ? _c('div', {\n staticClass: \"highlighter\"\n }, [(_vm.userHighlightType !== 'disabled') ? _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.userHighlightColor),\n expression: \"userHighlightColor\"\n }],\n staticClass: \"userHighlightText\",\n attrs: {\n \"type\": \"text\",\n \"id\": 'userHighlightColorTx' + _vm.user.id\n },\n domProps: {\n \"value\": (_vm.userHighlightColor)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.userHighlightColor = $event.target.value\n }\n }\n }) : _vm._e(), _vm._v(\" \"), (_vm.userHighlightType !== 'disabled') ? _c('input', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.userHighlightColor),\n expression: \"userHighlightColor\"\n }],\n staticClass: \"userHighlightCl\",\n attrs: {\n \"type\": \"color\",\n \"id\": 'userHighlightColor' + _vm.user.id\n },\n domProps: {\n \"value\": (_vm.userHighlightColor)\n },\n on: {\n \"input\": function($event) {\n if ($event.target.composing) { return; }\n _vm.userHighlightColor = $event.target.value\n }\n }\n }) : _vm._e(), _vm._v(\" \"), _c('label', {\n staticClass: \"userHighlightSel select\",\n attrs: {\n \"for\": \"style-switcher\"\n }\n }, [_c('select', {\n directives: [{\n name: \"model\",\n rawName: \"v-model\",\n value: (_vm.userHighlightType),\n expression: \"userHighlightType\"\n }],\n staticClass: \"userHighlightSel\",\n attrs: {\n \"id\": 'userHighlightSel' + _vm.user.id\n },\n on: {\n \"change\": function($event) {\n var $$selectedVal = Array.prototype.filter.call($event.target.options, function(o) {\n return o.selected\n }).map(function(o) {\n var val = \"_value\" in o ? o._value : o.value;\n return val\n });\n _vm.userHighlightType = $event.target.multiple ? $$selectedVal : $$selectedVal[0]\n }\n }\n }, [_c('option', {\n attrs: {\n \"value\": \"disabled\"\n }\n }, [_vm._v(\"No highlight\")]), _vm._v(\" \"), _c('option', {\n attrs: {\n \"value\": \"solid\"\n }\n }, [_vm._v(\"Solid bg\")]), _vm._v(\" \"), _c('option', {\n attrs: {\n \"value\": \"striped\"\n }\n }, [_vm._v(\"Striped bg\")]), _vm._v(\" \"), _c('option', {\n attrs: {\n \"value\": \"side\"\n }\n }, [_vm._v(\"Side stripe\")])]), _vm._v(\" \"), _c('i', {\n staticClass: \"icon-down-open\"\n })])]) : _vm._e()]), _vm._v(\" \"), (_vm.isOtherUser) ? _c('div', {\n staticClass: \"user-interactions\"\n }, [(_vm.loggedIn) ? _c('div', {\n staticClass: \"follow\"\n }, [(_vm.user.following) ? _c('span', [_c('button', {\n staticClass: \"pressed\",\n attrs: {\n \"disabled\": _vm.followRequestInProgress,\n \"title\": _vm.$t('user_card.follow_unfollow')\n },\n on: {\n \"click\": _vm.unfollowUser\n }\n }, [(_vm.followRequestInProgress) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follow_progress')) + \"\\n \")] : [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.following')) + \"\\n \")]], 2)]) : _vm._e(), _vm._v(\" \"), (!_vm.user.following) ? _c('span', [_c('button', {\n attrs: {\n \"disabled\": _vm.followRequestInProgress,\n \"title\": _vm.followRequestSent ? _vm.$t('user_card.follow_again') : ''\n },\n on: {\n \"click\": _vm.followUser\n }\n }, [(_vm.followRequestInProgress) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follow_progress')) + \"\\n \")] : (_vm.followRequestSent) ? [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follow_sent')) + \"\\n \")] : [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.follow')) + \"\\n \")]], 2)]) : _vm._e()]) : _vm._e(), _vm._v(\" \"), (_vm.isOtherUser && _vm.loggedIn) ? _c('div', {\n staticClass: \"mute\"\n }, [(_vm.user.muted) ? _c('span', [_c('button', {\n staticClass: \"pressed\",\n on: {\n \"click\": _vm.toggleMute\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.muted')) + \"\\n \")])]) : _vm._e(), _vm._v(\" \"), (!_vm.user.muted) ? _c('span', [_c('button', {\n on: {\n \"click\": _vm.toggleMute\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.mute')) + \"\\n \")])]) : _vm._e()]) : _vm._e(), _vm._v(\" \"), (!_vm.loggedIn && _vm.user.is_local) ? _c('div', {\n staticClass: \"remote-follow\"\n }, [_c('form', {\n attrs: {\n \"method\": \"POST\",\n \"action\": _vm.subscribeUrl\n }\n }, [_c('input', {\n attrs: {\n \"type\": \"hidden\",\n \"name\": \"nickname\"\n },\n domProps: {\n \"value\": _vm.user.screen_name\n }\n }), _vm._v(\" \"), _c('input', {\n attrs: {\n \"type\": \"hidden\",\n \"name\": \"profile\",\n \"value\": \"\"\n }\n }), _vm._v(\" \"), _c('button', {\n staticClass: \"remote-button\",\n attrs: {\n \"click\": \"submit\"\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.remote_follow')) + \"\\n \")])])]) : _vm._e(), _vm._v(\" \"), (_vm.isOtherUser && _vm.loggedIn) ? _c('div', {\n staticClass: \"block\"\n }, [(_vm.user.statusnet_blocking) ? _c('span', [_c('button', {\n staticClass: \"pressed\",\n on: {\n \"click\": _vm.unblockUser\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.blocked')) + \"\\n \")])]) : _vm._e(), _vm._v(\" \"), (!_vm.user.statusnet_blocking) ? _c('span', [_c('button', {\n on: {\n \"click\": _vm.blockUser\n }\n }, [_vm._v(\"\\n \" + _vm._s(_vm.$t('user_card.block')) + \"\\n \")])]) : _vm._e()]) : _vm._e()]) : _vm._e()])]), _vm._v(\" \"), (!_vm.hideBio) ? _c('div', {\n staticClass: \"panel-body\"\n }, [(!_vm.hideUserStatsLocal && _vm.switcher) ? _c('div', {\n staticClass: \"user-counts\"\n }, [_c('div', {\n staticClass: \"user-count\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n _vm.setProfileView('statuses')\n }\n }\n }, [_c('h5', [_vm._v(_vm._s(_vm.$t('user_card.statuses')))]), _vm._v(\" \"), _c('span', [_vm._v(_vm._s(_vm.user.statuses_count) + \" \"), _c('br')])]), _vm._v(\" \"), _c('div', {\n staticClass: \"user-count\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n _vm.setProfileView('friends')\n }\n }\n }, [_c('h5', [_vm._v(_vm._s(_vm.$t('user_card.followees')))]), _vm._v(\" \"), _c('span', [_vm._v(_vm._s(_vm.user.friends_count))])]), _vm._v(\" \"), _c('div', {\n staticClass: \"user-count\",\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n _vm.setProfileView('followers')\n }\n }\n }, [_c('h5', [_vm._v(_vm._s(_vm.$t('user_card.followers')))]), _vm._v(\" \"), _c('span', [_vm._v(_vm._s(_vm.user.followers_count))])])]) : _vm._e(), _vm._v(\" \"), (!_vm.hideBio && _vm.user.description_html) ? _c('p', {\n staticClass: \"user-card-bio\",\n domProps: {\n \"innerHTML\": _vm._s(_vm.user.description_html)\n },\n on: {\n \"click\": function($event) {\n $event.preventDefault();\n return _vm.linkClicked($event)\n }\n }\n }) : (!_vm.hideBio) ? _c('p', {\n staticClass: \"user-card-bio\"\n }, [_vm._v(_vm._s(_vm.user.description))]) : _vm._e()]) : _vm._e()])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-f117c42c\"}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/components/user_card/user_card.vue\n// module id = 739\n// module chunks = 2"],"sourceRoot":""} \ No newline at end of file diff --git a/priv/static/static/js/manifest.6c8fd5aa8c8c4aee99d3.js b/priv/static/static/js/manifest.0b2f423dda42f0dbbf65.js similarity index 86% rename from priv/static/static/js/manifest.6c8fd5aa8c8c4aee99d3.js rename to priv/static/static/js/manifest.0b2f423dda42f0dbbf65.js index 5de86e9fb..ecc4a13d3 100644 --- a/priv/static/static/js/manifest.6c8fd5aa8c8c4aee99d3.js +++ b/priv/static/static/js/manifest.0b2f423dda42f0dbbf65.js @@ -1,2 +1,2 @@ -!function(e){function t(r){if(n[r])return n[r].exports;var a=n[r]={exports:{},id:r,loaded:!1};return e[r].call(a.exports,a,a.exports,t),a.loaded=!0,a.exports}var r=window.webpackJsonp;window.webpackJsonp=function(o,p){for(var c,l,s=0,i=[];s true\n\t *\n\t * _.isArray(document.body.children);\n\t * // => false\n\t *\n\t * _.isArray('abc');\n\t * // => false\n\t *\n\t * _.isArray(_.noop);\n\t * // => false\n\t */\n\tvar isArray = Array.isArray;\n\t\n\tmodule.exports = isArray;\n\n\n/***/ }),\n/* 5 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\tvar global = __webpack_require__(6);\n\tvar core = __webpack_require__(2);\n\tvar ctx = __webpack_require__(19);\n\tvar hide = __webpack_require__(20);\n\tvar has = __webpack_require__(27);\n\tvar PROTOTYPE = 'prototype';\n\t\n\tvar $export = function (type, name, source) {\n\t var IS_FORCED = type & $export.F;\n\t var IS_GLOBAL = type & $export.G;\n\t var IS_STATIC = type & $export.S;\n\t var IS_PROTO = type & $export.P;\n\t var IS_BIND = type & $export.B;\n\t var IS_WRAP = type & $export.W;\n\t var exports = IS_GLOBAL ? core : core[name] || (core[name] = {});\n\t var expProto = exports[PROTOTYPE];\n\t var target = IS_GLOBAL ? global : IS_STATIC ? global[name] : (global[name] || {})[PROTOTYPE];\n\t var key, own, out;\n\t if (IS_GLOBAL) source = name;\n\t for (key in source) {\n\t // contains in native\n\t own = !IS_FORCED && target && target[key] !== undefined;\n\t if (own && has(exports, key)) continue;\n\t // export native or passed\n\t out = own ? target[key] : source[key];\n\t // prevent global pollution for namespaces\n\t exports[key] = IS_GLOBAL && typeof target[key] != 'function' ? source[key]\n\t // bind timers to global for call from export context\n\t : IS_BIND && own ? ctx(out, global)\n\t // wrap global constructors for prevent change them in library\n\t : IS_WRAP && target[key] == out ? (function (C) {\n\t var F = function (a, b, c) {\n\t if (this instanceof C) {\n\t switch (arguments.length) {\n\t case 0: return new C();\n\t case 1: return new C(a);\n\t case 2: return new C(a, b);\n\t } return new C(a, b, c);\n\t } return C.apply(this, arguments);\n\t };\n\t F[PROTOTYPE] = C[PROTOTYPE];\n\t return F;\n\t // make static versions for prototype methods\n\t })(out) : IS_PROTO && typeof out == 'function' ? ctx(Function.call, out) : out;\n\t // export proto methods to core.%CONSTRUCTOR%.methods.%NAME%\n\t if (IS_PROTO) {\n\t (exports.virtual || (exports.virtual = {}))[key] = out;\n\t // export proto methods to core.%CONSTRUCTOR%.prototype.%NAME%\n\t if (type & $export.R && expProto && !expProto[key]) hide(expProto, key, out);\n\t }\n\t }\n\t};\n\t// type bitmap\n\t$export.F = 1; // forced\n\t$export.G = 2; // global\n\t$export.S = 4; // static\n\t$export.P = 8; // proto\n\t$export.B = 16; // bind\n\t$export.W = 32; // wrap\n\t$export.U = 64; // safe\n\t$export.R = 128; // real proto method for `library`\n\tmodule.exports = $export;\n\n\n/***/ }),\n/* 6 */\n/***/ (function(module, exports) {\n\n\t// https://github.com/zloirock/core-js/issues/86#issuecomment-115759028\n\tvar global = module.exports = typeof window != 'undefined' && window.Math == Math\n\t ? window : typeof self != 'undefined' && self.Math == Math ? self\n\t // eslint-disable-next-line no-new-func\n\t : Function('return this')();\n\tif (typeof __g == 'number') __g = global; // eslint-disable-line no-undef\n\n\n/***/ }),\n/* 7 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\tvar store = __webpack_require__(103)('wks');\n\tvar uid = __webpack_require__(70);\n\tvar Symbol = __webpack_require__(6).Symbol;\n\tvar USE_SYMBOL = typeof Symbol == 'function';\n\t\n\tvar $exports = module.exports = function (name) {\n\t return store[name] || (store[name] =\n\t USE_SYMBOL && Symbol[name] || (USE_SYMBOL ? Symbol : uid)('Symbol.' + name));\n\t};\n\t\n\t$exports.store = store;\n\n\n/***/ }),\n/* 8 */\n/***/ (function(module, exports, __webpack_require__) {\n\n\t/* WEBPACK VAR INJECTION */(function(global, setImmediate) {/*!\n\t * Vue.js v2.5.21\n\t * (c) 2014-2018 Evan You\n\t * Released under the MIT License.\n\t */\n\t'use strict';\n\t\n\t/* */\n\t\n\tvar emptyObject = Object.freeze({});\n\t\n\t// These helpers produce better VM code in JS engines due to their\n\t// explicitness and function inlining.\n\tfunction isUndef (v) {\n\t return v === undefined || v === null\n\t}\n\t\n\tfunction isDef (v) {\n\t return v !== undefined && v !== null\n\t}\n\t\n\tfunction isTrue (v) {\n\t return v === true\n\t}\n\t\n\tfunction isFalse (v) {\n\t return v === false\n\t}\n\t\n\t/**\n\t * Check if value is primitive.\n\t */\n\tfunction isPrimitive (value) {\n\t return (\n\t typeof value === 'string' ||\n\t typeof value === 'number' ||\n\t // $flow-disable-line\n\t typeof value === 'symbol' ||\n\t typeof value === 'boolean'\n\t )\n\t}\n\t\n\t/**\n\t * Quick object check - this is primarily used to tell\n\t * Objects from primitive values when we know the value\n\t * is a JSON-compliant type.\n\t */\n\tfunction isObject (obj) {\n\t return obj !== null && typeof obj === 'object'\n\t}\n\t\n\t/**\n\t * Get the raw type string of a value, e.g., [object Object].\n\t */\n\tvar _toString = Object.prototype.toString;\n\t\n\tfunction toRawType (value) {\n\t return _toString.call(value).slice(8, -1)\n\t}\n\t\n\t/**\n\t * Strict object type check. Only returns true\n\t * for plain JavaScript objects.\n\t */\n\tfunction isPlainObject (obj) {\n\t return _toString.call(obj) === '[object Object]'\n\t}\n\t\n\tfunction isRegExp (v) {\n\t return _toString.call(v) === '[object RegExp]'\n\t}\n\t\n\t/**\n\t * Check if val is a valid array index.\n\t */\n\tfunction isValidArrayIndex (val) {\n\t var n = parseFloat(String(val));\n\t return n >= 0 && Math.floor(n) === n && isFinite(val)\n\t}\n\t\n\t/**\n\t * Convert a value to a string that is actually rendered.\n\t */\n\tfunction toString (val) {\n\t return val == null\n\t ? ''\n\t : typeof val === 'object'\n\t ? JSON.stringify(val, null, 2)\n\t : String(val)\n\t}\n\t\n\t/**\n\t * Convert an input value to a number for persistence.\n\t * If the conversion fails, return original string.\n\t */\n\tfunction toNumber (val) {\n\t var n = parseFloat(val);\n\t return isNaN(n) ? val : n\n\t}\n\t\n\t/**\n\t * Make a map and return a function for checking if a key\n\t * is in that map.\n\t */\n\tfunction makeMap (\n\t str,\n\t expectsLowerCase\n\t) {\n\t var map = Object.create(null);\n\t var list = str.split(',');\n\t for (var i = 0; i < list.length; i++) {\n\t map[list[i]] = true;\n\t }\n\t return expectsLowerCase\n\t ? function (val) { return map[val.toLowerCase()]; }\n\t : function (val) { return map[val]; }\n\t}\n\t\n\t/**\n\t * Check if a tag is a built-in tag.\n\t */\n\tvar isBuiltInTag = makeMap('slot,component', true);\n\t\n\t/**\n\t * Check if an attribute is a reserved attribute.\n\t */\n\tvar isReservedAttribute = makeMap('key,ref,slot,slot-scope,is');\n\t\n\t/**\n\t * Remove an item from an array.\n\t */\n\tfunction remove (arr, item) {\n\t if (arr.length) {\n\t var index = arr.indexOf(item);\n\t if (index > -1) {\n\t return arr.splice(index, 1)\n\t }\n\t }\n\t}\n\t\n\t/**\n\t * Check whether an object has the property.\n\t */\n\tvar hasOwnProperty = Object.prototype.hasOwnProperty;\n\tfunction hasOwn (obj, key) {\n\t return hasOwnProperty.call(obj, key)\n\t}\n\t\n\t/**\n\t * Create a cached version of a pure function.\n\t */\n\tfunction cached (fn) {\n\t var cache = Object.create(null);\n\t return (function cachedFn (str) {\n\t var hit = cache[str];\n\t return hit || (cache[str] = fn(str))\n\t })\n\t}\n\t\n\t/**\n\t * Camelize a hyphen-delimited string.\n\t */\n\tvar camelizeRE = /-(\\w)/g;\n\tvar camelize = cached(function (str) {\n\t return str.replace(camelizeRE, function (_, c) { return c ? c.toUpperCase() : ''; })\n\t});\n\t\n\t/**\n\t * Capitalize a string.\n\t */\n\tvar capitalize = cached(function (str) {\n\t return str.charAt(0).toUpperCase() + str.slice(1)\n\t});\n\t\n\t/**\n\t * Hyphenate a camelCase string.\n\t */\n\tvar hyphenateRE = /\\B([A-Z])/g;\n\tvar hyphenate = cached(function (str) {\n\t return str.replace(hyphenateRE, '-$1').toLowerCase()\n\t});\n\t\n\t/**\n\t * Simple bind polyfill for environments that do not support it,\n\t * e.g., PhantomJS 1.x. Technically, we don't need this anymore\n\t * since native bind is now performant enough in most browsers.\n\t * But removing it would mean breaking code that was able to run in\n\t * PhantomJS 1.x, so this must be kept for backward compatibility.\n\t */\n\t\n\t/* istanbul ignore next */\n\tfunction polyfillBind (fn, ctx) {\n\t function boundFn (a) {\n\t var l = arguments.length;\n\t return l\n\t ? l > 1\n\t ? fn.apply(ctx, arguments)\n\t : fn.call(ctx, a)\n\t : fn.call(ctx)\n\t }\n\t\n\t boundFn._length = fn.length;\n\t return boundFn\n\t}\n\t\n\tfunction nativeBind (fn, ctx) {\n\t return fn.bind(ctx)\n\t}\n\t\n\tvar bind = Function.prototype.bind\n\t ? nativeBind\n\t : polyfillBind;\n\t\n\t/**\n\t * Convert an Array-like object to a real Array.\n\t */\n\tfunction toArray (list, start) {\n\t start = start || 0;\n\t var i = list.length - start;\n\t var ret = new Array(i);\n\t while (i--) {\n\t ret[i] = list[i + start];\n\t }\n\t return ret\n\t}\n\t\n\t/**\n\t * Mix properties into target object.\n\t */\n\tfunction extend (to, _from) {\n\t for (var key in _from) {\n\t to[key] = _from[key];\n\t }\n\t return to\n\t}\n\t\n\t/**\n\t * Merge an Array of Objects into a single Object.\n\t */\n\tfunction toObject (arr) {\n\t var res = {};\n\t for (var i = 0; i < arr.length; i++) {\n\t if (arr[i]) {\n\t extend(res, arr[i]);\n\t }\n\t }\n\t return res\n\t}\n\t\n\t/* eslint-disable no-unused-vars */\n\t\n\t/**\n\t * Perform no operation.\n\t * Stubbing args to make Flow happy without leaving useless transpiled code\n\t * with ...rest (https://flow.org/blog/2017/05/07/Strict-Function-Call-Arity/).\n\t */\n\tfunction noop (a, b, c) {}\n\t\n\t/**\n\t * Always return false.\n\t */\n\tvar no = function (a, b, c) { return false; };\n\t\n\t/* eslint-enable no-unused-vars */\n\t\n\t/**\n\t * Return the same value.\n\t */\n\tvar identity = function (_) { return _; };\n\t\n\t/**\n\t * Check if two values are loosely equal - that is,\n\t * if they are plain objects, do they have the same shape?\n\t */\n\tfunction looseEqual (a, b) {\n\t if (a === b) { return true }\n\t var isObjectA = isObject(a);\n\t var isObjectB = isObject(b);\n\t if (isObjectA && isObjectB) {\n\t try {\n\t var isArrayA = Array.isArray(a);\n\t var isArrayB = Array.isArray(b);\n\t if (isArrayA && isArrayB) {\n\t return a.length === b.length && a.every(function (e, i) {\n\t return looseEqual(e, b[i])\n\t })\n\t } else if (a instanceof Date && b instanceof Date) {\n\t return a.getTime() === b.getTime()\n\t } else if (!isArrayA && !isArrayB) {\n\t var keysA = Object.keys(a);\n\t var keysB = Object.keys(b);\n\t return keysA.length === keysB.length && keysA.every(function (key) {\n\t return looseEqual(a[key], b[key])\n\t })\n\t } else {\n\t /* istanbul ignore next */\n\t return false\n\t }\n\t } catch (e) {\n\t /* istanbul ignore next */\n\t return false\n\t }\n\t } else if (!isObjectA && !isObjectB) {\n\t return String(a) === String(b)\n\t } else {\n\t return false\n\t }\n\t}\n\t\n\t/**\n\t * Return the first index at which a loosely equal value can be\n\t * found in the array (if value is a plain object, the array must\n\t * contain an object of the same shape), or -1 if it is not present.\n\t */\n\tfunction looseIndexOf (arr, val) {\n\t for (var i = 0; i < arr.length; i++) {\n\t if (looseEqual(arr[i], val)) { return i }\n\t }\n\t return -1\n\t}\n\t\n\t/**\n\t * Ensure a function is called only once.\n\t */\n\tfunction once (fn) {\n\t var called = false;\n\t return function () {\n\t if (!called) {\n\t called = true;\n\t fn.apply(this, arguments);\n\t }\n\t }\n\t}\n\t\n\tvar SSR_ATTR = 'data-server-rendered';\n\t\n\tvar ASSET_TYPES = [\n\t 'component',\n\t 'directive',\n\t 'filter'\n\t];\n\t\n\tvar LIFECYCLE_HOOKS = [\n\t 'beforeCreate',\n\t 'created',\n\t 'beforeMount',\n\t 'mounted',\n\t 'beforeUpdate',\n\t 'updated',\n\t 'beforeDestroy',\n\t 'destroyed',\n\t 'activated',\n\t 'deactivated',\n\t 'errorCaptured'\n\t];\n\t\n\t/* */\n\t\n\t\n\t\n\tvar config = ({\n\t /**\n\t * Option merge strategies (used in core/util/options)\n\t */\n\t // $flow-disable-line\n\t optionMergeStrategies: Object.create(null),\n\t\n\t /**\n\t * Whether to suppress warnings.\n\t */\n\t silent: false,\n\t\n\t /**\n\t * Show production mode tip message on boot?\n\t */\n\t productionTip: (\"production\") !== 'production',\n\t\n\t /**\n\t * Whether to enable devtools\n\t */\n\t devtools: (\"production\") !== 'production',\n\t\n\t /**\n\t * Whether to record perf\n\t */\n\t performance: false,\n\t\n\t /**\n\t * Error handler for watcher errors\n\t */\n\t errorHandler: null,\n\t\n\t /**\n\t * Warn handler for watcher warns\n\t */\n\t warnHandler: null,\n\t\n\t /**\n\t * Ignore certain custom elements\n\t */\n\t ignoredElements: [],\n\t\n\t /**\n\t * Custom user key aliases for v-on\n\t */\n\t // $flow-disable-line\n\t keyCodes: Object.create(null),\n\t\n\t /**\n\t * Check if a tag is reserved so that it cannot be registered as a\n\t * component. This is platform-dependent and may be overwritten.\n\t */\n\t isReservedTag: no,\n\t\n\t /**\n\t * Check if an attribute is reserved so that it cannot be used as a component\n\t * prop. This is platform-dependent and may be overwritten.\n\t */\n\t isReservedAttr: no,\n\t\n\t /**\n\t * Check if a tag is an unknown element.\n\t * Platform-dependent.\n\t */\n\t isUnknownElement: no,\n\t\n\t /**\n\t * Get the namespace of an element\n\t */\n\t getTagNamespace: noop,\n\t\n\t /**\n\t * Parse the real tag name for the specific platform.\n\t */\n\t parsePlatformTagName: identity,\n\t\n\t /**\n\t * Check if an attribute must be bound using property, e.g. value\n\t * Platform-dependent.\n\t */\n\t mustUseProp: no,\n\t\n\t /**\n\t * Perform updates asynchronously. Intended to be used by Vue Test Utils\n\t * This will significantly reduce performance if set to false.\n\t */\n\t async: true,\n\t\n\t /**\n\t * Exposed for legacy reasons\n\t */\n\t _lifecycleHooks: LIFECYCLE_HOOKS\n\t});\n\t\n\t/* */\n\t\n\t/**\n\t * Check if a string starts with $ or _\n\t */\n\tfunction isReserved (str) {\n\t var c = (str + '').charCodeAt(0);\n\t return c === 0x24 || c === 0x5F\n\t}\n\t\n\t/**\n\t * Define a property.\n\t */\n\tfunction def (obj, key, val, enumerable) {\n\t Object.defineProperty(obj, key, {\n\t value: val,\n\t enumerable: !!enumerable,\n\t writable: true,\n\t configurable: true\n\t });\n\t}\n\t\n\t/**\n\t * Parse simple path.\n\t */\n\tvar bailRE = /[^\\w.$]/;\n\tfunction parsePath (path) {\n\t if (bailRE.test(path)) {\n\t return\n\t }\n\t var segments = path.split('.');\n\t return function (obj) {\n\t for (var i = 0; i < segments.length; i++) {\n\t if (!obj) { return }\n\t obj = obj[segments[i]];\n\t }\n\t return obj\n\t }\n\t}\n\t\n\t/* */\n\t\n\t// can we use __proto__?\n\tvar hasProto = '__proto__' in {};\n\t\n\t// Browser environment sniffing\n\tvar inBrowser = typeof window !== 'undefined';\n\tvar inWeex = typeof WXEnvironment !== 'undefined' && !!WXEnvironment.platform;\n\tvar weexPlatform = inWeex && WXEnvironment.platform.toLowerCase();\n\tvar UA = inBrowser && window.navigator.userAgent.toLowerCase();\n\tvar isIE = UA && /msie|trident/.test(UA);\n\tvar isIE9 = UA && UA.indexOf('msie 9.0') > 0;\n\tvar isEdge = UA && UA.indexOf('edge/') > 0;\n\tvar isAndroid = (UA && UA.indexOf('android') > 0) || (weexPlatform === 'android');\n\tvar isIOS = (UA && /iphone|ipad|ipod|ios/.test(UA)) || (weexPlatform === 'ios');\n\tvar isChrome = UA && /chrome\\/\\d+/.test(UA) && !isEdge;\n\t\n\t// Firefox has a \"watch\" function on Object.prototype...\n\tvar nativeWatch = ({}).watch;\n\t\n\tvar supportsPassive = false;\n\tif (inBrowser) {\n\t try {\n\t var opts = {};\n\t Object.defineProperty(opts, 'passive', ({\n\t get: function get () {\n\t /* istanbul ignore next */\n\t supportsPassive = true;\n\t }\n\t })); // https://github.com/facebook/flow/issues/285\n\t window.addEventListener('test-passive', null, opts);\n\t } catch (e) {}\n\t}\n\t\n\t// this needs to be lazy-evaled because vue may be required before\n\t// vue-server-renderer can set VUE_ENV\n\tvar _isServer;\n\tvar isServerRendering = function () {\n\t if (_isServer === undefined) {\n\t /* istanbul ignore if */\n\t if (!inBrowser && !inWeex && typeof global !== 'undefined') {\n\t // detect presence of vue-server-renderer and avoid\n\t // Webpack shimming the process\n\t _isServer = global['process'] && global['process'].env.VUE_ENV === 'server';\n\t } else {\n\t _isServer = false;\n\t }\n\t }\n\t return _isServer\n\t};\n\t\n\t// detect devtools\n\tvar devtools = inBrowser && window.__VUE_DEVTOOLS_GLOBAL_HOOK__;\n\t\n\t/* istanbul ignore next */\n\tfunction isNative (Ctor) {\n\t return typeof Ctor === 'function' && /native code/.test(Ctor.toString())\n\t}\n\t\n\tvar hasSymbol =\n\t typeof Symbol !== 'undefined' && isNative(Symbol) &&\n\t typeof Reflect !== 'undefined' && isNative(Reflect.ownKeys);\n\t\n\tvar _Set;\n\t/* istanbul ignore if */ // $flow-disable-line\n\tif (typeof Set !== 'undefined' && isNative(Set)) {\n\t // use native Set when available.\n\t _Set = Set;\n\t} else {\n\t // a non-standard Set polyfill that only works with primitive keys.\n\t _Set = /*@__PURE__*/(function () {\n\t function Set () {\n\t this.set = Object.create(null);\n\t }\n\t Set.prototype.has = function has (key) {\n\t return this.set[key] === true\n\t };\n\t Set.prototype.add = function add (key) {\n\t this.set[key] = true;\n\t };\n\t Set.prototype.clear = function clear () {\n\t this.set = Object.create(null);\n\t };\n\t\n\t return Set;\n\t }());\n\t}\n\t\n\t/* */\n\t\n\tvar warn = noop;\n\tvar tip = noop;\n\tvar generateComponentTrace = (noop); // work around flow check\n\tvar formatComponentName = (noop);\n\t\n\tif (false) {\n\t var hasConsole = typeof console !== 'undefined';\n\t var classifyRE = /(?:^|[-_])(\\w)/g;\n\t var classify = function (str) { return str\n\t .replace(classifyRE, function (c) { return c.toUpperCase(); })\n\t .replace(/[-_]/g, ''); };\n\t\n\t warn = function (msg, vm) {\n\t var trace = vm ? generateComponentTrace(vm) : '';\n\t\n\t if (config.warnHandler) {\n\t config.warnHandler.call(null, msg, vm, trace);\n\t } else if (hasConsole && (!config.silent)) {\n\t console.error((\"[Vue warn]: \" + msg + trace));\n\t }\n\t };\n\t\n\t tip = function (msg, vm) {\n\t if (hasConsole && (!config.silent)) {\n\t console.warn(\"[Vue tip]: \" + msg + (\n\t vm ? generateComponentTrace(vm) : ''\n\t ));\n\t }\n\t };\n\t\n\t formatComponentName = function (vm, includeFile) {\n\t if (vm.$root === vm) {\n\t return ''\n\t }\n\t var options = typeof vm === 'function' && vm.cid != null\n\t ? vm.options\n\t : vm._isVue\n\t ? vm.$options || vm.constructor.options\n\t : vm || {};\n\t var name = options.name || options._componentTag;\n\t var file = options.__file;\n\t if (!name && file) {\n\t var match = file.match(/([^/\\\\]+)\\.vue$/);\n\t name = match && match[1];\n\t }\n\t\n\t return (\n\t (name ? (\"<\" + (classify(name)) + \">\") : \"\") +\n\t (file && includeFile !== false ? (\" at \" + file) : '')\n\t )\n\t };\n\t\n\t var repeat = function (str, n) {\n\t var res = '';\n\t while (n) {\n\t if (n % 2 === 1) { res += str; }\n\t if (n > 1) { str += str; }\n\t n >>= 1;\n\t }\n\t return res\n\t };\n\t\n\t generateComponentTrace = function (vm) {\n\t if (vm._isVue && vm.$parent) {\n\t var tree = [];\n\t var currentRecursiveSequence = 0;\n\t while (vm) {\n\t if (tree.length > 0) {\n\t var last = tree[tree.length - 1];\n\t if (last.constructor === vm.constructor) {\n\t currentRecursiveSequence++;\n\t vm = vm.$parent;\n\t continue\n\t } else if (currentRecursiveSequence > 0) {\n\t tree[tree.length - 1] = [last, currentRecursiveSequence];\n\t currentRecursiveSequence = 0;\n\t }\n\t }\n\t tree.push(vm);\n\t vm = vm.$parent;\n\t }\n\t return '\\n\\nfound in\\n\\n' + tree\n\t .map(function (vm, i) { return (\"\" + (i === 0 ? '---> ' : repeat(' ', 5 + i * 2)) + (Array.isArray(vm)\n\t ? ((formatComponentName(vm[0])) + \"... (\" + (vm[1]) + \" recursive calls)\")\n\t : formatComponentName(vm))); })\n\t .join('\\n')\n\t } else {\n\t return (\"\\n\\n(found in \" + (formatComponentName(vm)) + \")\")\n\t }\n\t };\n\t}\n\t\n\t/* */\n\t\n\tvar uid = 0;\n\t\n\t/**\n\t * A dep is an observable that can have multiple\n\t * directives subscribing to it.\n\t */\n\tvar Dep = function Dep () {\n\t this.id = uid++;\n\t this.subs = [];\n\t};\n\t\n\tDep.prototype.addSub = function addSub (sub) {\n\t this.subs.push(sub);\n\t};\n\t\n\tDep.prototype.removeSub = function removeSub (sub) {\n\t remove(this.subs, sub);\n\t};\n\t\n\tDep.prototype.depend = function depend () {\n\t if (Dep.target) {\n\t Dep.target.addDep(this);\n\t }\n\t};\n\t\n\tDep.prototype.notify = function notify () {\n\t // stabilize the subscriber list first\n\t var subs = this.subs.slice();\n\t if (false) {\n\t // subs aren't sorted in scheduler if not running async\n\t // we need to sort them now to make sure they fire in correct\n\t // order\n\t subs.sort(function (a, b) { return a.id - b.id; });\n\t }\n\t for (var i = 0, l = subs.length; i < l; i++) {\n\t subs[i].update();\n\t }\n\t};\n\t\n\t// the current target watcher being evaluated.\n\t// this is globally unique because there could be only one\n\t// watcher being evaluated at any time.\n\tDep.target = null;\n\tvar targetStack = [];\n\t\n\tfunction pushTarget (target) {\n\t targetStack.push(target);\n\t Dep.target = target;\n\t}\n\t\n\tfunction popTarget () {\n\t targetStack.pop();\n\t Dep.target = targetStack[targetStack.length - 1];\n\t}\n\t\n\t/* */\n\t\n\tvar VNode = function VNode (\n\t tag,\n\t data,\n\t children,\n\t text,\n\t elm,\n\t context,\n\t componentOptions,\n\t asyncFactory\n\t) {\n\t this.tag = tag;\n\t this.data = data;\n\t this.children = children;\n\t this.text = text;\n\t this.elm = elm;\n\t this.ns = undefined;\n\t this.context = context;\n\t this.fnContext = undefined;\n\t this.fnOptions = undefined;\n\t this.fnScopeId = undefined;\n\t this.key = data && data.key;\n\t this.componentOptions = componentOptions;\n\t this.componentInstance = undefined;\n\t this.parent = undefined;\n\t this.raw = false;\n\t this.isStatic = false;\n\t this.isRootInsert = true;\n\t this.isComment = false;\n\t this.isCloned = false;\n\t this.isOnce = false;\n\t this.asyncFactory = asyncFactory;\n\t this.asyncMeta = undefined;\n\t this.isAsyncPlaceholder = false;\n\t};\n\t\n\tvar prototypeAccessors = { child: { configurable: true } };\n\t\n\t// DEPRECATED: alias for componentInstance for backwards compat.\n\t/* istanbul ignore next */\n\tprototypeAccessors.child.get = function () {\n\t return this.componentInstance\n\t};\n\t\n\tObject.defineProperties( VNode.prototype, prototypeAccessors );\n\t\n\tvar createEmptyVNode = function (text) {\n\t if ( text === void 0 ) text = '';\n\t\n\t var node = new VNode();\n\t node.text = text;\n\t node.isComment = true;\n\t return node\n\t};\n\t\n\tfunction createTextVNode (val) {\n\t return new VNode(undefined, undefined, undefined, String(val))\n\t}\n\t\n\t// optimized shallow clone\n\t// used for static nodes and slot nodes because they may be reused across\n\t// multiple renders, cloning them avoids errors when DOM manipulations rely\n\t// on their elm reference.\n\tfunction cloneVNode (vnode) {\n\t var cloned = new VNode(\n\t vnode.tag,\n\t vnode.data,\n\t // #7975\n\t // clone children array to avoid mutating original in case of cloning\n\t // a child.\n\t vnode.children && vnode.children.slice(),\n\t vnode.text,\n\t vnode.elm,\n\t vnode.context,\n\t vnode.componentOptions,\n\t vnode.asyncFactory\n\t );\n\t cloned.ns = vnode.ns;\n\t cloned.isStatic = vnode.isStatic;\n\t cloned.key = vnode.key;\n\t cloned.isComment = vnode.isComment;\n\t cloned.fnContext = vnode.fnContext;\n\t cloned.fnOptions = vnode.fnOptions;\n\t cloned.fnScopeId = vnode.fnScopeId;\n\t cloned.asyncMeta = vnode.asyncMeta;\n\t cloned.isCloned = true;\n\t return cloned\n\t}\n\t\n\t/*\n\t * not type checking this file because flow doesn't play well with\n\t * dynamically accessing methods on Array prototype\n\t */\n\t\n\tvar arrayProto = Array.prototype;\n\tvar arrayMethods = Object.create(arrayProto);\n\t\n\tvar methodsToPatch = [\n\t 'push',\n\t 'pop',\n\t 'shift',\n\t 'unshift',\n\t 'splice',\n\t 'sort',\n\t 'reverse'\n\t];\n\t\n\t/**\n\t * Intercept mutating methods and emit events\n\t */\n\tmethodsToPatch.forEach(function (method) {\n\t // cache original method\n\t var original = arrayProto[method];\n\t def(arrayMethods, method, function mutator () {\n\t var args = [], len = arguments.length;\n\t while ( len-- ) args[ len ] = arguments[ len ];\n\t\n\t var result = original.apply(this, args);\n\t var ob = this.__ob__;\n\t var inserted;\n\t switch (method) {\n\t case 'push':\n\t case 'unshift':\n\t inserted = args;\n\t break\n\t case 'splice':\n\t inserted = args.slice(2);\n\t break\n\t }\n\t if (inserted) { ob.observeArray(inserted); }\n\t // notify change\n\t ob.dep.notify();\n\t return result\n\t });\n\t});\n\t\n\t/* */\n\t\n\tvar arrayKeys = Object.getOwnPropertyNames(arrayMethods);\n\t\n\t/**\n\t * In some cases we may want to disable observation inside a component's\n\t * update computation.\n\t */\n\tvar shouldObserve = true;\n\t\n\tfunction toggleObserving (value) {\n\t shouldObserve = value;\n\t}\n\t\n\t/**\n\t * Observer class that is attached to each observed\n\t * object. Once attached, the observer converts the target\n\t * object's property keys into getter/setters that\n\t * collect dependencies and dispatch updates.\n\t */\n\tvar Observer = function Observer (value) {\n\t this.value = value;\n\t this.dep = new Dep();\n\t this.vmCount = 0;\n\t def(value, '__ob__', this);\n\t if (Array.isArray(value)) {\n\t if (hasProto) {\n\t protoAugment(value, arrayMethods);\n\t } else {\n\t copyAugment(value, arrayMethods, arrayKeys);\n\t }\n\t this.observeArray(value);\n\t } else {\n\t this.walk(value);\n\t }\n\t};\n\t\n\t/**\n\t * Walk through all properties and convert them into\n\t * getter/setters. This method should only be called when\n\t * value type is Object.\n\t */\n\tObserver.prototype.walk = function walk (obj) {\n\t var keys = Object.keys(obj);\n\t for (var i = 0; i < keys.length; i++) {\n\t defineReactive$$1(obj, keys[i]);\n\t }\n\t};\n\t\n\t/**\n\t * Observe a list of Array items.\n\t */\n\tObserver.prototype.observeArray = function observeArray (items) {\n\t for (var i = 0, l = items.length; i < l; i++) {\n\t observe(items[i]);\n\t }\n\t};\n\t\n\t// helpers\n\t\n\t/**\n\t * Augment a target Object or Array by intercepting\n\t * the prototype chain using __proto__\n\t */\n\tfunction protoAugment (target, src) {\n\t /* eslint-disable no-proto */\n\t target.__proto__ = src;\n\t /* eslint-enable no-proto */\n\t}\n\t\n\t/**\n\t * Augment a target Object or Array by defining\n\t * hidden properties.\n\t */\n\t/* istanbul ignore next */\n\tfunction copyAugment (target, src, keys) {\n\t for (var i = 0, l = keys.length; i < l; i++) {\n\t var key = keys[i];\n\t def(target, key, src[key]);\n\t }\n\t}\n\t\n\t/**\n\t * Attempt to create an observer instance for a value,\n\t * returns the new observer if successfully observed,\n\t * or the existing observer if the value already has one.\n\t */\n\tfunction observe (value, asRootData) {\n\t if (!isObject(value) || value instanceof VNode) {\n\t return\n\t }\n\t var ob;\n\t if (hasOwn(value, '__ob__') && value.__ob__ instanceof Observer) {\n\t ob = value.__ob__;\n\t } else if (\n\t shouldObserve &&\n\t !isServerRendering() &&\n\t (Array.isArray(value) || isPlainObject(value)) &&\n\t Object.isExtensible(value) &&\n\t !value._isVue\n\t ) {\n\t ob = new Observer(value);\n\t }\n\t if (asRootData && ob) {\n\t ob.vmCount++;\n\t }\n\t return ob\n\t}\n\t\n\t/**\n\t * Define a reactive property on an Object.\n\t */\n\tfunction defineReactive$$1 (\n\t obj,\n\t key,\n\t val,\n\t customSetter,\n\t shallow\n\t) {\n\t var dep = new Dep();\n\t\n\t var property = Object.getOwnPropertyDescriptor(obj, key);\n\t if (property && property.configurable === false) {\n\t return\n\t }\n\t\n\t // cater for pre-defined getter/setters\n\t var getter = property && property.get;\n\t var setter = property && property.set;\n\t if ((!getter || setter) && arguments.length === 2) {\n\t val = obj[key];\n\t }\n\t\n\t var childOb = !shallow && observe(val);\n\t Object.defineProperty(obj, key, {\n\t enumerable: true,\n\t configurable: true,\n\t get: function reactiveGetter () {\n\t var value = getter ? getter.call(obj) : val;\n\t if (Dep.target) {\n\t dep.depend();\n\t if (childOb) {\n\t childOb.dep.depend();\n\t if (Array.isArray(value)) {\n\t dependArray(value);\n\t }\n\t }\n\t }\n\t return value\n\t },\n\t set: function reactiveSetter (newVal) {\n\t var value = getter ? getter.call(obj) : val;\n\t /* eslint-disable no-self-compare */\n\t if (newVal === value || (newVal !== newVal && value !== value)) {\n\t return\n\t }\n\t /* eslint-enable no-self-compare */\n\t if (false) {\n\t customSetter();\n\t }\n\t // #7981: for accessor properties without setter\n\t if (getter && !setter) { return }\n\t if (setter) {\n\t setter.call(obj, newVal);\n\t } else {\n\t val = newVal;\n\t }\n\t childOb = !shallow && observe(newVal);\n\t dep.notify();\n\t }\n\t });\n\t}\n\t\n\t/**\n\t * Set a property on an object. Adds the new property and\n\t * triggers change notification if the property doesn't\n\t * already exist.\n\t */\n\tfunction set (target, key, val) {\n\t if (false\n\t ) {\n\t warn((\"Cannot set reactive property on undefined, null, or primitive value: \" + ((target))));\n\t }\n\t if (Array.isArray(target) && isValidArrayIndex(key)) {\n\t target.length = Math.max(target.length, key);\n\t target.splice(key, 1, val);\n\t return val\n\t }\n\t if (key in target && !(key in Object.prototype)) {\n\t target[key] = val;\n\t return val\n\t }\n\t var ob = (target).__ob__;\n\t if (target._isVue || (ob && ob.vmCount)) {\n\t (\"production\") !== 'production' && warn(\n\t 'Avoid adding reactive properties to a Vue instance or its root $data ' +\n\t 'at runtime - declare it upfront in the data option.'\n\t );\n\t return val\n\t }\n\t if (!ob) {\n\t target[key] = val;\n\t return val\n\t }\n\t defineReactive$$1(ob.value, key, val);\n\t ob.dep.notify();\n\t return val\n\t}\n\t\n\t/**\n\t * Delete a property and trigger change if necessary.\n\t */\n\tfunction del (target, key) {\n\t if (false\n\t ) {\n\t warn((\"Cannot delete reactive property on undefined, null, or primitive value: \" + ((target))));\n\t }\n\t if (Array.isArray(target) && isValidArrayIndex(key)) {\n\t target.splice(key, 1);\n\t return\n\t }\n\t var ob = (target).__ob__;\n\t if (target._isVue || (ob && ob.vmCount)) {\n\t (\"production\") !== 'production' && warn(\n\t 'Avoid deleting properties on a Vue instance or its root $data ' +\n\t '- just set it to null.'\n\t );\n\t return\n\t }\n\t if (!hasOwn(target, key)) {\n\t return\n\t }\n\t delete target[key];\n\t if (!ob) {\n\t return\n\t }\n\t ob.dep.notify();\n\t}\n\t\n\t/**\n\t * Collect dependencies on array elements when the array is touched, since\n\t * we cannot intercept array element access like property getters.\n\t */\n\tfunction dependArray (value) {\n\t for (var e = (void 0), i = 0, l = value.length; i < l; i++) {\n\t e = value[i];\n\t e && e.__ob__ && e.__ob__.dep.depend();\n\t if (Array.isArray(e)) {\n\t dependArray(e);\n\t }\n\t }\n\t}\n\t\n\t/* */\n\t\n\t/**\n\t * Option overwriting strategies are functions that handle\n\t * how to merge a parent option value and a child option\n\t * value into the final value.\n\t */\n\tvar strats = config.optionMergeStrategies;\n\t\n\t/**\n\t * Options with restrictions\n\t */\n\tif (false) {\n\t strats.el = strats.propsData = function (parent, child, vm, key) {\n\t if (!vm) {\n\t warn(\n\t \"option \\\"\" + key + \"\\\" can only be used during instance \" +\n\t 'creation with the `new` keyword.'\n\t );\n\t }\n\t return defaultStrat(parent, child)\n\t };\n\t}\n\t\n\t/**\n\t * Helper that recursively merges two data objects together.\n\t */\n\tfunction mergeData (to, from) {\n\t if (!from) { return to }\n\t var key, toVal, fromVal;\n\t var keys = Object.keys(from);\n\t for (var i = 0; i < keys.length; i++) {\n\t key = keys[i];\n\t toVal = to[key];\n\t fromVal = from[key];\n\t if (!hasOwn(to, key)) {\n\t set(to, key, fromVal);\n\t } else if (\n\t toVal !== fromVal &&\n\t isPlainObject(toVal) &&\n\t isPlainObject(fromVal)\n\t ) {\n\t mergeData(toVal, fromVal);\n\t }\n\t }\n\t return to\n\t}\n\t\n\t/**\n\t * Data\n\t */\n\tfunction mergeDataOrFn (\n\t parentVal,\n\t childVal,\n\t vm\n\t) {\n\t if (!vm) {\n\t // in a Vue.extend merge, both should be functions\n\t if (!childVal) {\n\t return parentVal\n\t }\n\t if (!parentVal) {\n\t return childVal\n\t }\n\t // when parentVal & childVal are both present,\n\t // we need to return a function that returns the\n\t // merged result of both functions... no need to\n\t // check if parentVal is a function here because\n\t // it has to be a function to pass previous merges.\n\t return function mergedDataFn () {\n\t return mergeData(\n\t typeof childVal === 'function' ? childVal.call(this, this) : childVal,\n\t typeof parentVal === 'function' ? parentVal.call(this, this) : parentVal\n\t )\n\t }\n\t } else {\n\t return function mergedInstanceDataFn () {\n\t // instance merge\n\t var instanceData = typeof childVal === 'function'\n\t ? childVal.call(vm, vm)\n\t : childVal;\n\t var defaultData = typeof parentVal === 'function'\n\t ? parentVal.call(vm, vm)\n\t : parentVal;\n\t if (instanceData) {\n\t return mergeData(instanceData, defaultData)\n\t } else {\n\t return defaultData\n\t }\n\t }\n\t }\n\t}\n\t\n\tstrats.data = function (\n\t parentVal,\n\t childVal,\n\t vm\n\t) {\n\t if (!vm) {\n\t if (childVal && typeof childVal !== 'function') {\n\t (\"production\") !== 'production' && warn(\n\t 'The \"data\" option should be a function ' +\n\t 'that returns a per-instance value in component ' +\n\t 'definitions.',\n\t vm\n\t );\n\t\n\t return parentVal\n\t }\n\t return mergeDataOrFn(parentVal, childVal)\n\t }\n\t\n\t return mergeDataOrFn(parentVal, childVal, vm)\n\t};\n\t\n\t/**\n\t * Hooks and props are merged as arrays.\n\t */\n\tfunction mergeHook (\n\t parentVal,\n\t childVal\n\t) {\n\t return childVal\n\t ? parentVal\n\t ? parentVal.concat(childVal)\n\t : Array.isArray(childVal)\n\t ? childVal\n\t : [childVal]\n\t : parentVal\n\t}\n\t\n\tLIFECYCLE_HOOKS.forEach(function (hook) {\n\t strats[hook] = mergeHook;\n\t});\n\t\n\t/**\n\t * Assets\n\t *\n\t * When a vm is present (instance creation), we need to do\n\t * a three-way merge between constructor options, instance\n\t * options and parent options.\n\t */\n\tfunction mergeAssets (\n\t parentVal,\n\t childVal,\n\t vm,\n\t key\n\t) {\n\t var res = Object.create(parentVal || null);\n\t if (childVal) {\n\t (\"production\") !== 'production' && assertObjectType(key, childVal, vm);\n\t return extend(res, childVal)\n\t } else {\n\t return res\n\t }\n\t}\n\t\n\tASSET_TYPES.forEach(function (type) {\n\t strats[type + 's'] = mergeAssets;\n\t});\n\t\n\t/**\n\t * Watchers.\n\t *\n\t * Watchers hashes should not overwrite one\n\t * another, so we merge them as arrays.\n\t */\n\tstrats.watch = function (\n\t parentVal,\n\t childVal,\n\t vm,\n\t key\n\t) {\n\t // work around Firefox's Object.prototype.watch...\n\t if (parentVal === nativeWatch) { parentVal = undefined; }\n\t if (childVal === nativeWatch) { childVal = undefined; }\n\t /* istanbul ignore if */\n\t if (!childVal) { return Object.create(parentVal || null) }\n\t if (false) {\n\t assertObjectType(key, childVal, vm);\n\t }\n\t if (!parentVal) { return childVal }\n\t var ret = {};\n\t extend(ret, parentVal);\n\t for (var key$1 in childVal) {\n\t var parent = ret[key$1];\n\t var child = childVal[key$1];\n\t if (parent && !Array.isArray(parent)) {\n\t parent = [parent];\n\t }\n\t ret[key$1] = parent\n\t ? parent.concat(child)\n\t : Array.isArray(child) ? child : [child];\n\t }\n\t return ret\n\t};\n\t\n\t/**\n\t * Other object hashes.\n\t */\n\tstrats.props =\n\tstrats.methods =\n\tstrats.inject =\n\tstrats.computed = function (\n\t parentVal,\n\t childVal,\n\t vm,\n\t key\n\t) {\n\t if (childVal && (\"production\") !== 'production') {\n\t assertObjectType(key, childVal, vm);\n\t }\n\t if (!parentVal) { return childVal }\n\t var ret = Object.create(null);\n\t extend(ret, parentVal);\n\t if (childVal) { extend(ret, childVal); }\n\t return ret\n\t};\n\tstrats.provide = mergeDataOrFn;\n\t\n\t/**\n\t * Default strategy.\n\t */\n\tvar defaultStrat = function (parentVal, childVal) {\n\t return childVal === undefined\n\t ? parentVal\n\t : childVal\n\t};\n\t\n\t/**\n\t * Validate component names\n\t */\n\tfunction checkComponents (options) {\n\t for (var key in options.components) {\n\t validateComponentName(key);\n\t }\n\t}\n\t\n\tfunction validateComponentName (name) {\n\t if (!/^[a-zA-Z][\\w-]*$/.test(name)) {\n\t warn(\n\t 'Invalid component name: \"' + name + '\". Component names ' +\n\t 'can only contain alphanumeric characters and the hyphen, ' +\n\t 'and must start with a letter.'\n\t );\n\t }\n\t if (isBuiltInTag(name) || config.isReservedTag(name)) {\n\t warn(\n\t 'Do not use built-in or reserved HTML elements as component ' +\n\t 'id: ' + name\n\t );\n\t }\n\t}\n\t\n\t/**\n\t * Ensure all props option syntax are normalized into the\n\t * Object-based format.\n\t */\n\tfunction normalizeProps (options, vm) {\n\t var props = options.props;\n\t if (!props) { return }\n\t var res = {};\n\t var i, val, name;\n\t if (Array.isArray(props)) {\n\t i = props.length;\n\t while (i--) {\n\t val = props[i];\n\t if (typeof val === 'string') {\n\t name = camelize(val);\n\t res[name] = { type: null };\n\t } else if (false) {\n\t warn('props must be strings when using array syntax.');\n\t }\n\t }\n\t } else if (isPlainObject(props)) {\n\t for (var key in props) {\n\t val = props[key];\n\t name = camelize(key);\n\t res[name] = isPlainObject(val)\n\t ? val\n\t : { type: val };\n\t }\n\t } else if (false) {\n\t warn(\n\t \"Invalid value for option \\\"props\\\": expected an Array or an Object, \" +\n\t \"but got \" + (toRawType(props)) + \".\",\n\t vm\n\t );\n\t }\n\t options.props = res;\n\t}\n\t\n\t/**\n\t * Normalize all injections into Object-based format\n\t */\n\tfunction normalizeInject (options, vm) {\n\t var inject = options.inject;\n\t if (!inject) { return }\n\t var normalized = options.inject = {};\n\t if (Array.isArray(inject)) {\n\t for (var i = 0; i < inject.length; i++) {\n\t normalized[inject[i]] = { from: inject[i] };\n\t }\n\t } else if (isPlainObject(inject)) {\n\t for (var key in inject) {\n\t var val = inject[key];\n\t normalized[key] = isPlainObject(val)\n\t ? extend({ from: key }, val)\n\t : { from: val };\n\t }\n\t } else if (false) {\n\t warn(\n\t \"Invalid value for option \\\"inject\\\": expected an Array or an Object, \" +\n\t \"but got \" + (toRawType(inject)) + \".\",\n\t vm\n\t );\n\t }\n\t}\n\t\n\t/**\n\t * Normalize raw function directives into object format.\n\t */\n\tfunction normalizeDirectives (options) {\n\t var dirs = options.directives;\n\t if (dirs) {\n\t for (var key in dirs) {\n\t var def = dirs[key];\n\t if (typeof def === 'function') {\n\t dirs[key] = { bind: def, update: def };\n\t }\n\t }\n\t }\n\t}\n\t\n\tfunction assertObjectType (name, value, vm) {\n\t if (!isPlainObject(value)) {\n\t warn(\n\t \"Invalid value for option \\\"\" + name + \"\\\": expected an Object, \" +\n\t \"but got \" + (toRawType(value)) + \".\",\n\t vm\n\t );\n\t }\n\t}\n\t\n\t/**\n\t * Merge two option objects into a new one.\n\t * Core utility used in both instantiation and inheritance.\n\t */\n\tfunction mergeOptions (\n\t parent,\n\t child,\n\t vm\n\t) {\n\t if (false) {\n\t checkComponents(child);\n\t }\n\t\n\t if (typeof child === 'function') {\n\t child = child.options;\n\t }\n\t\n\t normalizeProps(child, vm);\n\t normalizeInject(child, vm);\n\t normalizeDirectives(child);\n\t \n\t // Apply extends and mixins on the child options,\n\t // but only if it is a raw options object that isn't\n\t // the result of another mergeOptions call.\n\t // Only merged options has the _base property.\n\t if (!child._base) {\n\t if (child.extends) {\n\t parent = mergeOptions(parent, child.extends, vm);\n\t }\n\t if (child.mixins) {\n\t for (var i = 0, l = child.mixins.length; i < l; i++) {\n\t parent = mergeOptions(parent, child.mixins[i], vm);\n\t }\n\t }\n\t }\n\t\n\t var options = {};\n\t var key;\n\t for (key in parent) {\n\t mergeField(key);\n\t }\n\t for (key in child) {\n\t if (!hasOwn(parent, key)) {\n\t mergeField(key);\n\t }\n\t }\n\t function mergeField (key) {\n\t var strat = strats[key] || defaultStrat;\n\t options[key] = strat(parent[key], child[key], vm, key);\n\t }\n\t return options\n\t}\n\t\n\t/**\n\t * Resolve an asset.\n\t * This function is used because child instances need access\n\t * to assets defined in its ancestor chain.\n\t */\n\tfunction resolveAsset (\n\t options,\n\t type,\n\t id,\n\t warnMissing\n\t) {\n\t /* istanbul ignore if */\n\t if (typeof id !== 'string') {\n\t return\n\t }\n\t var assets = options[type];\n\t // check local registration variations first\n\t if (hasOwn(assets, id)) { return assets[id] }\n\t var camelizedId = camelize(id);\n\t if (hasOwn(assets, camelizedId)) { return assets[camelizedId] }\n\t var PascalCaseId = capitalize(camelizedId);\n\t if (hasOwn(assets, PascalCaseId)) { return assets[PascalCaseId] }\n\t // fallback to prototype chain\n\t var res = assets[id] || assets[camelizedId] || assets[PascalCaseId];\n\t if (false) {\n\t warn(\n\t 'Failed to resolve ' + type.slice(0, -1) + ': ' + id,\n\t options\n\t );\n\t }\n\t return res\n\t}\n\t\n\t/* */\n\t\n\t\n\t\n\tfunction validateProp (\n\t key,\n\t propOptions,\n\t propsData,\n\t vm\n\t) {\n\t var prop = propOptions[key];\n\t var absent = !hasOwn(propsData, key);\n\t var value = propsData[key];\n\t // boolean casting\n\t var booleanIndex = getTypeIndex(Boolean, prop.type);\n\t if (booleanIndex > -1) {\n\t if (absent && !hasOwn(prop, 'default')) {\n\t value = false;\n\t } else if (value === '' || value === hyphenate(key)) {\n\t // only cast empty string / same name to boolean if\n\t // boolean has higher priority\n\t var stringIndex = getTypeIndex(String, prop.type);\n\t if (stringIndex < 0 || booleanIndex < stringIndex) {\n\t value = true;\n\t }\n\t }\n\t }\n\t // check default value\n\t if (value === undefined) {\n\t value = getPropDefaultValue(vm, prop, key);\n\t // since the default value is a fresh copy,\n\t // make sure to observe it.\n\t var prevShouldObserve = shouldObserve;\n\t toggleObserving(true);\n\t observe(value);\n\t toggleObserving(prevShouldObserve);\n\t }\n\t if (\n\t false\n\t ) {\n\t assertProp(prop, key, value, vm, absent);\n\t }\n\t return value\n\t}\n\t\n\t/**\n\t * Get the default value of a prop.\n\t */\n\tfunction getPropDefaultValue (vm, prop, key) {\n\t // no default, return undefined\n\t if (!hasOwn(prop, 'default')) {\n\t return undefined\n\t }\n\t var def = prop.default;\n\t // warn against non-factory defaults for Object & Array\n\t if (false) {\n\t warn(\n\t 'Invalid default value for prop \"' + key + '\": ' +\n\t 'Props with type Object/Array must use a factory function ' +\n\t 'to return the default value.',\n\t vm\n\t );\n\t }\n\t // the raw prop value was also undefined from previous render,\n\t // return previous default value to avoid unnecessary watcher trigger\n\t if (vm && vm.$options.propsData &&\n\t vm.$options.propsData[key] === undefined &&\n\t vm._props[key] !== undefined\n\t ) {\n\t return vm._props[key]\n\t }\n\t // call factory function for non-Function types\n\t // a value is Function if its prototype is function even across different execution context\n\t return typeof def === 'function' && getType(prop.type) !== 'Function'\n\t ? def.call(vm)\n\t : def\n\t}\n\t\n\t/**\n\t * Assert whether a prop is valid.\n\t */\n\tfunction assertProp (\n\t prop,\n\t name,\n\t value,\n\t vm,\n\t absent\n\t) {\n\t if (prop.required && absent) {\n\t warn(\n\t 'Missing required prop: \"' + name + '\"',\n\t vm\n\t );\n\t return\n\t }\n\t if (value == null && !prop.required) {\n\t return\n\t }\n\t var type = prop.type;\n\t var valid = !type || type === true;\n\t var expectedTypes = [];\n\t if (type) {\n\t if (!Array.isArray(type)) {\n\t type = [type];\n\t }\n\t for (var i = 0; i < type.length && !valid; i++) {\n\t var assertedType = assertType(value, type[i]);\n\t expectedTypes.push(assertedType.expectedType || '');\n\t valid = assertedType.valid;\n\t }\n\t }\n\t\n\t if (!valid) {\n\t warn(\n\t getInvalidTypeMessage(name, value, expectedTypes),\n\t vm\n\t );\n\t return\n\t }\n\t var validator = prop.validator;\n\t if (validator) {\n\t if (!validator(value)) {\n\t warn(\n\t 'Invalid prop: custom validator check failed for prop \"' + name + '\".',\n\t vm\n\t );\n\t }\n\t }\n\t}\n\t\n\tvar simpleCheckRE = /^(String|Number|Boolean|Function|Symbol)$/;\n\t\n\tfunction assertType (value, type) {\n\t var valid;\n\t var expectedType = getType(type);\n\t if (simpleCheckRE.test(expectedType)) {\n\t var t = typeof value;\n\t valid = t === expectedType.toLowerCase();\n\t // for primitive wrapper objects\n\t if (!valid && t === 'object') {\n\t valid = value instanceof type;\n\t }\n\t } else if (expectedType === 'Object') {\n\t valid = isPlainObject(value);\n\t } else if (expectedType === 'Array') {\n\t valid = Array.isArray(value);\n\t } else {\n\t valid = value instanceof type;\n\t }\n\t return {\n\t valid: valid,\n\t expectedType: expectedType\n\t }\n\t}\n\t\n\t/**\n\t * Use function string name to check built-in types,\n\t * because a simple equality check will fail when running\n\t * across different vms / iframes.\n\t */\n\tfunction getType (fn) {\n\t var match = fn && fn.toString().match(/^\\s*function (\\w+)/);\n\t return match ? match[1] : ''\n\t}\n\t\n\tfunction isSameType (a, b) {\n\t return getType(a) === getType(b)\n\t}\n\t\n\tfunction getTypeIndex (type, expectedTypes) {\n\t if (!Array.isArray(expectedTypes)) {\n\t return isSameType(expectedTypes, type) ? 0 : -1\n\t }\n\t for (var i = 0, len = expectedTypes.length; i < len; i++) {\n\t if (isSameType(expectedTypes[i], type)) {\n\t return i\n\t }\n\t }\n\t return -1\n\t}\n\t\n\tfunction getInvalidTypeMessage (name, value, expectedTypes) {\n\t var message = \"Invalid prop: type check failed for prop \\\"\" + name + \"\\\".\" +\n\t \" Expected \" + (expectedTypes.map(capitalize).join(', '));\n\t var expectedType = expectedTypes[0];\n\t var receivedType = toRawType(value);\n\t var expectedValue = styleValue(value, expectedType);\n\t var receivedValue = styleValue(value, receivedType);\n\t // check if we need to specify expected value\n\t if (expectedTypes.length === 1 &&\n\t isExplicable(expectedType) &&\n\t !isBoolean(expectedType, receivedType)) {\n\t message += \" with value \" + expectedValue;\n\t }\n\t message += \", got \" + receivedType + \" \";\n\t // check if we need to specify received value\n\t if (isExplicable(receivedType)) {\n\t message += \"with value \" + receivedValue + \".\";\n\t }\n\t return message\n\t}\n\t\n\tfunction styleValue (value, type) {\n\t if (type === 'String') {\n\t return (\"\\\"\" + value + \"\\\"\")\n\t } else if (type === 'Number') {\n\t return (\"\" + (Number(value)))\n\t } else {\n\t return (\"\" + value)\n\t }\n\t}\n\t\n\tfunction isExplicable (value) {\n\t var explicitTypes = ['string', 'number', 'boolean'];\n\t return explicitTypes.some(function (elem) { return value.toLowerCase() === elem; })\n\t}\n\t\n\tfunction isBoolean () {\n\t var args = [], len = arguments.length;\n\t while ( len-- ) args[ len ] = arguments[ len ];\n\t\n\t return args.some(function (elem) { return elem.toLowerCase() === 'boolean'; })\n\t}\n\t\n\t/* */\n\t\n\tfunction handleError (err, vm, info) {\n\t if (vm) {\n\t var cur = vm;\n\t while ((cur = cur.$parent)) {\n\t var hooks = cur.$options.errorCaptured;\n\t if (hooks) {\n\t for (var i = 0; i < hooks.length; i++) {\n\t try {\n\t var capture = hooks[i].call(cur, err, vm, info) === false;\n\t if (capture) { return }\n\t } catch (e) {\n\t globalHandleError(e, cur, 'errorCaptured hook');\n\t }\n\t }\n\t }\n\t }\n\t }\n\t globalHandleError(err, vm, info);\n\t}\n\t\n\tfunction globalHandleError (err, vm, info) {\n\t if (config.errorHandler) {\n\t try {\n\t return config.errorHandler.call(null, err, vm, info)\n\t } catch (e) {\n\t logError(e, null, 'config.errorHandler');\n\t }\n\t }\n\t logError(err, vm, info);\n\t}\n\t\n\tfunction logError (err, vm, info) {\n\t if (false) {\n\t warn((\"Error in \" + info + \": \\\"\" + (err.toString()) + \"\\\"\"), vm);\n\t }\n\t /* istanbul ignore else */\n\t if ((inBrowser || inWeex) && typeof console !== 'undefined') {\n\t console.error(err);\n\t } else {\n\t throw err\n\t }\n\t}\n\t\n\t/* */\n\t\n\tvar callbacks = [];\n\tvar pending = false;\n\t\n\tfunction flushCallbacks () {\n\t pending = false;\n\t var copies = callbacks.slice(0);\n\t callbacks.length = 0;\n\t for (var i = 0; i < copies.length; i++) {\n\t copies[i]();\n\t }\n\t}\n\t\n\t// Here we have async deferring wrappers using both microtasks and (macro) tasks.\n\t// In < 2.4 we used microtasks everywhere, but there are some scenarios where\n\t// microtasks have too high a priority and fire in between supposedly\n\t// sequential events (e.g. #4521, #6690) or even between bubbling of the same\n\t// event (#6566). However, using (macro) tasks everywhere also has subtle problems\n\t// when state is changed right before repaint (e.g. #6813, out-in transitions).\n\t// Here we use microtask by default, but expose a way to force (macro) task when\n\t// needed (e.g. in event handlers attached by v-on).\n\tvar microTimerFunc;\n\tvar macroTimerFunc;\n\tvar useMacroTask = false;\n\t\n\t// Determine (macro) task defer implementation.\n\t// Technically setImmediate should be the ideal choice, but it's only available\n\t// in IE. The only polyfill that consistently queues the callback after all DOM\n\t// events triggered in the same loop is by using MessageChannel.\n\t/* istanbul ignore if */\n\tif (typeof setImmediate !== 'undefined' && isNative(setImmediate)) {\n\t macroTimerFunc = function () {\n\t setImmediate(flushCallbacks);\n\t };\n\t} else if (typeof MessageChannel !== 'undefined' && (\n\t isNative(MessageChannel) ||\n\t // PhantomJS\n\t MessageChannel.toString() === '[object MessageChannelConstructor]'\n\t)) {\n\t var channel = new MessageChannel();\n\t var port = channel.port2;\n\t channel.port1.onmessage = flushCallbacks;\n\t macroTimerFunc = function () {\n\t port.postMessage(1);\n\t };\n\t} else {\n\t /* istanbul ignore next */\n\t macroTimerFunc = function () {\n\t setTimeout(flushCallbacks, 0);\n\t };\n\t}\n\t\n\t// Determine microtask defer implementation.\n\t/* istanbul ignore next, $flow-disable-line */\n\tif (typeof Promise !== 'undefined' && isNative(Promise)) {\n\t var p = Promise.resolve();\n\t microTimerFunc = function () {\n\t p.then(flushCallbacks);\n\t // in problematic UIWebViews, Promise.then doesn't completely break, but\n\t // it can get stuck in a weird state where callbacks are pushed into the\n\t // microtask queue but the queue isn't being flushed, until the browser\n\t // needs to do some other work, e.g. handle a timer. Therefore we can\n\t // \"force\" the microtask queue to be flushed by adding an empty timer.\n\t if (isIOS) { setTimeout(noop); }\n\t };\n\t} else {\n\t // fallback to macro\n\t microTimerFunc = macroTimerFunc;\n\t}\n\t\n\t/**\n\t * Wrap a function so that if any code inside triggers state change,\n\t * the changes are queued using a (macro) task instead of a microtask.\n\t */\n\tfunction withMacroTask (fn) {\n\t return fn._withTask || (fn._withTask = function () {\n\t useMacroTask = true;\n\t try {\n\t return fn.apply(null, arguments)\n\t } finally {\n\t useMacroTask = false; \n\t }\n\t })\n\t}\n\t\n\tfunction nextTick (cb, ctx) {\n\t var _resolve;\n\t callbacks.push(function () {\n\t if (cb) {\n\t try {\n\t cb.call(ctx);\n\t } catch (e) {\n\t handleError(e, ctx, 'nextTick');\n\t }\n\t } else if (_resolve) {\n\t _resolve(ctx);\n\t }\n\t });\n\t if (!pending) {\n\t pending = true;\n\t if (useMacroTask) {\n\t macroTimerFunc();\n\t } else {\n\t microTimerFunc();\n\t }\n\t }\n\t // $flow-disable-line\n\t if (!cb && typeof Promise !== 'undefined') {\n\t return new Promise(function (resolve) {\n\t _resolve = resolve;\n\t })\n\t }\n\t}\n\t\n\t/* */\n\t\n\t/* not type checking this file because flow doesn't play well with Proxy */\n\t\n\tvar initProxy;\n\t\n\tif (false) {\n\t var allowedGlobals = makeMap(\n\t 'Infinity,undefined,NaN,isFinite,isNaN,' +\n\t 'parseFloat,parseInt,decodeURI,decodeURIComponent,encodeURI,encodeURIComponent,' +\n\t 'Math,Number,Date,Array,Object,Boolean,String,RegExp,Map,Set,JSON,Intl,' +\n\t 'require' // for Webpack/Browserify\n\t );\n\t\n\t var warnNonPresent = function (target, key) {\n\t warn(\n\t \"Property or method \\\"\" + key + \"\\\" is not defined on the instance but \" +\n\t 'referenced during render. Make sure that this property is reactive, ' +\n\t 'either in the data option, or for class-based components, by ' +\n\t 'initializing the property. ' +\n\t 'See: https://vuejs.org/v2/guide/reactivity.html#Declaring-Reactive-Properties.',\n\t target\n\t );\n\t };\n\t\n\t var warnReservedPrefix = function (target, key) {\n\t warn(\n\t \"Property \\\"\" + key + \"\\\" must be accessed with \\\"$data.\" + key + \"\\\" because \" +\n\t 'properties starting with \"$\" or \"_\" are not proxied in the Vue instance to ' +\n\t 'prevent conflicts with Vue internals' +\n\t 'See: https://vuejs.org/v2/api/#data',\n\t target\n\t );\n\t };\n\t\n\t var hasProxy =\n\t typeof Proxy !== 'undefined' && isNative(Proxy);\n\t\n\t if (hasProxy) {\n\t var isBuiltInModifier = makeMap('stop,prevent,self,ctrl,shift,alt,meta,exact');\n\t config.keyCodes = new Proxy(config.keyCodes, {\n\t set: function set (target, key, value) {\n\t if (isBuiltInModifier(key)) {\n\t warn((\"Avoid overwriting built-in modifier in config.keyCodes: .\" + key));\n\t return false\n\t } else {\n\t target[key] = value;\n\t return true\n\t }\n\t }\n\t });\n\t }\n\t\n\t var hasHandler = {\n\t has: function has (target, key) {\n\t var has = key in target;\n\t var isAllowed = allowedGlobals(key) ||\n\t (typeof key === 'string' && key.charAt(0) === '_' && !(key in target.$data));\n\t if (!has && !isAllowed) {\n\t if (key in target.$data) { warnReservedPrefix(target, key); }\n\t else { warnNonPresent(target, key); }\n\t }\n\t return has || !isAllowed\n\t }\n\t };\n\t\n\t var getHandler = {\n\t get: function get (target, key) {\n\t if (typeof key === 'string' && !(key in target)) {\n\t if (key in target.$data) { warnReservedPrefix(target, key); }\n\t else { warnNonPresent(target, key); }\n\t }\n\t return target[key]\n\t }\n\t };\n\t\n\t initProxy = function initProxy (vm) {\n\t if (hasProxy) {\n\t // determine which proxy handler to use\n\t var options = vm.$options;\n\t var handlers = options.render && options.render._withStripped\n\t ? getHandler\n\t : hasHandler;\n\t vm._renderProxy = new Proxy(vm, handlers);\n\t } else {\n\t vm._renderProxy = vm;\n\t }\n\t };\n\t}\n\t\n\t/* */\n\t\n\tvar seenObjects = new _Set();\n\t\n\t/**\n\t * Recursively traverse an object to evoke all converted\n\t * getters, so that every nested property inside the object\n\t * is collected as a \"deep\" dependency.\n\t */\n\tfunction traverse (val) {\n\t _traverse(val, seenObjects);\n\t seenObjects.clear();\n\t}\n\t\n\tfunction _traverse (val, seen) {\n\t var i, keys;\n\t var isA = Array.isArray(val);\n\t if ((!isA && !isObject(val)) || Object.isFrozen(val) || val instanceof VNode) {\n\t return\n\t }\n\t if (val.__ob__) {\n\t var depId = val.__ob__.dep.id;\n\t if (seen.has(depId)) {\n\t return\n\t }\n\t seen.add(depId);\n\t }\n\t if (isA) {\n\t i = val.length;\n\t while (i--) { _traverse(val[i], seen); }\n\t } else {\n\t keys = Object.keys(val);\n\t i = keys.length;\n\t while (i--) { _traverse(val[keys[i]], seen); }\n\t }\n\t}\n\t\n\tvar mark;\n\tvar measure;\n\t\n\tif (false) {\n\t var perf = inBrowser && window.performance;\n\t /* istanbul ignore if */\n\t if (\n\t perf &&\n\t perf.mark &&\n\t perf.measure &&\n\t perf.clearMarks &&\n\t perf.clearMeasures\n\t ) {\n\t mark = function (tag) { return perf.mark(tag); };\n\t measure = function (name, startTag, endTag) {\n\t perf.measure(name, startTag, endTag);\n\t perf.clearMarks(startTag);\n\t perf.clearMarks(endTag);\n\t perf.clearMeasures(name);\n\t };\n\t }\n\t}\n\t\n\t/* */\n\t\n\tvar normalizeEvent = cached(function (name) {\n\t var passive = name.charAt(0) === '&';\n\t name = passive ? name.slice(1) : name;\n\t var once$$1 = name.charAt(0) === '~'; // Prefixed last, checked first\n\t name = once$$1 ? name.slice(1) : name;\n\t var capture = name.charAt(0) === '!';\n\t name = capture ? name.slice(1) : name;\n\t return {\n\t name: name,\n\t once: once$$1,\n\t capture: capture,\n\t passive: passive\n\t }\n\t});\n\t\n\tfunction createFnInvoker (fns) {\n\t function invoker () {\n\t var arguments$1 = arguments;\n\t\n\t var fns = invoker.fns;\n\t if (Array.isArray(fns)) {\n\t var cloned = fns.slice();\n\t for (var i = 0; i < cloned.length; i++) {\n\t cloned[i].apply(null, arguments$1);\n\t }\n\t } else {\n\t // return handler return value for single handlers\n\t return fns.apply(null, arguments)\n\t }\n\t }\n\t invoker.fns = fns;\n\t return invoker\n\t}\n\t\n\tfunction updateListeners (\n\t on,\n\t oldOn,\n\t add,\n\t remove$$1,\n\t createOnceHandler,\n\t vm\n\t) {\n\t var name, def$$1, cur, old, event;\n\t for (name in on) {\n\t def$$1 = cur = on[name];\n\t old = oldOn[name];\n\t event = normalizeEvent(name);\n\t if (isUndef(cur)) {\n\t (\"production\") !== 'production' && warn(\n\t \"Invalid handler for event \\\"\" + (event.name) + \"\\\": got \" + String(cur),\n\t vm\n\t );\n\t } else if (isUndef(old)) {\n\t if (isUndef(cur.fns)) {\n\t cur = on[name] = createFnInvoker(cur);\n\t }\n\t if (isTrue(event.once)) {\n\t cur = on[name] = createOnceHandler(event.name, cur, event.capture);\n\t }\n\t add(event.name, cur, event.capture, event.passive, event.params);\n\t } else if (cur !== old) {\n\t old.fns = cur;\n\t on[name] = old;\n\t }\n\t }\n\t for (name in oldOn) {\n\t if (isUndef(on[name])) {\n\t event = normalizeEvent(name);\n\t remove$$1(event.name, oldOn[name], event.capture);\n\t }\n\t }\n\t}\n\t\n\t/* */\n\t\n\tfunction mergeVNodeHook (def, hookKey, hook) {\n\t if (def instanceof VNode) {\n\t def = def.data.hook || (def.data.hook = {});\n\t }\n\t var invoker;\n\t var oldHook = def[hookKey];\n\t\n\t function wrappedHook () {\n\t hook.apply(this, arguments);\n\t // important: remove merged hook to ensure it's called only once\n\t // and prevent memory leak\n\t remove(invoker.fns, wrappedHook);\n\t }\n\t\n\t if (isUndef(oldHook)) {\n\t // no existing hook\n\t invoker = createFnInvoker([wrappedHook]);\n\t } else {\n\t /* istanbul ignore if */\n\t if (isDef(oldHook.fns) && isTrue(oldHook.merged)) {\n\t // already a merged invoker\n\t invoker = oldHook;\n\t invoker.fns.push(wrappedHook);\n\t } else {\n\t // existing plain hook\n\t invoker = createFnInvoker([oldHook, wrappedHook]);\n\t }\n\t }\n\t\n\t invoker.merged = true;\n\t def[hookKey] = invoker;\n\t}\n\t\n\t/* */\n\t\n\tfunction extractPropsFromVNodeData (\n\t data,\n\t Ctor,\n\t tag\n\t) {\n\t // we are only extracting raw values here.\n\t // validation and default values are handled in the child\n\t // component itself.\n\t var propOptions = Ctor.options.props;\n\t if (isUndef(propOptions)) {\n\t return\n\t }\n\t var res = {};\n\t var attrs = data.attrs;\n\t var props = data.props;\n\t if (isDef(attrs) || isDef(props)) {\n\t for (var key in propOptions) {\n\t var altKey = hyphenate(key);\n\t if (false) {\n\t var keyInLowerCase = key.toLowerCase();\n\t if (\n\t key !== keyInLowerCase &&\n\t attrs && hasOwn(attrs, keyInLowerCase)\n\t ) {\n\t tip(\n\t \"Prop \\\"\" + keyInLowerCase + \"\\\" is passed to component \" +\n\t (formatComponentName(tag || Ctor)) + \", but the declared prop name is\" +\n\t \" \\\"\" + key + \"\\\". \" +\n\t \"Note that HTML attributes are case-insensitive and camelCased \" +\n\t \"props need to use their kebab-case equivalents when using in-DOM \" +\n\t \"templates. You should probably use \\\"\" + altKey + \"\\\" instead of \\\"\" + key + \"\\\".\"\n\t );\n\t }\n\t }\n\t checkProp(res, props, key, altKey, true) ||\n\t checkProp(res, attrs, key, altKey, false);\n\t }\n\t }\n\t return res\n\t}\n\t\n\tfunction checkProp (\n\t res,\n\t hash,\n\t key,\n\t altKey,\n\t preserve\n\t) {\n\t if (isDef(hash)) {\n\t if (hasOwn(hash, key)) {\n\t res[key] = hash[key];\n\t if (!preserve) {\n\t delete hash[key];\n\t }\n\t return true\n\t } else if (hasOwn(hash, altKey)) {\n\t res[key] = hash[altKey];\n\t if (!preserve) {\n\t delete hash[altKey];\n\t }\n\t return true\n\t }\n\t }\n\t return false\n\t}\n\t\n\t/* */\n\t\n\t// The template compiler attempts to minimize the need for normalization by\n\t// statically analyzing the template at compile time.\n\t//\n\t// For plain HTML markup, normalization can be completely skipped because the\n\t// generated render function is guaranteed to return Array. There are\n\t// two cases where extra normalization is needed:\n\t\n\t// 1. When the children contains components - because a functional component\n\t// may return an Array instead of a single root. In this case, just a simple\n\t// normalization is needed - if any child is an Array, we flatten the whole\n\t// thing with Array.prototype.concat. It is guaranteed to be only 1-level deep\n\t// because functional components already normalize their own children.\n\tfunction simpleNormalizeChildren (children) {\n\t for (var i = 0; i < children.length; i++) {\n\t if (Array.isArray(children[i])) {\n\t return Array.prototype.concat.apply([], children)\n\t }\n\t }\n\t return children\n\t}\n\t\n\t// 2. When the children contains constructs that always generated nested Arrays,\n\t// e.g.