diff --git a/.browserslistrc b/.browserslistrc deleted file mode 100644 index 47c683699..000000000 --- a/.browserslistrc +++ /dev/null @@ -1,2 +0,0 @@ ->0.25% -not op_mini all \ No newline at end of file diff --git a/.env.example.complete b/.env.example.complete index 37421a419..829a7509b 100644 --- a/.env.example.complete +++ b/.env.example.complete @@ -95,6 +95,16 @@ QUEUE_DRIVER=sync # Can be 'local', 'local_secure' or 's3' STORAGE_TYPE=local +# Image storage system to use +# Defaults to the value of STORAGE_TYPE if unset. +# Accepts the same values as STORAGE_TYPE. +STORAGE_IMAGE_TYPE=local + +# Attachment storage system to use +# Defaults to the value of STORAGE_TYPE if unset. +# Accepts the same values as STORAGE_TYPE although 'local' will be forced to 'local_secure'. +STORAGE_ATTACHMENT_TYPE=local_secure + # Amazon S3 storage configuration STORAGE_S3_KEY=your-s3-key STORAGE_S3_SECRET=your-s3-secret diff --git a/app/Application.php b/app/Application.php new file mode 100644 index 000000000..8c56e9dac --- /dev/null +++ b/app/Application.php @@ -0,0 +1,19 @@ +basePath.DIRECTORY_SEPARATOR.'app'.DIRECTORY_SEPARATOR.'Config'.($path ? DIRECTORY_SEPARATOR.$path : $path); + } + +} \ No newline at end of file diff --git a/app/Auth/Access/EmailConfirmationService.php b/app/Auth/Access/EmailConfirmationService.php index 4df014116..a94c54d19 100644 --- a/app/Auth/Access/EmailConfirmationService.php +++ b/app/Auth/Access/EmailConfirmationService.php @@ -1,33 +1,18 @@ db = $db; - $this->users = $users; - } + protected $tokenTable = 'email_confirmations'; + protected $expiryTime = 24; /** * Create new confirmation for a user, * Also removes any existing old ones. - * @param \BookStack\Auth\User $user + * @param User $user * @throws ConfirmationEmailException */ public function sendConfirmation(User $user) @@ -36,76 +21,20 @@ class EmailConfirmationService throw new ConfirmationEmailException(trans('errors.email_already_confirmed'), '/login'); } - $this->deleteConfirmationsByUser($user); - $token = $this->createEmailConfirmation($user); + $this->deleteByUser($user); + $token = $this->createTokenForUser($user); $user->notify(new ConfirmEmail($token)); } /** - * Creates a new email confirmation in the database and returns the token. - * @param User $user - * @return string + * Check if confirmation is required in this instance. + * @return bool */ - public function createEmailConfirmation(User $user) + public function confirmationRequired() : bool { - $token = $this->getToken(); - $this->db->table('email_confirmations')->insert([ - 'user_id' => $user->id, - 'token' => $token, - 'created_at' => Carbon::now(), - 'updated_at' => Carbon::now() - ]); - return $token; + return setting('registration-confirmation') + || setting('registration-restrict'); } - /** - * Gets an email confirmation by looking up the token, - * Ensures the token has not expired. - * @param string $token - * @return array|null|\stdClass - * @throws UserRegistrationException - */ - public function getEmailConfirmationFromToken($token) - { - $emailConfirmation = $this->db->table('email_confirmations')->where('token', '=', $token)->first(); - - // If not found show error - if ($emailConfirmation === null) { - throw new UserRegistrationException(trans('errors.email_confirmation_invalid'), '/register'); - } - - // If more than a day old - if (Carbon::now()->subDay()->gt(new Carbon($emailConfirmation->created_at))) { - $user = $this->users->getById($emailConfirmation->user_id); - $this->sendConfirmation($user); - throw new UserRegistrationException(trans('errors.email_confirmation_expired'), '/register/confirm'); - } - - $emailConfirmation->user = $this->users->getById($emailConfirmation->user_id); - return $emailConfirmation; - } - - /** - * Delete all email confirmations that belong to a user. - * @param \BookStack\Auth\User $user - * @return mixed - */ - public function deleteConfirmationsByUser(User $user) - { - return $this->db->table('email_confirmations')->where('user_id', '=', $user->id)->delete(); - } - - /** - * Creates a unique token within the email confirmation database. - * @return string - */ - protected function getToken() - { - $token = str_random(24); - while ($this->db->table('email_confirmations')->where('token', '=', $token)->exists()) { - $token = str_random(25); - } - return $token; - } } diff --git a/app/Auth/Access/UserInviteService.php b/app/Auth/Access/UserInviteService.php new file mode 100644 index 000000000..8e04d7b22 --- /dev/null +++ b/app/Auth/Access/UserInviteService.php @@ -0,0 +1,23 @@ +deleteByUser($user); + $token = $this->createTokenForUser($user); + $user->notify(new UserInvite($token)); + } + +} diff --git a/app/Auth/Access/UserTokenService.php b/app/Auth/Access/UserTokenService.php new file mode 100644 index 000000000..34f3b2851 --- /dev/null +++ b/app/Auth/Access/UserTokenService.php @@ -0,0 +1,134 @@ +db = $db; + } + + /** + * Delete all email confirmations that belong to a user. + * @param User $user + * @return mixed + */ + public function deleteByUser(User $user) + { + return $this->db->table($this->tokenTable) + ->where('user_id', '=', $user->id) + ->delete(); + } + + /** + * Get the user id from a token, while check the token exists and has not expired. + * @param string $token + * @return int + * @throws UserTokenNotFoundException + * @throws UserTokenExpiredException + */ + public function checkTokenAndGetUserId(string $token) : int + { + $entry = $this->getEntryByToken($token); + + if (is_null($entry)) { + throw new UserTokenNotFoundException('Token "' . $token . '" not found'); + } + + if ($this->entryExpired($entry)) { + throw new UserTokenExpiredException("Token of id {$entry->id} has expired.", $entry->user_id); + } + + return $entry->user_id; + } + + /** + * Creates a unique token within the email confirmation database. + * @return string + */ + protected function generateToken() : string + { + $token = str_random(24); + while ($this->tokenExists($token)) { + $token = str_random(25); + } + return $token; + } + + /** + * Generate and store a token for the given user. + * @param User $user + * @return string + */ + protected function createTokenForUser(User $user) : string + { + $token = $this->generateToken(); + $this->db->table($this->tokenTable)->insert([ + 'user_id' => $user->id, + 'token' => $token, + 'created_at' => Carbon::now(), + 'updated_at' => Carbon::now() + ]); + return $token; + } + + /** + * Check if the given token exists. + * @param string $token + * @return bool + */ + protected function tokenExists(string $token) : bool + { + return $this->db->table($this->tokenTable) + ->where('token', '=', $token)->exists(); + } + + /** + * Get a token entry for the given token. + * @param string $token + * @return object|null + */ + protected function getEntryByToken(string $token) + { + return $this->db->table($this->tokenTable) + ->where('token', '=', $token) + ->first(); + } + + /** + * Check if the given token entry has expired. + * @param stdClass $tokenEntry + * @return bool + */ + protected function entryExpired(stdClass $tokenEntry) : bool + { + return Carbon::now()->subHours($this->expiryTime) + ->gt(new Carbon($tokenEntry->created_at)); + } + +} \ No newline at end of file diff --git a/app/Auth/User.php b/app/Auth/User.php index 259b8eec0..7ad14d9f0 100644 --- a/app/Auth/User.php +++ b/app/Auth/User.php @@ -3,6 +3,7 @@ use BookStack\Model; use BookStack\Notifications\ResetPassword; use BookStack\Uploads\Image; +use Carbon\Carbon; use Illuminate\Auth\Authenticatable; use Illuminate\Auth\Passwords\CanResetPassword; use Illuminate\Contracts\Auth\Authenticatable as AuthenticatableContract; @@ -10,6 +11,20 @@ use Illuminate\Contracts\Auth\CanResetPassword as CanResetPasswordContract; use Illuminate\Database\Eloquent\Relations\BelongsToMany; use Illuminate\Notifications\Notifiable; +/** + * Class User + * @package BookStack\Auth + * @property string $id + * @property string $name + * @property string $email + * @property string $password + * @property Carbon $created_at + * @property Carbon $updated_at + * @property bool $email_confirmed + * @property int $image_id + * @property string $external_auth_id + * @property string $system_name + */ class User extends Model implements AuthenticatableContract, CanResetPasswordContract { use Authenticatable, CanResetPassword, Notifiable; @@ -168,14 +183,14 @@ class User extends Model implements AuthenticatableContract, CanResetPasswordCon */ public function getAvatar($size = 50) { - $default = baseUrl('/user_avatar.png'); + $default = url('/user_avatar.png'); $imageId = $this->image_id; if ($imageId === 0 || $imageId === '0' || $imageId === null) { return $default; } try { - $avatar = $this->avatar ? baseUrl($this->avatar->getThumb($size, $size, false)) : $default; + $avatar = $this->avatar ? url($this->avatar->getThumb($size, $size, false)) : $default; } catch (\Exception $err) { $avatar = $default; } @@ -197,7 +212,7 @@ class User extends Model implements AuthenticatableContract, CanResetPasswordCon */ public function getEditUrl() { - return baseUrl('/settings/users/' . $this->id); + return url('/settings/users/' . $this->id); } /** @@ -206,7 +221,7 @@ class User extends Model implements AuthenticatableContract, CanResetPasswordCon */ public function getProfileUrl() { - return baseUrl('/user/' . $this->id); + return url('/user/' . $this->id); } /** diff --git a/config/app.php b/app/Config/app.php similarity index 98% rename from config/app.php rename to app/Config/app.php index aaeafb98d..88052e94c 100755 --- a/config/app.php +++ b/app/Config/app.php @@ -52,7 +52,7 @@ return [ 'locale' => env('APP_LANG', 'en'), // Locales available - 'locales' => ['en', 'ar', 'de', 'de_informal', 'es', 'es_AR', 'fr', 'nl', 'pt_BR', 'sk', 'cs', 'sv', 'kr', 'ja', 'pl', 'it', 'ru', 'uk', 'zh_CN', 'zh_TW'], + 'locales' => ['en', 'ar', 'de', 'de_informal', 'es', 'es_AR', 'fr', 'hu', 'nl', 'pt_BR', 'sk', 'cs', 'sv', 'kr', 'ja', 'pl', 'it', 'ru', 'uk', 'zh_CN', 'zh_TW'], // Application Fallback Locale 'fallback_locale' => 'en', diff --git a/config/auth.php b/app/Config/auth.php similarity index 100% rename from config/auth.php rename to app/Config/auth.php diff --git a/config/broadcasting.php b/app/Config/broadcasting.php similarity index 100% rename from config/broadcasting.php rename to app/Config/broadcasting.php diff --git a/config/cache.php b/app/Config/cache.php similarity index 100% rename from config/cache.php rename to app/Config/cache.php diff --git a/config/database.php b/app/Config/database.php similarity index 100% rename from config/database.php rename to app/Config/database.php diff --git a/app/Config/debugbar.php b/app/Config/debugbar.php new file mode 100644 index 000000000..ec942dcd3 --- /dev/null +++ b/app/Config/debugbar.php @@ -0,0 +1,132 @@ + env('DEBUGBAR_ENABLED', false), + 'except' => [ + 'telescope*' + ], + + + // DebugBar stores data for session/ajax requests. + // You can disable this, so the debugbar stores data in headers/session, + // but this can cause problems with large data collectors. + // By default, file storage (in the storage folder) is used. Redis and PDO + // can also be used. For PDO, run the package migrations first. + 'storage' => [ + 'enabled' => true, + 'driver' => 'file', // redis, file, pdo, custom + 'path' => storage_path('debugbar'), // For file driver + 'connection' => null, // Leave null for default connection (Redis/PDO) + 'provider' => '' // Instance of StorageInterface for custom driver + ], + + // Vendor files are included by default, but can be set to false. + // This can also be set to 'js' or 'css', to only include javascript or css vendor files. + // Vendor files are for css: font-awesome (including fonts) and highlight.js (css files) + // and for js: jquery and and highlight.js + // So if you want syntax highlighting, set it to true. + // jQuery is set to not conflict with existing jQuery scripts. + 'include_vendors' => true, + + // The Debugbar can capture Ajax requests and display them. If you don't want this (ie. because of errors), + // you can use this option to disable sending the data through the headers. + // Optionally, you can also send ServerTiming headers on ajax requests for the Chrome DevTools. + + 'capture_ajax' => true, + 'add_ajax_timing' => false, + + // When enabled, the Debugbar shows deprecated warnings for Symfony components + // in the Messages tab. + 'error_handler' => false, + + // The Debugbar can emulate the Clockwork headers, so you can use the Chrome + // Extension, without the server-side code. It uses Debugbar collectors instead. + 'clockwork' => false, + + // Enable/disable DataCollectors + 'collectors' => [ + 'phpinfo' => true, // Php version + 'messages' => true, // Messages + 'time' => true, // Time Datalogger + 'memory' => true, // Memory usage + 'exceptions' => true, // Exception displayer + 'log' => true, // Logs from Monolog (merged in messages if enabled) + 'db' => true, // Show database (PDO) queries and bindings + 'views' => true, // Views with their data + 'route' => true, // Current route information + 'auth' => true, // Display Laravel authentication status + 'gate' => true, // Display Laravel Gate checks + 'session' => true, // Display session data + 'symfony_request' => true, // Only one can be enabled.. + 'mail' => true, // Catch mail messages + 'laravel' => false, // Laravel version and environment + 'events' => false, // All events fired + 'default_request' => false, // Regular or special Symfony request logger + 'logs' => false, // Add the latest log messages + 'files' => false, // Show the included files + 'config' => false, // Display config settings + 'cache' => false, // Display cache events + ], + + // Configure some DataCollectors + 'options' => [ + 'auth' => [ + 'show_name' => true, // Also show the users name/email in the debugbar + ], + 'db' => [ + 'with_params' => true, // Render SQL with the parameters substituted + 'backtrace' => true, // Use a backtrace to find the origin of the query in your files. + 'timeline' => false, // Add the queries to the timeline + 'explain' => [ // Show EXPLAIN output on queries + 'enabled' => false, + 'types' => ['SELECT'], // ['SELECT', 'INSERT', 'UPDATE', 'DELETE']; for MySQL 5.6.3+ + ], + 'hints' => true, // Show hints for common mistakes + ], + 'mail' => [ + 'full_log' => false + ], + 'views' => [ + 'data' => false, //Note: Can slow down the application, because the data can be quite large.. + ], + 'route' => [ + 'label' => true // show complete route on bar + ], + 'logs' => [ + 'file' => null + ], + 'cache' => [ + 'values' => true // collect cache values + ], + ], + + // Inject Debugbar into the response + // Usually, the debugbar is added just before , by listening to the + // Response after the App is done. If you disable this, you have to add them + // in your template yourself. See http://phpdebugbar.com/docs/rendering.html + 'inject' => true, + + // DebugBar route prefix + // Sometimes you want to set route prefix to be used by DebugBar to load + // its resources from. Usually the need comes from misconfigured web server or + // from trying to overcome bugs like this: http://trac.nginx.org/nginx/ticket/97 + 'route_prefix' => '_debugbar', + + // DebugBar route domain + // By default DebugBar route served from the same domain that request served. + // To override default domain, specify it as a non-empty value. + 'route_domain' => env('APP_URL', '') === 'http://bookstack.dev' ? '' : env('APP_URL', ''), +]; diff --git a/config/dompdf.php b/app/Config/dompdf.php similarity index 100% rename from config/dompdf.php rename to app/Config/dompdf.php diff --git a/config/filesystems.php b/app/Config/filesystems.php similarity index 88% rename from config/filesystems.php rename to app/Config/filesystems.php index 13198a505..bd7d28300 100644 --- a/config/filesystems.php +++ b/app/Config/filesystems.php @@ -14,6 +14,12 @@ return [ // Options: local, local_secure, s3 'default' => env('STORAGE_TYPE', 'local'), + // Filesystem to use specifically for image uploads. + 'images' => env('STORAGE_IMAGE_TYPE', env('STORAGE_TYPE', 'local')), + + // Filesystem to use specifically for file attachments. + 'attachments' => env('STORAGE_ATTACHMENT_TYPE', env('STORAGE_TYPE', 'local')), + // Storage URL // This is the url to where the storage is located for when using an external // file storage service, such as s3, to store publicly accessible assets. diff --git a/config/mail.php b/app/Config/mail.php similarity index 100% rename from config/mail.php rename to app/Config/mail.php diff --git a/config/queue.php b/app/Config/queue.php similarity index 100% rename from config/queue.php rename to app/Config/queue.php diff --git a/config/services.php b/app/Config/services.php similarity index 100% rename from config/services.php rename to app/Config/services.php diff --git a/config/session.php b/app/Config/session.php similarity index 100% rename from config/session.php rename to app/Config/session.php diff --git a/config/setting-defaults.php b/app/Config/setting-defaults.php similarity index 84% rename from config/setting-defaults.php rename to app/Config/setting-defaults.php index b48253eb1..4a135573b 100644 --- a/config/setting-defaults.php +++ b/app/Config/setting-defaults.php @@ -14,8 +14,8 @@ return [ 'app-logo' => '', 'app-name-header' => true, 'app-editor' => 'wysiwyg', - 'app-color' => '#0288D1', - 'app-color-light' => 'rgba(21, 101, 192, 0.15)', + 'app-color' => '#206ea7', + 'app-color-light' => 'rgba(32,110,167,0.15)', 'app-custom-head' => false, 'registration-enabled' => false, diff --git a/config/snappy.php b/app/Config/snappy.php similarity index 100% rename from config/snappy.php rename to app/Config/snappy.php diff --git a/config/view.php b/app/Config/view.php similarity index 100% rename from config/view.php rename to app/Config/view.php diff --git a/app/Entities/Book.php b/app/Entities/Book.php index decdde9dc..7d3d5e4ae 100644 --- a/app/Entities/Book.php +++ b/app/Entities/Book.php @@ -25,9 +25,9 @@ class Book extends Entity public function getUrl($path = false) { if ($path !== false) { - return baseUrl('/books/' . urlencode($this->slug) . '/' . trim($path, '/')); + return url('/books/' . urlencode($this->slug) . '/' . trim($path, '/')); } - return baseUrl('/books/' . urlencode($this->slug)); + return url('/books/' . urlencode($this->slug)); } /** @@ -44,7 +44,7 @@ class Book extends Entity } try { - $cover = $this->cover ? baseUrl($this->cover->getThumb($width, $height, false)) : $default; + $cover = $this->cover ? url($this->cover->getThumb($width, $height, false)) : $default; } catch (\Exception $err) { $cover = $default; } diff --git a/app/Entities/Bookshelf.php b/app/Entities/Bookshelf.php index c8f8b990c..db6685688 100644 --- a/app/Entities/Bookshelf.php +++ b/app/Entities/Bookshelf.php @@ -39,9 +39,9 @@ class Bookshelf extends Entity public function getUrl($path = false) { if ($path !== false) { - return baseUrl('/shelves/' . urlencode($this->slug) . '/' . trim($path, '/')); + return url('/shelves/' . urlencode($this->slug) . '/' . trim($path, '/')); } - return baseUrl('/shelves/' . urlencode($this->slug)); + return url('/shelves/' . urlencode($this->slug)); } /** @@ -59,7 +59,7 @@ class Bookshelf extends Entity } try { - $cover = $this->cover ? baseUrl($this->cover->getThumb($width, $height, false)) : $default; + $cover = $this->cover ? url($this->cover->getThumb($width, $height, false)) : $default; } catch (\Exception $err) { $cover = $default; } diff --git a/app/Entities/Chapter.php b/app/Entities/Chapter.php index 936404758..b204f1903 100644 --- a/app/Entities/Chapter.php +++ b/app/Entities/Chapter.php @@ -42,10 +42,13 @@ class Chapter extends Entity public function getUrl($path = false) { $bookSlug = $this->getAttribute('bookSlug') ? $this->getAttribute('bookSlug') : $this->book->slug; + $fullPath = '/books/' . urlencode($bookSlug) . '/chapter/' . urlencode($this->slug); + if ($path !== false) { - return baseUrl('/books/' . urlencode($bookSlug) . '/chapter/' . urlencode($this->slug) . '/' . trim($path, '/')); + $fullPath .= '/' . trim($path, '/'); } - return baseUrl('/books/' . urlencode($bookSlug) . '/chapter/' . urlencode($this->slug)); + + return url($fullPath); } /** diff --git a/app/Entities/Page.php b/app/Entities/Page.php index 1c2cc5cff..c32417418 100644 --- a/app/Entities/Page.php +++ b/app/Entities/Page.php @@ -96,10 +96,10 @@ class Page extends Entity $idComponent = $this->draft ? $this->id : urlencode($this->slug); if ($path !== false) { - return baseUrl('/books/' . urlencode($bookSlug) . $midText . $idComponent . '/' . trim($path, '/')); + return url('/books/' . urlencode($bookSlug) . $midText . $idComponent . '/' . trim($path, '/')); } - return baseUrl('/books/' . urlencode($bookSlug) . $midText . $idComponent); + return url('/books/' . urlencode($bookSlug) . $midText . $idComponent); } /** diff --git a/app/Entities/Repos/EntityRepo.php b/app/Entities/Repos/EntityRepo.php index 7ca25b785..996873bcc 100644 --- a/app/Entities/Repos/EntityRepo.php +++ b/app/Entities/Repos/EntityRepo.php @@ -766,7 +766,7 @@ class EntityRepo } // Remove data or JavaScript iFrames - $badIframes = $xPath->query('//*[contains(@src, \'data:\')] | //*[contains(@src, \'javascript:\')]'); + $badIframes = $xPath->query('//*[contains(@src, \'data:\')] | //*[contains(@src, \'javascript:\')] | //*[@srcdoc]'); foreach ($badIframes as $badIframe) { $badIframe->parentNode->removeChild($badIframe); } diff --git a/app/Entities/Repos/PageRepo.php b/app/Entities/Repos/PageRepo.php index e6cb309e7..ed142eb61 100644 --- a/app/Entities/Repos/PageRepo.php +++ b/app/Entities/Repos/PageRepo.php @@ -9,6 +9,7 @@ use Carbon\Carbon; use DOMDocument; use DOMElement; use DOMXPath; +use Illuminate\Support\Collection; class PageRepo extends EntityRepo { @@ -69,6 +70,10 @@ class PageRepo extends EntityRepo $this->tagRepo->saveTagsToEntity($page, $input['tags']); } + if (isset($input['template']) && userCan('templates-manage')) { + $page->template = ($input['template'] === 'true'); + } + // Update with new details $userId = user()->id; $page->fill($input); @@ -85,8 +90,9 @@ class PageRepo extends EntityRepo $this->userUpdatePageDraftsQuery($page, $userId)->delete(); // Save a revision after updating - if ($oldHtml !== $input['html'] || $oldName !== $input['name'] || $input['summary'] !== null) { - $this->savePageRevision($page, $input['summary']); + $summary = $input['summary'] ?? null; + if ($oldHtml !== $input['html'] || $oldName !== $input['name'] || $summary !== null) { + $this->savePageRevision($page, $summary); } $this->searchService->indexEntity($page); @@ -300,6 +306,10 @@ class PageRepo extends EntityRepo $this->tagRepo->saveTagsToEntity($draftPage, $input['tags']); } + if (isset($input['template']) && userCan('templates-manage')) { + $draftPage->template = ($input['template'] === 'true'); + } + $draftPage->slug = $this->findSuitableSlug('page', $draftPage->name, false, $draftPage->book->id); $draftPage->html = $this->formatHtml($input['html']); $draftPage->text = $this->pageToPlainText($draftPage); @@ -424,9 +434,7 @@ class PageRepo extends EntityRepo $tree = collect($headers)->map(function($header) { $text = trim(str_replace("\xc2\xa0", '', $header->nodeValue)); - if (mb_strlen($text) > 30) { - $text = mb_substr($text, 0, 27) . '...'; - } + $text = mb_substr($text, 0, 100); return [ 'nodeName' => strtolower($header->nodeName), @@ -438,10 +446,10 @@ class PageRepo extends EntityRepo return mb_strlen($header['text']) > 0; }); - // Normalise headers if only smaller headers have been used - $minLevel = $tree->pluck('level')->min(); - $tree = $tree->map(function ($header) use ($minLevel) { - $header['level'] -= ($minLevel - 2); + // Shift headers if only smaller headers have been used + $levelChange = ($tree->pluck('level')->min() - 1); + $tree = $tree->map(function ($header) use ($levelChange) { + $header['level'] -= ($levelChange); return $header; }); @@ -525,4 +533,29 @@ class PageRepo extends EntityRepo return $this->publishPageDraft($copyPage, $pageData); } + + /** + * Get pages that have been marked as templates. + * @param int $count + * @param int $page + * @param string $search + * @return \Illuminate\Contracts\Pagination\LengthAwarePaginator + */ + public function getPageTemplates(int $count = 10, int $page = 1, string $search = '') + { + $query = $this->entityQuery('page') + ->where('template', '=', true) + ->orderBy('name', 'asc') + ->skip( ($page - 1) * $count) + ->take($count); + + if ($search) { + $query->where('name', 'like', '%' . $search . '%'); + } + + $paginator = $query->paginate($count, ['*'], 'page', $page); + $paginator->withPath('/templates'); + + return $paginator; + } } diff --git a/app/Exceptions/UserTokenExpiredException.php b/app/Exceptions/UserTokenExpiredException.php new file mode 100644 index 000000000..203e08c85 --- /dev/null +++ b/app/Exceptions/UserTokenExpiredException.php @@ -0,0 +1,19 @@ +userId = $userId; + parent::__construct($message); + } + + +} \ No newline at end of file diff --git a/app/Exceptions/UserTokenNotFoundException.php b/app/Exceptions/UserTokenNotFoundException.php new file mode 100644 index 000000000..08c1fd830 --- /dev/null +++ b/app/Exceptions/UserTokenNotFoundException.php @@ -0,0 +1,3 @@ +emailConfirmationService = $emailConfirmationService; + $this->userRepo = $userRepo; + parent::__construct(); + } + + + /** + * Show the page to tell the user to check their email + * and confirm their address. + */ + public function show() + { + return view('auth.register-confirm'); + } + + /** + * Shows a notice that a user's email address has not been confirmed, + * Also has the option to re-send the confirmation email. + * @return View + */ + public function showAwaiting() + { + return view('auth.user-unconfirmed'); + } + + /** + * Confirms an email via a token and logs the user into the system. + * @param $token + * @return RedirectResponse|Redirector + * @throws ConfirmationEmailException + * @throws Exception + */ + public function confirm($token) + { + try { + $userId = $this->emailConfirmationService->checkTokenAndGetUserId($token); + } catch (Exception $exception) { + + if ($exception instanceof UserTokenNotFoundException) { + session()->flash('error', trans('errors.email_confirmation_invalid')); + return redirect('/register'); + } + + if ($exception instanceof UserTokenExpiredException) { + $user = $this->userRepo->getById($exception->userId); + $this->emailConfirmationService->sendConfirmation($user); + session()->flash('error', trans('errors.email_confirmation_expired')); + return redirect('/register/confirm'); + } + + throw $exception; + } + + $user = $this->userRepo->getById($userId); + $user->email_confirmed = true; + $user->save(); + + auth()->login($user); + session()->flash('success', trans('auth.email_confirm_success')); + $this->emailConfirmationService->deleteByUser($user); + + return redirect('/'); + } + + + /** + * Resend the confirmation email + * @param Request $request + * @return View + */ + public function resend(Request $request) + { + $this->validate($request, [ + 'email' => 'required|email|exists:users,email' + ]); + $user = $this->userRepo->getByEmail($request->get('email')); + + try { + $this->emailConfirmationService->sendConfirmation($user); + } catch (Exception $e) { + session()->flash('error', trans('auth.email_confirm_send_error')); + return redirect('/register/confirm'); + } + + session()->flash('success', trans('auth.email_confirm_resent')); + return redirect('/register/confirm'); + } + +} diff --git a/app/Http/Controllers/Auth/LoginController.php b/app/Http/Controllers/Auth/LoginController.php index 78a8d33c0..c739fd9a3 100644 --- a/app/Http/Controllers/Auth/LoginController.php +++ b/app/Http/Controllers/Auth/LoginController.php @@ -53,8 +53,8 @@ class LoginController extends Controller $this->socialAuthService = $socialAuthService; $this->ldapService = $ldapService; $this->userRepo = $userRepo; - $this->redirectPath = baseUrl('/'); - $this->redirectAfterLogout = baseUrl('/login'); + $this->redirectPath = url('/'); + $this->redirectAfterLogout = url('/login'); parent::__construct(); } @@ -106,9 +106,7 @@ class LoginController extends Controller $this->ldapService->syncGroups($user, $request->get($this->username())); } - $path = session()->pull('url.intended', '/'); - $path = baseUrl($path, true); - return redirect($path); + return redirect()->intended('/'); } /** diff --git a/app/Http/Controllers/Auth/RegisterController.php b/app/Http/Controllers/Auth/RegisterController.php index d57105b62..c411f2363 100644 --- a/app/Http/Controllers/Auth/RegisterController.php +++ b/app/Http/Controllers/Auth/RegisterController.php @@ -2,17 +2,22 @@ namespace BookStack\Http\Controllers\Auth; +use BookStack\Auth\Access\EmailConfirmationService; +use BookStack\Auth\Access\SocialAuthService; use BookStack\Auth\SocialAccount; use BookStack\Auth\User; use BookStack\Auth\UserRepo; +use BookStack\Exceptions\SocialDriverNotConfigured; use BookStack\Exceptions\SocialSignInAccountNotUsed; use BookStack\Exceptions\SocialSignInException; use BookStack\Exceptions\UserRegistrationException; use BookStack\Http\Controllers\Controller; use Exception; use Illuminate\Foundation\Auth\RegistersUsers; +use Illuminate\Http\RedirectResponse; use Illuminate\Http\Request; use Illuminate\Http\Response; +use Illuminate\Routing\Redirector; use Laravel\Socialite\Contracts\User as SocialUser; use Validator; @@ -46,18 +51,18 @@ class RegisterController extends Controller /** * Create a new controller instance. * - * @param \BookStack\Auth\Access\SocialAuthService $socialAuthService - * @param \BookStack\Auth\EmailConfirmationService $emailConfirmationService - * @param \BookStack\Auth\UserRepo $userRepo + * @param SocialAuthService $socialAuthService + * @param EmailConfirmationService $emailConfirmationService + * @param UserRepo $userRepo */ - public function __construct(\BookStack\Auth\Access\SocialAuthService $socialAuthService, \BookStack\Auth\Access\EmailConfirmationService $emailConfirmationService, UserRepo $userRepo) + public function __construct(SocialAuthService $socialAuthService, EmailConfirmationService $emailConfirmationService, UserRepo $userRepo) { $this->middleware('guest')->only(['getRegister', 'postRegister', 'socialRegister']); $this->socialAuthService = $socialAuthService; $this->emailConfirmationService = $emailConfirmationService; $this->userRepo = $userRepo; - $this->redirectTo = baseUrl('/'); - $this->redirectPath = baseUrl('/'); + $this->redirectTo = url('/'); + $this->redirectPath = url('/'); parent::__construct(); } @@ -101,8 +106,8 @@ class RegisterController extends Controller /** * Handle a registration request for the application. - * @param Request|\Illuminate\Http\Request $request - * @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector + * @param Request|Request $request + * @return RedirectResponse|Redirector * @throws UserRegistrationException */ public function postRegister(Request $request) @@ -117,7 +122,7 @@ class RegisterController extends Controller /** * Create a new user instance after a valid registration. * @param array $data - * @return \BookStack\Auth\User + * @return User */ protected function create(array $data) { @@ -133,7 +138,7 @@ class RegisterController extends Controller * @param array $userData * @param bool|false|SocialAccount $socialAccount * @param bool $emailVerified - * @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector + * @return RedirectResponse|Redirector * @throws UserRegistrationException */ protected function registerUser(array $userData, $socialAccount = false, $emailVerified = false) @@ -153,7 +158,7 @@ class RegisterController extends Controller $newUser->socialAccounts()->save($socialAccount); } - if ((setting('registration-confirmation') || $registrationRestrict) && !$emailVerified) { + if ($this->emailConfirmationService->confirmationRequired() && !$emailVerified) { $newUser->save(); try { @@ -170,72 +175,12 @@ class RegisterController extends Controller return redirect($this->redirectPath()); } - /** - * Show the page to tell the user to check their email - * and confirm their address. - */ - public function getRegisterConfirmation() - { - return view('auth.register-confirm'); - } - - /** - * Confirms an email via a token and logs the user into the system. - * @param $token - * @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector - * @throws UserRegistrationException - */ - public function confirmEmail($token) - { - $confirmation = $this->emailConfirmationService->getEmailConfirmationFromToken($token); - $user = $confirmation->user; - $user->email_confirmed = true; - $user->save(); - auth()->login($user); - session()->flash('success', trans('auth.email_confirm_success')); - $this->emailConfirmationService->deleteConfirmationsByUser($user); - return redirect($this->redirectPath); - } - - /** - * Shows a notice that a user's email address has not been confirmed, - * Also has the option to re-send the confirmation email. - * @return \Illuminate\View\View - */ - public function showAwaitingConfirmation() - { - return view('auth.user-unconfirmed'); - } - - /** - * Resend the confirmation email - * @param Request $request - * @return \Illuminate\View\View - */ - public function resendConfirmation(Request $request) - { - $this->validate($request, [ - 'email' => 'required|email|exists:users,email' - ]); - $user = $this->userRepo->getByEmail($request->get('email')); - - try { - $this->emailConfirmationService->sendConfirmation($user); - } catch (Exception $e) { - session()->flash('error', trans('auth.email_confirm_send_error')); - return redirect('/register/confirm'); - } - - session()->flash('success', trans('auth.email_confirm_resent')); - return redirect('/register/confirm'); - } - /** * Redirect to the social site for authentication intended to register. * @param $socialDriver * @return mixed * @throws UserRegistrationException - * @throws \BookStack\Exceptions\SocialDriverNotConfigured + * @throws SocialDriverNotConfigured */ public function socialRegister($socialDriver) { @@ -248,10 +193,10 @@ class RegisterController extends Controller * The callback for social login services. * @param $socialDriver * @param Request $request - * @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector + * @return RedirectResponse|Redirector * @throws SocialSignInException * @throws UserRegistrationException - * @throws \BookStack\Exceptions\SocialDriverNotConfigured + * @throws SocialDriverNotConfigured */ public function socialCallback($socialDriver, Request $request) { @@ -292,7 +237,7 @@ class RegisterController extends Controller /** * Detach a social account from a user. * @param $socialDriver - * @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector + * @return RedirectResponse|Redirector */ public function detachSocialAccount($socialDriver) { @@ -303,7 +248,7 @@ class RegisterController extends Controller * Register a new user after a registration callback. * @param string $socialDriver * @param SocialUser $socialUser - * @return \Illuminate\Http\RedirectResponse|\Illuminate\Routing\Redirector + * @return RedirectResponse|Redirector * @throws UserRegistrationException */ protected function socialRegisterCallback(string $socialDriver, SocialUser $socialUser) diff --git a/app/Http/Controllers/Auth/UserInviteController.php b/app/Http/Controllers/Auth/UserInviteController.php new file mode 100644 index 000000000..5d9373f45 --- /dev/null +++ b/app/Http/Controllers/Auth/UserInviteController.php @@ -0,0 +1,106 @@ +inviteService = $inviteService; + $this->userRepo = $userRepo; + $this->middleware('guest'); + parent::__construct(); + } + + /** + * Show the page for the user to set the password for their account. + * @param string $token + * @return Factory|View|RedirectResponse + * @throws Exception + */ + public function showSetPassword(string $token) + { + try { + $this->inviteService->checkTokenAndGetUserId($token); + } catch (Exception $exception) { + return $this->handleTokenException($exception); + } + + return view('auth.invite-set-password', [ + 'token' => $token, + ]); + } + + /** + * Sets the password for an invited user and then grants them access. + * @param string $token + * @param Request $request + * @return RedirectResponse|Redirector + * @throws Exception + */ + public function setPassword(string $token, Request $request) + { + $this->validate($request, [ + 'password' => 'required|min:6' + ]); + + try { + $userId = $this->inviteService->checkTokenAndGetUserId($token); + } catch (Exception $exception) { + return $this->handleTokenException($exception); + } + + $user = $this->userRepo->getById($userId); + $user->password = bcrypt($request->get('password')); + $user->email_confirmed = true; + $user->save(); + + auth()->login($user); + session()->flash('success', trans('auth.user_invite_success', ['appName' => setting('app-name')])); + $this->inviteService->deleteByUser($user); + + return redirect('/'); + } + + /** + * Check and validate the exception thrown when checking an invite token. + * @param Exception $exception + * @return RedirectResponse|Redirector + * @throws Exception + */ + protected function handleTokenException(Exception $exception) + { + if ($exception instanceof UserTokenNotFoundException) { + return redirect('/'); + } + + if ($exception instanceof UserTokenExpiredException) { + session()->flash('error', trans('errors.invite_token_expired')); + return redirect('/password/email'); + } + + throw $exception; + } + +} diff --git a/app/Http/Controllers/HomeController.php b/app/Http/Controllers/HomeController.php index ba93bfe65..d2c75f956 100644 --- a/app/Http/Controllers/HomeController.php +++ b/app/Http/Controllers/HomeController.php @@ -91,35 +91,6 @@ class HomeController extends Controller return view('common.home', $commonData); } - /** - * Get a js representation of the current translations - * @return \Illuminate\Contracts\Routing\ResponseFactory|\Symfony\Component\HttpFoundation\Response - * @throws \Exception - */ - public function getTranslations() - { - $locale = app()->getLocale(); - $cacheKey = 'GLOBAL_TRANSLATIONS_' . $locale; - - if (cache()->has($cacheKey) && config('app.env') !== 'development') { - $resp = cache($cacheKey); - } else { - $translations = [ - // Get only translations which might be used in JS - 'common' => trans('common'), - 'components' => trans('components'), - 'entities' => trans('entities'), - 'errors' => trans('errors') - ]; - $resp = 'window.translations = ' . json_encode($translations); - cache()->put($cacheKey, $resp, 120); - } - - return response($resp, 200, [ - 'Content-Type' => 'application/javascript' - ]); - } - /** * Get custom head HTML, Used in ajax calls to show in editor. * @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View diff --git a/app/Http/Controllers/PageController.php b/app/Http/Controllers/PageController.php index 16a7d5a5e..ad1e32665 100644 --- a/app/Http/Controllers/PageController.php +++ b/app/Http/Controllers/PageController.php @@ -110,11 +110,14 @@ class PageController extends Controller $this->setPageTitle(trans('entities.pages_edit_draft')); $draftsEnabled = $this->signedIn; + $templates = $this->pageRepo->getPageTemplates(10); + return view('pages.edit', [ 'page' => $draft, 'book' => $draft->book, 'isDraft' => true, - 'draftsEnabled' => $draftsEnabled + 'draftsEnabled' => $draftsEnabled, + 'templates' => $templates, ]); } @@ -239,11 +242,14 @@ class PageController extends Controller } $draftsEnabled = $this->signedIn; + $templates = $this->pageRepo->getPageTemplates(10); + return view('pages.edit', [ 'page' => $page, 'book' => $page->book, 'current' => $page, - 'draftsEnabled' => $draftsEnabled + 'draftsEnabled' => $draftsEnabled, + 'templates' => $templates, ]); } @@ -489,7 +495,7 @@ class PageController extends Controller $revision->delete(); session()->flash('success', trans('entities.revision_delete_success')); - return view('pages.revisions', ['page' => $page, 'book' => $page->book, 'current' => $page]); + return redirect($page->getUrl('/revisions')); } /** @@ -541,7 +547,7 @@ class PageController extends Controller public function showRecentlyUpdated() { // TODO - Still exist? - $pages = $this->pageRepo->getRecentlyUpdatedPaginated('page', 20)->setPath(baseUrl('/pages/recently-updated')); + $pages = $this->pageRepo->getRecentlyUpdatedPaginated('page', 20)->setPath(url('/pages/recently-updated')); return view('pages.detailed-listing', [ 'title' => trans('entities.recently_updated_pages'), 'pages' => $pages diff --git a/app/Http/Controllers/PageTemplateController.php b/app/Http/Controllers/PageTemplateController.php new file mode 100644 index 000000000..05943351a --- /dev/null +++ b/app/Http/Controllers/PageTemplateController.php @@ -0,0 +1,63 @@ +pageRepo = $pageRepo; + parent::__construct(); + } + + /** + * Fetch a list of templates from the system. + * @param Request $request + * @return \Illuminate\Contracts\View\Factory|\Illuminate\View\View + */ + public function list(Request $request) + { + $page = $request->get('page', 1); + $search = $request->get('search', ''); + $templates = $this->pageRepo->getPageTemplates(10, $page, $search); + + if ($search) { + $templates->appends(['search' => $search]); + } + + return view('pages.template-manager-list', [ + 'templates' => $templates + ]); + } + + /** + * Get the content of a template. + * @param $templateId + * @return \Illuminate\Contracts\Routing\ResponseFactory|\Symfony\Component\HttpFoundation\Response + * @throws NotFoundException + */ + public function get($templateId) + { + $page = $this->pageRepo->getById('page', $templateId); + + if (!$page->template) { + throw new NotFoundException(); + } + + return response()->json([ + 'html' => $page->html, + 'markdown' => $page->markdown, + ]); + } + +} diff --git a/app/Http/Controllers/SearchController.php b/app/Http/Controllers/SearchController.php index 4bcf7b40e..1691ee9b0 100644 --- a/app/Http/Controllers/SearchController.php +++ b/app/Http/Controllers/SearchController.php @@ -48,7 +48,7 @@ class SearchController extends Controller $this->setPageTitle(trans('entities.search_for_term', ['term' => $searchTerm])); $page = intval($request->get('page', '0')) ?: 1; - $nextPageLink = baseUrl('/search?term=' . urlencode($searchTerm) . '&page=' . ($page+1)); + $nextPageLink = url('/search?term=' . urlencode($searchTerm) . '&page=' . ($page+1)); $results = $this->searchService->searchEntities($searchTerm, 'all', $page, 20); diff --git a/app/Http/Controllers/UserController.php b/app/Http/Controllers/UserController.php index 570896ab6..c9d2560ba 100644 --- a/app/Http/Controllers/UserController.php +++ b/app/Http/Controllers/UserController.php @@ -1,6 +1,7 @@ user = $user; $this->userRepo = $userRepo; + $this->inviteService = $inviteService; $this->imageRepo = $imageRepo; parent::__construct(); } @@ -75,8 +79,10 @@ class UserController extends Controller ]; $authMethod = config('auth.method'); - if ($authMethod === 'standard') { - $validationRules['password'] = 'required|min:5'; + $sendInvite = ($request->get('send_invite', 'false') === 'true'); + + if ($authMethod === 'standard' && !$sendInvite) { + $validationRules['password'] = 'required|min:6'; $validationRules['password-confirm'] = 'required|same:password'; } elseif ($authMethod === 'ldap') { $validationRules['external_auth_id'] = 'required'; @@ -86,13 +92,17 @@ class UserController extends Controller $user = $this->user->fill($request->all()); if ($authMethod === 'standard') { - $user->password = bcrypt($request->get('password')); + $user->password = bcrypt($request->get('password', str_random(32))); } elseif ($authMethod === 'ldap') { $user->external_auth_id = $request->get('external_auth_id'); } $user->save(); + if ($sendInvite) { + $this->inviteService->sendInvitation($user); + } + if ($request->filled('roles')) { $roles = $request->get('roles'); $this->userRepo->setUserRoles($user, $roles); @@ -139,7 +149,7 @@ class UserController extends Controller $this->validate($request, [ 'name' => 'min:2', 'email' => 'min:2|email|unique:users,email,' . $id, - 'password' => 'min:5|required_with:password_confirm', + 'password' => 'min:6|required_with:password_confirm', 'password-confirm' => 'same:password|required_with:password', 'setting' => 'array', 'profile_image' => $this->imageRepo->getImageValidationRules(), diff --git a/app/Http/Middleware/Authenticate.php b/app/Http/Middleware/Authenticate.php index 1a3384367..d840a9b2e 100644 --- a/app/Http/Middleware/Authenticate.php +++ b/app/Http/Middleware/Authenticate.php @@ -41,7 +41,7 @@ class Authenticate if ($request->ajax()) { return response('Unauthorized.', 401); } else { - return redirect()->guest(baseUrl('/login')); + return redirect()->guest(url('/login')); } } diff --git a/app/Http/Middleware/Localization.php b/app/Http/Middleware/Localization.php index ff5526cc7..b5e702781 100644 --- a/app/Http/Middleware/Localization.php +++ b/app/Http/Middleware/Localization.php @@ -31,12 +31,10 @@ class Localization 'nl' => 'nl_NL', 'pl' => 'pl_PL', 'pt_BR' => 'pt_BR', - 'pt_BR' => 'pt_BR', 'ru' => 'ru', 'sk' => 'sk_SK', 'sv' => 'sv_SE', 'uk' => 'uk_UA', - 'uk' => 'uk_UA', 'zh_CN' => 'zh_CN', 'zh_TW' => 'zh_TW', ]; @@ -59,6 +57,8 @@ class Localization $locale = setting()->getUser(user(), 'language', $defaultLang); } + config()->set('app.lang', str_replace('_', '-', $this->getLocaleIso($locale))); + // Set text direction if (in_array($locale, $this->rtlLocales)) { config()->set('app.rtl', true); @@ -88,6 +88,16 @@ class Localization return $default; } + /** + * Get the ISO version of a BookStack language name + * @param string $locale + * @return string + */ + public function getLocaleIso(string $locale) + { + return $this->localeMap[$locale] ?? $locale; + } + /** * Set the system date locale for localized date formatting. * Will try both the standard locale name and the UTF8 variant. @@ -95,7 +105,7 @@ class Localization */ protected function setSystemDateLocale(string $locale) { - $systemLocale = $this->localeMap[$locale] ?? $locale; + $systemLocale = $this->getLocaleIso($locale); $set = setlocale(LC_TIME, $systemLocale); if ($set === false) { setlocale(LC_TIME, $systemLocale . '.utf8'); diff --git a/app/Http/Request.php b/app/Http/Request.php new file mode 100644 index 000000000..bd2761a0b --- /dev/null +++ b/app/Http/Request.php @@ -0,0 +1,26 @@ +getScheme().'://'.$this->getHttpHost(); + } + + return $base; + } + +} \ No newline at end of file diff --git a/app/Notifications/ConfirmEmail.php b/app/Notifications/ConfirmEmail.php index 7ecadc298..229408f5c 100644 --- a/app/Notifications/ConfirmEmail.php +++ b/app/Notifications/ConfirmEmail.php @@ -26,6 +26,6 @@ class ConfirmEmail extends MailNotification ->subject(trans('auth.email_confirm_subject', $appName)) ->greeting(trans('auth.email_confirm_greeting', $appName)) ->line(trans('auth.email_confirm_text')) - ->action(trans('auth.email_confirm_action'), baseUrl('/register/confirm/' . $this->token)); + ->action(trans('auth.email_confirm_action'), url('/register/confirm/' . $this->token)); } } diff --git a/app/Notifications/ResetPassword.php b/app/Notifications/ResetPassword.php index 305a7da72..208752764 100644 --- a/app/Notifications/ResetPassword.php +++ b/app/Notifications/ResetPassword.php @@ -29,7 +29,7 @@ class ResetPassword extends MailNotification return $this->newMailMessage() ->subject(trans('auth.email_reset_subject', ['appName' => setting('app-name')])) ->line(trans('auth.email_reset_text')) - ->action(trans('auth.reset_password'), baseUrl('password/reset/' . $this->token)) + ->action(trans('auth.reset_password'), url('password/reset/' . $this->token)) ->line(trans('auth.email_reset_not_requested')); } } diff --git a/app/Notifications/UserInvite.php b/app/Notifications/UserInvite.php new file mode 100644 index 000000000..b01911bcd --- /dev/null +++ b/app/Notifications/UserInvite.php @@ -0,0 +1,31 @@ +token = $token; + } + + /** + * Get the mail representation of the notification. + * + * @param mixed $notifiable + * @return \Illuminate\Notifications\Messages\MailMessage + */ + public function toMail($notifiable) + { + $appName = ['appName' => setting('app-name')]; + return $this->newMailMessage() + ->subject(trans('auth.user_invite_email_subject', $appName)) + ->greeting(trans('auth.user_invite_email_greeting', $appName)) + ->line(trans('auth.user_invite_email_text')) + ->action(trans('auth.user_invite_email_action'), url('/register/invite/' . $this->token)); + } +} diff --git a/app/Providers/AppServiceProvider.php b/app/Providers/AppServiceProvider.php index 9b91ba126..a2fc673f4 100644 --- a/app/Providers/AppServiceProvider.php +++ b/app/Providers/AppServiceProvider.php @@ -9,10 +9,10 @@ use BookStack\Entities\Page; use BookStack\Settings\Setting; use BookStack\Settings\SettingService; use Illuminate\Database\Eloquent\Relations\Relation; -use Illuminate\Http\UploadedFile; use Illuminate\Support\Facades\View; use Illuminate\Support\ServiceProvider; use Schema; +use URL; use Validator; class AppServiceProvider extends ServiceProvider @@ -24,6 +24,9 @@ class AppServiceProvider extends ServiceProvider */ public function boot() { + // Set root URL + URL::forceRootUrl(config('app.url')); + // Custom validation methods Validator::extend('image_extension', function ($attribute, $value, $parameters, $validator) { $validImageExtensions = ['png', 'jpg', 'jpeg', 'bmp', 'gif', 'tiff', 'webp']; @@ -40,6 +43,14 @@ class AppServiceProvider extends ServiceProvider return ""; }); + Blade::directive('exposeTranslations', function($expression) { + return "startPush('translations'); ?>" . + "" . + '' . "\n" . + "" . + 'stopPush(); ?>'; + }); + // Allow longer string lengths after upgrade to utf8mb4 Schema::defaultStringLength(191); diff --git a/app/Providers/PaginationServiceProvider.php b/app/Providers/PaginationServiceProvider.php index 3a695c5e3..1c982b82e 100644 --- a/app/Providers/PaginationServiceProvider.php +++ b/app/Providers/PaginationServiceProvider.php @@ -18,7 +18,7 @@ class PaginationServiceProvider extends IlluminatePaginationServiceProvider }); Paginator::currentPathResolver(function () { - return baseUrl($this->app['request']->path()); + return url($this->app['request']->path()); }); Paginator::currentPageResolver(function ($pageName = 'page') { diff --git a/app/Uploads/Attachment.php b/app/Uploads/Attachment.php index eb9a0fe68..8720d3c09 100644 --- a/app/Uploads/Attachment.php +++ b/app/Uploads/Attachment.php @@ -37,6 +37,6 @@ class Attachment extends Ownable if ($this->external && strpos($this->path, 'http') !== 0) { return $this->path; } - return baseUrl('/attachments/' . $this->id); + return url('/attachments/' . $this->id); } } diff --git a/app/Uploads/AttachmentService.php b/app/Uploads/AttachmentService.php index e613642c4..6e875a1e7 100644 --- a/app/Uploads/AttachmentService.php +++ b/app/Uploads/AttachmentService.php @@ -13,7 +13,7 @@ class AttachmentService extends UploadService */ protected function getStorage() { - $storageType = config('filesystems.default'); + $storageType = config('filesystems.attachments'); // Override default location if set to local public to ensure not visible. if ($storageType === 'local') { diff --git a/app/Uploads/ImageService.php b/app/Uploads/ImageService.php index 8eefbaf9d..860230d00 100644 --- a/app/Uploads/ImageService.php +++ b/app/Uploads/ImageService.php @@ -45,9 +45,9 @@ class ImageService extends UploadService */ protected function getStorage($type = '') { - $storageType = config('filesystems.default'); + $storageType = config('filesystems.images'); - // Override default location if set to local public to ensure not visible. + // Ensure system images (App logo) are uploaded to a public space if ($type === 'system' && $storageType === 'local_secure') { $storageType = 'local'; } @@ -417,7 +417,7 @@ class ImageService extends UploadService $isLocal = strpos(trim($uri), 'http') !== 0; // Attempt to find local files even if url not absolute - $base = baseUrl('/'); + $base = url('/'); if (!$isLocal && strpos($uri, $base) === 0) { $isLocal = true; $uri = str_replace($base, '', $uri); @@ -442,7 +442,12 @@ class ImageService extends UploadService return null; } - return 'data:image/' . pathinfo($uri, PATHINFO_EXTENSION) . ';base64,' . base64_encode($imageData); + $extension = pathinfo($uri, PATHINFO_EXTENSION); + if ($extension === 'svg') { + $extension = 'svg+xml'; + } + + return 'data:image/' . $extension . ';base64,' . base64_encode($imageData); } /** @@ -458,7 +463,7 @@ class ImageService extends UploadService // Get the standard public s3 url if s3 is set as storage type // Uses the nice, short URL if bucket name has no periods in otherwise the longer // region-based url will be used to prevent http issues. - if ($storageUrl == false && config('filesystems.default') === 's3') { + if ($storageUrl == false && config('filesystems.images') === 's3') { $storageDetails = config('filesystems.disks.s3'); if (strpos($storageDetails['bucket'], '.') === false) { $storageUrl = 'https://' . $storageDetails['bucket'] . '.s3.amazonaws.com'; @@ -469,7 +474,7 @@ class ImageService extends UploadService $this->storageUrl = $storageUrl; } - $basePath = ($this->storageUrl == false) ? baseUrl('/') : $this->storageUrl; + $basePath = ($this->storageUrl == false) ? url('/') : $this->storageUrl; return rtrim($basePath, '/') . $filePath; } } diff --git a/app/helpers.php b/app/helpers.php index 8cb3fa3f4..f36f2e59d 100644 --- a/app/helpers.php +++ b/app/helpers.php @@ -1,8 +1,9 @@ user() ?: \BookStack\Auth\User::getDefault(); + return auth()->user() ?: User::getDefault(); } /** @@ -63,9 +64,9 @@ function hasAppAccess() : bool * that particular item. * @param string $permission * @param Ownable $ownable - * @return mixed + * @return bool */ -function userCan(string $permission, Ownable $ownable = null) +function userCan(string $permission, Ownable $ownable = null) : bool { if ($ownable === null) { return user() && user()->can($permission); @@ -83,7 +84,7 @@ function userCan(string $permission, Ownable $ownable = null) * @param string|null $entityClass * @return bool */ -function userCanOnAny(string $permission, string $entityClass = null) +function userCanOnAny(string $permission, string $entityClass = null) : bool { $permissionService = app(PermissionService::class); return $permissionService->checkUserHasPermissionOnAnything($permission, $entityClass); @@ -93,83 +94,27 @@ function userCanOnAny(string $permission, string $entityClass = null) * Helper to access system settings. * @param $key * @param bool $default - * @return bool|string|\BookStack\Settings\SettingService + * @return bool|string|SettingService */ function setting($key = null, $default = false) { - $settingService = resolve(\BookStack\Settings\SettingService::class); + $settingService = resolve(SettingService::class); if (is_null($key)) { return $settingService; } return $settingService->get($key, $default); } -/** - * Helper to create url's relative to the applications root path. - * @param string $path - * @param bool $forceAppDomain - * @return string - */ -function baseUrl($path, $forceAppDomain = false) -{ - $isFullUrl = strpos($path, 'http') === 0; - if ($isFullUrl && !$forceAppDomain) { - return $path; - } - - $path = trim($path, '/'); - $base = rtrim(config('app.url'), '/'); - - // Remove non-specified domain if forced and we have a domain - if ($isFullUrl && $forceAppDomain) { - if (!empty($base) && strpos($path, $base) === 0) { - $path = mb_substr($path, mb_strlen($base)); - } else { - $explodedPath = explode('/', $path); - $path = implode('/', array_splice($explodedPath, 3)); - } - } - - // Return normal url path if not specified in config - if (config('app.url') === '') { - return url($path); - } - - return $base . '/' . ltrim($path, '/'); -} - -/** - * Get an instance of the redirector. - * Overrides the default laravel redirect helper. - * Ensures it redirects even when the app is in a subdirectory. - * - * @param string|null $to - * @param int $status - * @param array $headers - * @param bool $secure - * @return \Illuminate\Routing\Redirector|\Illuminate\Http\RedirectResponse - */ -function redirect($to = null, $status = 302, $headers = [], $secure = null) -{ - if (is_null($to)) { - return app('redirect'); - } - - $to = baseUrl($to); - - return app('redirect')->to($to, $status, $headers, $secure); -} - /** * Get a path to a theme resource. * @param string $path - * @return string|boolean + * @return string */ -function theme_path($path = '') +function theme_path($path = '') : string { $theme = config('view.theme'); if (!$theme) { - return false; + return ''; } return base_path('themes/' . $theme .($path ? DIRECTORY_SEPARATOR.$path : $path)); @@ -188,8 +133,9 @@ function theme_path($path = '') function icon($name, $attrs = []) { $attrs = array_merge([ - 'class' => 'svg-icon', - 'data-icon' => $name + 'class' => 'svg-icon', + 'data-icon' => $name, + 'role' => 'presentation', ], $attrs); $attrString = ' '; foreach ($attrs as $attrName => $attr) { @@ -241,5 +187,5 @@ function sortUrl($path, $data, $overrideData = []) return $path; } - return baseUrl($path . '?' . implode('&', $queryStringSections)); + return url($path . '?' . implode('&', $queryStringSections)); } diff --git a/bootstrap/app.php b/bootstrap/app.php index 371f93913..516980cc1 100644 --- a/bootstrap/app.php +++ b/bootstrap/app.php @@ -11,7 +11,7 @@ | */ -$app = new Illuminate\Foundation\Application( +$app = new \BookStack\Application( realpath(__DIR__.'/../') ); diff --git a/database/migrations/2019_07_07_112515_add_template_support.php b/database/migrations/2019_07_07_112515_add_template_support.php new file mode 100644 index 000000000..a54508198 --- /dev/null +++ b/database/migrations/2019_07_07_112515_add_template_support.php @@ -0,0 +1,54 @@ +boolean('template')->default(false); + $table->index('template'); + }); + + // Create new templates-manage permission and assign to admin role + $adminRoleId = DB::table('roles')->where('system_name', '=', 'admin')->first()->id; + $permissionId = DB::table('role_permissions')->insertGetId([ + 'name' => 'templates-manage', + 'display_name' => 'Manage Page Templates', + 'created_at' => Carbon::now()->toDateTimeString(), + 'updated_at' => Carbon::now()->toDateTimeString() + ]); + DB::table('permission_role')->insert([ + 'role_id' => $adminRoleId, + 'permission_id' => $permissionId + ]); + } + + /** + * Reverse the migrations. + * + * @return void + */ + public function down() + { + Schema::table('pages', function (Blueprint $table) { + $table->dropColumn('template'); + }); + + // Remove templates-manage permission + $templatesManagePermission = DB::table('role_permissions') + ->where('name', '=', 'templates_manage')->first(); + + DB::table('permission_role')->where('permission_id', '=', $templatesManagePermission->id)->delete(); + DB::table('role_permissions')->where('name', '=', 'templates_manage')->delete(); + } +} diff --git a/database/migrations/2019_08_17_140214_add_user_invites_table.php b/database/migrations/2019_08_17_140214_add_user_invites_table.php new file mode 100644 index 000000000..23bd6988c --- /dev/null +++ b/database/migrations/2019_08_17_140214_add_user_invites_table.php @@ -0,0 +1,33 @@ +increments('id'); + $table->integer('user_id')->index(); + $table->string('token')->index(); + $table->nullableTimestamps(); + }); + } + + /** + * Reverse the migrations. + * + * @return void + */ + public function down() + { + Schema::dropIfExists('user_invites'); + } +} diff --git a/dev/docker/Dockerfile b/dev/docker/Dockerfile new file mode 100644 index 000000000..82ea2b6f6 --- /dev/null +++ b/dev/docker/Dockerfile @@ -0,0 +1,16 @@ +FROM php:7.3-apache + +ENV APACHE_DOCUMENT_ROOT /app/public +WORKDIR /app + +RUN apt-get update -y \ + && apt-get install -y libtidy-dev libpng-dev libldap2-dev libxml++2.6-dev wait-for-it \ + && docker-php-ext-configure ldap --with-libdir=lib/x86_64-linux-gnu \ + && docker-php-ext-install pdo pdo_mysql tidy dom xml mbstring gd ldap \ + && a2enmod rewrite \ + && sed -ri -e 's!/var/www/html!${APACHE_DOCUMENT_ROOT}!g' /etc/apache2/sites-available/*.conf \ + && sed -ri -e 's!/var/www/!${APACHE_DOCUMENT_ROOT}!g' /etc/apache2/apache2.conf /etc/apache2/conf-available/*.conf \ + && php -r "copy('https://getcomposer.org/installer', 'composer-setup.php');" \ + && php composer-setup.php \ + && mv composer.phar /usr/bin/composer \ + && php -r "unlink('composer-setup.php');" diff --git a/dev/docker/entrypoint.app.sh b/dev/docker/entrypoint.app.sh new file mode 100755 index 000000000..ff44f0c8d --- /dev/null +++ b/dev/docker/entrypoint.app.sh @@ -0,0 +1,14 @@ +#!/bin/bash + +set -e + +env + +if [[ -n "$1" ]]; then + exec "$@" +else + wait-for-it db:3306 -t 45 + php artisan migrate --database=mysql + chown -R www-data:www-data storage + exec apache2-foreground +fi \ No newline at end of file diff --git a/dev/docker/entrypoint.node.sh b/dev/docker/entrypoint.node.sh new file mode 100755 index 000000000..e59e1e8a0 --- /dev/null +++ b/dev/docker/entrypoint.node.sh @@ -0,0 +1,8 @@ +#!/bin/sh + +set -e + +npm install +npm rebuild node-sass + +exec npm run watch \ No newline at end of file diff --git a/docker-compose.yml b/docker-compose.yml new file mode 100644 index 000000000..47f38184e --- /dev/null +++ b/docker-compose.yml @@ -0,0 +1,41 @@ +# This is a Docker Compose configuration +# intended for development purposes only + +version: '3' + +volumes: + db: {} + +services: + db: + image: mysql:8 + environment: + MYSQL_DATABASE: bookstack-test + MYSQL_USER: bookstack-test + MYSQL_PASSWORD: bookstack-test + MYSQL_RANDOM_ROOT_PASSWORD: 'true' + command: --default-authentication-plugin=mysql_native_password + volumes: + - db:/var/lib/mysql + app: + build: + context: . + dockerfile: ./dev/docker/Dockerfile + environment: + DB_CONNECTION: mysql + DB_HOST: db + DB_PORT: 3306 + DB_DATABASE: bookstack-test + DB_USERNAME: bookstack-test + DB_PASSWORD: bookstack-test + ports: + - ${DEV_PORT:-8080}:80 + volumes: + - ./:/app + entrypoint: /app/dev/docker/entrypoint.app.sh + node: + image: node:alpine + working_dir: /app + volumes: + - ./:/app + entrypoint: /app/dev/docker/entrypoint.node.sh diff --git a/package-lock.json b/package-lock.json index 1a5fef175..3330ad5c7 100644 --- a/package-lock.json +++ b/package-lock.json @@ -2,926 +2,180 @@ "requires": true, "lockfileVersion": 1, "dependencies": { - "@babel/code-frame": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.0.0.tgz", - "integrity": "sha512-OfC2uemaknXr87bdLUkWog7nYuliM9Ij5HUcajsVcMCpQrcLmtxRbVFTIqmcSkSeYRBFBRxs2FiUqFJDLdiebA==", - "dev": true, - "requires": { - "@babel/highlight": "^7.0.0" - } - }, - "@babel/core": { - "version": "7.1.6", - "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.1.6.tgz", - "integrity": "sha512-Hz6PJT6e44iUNpAn8AoyAs6B3bl60g7MJQaI0rZEar6ECzh6+srYO1xlIdssio34mPaUtAb1y+XlkkSJzok3yw==", - "dev": true, - "requires": { - "@babel/code-frame": "^7.0.0", - "@babel/generator": "^7.1.6", - "@babel/helpers": "^7.1.5", - "@babel/parser": "^7.1.6", - "@babel/template": "^7.1.2", - "@babel/traverse": "^7.1.6", - "@babel/types": "^7.1.6", - "convert-source-map": "^1.1.0", - "debug": "^4.1.0", - "json5": "^2.1.0", - "lodash": "^4.17.10", - "resolve": "^1.3.2", - "semver": "^5.4.1", - "source-map": "^0.5.0" - }, - "dependencies": { - "json5": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/json5/-/json5-2.1.0.tgz", - "integrity": "sha512-8Mh9h6xViijj36g7Dxi+Y4S6hNGV96vcJZr/SrlHh1LR/pEn/8j/+qIBbs44YKl69Lrfctp4QD+AdWLTMqEZAQ==", - "dev": true, - "requires": { - "minimist": "^1.2.0" - } - }, - "minimist": { - "version": "1.2.0", - "resolved": "http://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", - "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", - "dev": true - }, - "source-map": { - "version": "0.5.7", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", - "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", - "dev": true - } - } - }, - "@babel/generator": { - "version": "7.1.6", - "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.1.6.tgz", - "integrity": "sha512-brwPBtVvdYdGxtenbQgfCdDPmtkmUBZPjUoK5SXJEBuHaA5BCubh9ly65fzXz7R6o5rA76Rs22ES8Z+HCc0YIQ==", - "dev": true, - "requires": { - "@babel/types": "^7.1.6", - "jsesc": "^2.5.1", - "lodash": "^4.17.10", - "source-map": "^0.5.0", - "trim-right": "^1.0.1" - }, - "dependencies": { - "source-map": { - "version": "0.5.7", - "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", - "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=", - "dev": true - } - } - }, - "@babel/helper-annotate-as-pure": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.0.0.tgz", - "integrity": "sha512-3UYcJUj9kvSLbLbUIfQTqzcy5VX7GRZ/CCDrnOaZorFFM01aXp1+GJwuFGV4NDDoAS+mOUyHcO6UD/RfqOks3Q==", - "dev": true, - "requires": { - "@babel/types": "^7.0.0" - } - }, - "@babel/helper-builder-binary-assignment-operator-visitor": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.1.0.tgz", - "integrity": "sha512-qNSR4jrmJ8M1VMM9tibvyRAHXQs2PmaksQF7c1CGJNipfe3D8p+wgNwgso/P2A2r2mdgBWAXljNWR0QRZAMW8w==", - "dev": true, - "requires": { - "@babel/helper-explode-assignable-expression": "^7.1.0", - "@babel/types": "^7.0.0" - } - }, - "@babel/helper-call-delegate": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/@babel/helper-call-delegate/-/helper-call-delegate-7.1.0.tgz", - "integrity": "sha512-YEtYZrw3GUK6emQHKthltKNZwszBcHK58Ygcis+gVUrF4/FmTVr5CCqQNSfmvg2y+YDEANyYoaLz/SHsnusCwQ==", - "dev": true, - "requires": { - "@babel/helper-hoist-variables": "^7.0.0", - "@babel/traverse": "^7.1.0", - "@babel/types": "^7.0.0" - } - }, - "@babel/helper-define-map": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/@babel/helper-define-map/-/helper-define-map-7.1.0.tgz", - "integrity": "sha512-yPPcW8dc3gZLN+U1mhYV91QU3n5uTbx7DUdf8NnPbjS0RMwBuHi9Xt2MUgppmNz7CJxTBWsGczTiEp1CSOTPRg==", - "dev": true, - "requires": { - "@babel/helper-function-name": "^7.1.0", - "@babel/types": "^7.0.0", - "lodash": "^4.17.10" - } - }, - "@babel/helper-explode-assignable-expression": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/@babel/helper-explode-assignable-expression/-/helper-explode-assignable-expression-7.1.0.tgz", - "integrity": "sha512-NRQpfHrJ1msCHtKjbzs9YcMmJZOg6mQMmGRB+hbamEdG5PNpaSm95275VD92DvJKuyl0s2sFiDmMZ+EnnvufqA==", - "dev": true, - "requires": { - "@babel/traverse": "^7.1.0", - "@babel/types": "^7.0.0" - } - }, - "@babel/helper-function-name": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.1.0.tgz", - "integrity": "sha512-A95XEoCpb3TO+KZzJ4S/5uW5fNe26DjBGqf1o9ucyLyCmi1dXq/B3c8iaWTfBk3VvetUxl16e8tIrd5teOCfGw==", - "dev": true, - "requires": { - "@babel/helper-get-function-arity": "^7.0.0", - "@babel/template": "^7.1.0", - "@babel/types": "^7.0.0" - } - }, - "@babel/helper-get-function-arity": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.0.0.tgz", - "integrity": "sha512-r2DbJeg4svYvt3HOS74U4eWKsUAMRH01Z1ds1zx8KNTPtpTL5JAsdFv8BNyOpVqdFhHkkRDIg5B4AsxmkjAlmQ==", - "dev": true, - "requires": { - "@babel/types": "^7.0.0" - } - }, - "@babel/helper-hoist-variables": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.0.0.tgz", - "integrity": "sha512-Ggv5sldXUeSKsuzLkddtyhyHe2YantsxWKNi7A+7LeD12ExRDWTRk29JCXpaHPAbMaIPZSil7n+lq78WY2VY7w==", - "dev": true, - "requires": { - "@babel/types": "^7.0.0" - } - }, - "@babel/helper-member-expression-to-functions": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.0.0.tgz", - "integrity": "sha512-avo+lm/QmZlv27Zsi0xEor2fKcqWG56D5ae9dzklpIaY7cQMK5N8VSpaNVPPagiqmy7LrEjK1IWdGMOqPu5csg==", - "dev": true, - "requires": { - "@babel/types": "^7.0.0" - } - }, - "@babel/helper-module-imports": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.0.0.tgz", - "integrity": "sha512-aP/hlLq01DWNEiDg4Jn23i+CXxW/owM4WpDLFUbpjxe4NS3BhLVZQ5i7E0ZrxuQ/vwekIeciyamgB1UIYxxM6A==", - "dev": true, - "requires": { - "@babel/types": "^7.0.0" - } - }, - "@babel/helper-module-transforms": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.1.0.tgz", - "integrity": "sha512-0JZRd2yhawo79Rcm4w0LwSMILFmFXjugG3yqf+P/UsKsRS1mJCmMwwlHDlMg7Avr9LrvSpp4ZSULO9r8jpCzcw==", - "dev": true, - "requires": { - "@babel/helper-module-imports": "^7.0.0", - "@babel/helper-simple-access": "^7.1.0", - "@babel/helper-split-export-declaration": "^7.0.0", - "@babel/template": "^7.1.0", - "@babel/types": "^7.0.0", - "lodash": "^4.17.10" - } - }, - "@babel/helper-optimise-call-expression": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.0.0.tgz", - "integrity": "sha512-u8nd9NQePYNQV8iPWu/pLLYBqZBa4ZaY1YWRFMuxrid94wKI1QNt67NEZ7GAe5Kc/0LLScbim05xZFWkAdrj9g==", - "dev": true, - "requires": { - "@babel/types": "^7.0.0" - } - }, - "@babel/helper-plugin-utils": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.0.0.tgz", - "integrity": "sha512-CYAOUCARwExnEixLdB6sDm2dIJ/YgEAKDM1MOeMeZu9Ld/bDgVo8aiWrXwcY7OBh+1Ea2uUcVRcxKk0GJvW7QA==", - "dev": true - }, - "@babel/helper-regex": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/helper-regex/-/helper-regex-7.0.0.tgz", - "integrity": "sha512-TR0/N0NDCcUIUEbqV6dCO+LptmmSQFQ7q70lfcEB4URsjD0E1HzicrwUH+ap6BAQ2jhCX9Q4UqZy4wilujWlkg==", - "dev": true, - "requires": { - "lodash": "^4.17.10" - } - }, - "@babel/helper-remap-async-to-generator": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.1.0.tgz", - "integrity": "sha512-3fOK0L+Fdlg8S5al8u/hWE6vhufGSn0bN09xm2LXMy//REAF8kDCrYoOBKYmA8m5Nom+sV9LyLCwrFynA8/slg==", - "dev": true, - "requires": { - "@babel/helper-annotate-as-pure": "^7.0.0", - "@babel/helper-wrap-function": "^7.1.0", - "@babel/template": "^7.1.0", - "@babel/traverse": "^7.1.0", - "@babel/types": "^7.0.0" - } - }, - "@babel/helper-replace-supers": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.1.0.tgz", - "integrity": "sha512-BvcDWYZRWVuDeXTYZWxekQNO5D4kO55aArwZOTFXw6rlLQA8ZaDicJR1sO47h+HrnCiDFiww0fSPV0d713KBGQ==", - "dev": true, - "requires": { - "@babel/helper-member-expression-to-functions": "^7.0.0", - "@babel/helper-optimise-call-expression": "^7.0.0", - "@babel/traverse": "^7.1.0", - "@babel/types": "^7.0.0" - } - }, - "@babel/helper-simple-access": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.1.0.tgz", - "integrity": "sha512-Vk+78hNjRbsiu49zAPALxTb+JUQCz1aolpd8osOF16BGnLtseD21nbHgLPGUwrXEurZgiCOUmvs3ExTu4F5x6w==", - "dev": true, - "requires": { - "@babel/template": "^7.1.0", - "@babel/types": "^7.0.0" - } - }, - "@babel/helper-split-export-declaration": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.0.0.tgz", - "integrity": "sha512-MXkOJqva62dfC0w85mEf/LucPPS/1+04nmmRMPEBUB++hiiThQ2zPtX/mEWQ3mtzCEjIJvPY8nuwxXtQeQwUag==", - "dev": true, - "requires": { - "@babel/types": "^7.0.0" - } - }, - "@babel/helper-wrap-function": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/@babel/helper-wrap-function/-/helper-wrap-function-7.1.0.tgz", - "integrity": "sha512-R6HU3dete+rwsdAfrOzTlE9Mcpk4RjU3aX3gi9grtmugQY0u79X7eogUvfXA5sI81Mfq1cn6AgxihfN33STjJA==", - "dev": true, - "requires": { - "@babel/helper-function-name": "^7.1.0", - "@babel/template": "^7.1.0", - "@babel/traverse": "^7.1.0", - "@babel/types": "^7.0.0" - } - }, - "@babel/helpers": { - "version": "7.1.5", - "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.1.5.tgz", - "integrity": "sha512-2jkcdL02ywNBry1YNFAH/fViq4fXG0vdckHqeJk+75fpQ2OH+Az6076tX/M0835zA45E0Cqa6pV5Kiv9YOqjEg==", - "dev": true, - "requires": { - "@babel/template": "^7.1.2", - "@babel/traverse": "^7.1.5", - "@babel/types": "^7.1.5" - } - }, - "@babel/highlight": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.0.0.tgz", - "integrity": "sha512-UFMC4ZeFC48Tpvj7C8UgLvtkaUuovQX+5xNWrsIoMG8o2z+XFKjKaN9iVmS84dPwVN00W4wPmqvYoZF3EGAsfw==", - "dev": true, - "requires": { - "chalk": "^2.0.0", - "esutils": "^2.0.2", - "js-tokens": "^4.0.0" - } - }, - "@babel/parser": { - "version": "7.1.6", - "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.1.6.tgz", - "integrity": "sha512-dWP6LJm9nKT6ALaa+bnL247GHHMWir3vSlZ2+IHgHgktZQx0L3Uvq2uAWcuzIe+fujRsYWBW2q622C5UvGK9iQ==", - "dev": true - }, - "@babel/plugin-proposal-async-generator-functions": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-async-generator-functions/-/plugin-proposal-async-generator-functions-7.1.0.tgz", - "integrity": "sha512-Fq803F3Jcxo20MXUSDdmZZXrPe6BWyGcWBPPNB/M7WaUYESKDeKMOGIxEzQOjGSmW/NWb6UaPZrtTB2ekhB/ew==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.0.0", - "@babel/helper-remap-async-to-generator": "^7.1.0", - "@babel/plugin-syntax-async-generators": "^7.0.0" - } - }, - "@babel/plugin-proposal-json-strings": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-json-strings/-/plugin-proposal-json-strings-7.0.0.tgz", - "integrity": "sha512-kfVdUkIAGJIVmHmtS/40i/fg/AGnw/rsZBCaapY5yjeO5RA9m165Xbw9KMOu2nqXP5dTFjEjHdfNdoVcHv133Q==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.0.0", - "@babel/plugin-syntax-json-strings": "^7.0.0" - } - }, - "@babel/plugin-proposal-object-rest-spread": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-object-rest-spread/-/plugin-proposal-object-rest-spread-7.0.0.tgz", - "integrity": "sha512-14fhfoPcNu7itSen7Py1iGN0gEm87hX/B+8nZPqkdmANyyYWYMY2pjA3r8WXbWVKMzfnSNS0xY8GVS0IjXi/iw==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.0.0", - "@babel/plugin-syntax-object-rest-spread": "^7.0.0" - } - }, - "@babel/plugin-proposal-optional-catch-binding": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-catch-binding/-/plugin-proposal-optional-catch-binding-7.0.0.tgz", - "integrity": "sha512-JPqAvLG1s13B/AuoBjdBYvn38RqW6n1TzrQO839/sIpqLpbnXKacsAgpZHzLD83Sm8SDXMkkrAvEnJ25+0yIpw==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.0.0", - "@babel/plugin-syntax-optional-catch-binding": "^7.0.0" - } - }, - "@babel/plugin-proposal-unicode-property-regex": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-unicode-property-regex/-/plugin-proposal-unicode-property-regex-7.0.0.tgz", - "integrity": "sha512-tM3icA6GhC3ch2SkmSxv7J/hCWKISzwycub6eGsDrFDgukD4dZ/I+x81XgW0YslS6mzNuQ1Cbzh5osjIMgepPQ==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.0.0", - "@babel/helper-regex": "^7.0.0", - "regexpu-core": "^4.2.0" - } - }, - "@babel/plugin-syntax-async-generators": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.0.0.tgz", - "integrity": "sha512-im7ged00ddGKAjcZgewXmp1vxSZQQywuQXe2B1A7kajjZmDeY/ekMPmWr9zJgveSaQH0k7BcGrojQhcK06l0zA==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.0.0" - } - }, - "@babel/plugin-syntax-json-strings": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.0.0.tgz", - "integrity": "sha512-UlSfNydC+XLj4bw7ijpldc1uZ/HB84vw+U6BTuqMdIEmz/LDe63w/GHtpQMdXWdqQZFeAI9PjnHe/vDhwirhKA==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.0.0" - } - }, - "@babel/plugin-syntax-object-rest-spread": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.0.0.tgz", - "integrity": "sha512-5A0n4p6bIiVe5OvQPxBnesezsgFJdHhSs3uFSvaPdMqtsovajLZ+G2vZyvNe10EzJBWWo3AcHGKhAFUxqwp2dw==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.0.0" - } - }, - "@babel/plugin-syntax-optional-catch-binding": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.0.0.tgz", - "integrity": "sha512-Wc+HVvwjcq5qBg1w5RG9o9RVzmCaAg/Vp0erHCKpAYV8La6I94o4GQAmFYNmkzoMO6gzoOSulpKeSSz6mPEoZw==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.0.0" - } - }, - "@babel/plugin-transform-arrow-functions": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.0.0.tgz", - "integrity": "sha512-2EZDBl1WIO/q4DIkIp4s86sdp4ZifL51MoIviLY/gG/mLSuOIEg7J8o6mhbxOTvUJkaN50n+8u41FVsr5KLy/w==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.0.0" - } - }, - "@babel/plugin-transform-async-to-generator": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.1.0.tgz", - "integrity": "sha512-rNmcmoQ78IrvNCIt/R9U+cixUHeYAzgusTFgIAv+wQb9HJU4szhpDD6e5GCACmj/JP5KxuCwM96bX3L9v4ZN/g==", - "dev": true, - "requires": { - "@babel/helper-module-imports": "^7.0.0", - "@babel/helper-plugin-utils": "^7.0.0", - "@babel/helper-remap-async-to-generator": "^7.1.0" - } - }, - "@babel/plugin-transform-block-scoped-functions": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.0.0.tgz", - "integrity": "sha512-AOBiyUp7vYTqz2Jibe1UaAWL0Hl9JUXEgjFvvvcSc9MVDItv46ViXFw2F7SVt1B5k+KWjl44eeXOAk3UDEaJjQ==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.0.0" - } - }, - "@babel/plugin-transform-block-scoping": { - "version": "7.1.5", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.1.5.tgz", - "integrity": "sha512-jlYcDrz+5ayWC7mxgpn1Wj8zj0mmjCT2w0mPIMSwO926eXBRxpEgoN/uQVRBfjtr8ayjcmS+xk2G1jaP8JjMJQ==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.0.0", - "lodash": "^4.17.10" - } - }, - "@babel/plugin-transform-classes": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.1.0.tgz", - "integrity": "sha512-rNaqoD+4OCBZjM7VaskladgqnZ1LO6o2UxuWSDzljzW21pN1KXkB7BstAVweZdxQkHAujps5QMNOTWesBciKFg==", - "dev": true, - "requires": { - "@babel/helper-annotate-as-pure": "^7.0.0", - "@babel/helper-define-map": "^7.1.0", - "@babel/helper-function-name": "^7.1.0", - "@babel/helper-optimise-call-expression": "^7.0.0", - "@babel/helper-plugin-utils": "^7.0.0", - "@babel/helper-replace-supers": "^7.1.0", - "@babel/helper-split-export-declaration": "^7.0.0", - "globals": "^11.1.0" - } - }, - "@babel/plugin-transform-computed-properties": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.0.0.tgz", - "integrity": "sha512-ubouZdChNAv4AAWAgU7QKbB93NU5sHwInEWfp+/OzJKA02E6Woh9RVoX4sZrbRwtybky/d7baTUqwFx+HgbvMA==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.0.0" - } - }, - "@babel/plugin-transform-destructuring": { - "version": "7.1.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.1.3.tgz", - "integrity": "sha512-Mb9M4DGIOspH1ExHOUnn2UUXFOyVTiX84fXCd+6B5iWrQg/QMeeRmSwpZ9lnjYLSXtZwiw80ytVMr3zue0ucYw==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.0.0" - } - }, - "@babel/plugin-transform-dotall-regex": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.0.0.tgz", - "integrity": "sha512-00THs8eJxOJUFVx1w8i1MBF4XH4PsAjKjQ1eqN/uCH3YKwP21GCKfrn6YZFZswbOk9+0cw1zGQPHVc1KBlSxig==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.0.0", - "@babel/helper-regex": "^7.0.0", - "regexpu-core": "^4.1.3" - } - }, - "@babel/plugin-transform-duplicate-keys": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.0.0.tgz", - "integrity": "sha512-w2vfPkMqRkdxx+C71ATLJG30PpwtTpW7DDdLqYt2acXU7YjztzeWW2Jk1T6hKqCLYCcEA5UQM/+xTAm+QCSnuQ==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.0.0" - } - }, - "@babel/plugin-transform-exponentiation-operator": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.1.0.tgz", - "integrity": "sha512-uZt9kD1Pp/JubkukOGQml9tqAeI8NkE98oZnHZ2qHRElmeKCodbTZgOEUtujSCSLhHSBWbzNiFSDIMC4/RBTLQ==", - "dev": true, - "requires": { - "@babel/helper-builder-binary-assignment-operator-visitor": "^7.1.0", - "@babel/helper-plugin-utils": "^7.0.0" - } - }, - "@babel/plugin-transform-for-of": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.0.0.tgz", - "integrity": "sha512-TlxKecN20X2tt2UEr2LNE6aqA0oPeMT1Y3cgz8k4Dn1j5ObT8M3nl9aA37LLklx0PBZKETC9ZAf9n/6SujTuXA==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.0.0" - } - }, - "@babel/plugin-transform-function-name": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.1.0.tgz", - "integrity": "sha512-VxOa1TMlFMtqPW2IDYZQaHsFrq/dDoIjgN098NowhexhZcz3UGlvPgZXuE1jEvNygyWyxRacqDpCZt+par1FNg==", - "dev": true, - "requires": { - "@babel/helper-function-name": "^7.1.0", - "@babel/helper-plugin-utils": "^7.0.0" - } - }, - "@babel/plugin-transform-literals": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-literals/-/plugin-transform-literals-7.0.0.tgz", - "integrity": "sha512-1NTDBWkeNXgpUcyoVFxbr9hS57EpZYXpje92zv0SUzjdu3enaRwF/l3cmyRnXLtIdyJASyiS6PtybK+CgKf7jA==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.0.0" - } - }, - "@babel/plugin-transform-modules-amd": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.1.0.tgz", - "integrity": "sha512-wt8P+xQ85rrnGNr2x1iV3DW32W8zrB6ctuBkYBbf5/ZzJY99Ob4MFgsZDFgczNU76iy9PWsy4EuxOliDjdKw6A==", - "dev": true, - "requires": { - "@babel/helper-module-transforms": "^7.1.0", - "@babel/helper-plugin-utils": "^7.0.0" - } - }, - "@babel/plugin-transform-modules-commonjs": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.1.0.tgz", - "integrity": "sha512-wtNwtMjn1XGwM0AXPspQgvmE6msSJP15CX2RVfpTSTNPLhKhaOjaIfBaVfj4iUZ/VrFSodcFedwtPg/NxwQlPA==", - "dev": true, - "requires": { - "@babel/helper-module-transforms": "^7.1.0", - "@babel/helper-plugin-utils": "^7.0.0", - "@babel/helper-simple-access": "^7.1.0" - } - }, - "@babel/plugin-transform-modules-systemjs": { - "version": "7.1.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.1.3.tgz", - "integrity": "sha512-PvTxgjxQAq4pvVUZF3mD5gEtVDuId8NtWkJsZLEJZMZAW3TvgQl1pmydLLN1bM8huHFVVU43lf0uvjQj9FRkKw==", - "dev": true, - "requires": { - "@babel/helper-hoist-variables": "^7.0.0", - "@babel/helper-plugin-utils": "^7.0.0" - } - }, - "@babel/plugin-transform-modules-umd": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.1.0.tgz", - "integrity": "sha512-enrRtn5TfRhMmbRwm7F8qOj0qEYByqUvTttPEGimcBH4CJHphjyK1Vg7sdU7JjeEmgSpM890IT/efS2nMHwYig==", - "dev": true, - "requires": { - "@babel/helper-module-transforms": "^7.1.0", - "@babel/helper-plugin-utils": "^7.0.0" - } - }, - "@babel/plugin-transform-new-target": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.0.0.tgz", - "integrity": "sha512-yin069FYjah+LbqfGeTfzIBODex/e++Yfa0rH0fpfam9uTbuEeEOx5GLGr210ggOV77mVRNoeqSYqeuaqSzVSw==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.0.0" - } - }, - "@babel/plugin-transform-object-super": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.1.0.tgz", - "integrity": "sha512-/O02Je1CRTSk2SSJaq0xjwQ8hG4zhZGNjE8psTsSNPXyLRCODv7/PBozqT5AmQMzp7MI3ndvMhGdqp9c96tTEw==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.0.0", - "@babel/helper-replace-supers": "^7.1.0" - } - }, - "@babel/plugin-transform-parameters": { - "version": "7.1.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.1.0.tgz", - "integrity": "sha512-vHV7oxkEJ8IHxTfRr3hNGzV446GAb+0hgbA7o/0Jd76s+YzccdWuTU296FOCOl/xweU4t/Ya4g41yWz80RFCRw==", - "dev": true, - "requires": { - "@babel/helper-call-delegate": "^7.1.0", - "@babel/helper-get-function-arity": "^7.0.0", - "@babel/helper-plugin-utils": "^7.0.0" - } - }, - "@babel/plugin-transform-regenerator": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.0.0.tgz", - "integrity": "sha512-sj2qzsEx8KDVv1QuJc/dEfilkg3RRPvPYx/VnKLtItVQRWt1Wqf5eVCOLZm29CiGFfYYsA3VPjfizTCV0S0Dlw==", - "dev": true, - "requires": { - "regenerator-transform": "^0.13.3" - } - }, - "@babel/plugin-transform-shorthand-properties": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.0.0.tgz", - "integrity": "sha512-g/99LI4vm5iOf5r1Gdxq5Xmu91zvjhEG5+yZDJW268AZELAu4J1EiFLnkSG3yuUsZyOipVOVUKoGPYwfsTymhw==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.0.0" - } - }, - "@babel/plugin-transform-spread": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-spread/-/plugin-transform-spread-7.0.0.tgz", - "integrity": "sha512-L702YFy2EvirrR4shTj0g2xQp7aNwZoWNCkNu2mcoU0uyzMl0XRwDSwzB/xp6DSUFiBmEXuyAyEN16LsgVqGGQ==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.0.0" - } - }, - "@babel/plugin-transform-sticky-regex": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.0.0.tgz", - "integrity": "sha512-LFUToxiyS/WD+XEWpkx/XJBrUXKewSZpzX68s+yEOtIbdnsRjpryDw9U06gYc6klYEij/+KQVRnD3nz3AoKmjw==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.0.0", - "@babel/helper-regex": "^7.0.0" - } - }, - "@babel/plugin-transform-template-literals": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.0.0.tgz", - "integrity": "sha512-vA6rkTCabRZu7Nbl9DfLZE1imj4tzdWcg5vtdQGvj+OH9itNNB6hxuRMHuIY8SGnEt1T9g5foqs9LnrHzsqEFg==", - "dev": true, - "requires": { - "@babel/helper-annotate-as-pure": "^7.0.0", - "@babel/helper-plugin-utils": "^7.0.0" - } - }, - "@babel/plugin-transform-typeof-symbol": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.0.0.tgz", - "integrity": "sha512-1r1X5DO78WnaAIvs5uC48t41LLckxsYklJrZjNKcevyz83sF2l4RHbw29qrCPr/6ksFsdfRpT/ZgxNWHXRnffg==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.0.0" - } - }, - "@babel/plugin-transform-unicode-regex": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.0.0.tgz", - "integrity": "sha512-uJBrJhBOEa3D033P95nPHu3nbFwFE9ZgXsfEitzoIXIwqAZWk7uXcg06yFKXz9FSxBH5ucgU/cYdX0IV8ldHKw==", - "dev": true, - "requires": { - "@babel/helper-plugin-utils": "^7.0.0", - "@babel/helper-regex": "^7.0.0", - "regexpu-core": "^4.1.3" - } - }, - "@babel/polyfill": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/@babel/polyfill/-/polyfill-7.0.0.tgz", - "integrity": "sha512-dnrMRkyyr74CRelJwvgnnSUDh2ge2NCTyHVwpOdvRMHtJUyxLtMAfhBN3s64pY41zdw0kgiLPh6S20eb1NcX6Q==", - "dev": true, - "requires": { - "core-js": "^2.5.7", - "regenerator-runtime": "^0.11.1" - } - }, - "@babel/preset-env": { - "version": "7.1.6", - "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.1.6.tgz", - "integrity": "sha512-YIBfpJNQMBkb6MCkjz/A9J76SNCSuGVamOVBgoUkLzpJD/z8ghHi9I42LQ4pulVX68N/MmImz6ZTixt7Azgexw==", - "dev": true, - "requires": { - "@babel/helper-module-imports": "^7.0.0", - "@babel/helper-plugin-utils": "^7.0.0", - "@babel/plugin-proposal-async-generator-functions": "^7.1.0", - "@babel/plugin-proposal-json-strings": "^7.0.0", - "@babel/plugin-proposal-object-rest-spread": "^7.0.0", - "@babel/plugin-proposal-optional-catch-binding": "^7.0.0", - "@babel/plugin-proposal-unicode-property-regex": "^7.0.0", - "@babel/plugin-syntax-async-generators": "^7.0.0", - "@babel/plugin-syntax-object-rest-spread": "^7.0.0", - "@babel/plugin-syntax-optional-catch-binding": "^7.0.0", - "@babel/plugin-transform-arrow-functions": "^7.0.0", - "@babel/plugin-transform-async-to-generator": "^7.1.0", - "@babel/plugin-transform-block-scoped-functions": "^7.0.0", - "@babel/plugin-transform-block-scoping": "^7.1.5", - "@babel/plugin-transform-classes": "^7.1.0", - "@babel/plugin-transform-computed-properties": "^7.0.0", - "@babel/plugin-transform-destructuring": "^7.0.0", - "@babel/plugin-transform-dotall-regex": "^7.0.0", - "@babel/plugin-transform-duplicate-keys": "^7.0.0", - "@babel/plugin-transform-exponentiation-operator": "^7.1.0", - "@babel/plugin-transform-for-of": "^7.0.0", - "@babel/plugin-transform-function-name": "^7.1.0", - "@babel/plugin-transform-literals": "^7.0.0", - "@babel/plugin-transform-modules-amd": "^7.1.0", - "@babel/plugin-transform-modules-commonjs": "^7.1.0", - "@babel/plugin-transform-modules-systemjs": "^7.0.0", - "@babel/plugin-transform-modules-umd": "^7.1.0", - "@babel/plugin-transform-new-target": "^7.0.0", - "@babel/plugin-transform-object-super": "^7.1.0", - "@babel/plugin-transform-parameters": "^7.1.0", - "@babel/plugin-transform-regenerator": "^7.0.0", - "@babel/plugin-transform-shorthand-properties": "^7.0.0", - "@babel/plugin-transform-spread": "^7.0.0", - "@babel/plugin-transform-sticky-regex": "^7.0.0", - "@babel/plugin-transform-template-literals": "^7.0.0", - "@babel/plugin-transform-typeof-symbol": "^7.0.0", - "@babel/plugin-transform-unicode-regex": "^7.0.0", - "browserslist": "^4.1.0", - "invariant": "^2.2.2", - "js-levenshtein": "^1.1.3", - "semver": "^5.3.0" - } - }, - "@babel/template": { - "version": "7.1.2", - "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.1.2.tgz", - "integrity": "sha512-SY1MmplssORfFiLDcOETrW7fCLl+PavlwMh92rrGcikQaRq4iWPVH0MpwPpY3etVMx6RnDjXtr6VZYr/IbP/Ag==", - "dev": true, - "requires": { - "@babel/code-frame": "^7.0.0", - "@babel/parser": "^7.1.2", - "@babel/types": "^7.1.2" - } - }, - "@babel/traverse": { - "version": "7.1.6", - "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.1.6.tgz", - "integrity": "sha512-CXedit6GpISz3sC2k2FsGCUpOhUqKdyL0lqNrImQojagnUMXf8hex4AxYFRuMkNGcvJX5QAFGzB5WJQmSv8SiQ==", - "dev": true, - "requires": { - "@babel/code-frame": "^7.0.0", - "@babel/generator": "^7.1.6", - "@babel/helper-function-name": "^7.1.0", - "@babel/helper-split-export-declaration": "^7.0.0", - "@babel/parser": "^7.1.6", - "@babel/types": "^7.1.6", - "debug": "^4.1.0", - "globals": "^11.1.0", - "lodash": "^4.17.10" - } - }, - "@babel/types": { - "version": "7.1.6", - "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.1.6.tgz", - "integrity": "sha512-DMiUzlY9DSjVsOylJssxLHSgj6tWM9PRFJOGW/RaOglVOK9nzTxoOMfTfRQXGUCUQ/HmlG2efwC+XqUEJ5ay4w==", - "dev": true, - "requires": { - "esutils": "^2.0.2", - "lodash": "^4.17.10", - "to-fast-properties": "^2.0.0" - } - }, "@webassemblyjs/ast": { - "version": "1.7.11", - "resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.7.11.tgz", - "integrity": "sha512-ZEzy4vjvTzScC+SH8RBssQUawpaInUdMTYwYYLh54/s8TuT0gBLuyUnppKsVyZEi876VmmStKsUs28UxPgdvrA==", + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.8.5.tgz", + "integrity": "sha512-aJMfngIZ65+t71C3y2nBBg5FFG0Okt9m0XEgWZ7Ywgn1oMAT8cNwx00Uv1cQyHtidq0Xn94R4TAywO+LCQ+ZAQ==", "dev": true, "requires": { - "@webassemblyjs/helper-module-context": "1.7.11", - "@webassemblyjs/helper-wasm-bytecode": "1.7.11", - "@webassemblyjs/wast-parser": "1.7.11" + "@webassemblyjs/helper-module-context": "1.8.5", + "@webassemblyjs/helper-wasm-bytecode": "1.8.5", + "@webassemblyjs/wast-parser": "1.8.5" } }, "@webassemblyjs/floating-point-hex-parser": { - "version": "1.7.11", - "resolved": "https://registry.npmjs.org/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.7.11.tgz", - "integrity": "sha512-zY8dSNyYcgzNRNT666/zOoAyImshm3ycKdoLsyDw/Bwo6+/uktb7p4xyApuef1dwEBo/U/SYQzbGBvV+nru2Xg==", + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.8.5.tgz", + "integrity": "sha512-9p+79WHru1oqBh9ewP9zW95E3XAo+90oth7S5Re3eQnECGq59ly1Ri5tsIipKGpiStHsUYmY3zMLqtk3gTcOtQ==", "dev": true }, "@webassemblyjs/helper-api-error": { - "version": "1.7.11", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-api-error/-/helper-api-error-1.7.11.tgz", - "integrity": "sha512-7r1qXLmiglC+wPNkGuXCvkmalyEstKVwcueZRP2GNC2PAvxbLYwLLPr14rcdJaE4UtHxQKfFkuDFuv91ipqvXg==", + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-api-error/-/helper-api-error-1.8.5.tgz", + "integrity": "sha512-Za/tnzsvnqdaSPOUXHyKJ2XI7PDX64kWtURyGiJJZKVEdFOsdKUCPTNEVFZq3zJ2R0G5wc2PZ5gvdTRFgm81zA==", "dev": true }, "@webassemblyjs/helper-buffer": { - "version": "1.7.11", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-buffer/-/helper-buffer-1.7.11.tgz", - "integrity": "sha512-MynuervdylPPh3ix+mKZloTcL06P8tenNH3sx6s0qE8SLR6DdwnfgA7Hc9NSYeob2jrW5Vql6GVlsQzKQCa13w==", + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-buffer/-/helper-buffer-1.8.5.tgz", + "integrity": "sha512-Ri2R8nOS0U6G49Q86goFIPNgjyl6+oE1abW1pS84BuhP1Qcr5JqMwRFT3Ah3ADDDYGEgGs1iyb1DGX+kAi/c/Q==", "dev": true }, "@webassemblyjs/helper-code-frame": { - "version": "1.7.11", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-code-frame/-/helper-code-frame-1.7.11.tgz", - "integrity": "sha512-T8ESC9KMXFTXA5urJcyor5cn6qWeZ4/zLPyWeEXZ03hj/x9weSokGNkVCdnhSabKGYWxElSdgJ+sFa9G/RdHNw==", + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-code-frame/-/helper-code-frame-1.8.5.tgz", + "integrity": "sha512-VQAadSubZIhNpH46IR3yWO4kZZjMxN1opDrzePLdVKAZ+DFjkGD/rf4v1jap744uPVU6yjL/smZbRIIJTOUnKQ==", "dev": true, "requires": { - "@webassemblyjs/wast-printer": "1.7.11" + "@webassemblyjs/wast-printer": "1.8.5" } }, "@webassemblyjs/helper-fsm": { - "version": "1.7.11", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-fsm/-/helper-fsm-1.7.11.tgz", - "integrity": "sha512-nsAQWNP1+8Z6tkzdYlXT0kxfa2Z1tRTARd8wYnc/e3Zv3VydVVnaeePgqUzFrpkGUyhUUxOl5ML7f1NuT+gC0A==", + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-fsm/-/helper-fsm-1.8.5.tgz", + "integrity": "sha512-kRuX/saORcg8se/ft6Q2UbRpZwP4y7YrWsLXPbbmtepKr22i8Z4O3V5QE9DbZK908dh5Xya4Un57SDIKwB9eow==", "dev": true }, "@webassemblyjs/helper-module-context": { - "version": "1.7.11", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-module-context/-/helper-module-context-1.7.11.tgz", - "integrity": "sha512-JxfD5DX8Ygq4PvXDucq0M+sbUFA7BJAv/GGl9ITovqE+idGX+J3QSzJYz+LwQmL7fC3Rs+utvWoJxDb6pmC0qg==", - "dev": true + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-module-context/-/helper-module-context-1.8.5.tgz", + "integrity": "sha512-/O1B236mN7UNEU4t9X7Pj38i4VoU8CcMHyy3l2cV/kIF4U5KoHXDVqcDuOs1ltkac90IM4vZdHc52t1x8Yfs3g==", + "dev": true, + "requires": { + "@webassemblyjs/ast": "1.8.5", + "mamacro": "^0.0.3" + } }, "@webassemblyjs/helper-wasm-bytecode": { - "version": "1.7.11", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.7.11.tgz", - "integrity": "sha512-cMXeVS9rhoXsI9LLL4tJxBgVD/KMOKXuFqYb5oCJ/opScWpkCMEz9EJtkonaNcnLv2R3K5jIeS4TRj/drde1JQ==", + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.8.5.tgz", + "integrity": "sha512-Cu4YMYG3Ddl72CbmpjU/wbP6SACcOPVbHN1dI4VJNJVgFwaKf1ppeFJrwydOG3NDHxVGuCfPlLZNyEdIYlQ6QQ==", "dev": true }, "@webassemblyjs/helper-wasm-section": { - "version": "1.7.11", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.7.11.tgz", - "integrity": "sha512-8ZRY5iZbZdtNFE5UFunB8mmBEAbSI3guwbrsCl4fWdfRiAcvqQpeqd5KHhSWLL5wuxo53zcaGZDBU64qgn4I4Q==", + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.8.5.tgz", + "integrity": "sha512-VV083zwR+VTrIWWtgIUpqfvVdK4ff38loRmrdDBgBT8ADXYsEZ5mPQ4Nde90N3UYatHdYoDIFb7oHzMncI02tA==", "dev": true, "requires": { - "@webassemblyjs/ast": "1.7.11", - "@webassemblyjs/helper-buffer": "1.7.11", - "@webassemblyjs/helper-wasm-bytecode": "1.7.11", - "@webassemblyjs/wasm-gen": "1.7.11" + "@webassemblyjs/ast": "1.8.5", + "@webassemblyjs/helper-buffer": "1.8.5", + "@webassemblyjs/helper-wasm-bytecode": "1.8.5", + "@webassemblyjs/wasm-gen": "1.8.5" } }, "@webassemblyjs/ieee754": { - "version": "1.7.11", - "resolved": "https://registry.npmjs.org/@webassemblyjs/ieee754/-/ieee754-1.7.11.tgz", - "integrity": "sha512-Mmqx/cS68K1tSrvRLtaV/Lp3NZWzXtOHUW2IvDvl2sihAwJh4ACE0eL6A8FvMyDG9abes3saB6dMimLOs+HMoQ==", + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/ieee754/-/ieee754-1.8.5.tgz", + "integrity": "sha512-aaCvQYrvKbY/n6wKHb/ylAJr27GglahUO89CcGXMItrOBqRarUMxWLJgxm9PJNuKULwN5n1csT9bYoMeZOGF3g==", "dev": true, "requires": { "@xtuc/ieee754": "^1.2.0" } }, "@webassemblyjs/leb128": { - "version": "1.7.11", - "resolved": "https://registry.npmjs.org/@webassemblyjs/leb128/-/leb128-1.7.11.tgz", - "integrity": "sha512-vuGmgZjjp3zjcerQg+JA+tGOncOnJLWVkt8Aze5eWQLwTQGNgVLcyOTqgSCxWTR4J42ijHbBxnuRaL1Rv7XMdw==", + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/leb128/-/leb128-1.8.5.tgz", + "integrity": "sha512-plYUuUwleLIziknvlP8VpTgO4kqNaH57Y3JnNa6DLpu/sGcP6hbVdfdX5aHAV716pQBKrfuU26BJK29qY37J7A==", "dev": true, "requires": { - "@xtuc/long": "4.2.1" + "@xtuc/long": "4.2.2" } }, "@webassemblyjs/utf8": { - "version": "1.7.11", - "resolved": "https://registry.npmjs.org/@webassemblyjs/utf8/-/utf8-1.7.11.tgz", - "integrity": "sha512-C6GFkc7aErQIAH+BMrIdVSmW+6HSe20wg57HEC1uqJP8E/xpMjXqQUxkQw07MhNDSDcGpxI9G5JSNOQCqJk4sA==", + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/utf8/-/utf8-1.8.5.tgz", + "integrity": "sha512-U7zgftmQriw37tfD934UNInokz6yTmn29inT2cAetAsaU9YeVCveWEwhKL1Mg4yS7q//NGdzy79nlXh3bT8Kjw==", "dev": true }, "@webassemblyjs/wasm-edit": { - "version": "1.7.11", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-edit/-/wasm-edit-1.7.11.tgz", - "integrity": "sha512-FUd97guNGsCZQgeTPKdgxJhBXkUbMTY6hFPf2Y4OedXd48H97J+sOY2Ltaq6WGVpIH8o/TGOVNiVz/SbpEMJGg==", + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-edit/-/wasm-edit-1.8.5.tgz", + "integrity": "sha512-A41EMy8MWw5yvqj7MQzkDjU29K7UJq1VrX2vWLzfpRHt3ISftOXqrtojn7nlPsZ9Ijhp5NwuODuycSvfAO/26Q==", "dev": true, "requires": { - "@webassemblyjs/ast": "1.7.11", - "@webassemblyjs/helper-buffer": "1.7.11", - "@webassemblyjs/helper-wasm-bytecode": "1.7.11", - "@webassemblyjs/helper-wasm-section": "1.7.11", - "@webassemblyjs/wasm-gen": "1.7.11", - "@webassemblyjs/wasm-opt": "1.7.11", - "@webassemblyjs/wasm-parser": "1.7.11", - "@webassemblyjs/wast-printer": "1.7.11" + "@webassemblyjs/ast": "1.8.5", + "@webassemblyjs/helper-buffer": "1.8.5", + "@webassemblyjs/helper-wasm-bytecode": "1.8.5", + "@webassemblyjs/helper-wasm-section": "1.8.5", + "@webassemblyjs/wasm-gen": "1.8.5", + "@webassemblyjs/wasm-opt": "1.8.5", + "@webassemblyjs/wasm-parser": "1.8.5", + "@webassemblyjs/wast-printer": "1.8.5" } }, "@webassemblyjs/wasm-gen": { - "version": "1.7.11", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-gen/-/wasm-gen-1.7.11.tgz", - "integrity": "sha512-U/KDYp7fgAZX5KPfq4NOupK/BmhDc5Kjy2GIqstMhvvdJRcER/kUsMThpWeRP8BMn4LXaKhSTggIJPOeYHwISA==", + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-gen/-/wasm-gen-1.8.5.tgz", + "integrity": "sha512-BCZBT0LURC0CXDzj5FXSc2FPTsxwp3nWcqXQdOZE4U7h7i8FqtFK5Egia6f9raQLpEKT1VL7zr4r3+QX6zArWg==", "dev": true, "requires": { - "@webassemblyjs/ast": "1.7.11", - "@webassemblyjs/helper-wasm-bytecode": "1.7.11", - "@webassemblyjs/ieee754": "1.7.11", - "@webassemblyjs/leb128": "1.7.11", - "@webassemblyjs/utf8": "1.7.11" + "@webassemblyjs/ast": "1.8.5", + "@webassemblyjs/helper-wasm-bytecode": "1.8.5", + "@webassemblyjs/ieee754": "1.8.5", + "@webassemblyjs/leb128": "1.8.5", + "@webassemblyjs/utf8": "1.8.5" } }, "@webassemblyjs/wasm-opt": { - "version": "1.7.11", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-opt/-/wasm-opt-1.7.11.tgz", - "integrity": "sha512-XynkOwQyiRidh0GLua7SkeHvAPXQV/RxsUeERILmAInZegApOUAIJfRuPYe2F7RcjOC9tW3Cb9juPvAC/sCqvg==", + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-opt/-/wasm-opt-1.8.5.tgz", + "integrity": "sha512-HKo2mO/Uh9A6ojzu7cjslGaHaUU14LdLbGEKqTR7PBKwT6LdPtLLh9fPY33rmr5wcOMrsWDbbdCHq4hQUdd37Q==", "dev": true, "requires": { - "@webassemblyjs/ast": "1.7.11", - "@webassemblyjs/helper-buffer": "1.7.11", - "@webassemblyjs/wasm-gen": "1.7.11", - "@webassemblyjs/wasm-parser": "1.7.11" + "@webassemblyjs/ast": "1.8.5", + "@webassemblyjs/helper-buffer": "1.8.5", + "@webassemblyjs/wasm-gen": "1.8.5", + "@webassemblyjs/wasm-parser": "1.8.5" } }, "@webassemblyjs/wasm-parser": { - "version": "1.7.11", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-parser/-/wasm-parser-1.7.11.tgz", - "integrity": "sha512-6lmXRTrrZjYD8Ng8xRyvyXQJYUQKYSXhJqXOBLw24rdiXsHAOlvw5PhesjdcaMadU/pyPQOJ5dHreMjBxwnQKg==", + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-parser/-/wasm-parser-1.8.5.tgz", + "integrity": "sha512-pi0SYE9T6tfcMkthwcgCpL0cM9nRYr6/6fjgDtL6q/ZqKHdMWvxitRi5JcZ7RI4SNJJYnYNaWy5UUrHQy998lw==", "dev": true, "requires": { - "@webassemblyjs/ast": "1.7.11", - "@webassemblyjs/helper-api-error": "1.7.11", - "@webassemblyjs/helper-wasm-bytecode": "1.7.11", - "@webassemblyjs/ieee754": "1.7.11", - "@webassemblyjs/leb128": "1.7.11", - "@webassemblyjs/utf8": "1.7.11" + "@webassemblyjs/ast": "1.8.5", + "@webassemblyjs/helper-api-error": "1.8.5", + "@webassemblyjs/helper-wasm-bytecode": "1.8.5", + "@webassemblyjs/ieee754": "1.8.5", + "@webassemblyjs/leb128": "1.8.5", + "@webassemblyjs/utf8": "1.8.5" } }, "@webassemblyjs/wast-parser": { - "version": "1.7.11", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-parser/-/wast-parser-1.7.11.tgz", - "integrity": "sha512-lEyVCg2np15tS+dm7+JJTNhNWq9yTZvi3qEhAIIOaofcYlUp0UR5/tVqOwa/gXYr3gjwSZqw+/lS9dscyLelbQ==", + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-parser/-/wast-parser-1.8.5.tgz", + "integrity": "sha512-daXC1FyKWHF1i11obK086QRlsMsY4+tIOKgBqI1lxAnkp9xe9YMcgOxm9kLe+ttjs5aWV2KKE1TWJCN57/Btsg==", "dev": true, "requires": { - "@webassemblyjs/ast": "1.7.11", - "@webassemblyjs/floating-point-hex-parser": "1.7.11", - "@webassemblyjs/helper-api-error": "1.7.11", - "@webassemblyjs/helper-code-frame": "1.7.11", - "@webassemblyjs/helper-fsm": "1.7.11", - "@xtuc/long": "4.2.1" + "@webassemblyjs/ast": "1.8.5", + "@webassemblyjs/floating-point-hex-parser": "1.8.5", + "@webassemblyjs/helper-api-error": "1.8.5", + "@webassemblyjs/helper-code-frame": "1.8.5", + "@webassemblyjs/helper-fsm": "1.8.5", + "@xtuc/long": "4.2.2" } }, "@webassemblyjs/wast-printer": { - "version": "1.7.11", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-printer/-/wast-printer-1.7.11.tgz", - "integrity": "sha512-m5vkAsuJ32QpkdkDOUPGSltrg8Cuk3KBx4YrmAGQwCZPRdUHXxG4phIOuuycLemHFr74sWL9Wthqss4fzdzSwg==", + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-printer/-/wast-printer-1.8.5.tgz", + "integrity": "sha512-w0U0pD4EhlnvRyeJzBqaVSJAo9w/ce7/WPogeXLzGkO6hzhr4GnQIZ4W4uUt5b9ooAaXPtnXlj0gzsXEOUNYMg==", "dev": true, "requires": { - "@webassemblyjs/ast": "1.7.11", - "@webassemblyjs/wast-parser": "1.7.11", - "@xtuc/long": "4.2.1" + "@webassemblyjs/ast": "1.8.5", + "@webassemblyjs/wast-parser": "1.8.5", + "@xtuc/long": "4.2.2" } }, "@xtuc/ieee754": { @@ -931,9 +185,9 @@ "dev": true }, "@xtuc/long": { - "version": "4.2.1", - "resolved": "https://registry.npmjs.org/@xtuc/long/-/long-4.2.1.tgz", - "integrity": "sha512-FZdkNBDqBRHKQ2MEbSC17xnPFOhZxeJ2YGSfr2BKf3sujG49Qe3bB+rGCwQfIaA7WHnGeGkSijX4FuBCdrzW/g==", + "version": "4.2.2", + "resolved": "https://registry.npmjs.org/@xtuc/long/-/long-4.2.2.tgz", + "integrity": "sha512-NuHqBY1PB/D8xU6s/thBgOAiAP7HOYDQ32+BFZILJ8ivkUkAHQnWfn6WhL79Owj1qmUnoN/YPhktdIoucipkAQ==", "dev": true }, "abbrev": { @@ -943,30 +197,27 @@ "dev": true }, "acorn": { - "version": "5.7.3", - "resolved": "https://registry.npmjs.org/acorn/-/acorn-5.7.3.tgz", - "integrity": "sha512-T/zvzYRfbVojPWahDsE5evJdHb3oJoQfFbsrKM7w5Zcs++Tr257tia3BmMP8XYVjp1S9RZXQMh7gao96BlqZOw==", + "version": "6.1.1", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-6.1.1.tgz", + "integrity": "sha512-jPTiwtOxaHNaAPg/dmrJ/beuzLRnXtB0kQPQ8JpotKJgTB6rX6c8mlf315941pyjBSaPg8NHXS9fhP4u17DpGA==", "dev": true }, "acorn-dynamic-import": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/acorn-dynamic-import/-/acorn-dynamic-import-3.0.0.tgz", - "integrity": "sha512-zVWV8Z8lislJoOKKqdNMOB+s6+XV5WERty8MnKBeFgwA+19XJjJHs2RP5dzM57FftIs+jQnRToLiWazKr6sSWg==", - "dev": true, - "requires": { - "acorn": "^5.0.0" - } + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/acorn-dynamic-import/-/acorn-dynamic-import-4.0.0.tgz", + "integrity": "sha512-d3OEjQV4ROpoflsnUA8HozoIR504TFxNivYEUi6uwz0IYhBkTDXGuWlNdMtybRt3nqVx/L6XqMt0FxkXuWKZhw==", + "dev": true }, "ajv": { - "version": "5.5.2", - "resolved": "https://registry.npmjs.org/ajv/-/ajv-5.5.2.tgz", - "integrity": "sha1-c7Xuyj+rZT49P5Qis0GtQiBdyWU=", + "version": "6.10.0", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.10.0.tgz", + "integrity": "sha512-nffhOpkymDECQyR0mnsUtoCE8RlX38G0rYP+wgLWFyZuUyuuojSSvi/+euOiQBIn63whYwYVIIH1TvE3tu4OEg==", "dev": true, "requires": { - "co": "^4.6.0", - "fast-deep-equal": "^1.0.0", + "fast-deep-equal": "^2.0.1", "fast-json-stable-stringify": "^2.0.0", - "json-schema-traverse": "^0.3.0" + "json-schema-traverse": "^0.4.1", + "uri-js": "^4.2.2" } }, "ajv-errors": { @@ -1003,13 +254,24 @@ } }, "anymatch": { - "version": "1.3.2", - "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-1.3.2.tgz", - "integrity": "sha512-0XNayC8lTHQ2OI8aljNCN3sSx6hsr/1+rlcDAotXJR7C1oZZHCNsfpbKwMjRA3Uqb5tF1Rae2oloTr4xpq+WjA==", + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-2.0.0.tgz", + "integrity": "sha512-5teOsQWABXHHBFP9y3skS5P3d/WfWXpv3FUpy+LorMrNYaT9pI4oLMQX7jzQ2KklNpGpWHzdCXTDT2Y3XGlZBw==", "dev": true, "requires": { - "micromatch": "^2.1.5", - "normalize-path": "^2.0.0" + "micromatch": "^3.1.4", + "normalize-path": "^2.1.1" + }, + "dependencies": { + "normalize-path": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", + "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", + "dev": true, + "requires": { + "remove-trailing-separator": "^1.0.1" + } + } } }, "aproba": { @@ -1037,13 +299,10 @@ } }, "arr-diff": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-2.0.0.tgz", - "integrity": "sha1-jzuCf5Vai9ZpaX5KQlasPOrjVs8=", - "dev": true, - "requires": { - "arr-flatten": "^1.0.1" - } + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-4.0.0.tgz", + "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=", + "dev": true }, "arr-flatten": { "version": "1.1.0", @@ -1082,9 +341,9 @@ "dev": true }, "array-unique": { - "version": "0.2.1", - "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.2.1.tgz", - "integrity": "sha1-odl8yvy8JiXMcPrc6zalDFiwGlM=", + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.3.2.tgz", + "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=", "dev": true }, "asn1": { @@ -1108,11 +367,12 @@ } }, "assert": { - "version": "1.4.1", - "resolved": "https://registry.npmjs.org/assert/-/assert-1.4.1.tgz", - "integrity": "sha1-mZEtWRg2tab1s0XA8H7vwI/GXZE=", + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/assert/-/assert-1.5.0.tgz", + "integrity": "sha512-EDsgawzwoun2CZkCgtxJbv392v4nbk9XDD06zI+kQYoBM/3RBWLlEyJARDOmhAAosBjWACEkKL6S+lIZtcAubA==", "dev": true, "requires": { + "object-assign": "^4.1.1", "util": "0.10.3" }, "dependencies": { @@ -1169,54 +429,6 @@ "integrity": "sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg==", "dev": true }, - "autoprefixer": { - "version": "9.4.7", - "resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-9.4.7.tgz", - "integrity": "sha512-qS5wW6aXHkm53Y4z73tFGsUhmZu4aMPV9iHXYlF0c/wxjknXNHuj/1cIQb+6YH692DbJGGWcckAXX+VxKvahMA==", - "dev": true, - "requires": { - "browserslist": "^4.4.1", - "caniuse-lite": "^1.0.30000932", - "normalize-range": "^0.1.2", - "num2fraction": "^1.2.2", - "postcss": "^7.0.14", - "postcss-value-parser": "^3.3.1" - }, - "dependencies": { - "browserslist": { - "version": "4.4.1", - "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.4.1.tgz", - "integrity": "sha512-pEBxEXg7JwaakBXjATYw/D1YZh4QUSCX/Mnd/wnqSRPPSi1U39iDhDoKGoBUcraKdxDlrYqJxSI5nNvD+dWP2A==", - "dev": true, - "requires": { - "caniuse-lite": "^1.0.30000929", - "electron-to-chromium": "^1.3.103", - "node-releases": "^1.1.3" - } - }, - "caniuse-lite": { - "version": "1.0.30000934", - "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30000934.tgz", - "integrity": "sha512-o7yfZn0R9N+mWAuksDsdLsb1gu9o//XK0QSU0zSSReKNRsXsFc/n/psxi0YSPNiqlKxImp5h4DHnAPdwYJ8nNA==", - "dev": true - }, - "electron-to-chromium": { - "version": "1.3.112", - "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.3.112.tgz", - "integrity": "sha512-FyVLdiRZnLw2WE5ECtveN0JJ7klyiz/HMfKE1/Rjff3l7pe4vfkYtBlcCqTckvR8E7asjJGh0m9gRPR3Anp/UA==", - "dev": true - }, - "node-releases": { - "version": "1.1.7", - "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-1.1.7.tgz", - "integrity": "sha512-bKdrwaqJUPHqlCzDD7so/R+Nk0jGv9a11ZhLrD9f6i947qGLrGAhU3OxRENa19QQmwzGy/g6zCDEuLGDO8HPvA==", - "dev": true, - "requires": { - "semver": "^5.3.0" - } - } - } - }, "aws-sign2": { "version": "0.7.0", "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", @@ -1229,45 +441,6 @@ "integrity": "sha512-ReZxvNHIOv88FlT7rxcXIIC0fPt4KZqZbOlivyWtXLt8ESx84zd3kMC6iK5jVeS2qt+g7ftS7ye4fi06X5rtRQ==", "dev": true }, - "axios": { - "version": "0.18.0", - "resolved": "https://registry.npmjs.org/axios/-/axios-0.18.0.tgz", - "integrity": "sha1-MtU+SFHv3AoRmTts0AB4nXDAUQI=", - "requires": { - "follow-redirects": "^1.3.0", - "is-buffer": "^1.1.5" - }, - "dependencies": { - "debug": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/debug/-/debug-3.1.0.tgz", - "integrity": "sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g==", - "requires": { - "ms": "2.0.0" - } - }, - "follow-redirects": { - "version": "1.4.1", - "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.4.1.tgz", - "integrity": "sha512-uxYePVPogtya1ktGnAAXOacnbIuRMB4dkvqeNz2qTtTQsuzSfbDolV+wMMKxAmCx0bLgAKLbBOkjItMbbkR1vg==", - "requires": { - "debug": "^3.1.0" - } - } - } - }, - "babel-loader": { - "version": "8.0.4", - "resolved": "https://registry.npmjs.org/babel-loader/-/babel-loader-8.0.4.tgz", - "integrity": "sha512-fhBhNkUToJcW9nV46v8w87AJOwAJDz84c1CL57n3Stj73FANM/b9TbCUK4YhdOwEyZ+OxhYpdeZDNzSI29Firw==", - "dev": true, - "requires": { - "find-cache-dir": "^1.0.0", - "loader-utils": "^1.0.2", - "mkdirp": "^0.5.1", - "util.promisify": "^1.0.0" - } - }, "balanced-match": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", @@ -1327,12 +500,6 @@ "kind-of": "^6.0.2" } }, - "isobject": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", - "dev": true - }, "kind-of": { "version": "6.0.2", "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", @@ -1378,9 +545,9 @@ } }, "bluebird": { - "version": "3.5.2", - "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.2.tgz", - "integrity": "sha512-dhHTWMI7kMx5whMQntl7Vr9C6BvV10lFXDAasnqnrMYhXVCzzk6IO9Fo2L75jXHT07WrOngL1WDXOp+yYS91Yg==", + "version": "3.5.5", + "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.5.tgz", + "integrity": "sha512-5am6HnnfN+urzt4yfg7IgTbotDjIT/u8AJpEt0sIU9FtXfVeezXAPKswrG+xKUCOYAINpSdgZVDU6QFh+cuH3w==", "dev": true }, "bn.js": { @@ -1400,14 +567,32 @@ } }, "braces": { - "version": "1.8.5", - "resolved": "https://registry.npmjs.org/braces/-/braces-1.8.5.tgz", - "integrity": "sha1-uneWLhLf+WnWt2cR6RS3N4V79qc=", + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/braces/-/braces-2.3.2.tgz", + "integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==", "dev": true, "requires": { - "expand-range": "^1.8.1", - "preserve": "^0.2.0", - "repeat-element": "^1.1.2" + "arr-flatten": "^1.1.0", + "array-unique": "^0.3.2", + "extend-shallow": "^2.0.1", + "fill-range": "^4.0.0", + "isobject": "^3.0.1", + "repeat-element": "^1.1.2", + "snapdragon": "^0.8.1", + "snapdragon-node": "^2.0.1", + "split-string": "^3.0.2", + "to-regex": "^3.0.1" + }, + "dependencies": { + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + } } }, "brorand": { @@ -1495,17 +680,6 @@ "pako": "~1.0.5" } }, - "browserslist": { - "version": "4.3.4", - "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.3.4.tgz", - "integrity": "sha512-u5iz+ijIMUlmV8blX82VGFrB9ecnUg5qEt55CMZ/YJEhha+d8qpBfOFuutJ6F/VKRXjZoD33b6uvarpPxcl3RA==", - "dev": true, - "requires": { - "caniuse-lite": "^1.0.30000899", - "electron-to-chromium": "^1.3.82", - "node-releases": "^1.0.1" - } - }, "buffer": { "version": "4.9.1", "resolved": "http://registry.npmjs.org/buffer/-/buffer-4.9.1.tgz", @@ -1563,12 +737,6 @@ "y18n": "^4.0.0" }, "dependencies": { - "bluebird": { - "version": "3.5.3", - "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.5.3.tgz", - "integrity": "sha512-/qKPUQlaW1OyR51WeCPBvRnAlnZFUJkCSG5HzGnuIqhgyJtF+T94lFnn33eiazjRm2LAHVy2guNnaq48X9SJuw==", - "dev": true - }, "graceful-fs": { "version": "4.1.15", "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.1.15.tgz", @@ -1613,20 +781,12 @@ "to-object-path": "^0.3.0", "union-value": "^1.0.0", "unset-value": "^1.0.0" - }, - "dependencies": { - "isobject": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", - "dev": true - } } }, "camelcase": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-2.1.1.tgz", - "integrity": "sha1-fB0W1nmhu+WcoCys7PsBHiAfWh8=", + "version": "5.3.1", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", + "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", "dev": true }, "camelcase-keys": { @@ -1637,14 +797,16 @@ "requires": { "camelcase": "^2.0.0", "map-obj": "^1.0.0" + }, + "dependencies": { + "camelcase": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-2.1.1.tgz", + "integrity": "sha1-fB0W1nmhu+WcoCys7PsBHiAfWh8=", + "dev": true + } } }, - "caniuse-lite": { - "version": "1.0.30000904", - "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30000904.tgz", - "integrity": "sha512-M4sXvogCoY5Fp6fuXIaQG/MIexlEFQ3Lgwban+KlqiQUbUIkSmjAB8ZJIP79aj2cdqz2F1Lb+Z+5GwHvCrbLtg==", - "dev": true - }, "caseless": { "version": "0.12.0", "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", @@ -1663,20 +825,23 @@ } }, "chokidar": { - "version": "1.7.0", - "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-1.7.0.tgz", - "integrity": "sha1-eY5ol3gVHIB2tLNg5e3SjNortGg=", + "version": "2.1.6", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-2.1.6.tgz", + "integrity": "sha512-V2jUo67OKkc6ySiRpJrjlpJKl9kDuG+Xb8VgsGzb+aEouhgS1D0weyPU4lEzdAcsCAvrih2J2BqyXqHWvVLw5g==", "dev": true, "requires": { - "anymatch": "^1.3.0", - "async-each": "^1.0.0", - "fsevents": "^1.0.0", - "glob-parent": "^2.0.0", - "inherits": "^2.0.1", + "anymatch": "^2.0.0", + "async-each": "^1.0.1", + "braces": "^2.3.2", + "fsevents": "^1.2.7", + "glob-parent": "^3.1.0", + "inherits": "^2.0.3", "is-binary-path": "^1.0.0", - "is-glob": "^2.0.0", + "is-glob": "^4.0.0", + "normalize-path": "^3.0.0", "path-is-absolute": "^1.0.0", - "readdirp": "^2.0.0" + "readdirp": "^2.2.1", + "upath": "^1.1.1" } }, "chownr": { @@ -1686,9 +851,9 @@ "dev": true }, "chrome-trace-event": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/chrome-trace-event/-/chrome-trace-event-1.0.0.tgz", - "integrity": "sha512-xDbVgyfDTT2piup/h8dK/y4QZfJRSa73bw1WZ8b4XM1o7fsFubUVGYcE+1ANtOzJJELGpYoG2961z0Z6OAld9A==", + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/chrome-trace-event/-/chrome-trace-event-1.0.2.tgz", + "integrity": "sha512-9e/zx1jw7B4CO+c/RXoCsfg/x1AfUBioy4owYH0bJprEYAx5hRFLRhWBqHAG57D0ZM4H7vxbP7bPe0VwhQRYDQ==", "dev": true, "requires": { "tslib": "^1.9.0" @@ -1724,12 +889,6 @@ "requires": { "is-descriptor": "^0.1.0" } - }, - "isobject": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", - "dev": true } } }, @@ -1766,15 +925,6 @@ "shallow-clone": "^1.0.0" }, "dependencies": { - "for-own": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/for-own/-/for-own-1.0.0.tgz", - "integrity": "sha1-xjMy9BXO3EsE2/5wz4NklMU8tEs=", - "dev": true, - "requires": { - "for-in": "^1.0.1" - } - }, "kind-of": { "version": "6.0.2", "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", @@ -1783,12 +933,6 @@ } } }, - "co": { - "version": "4.6.0", - "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", - "integrity": "sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ=", - "dev": true - }, "code-point-at": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", @@ -1796,9 +940,9 @@ "dev": true }, "codemirror": { - "version": "5.42.0", - "resolved": "https://registry.npmjs.org/codemirror/-/codemirror-5.42.0.tgz", - "integrity": "sha512-pbApC8zDzItP3HRphD6kQVwS976qB5Qi0hU3MZMixLk+AyugOW1RF+8XJEjeyl5yWsHNe88tDUxzeRh5AOxPRw==" + "version": "5.47.0", + "resolved": "https://registry.npmjs.org/codemirror/-/codemirror-5.47.0.tgz", + "integrity": "sha512-kV49Fr+NGFHFc/Imsx6g180hSlkGhuHxTSDDmDHOuyln0MQYFLixDY4+bFkBVeCEiepYfDimAF/e++9jPJk4QA==" }, "collection-visit": { "version": "1.0.0", @@ -1826,18 +970,18 @@ "dev": true }, "combined-stream": { - "version": "1.0.7", - "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.7.tgz", - "integrity": "sha512-brWl9y6vOB1xYPZcpZde3N9zDByXTosAeMDo4p1wzo6UMOX4vumB+TP1RZ76sfE6Md68Q0NJSrE/gbezd4Ul+w==", + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", + "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", "dev": true, "requires": { "delayed-stream": "~1.0.0" } }, "commander": { - "version": "2.17.1", - "resolved": "https://registry.npmjs.org/commander/-/commander-2.17.1.tgz", - "integrity": "sha512-wPMUt6FnH2yzG95SA6mzjQOEKUU3aLaDEmzs1ti+1E9h+CsrZghRlqEM/EJ4KscsQVG8uNN4uVreUeT8+drlgg==", + "version": "2.20.0", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.0.tgz", + "integrity": "sha512-7j2y+40w61zy6YC2iRNpUe/NwhNyoXrYpHMrSunaMG64nRnaf96zO/KMQR4OyN/UnE5KLyEBnKHd4aG3rskjpQ==", "dev": true }, "commondir": { @@ -1847,9 +991,9 @@ "dev": true }, "component-emitter": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.2.1.tgz", - "integrity": "sha1-E3kY1teCg/ffemt8WmPhQOaUJeY=", + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.3.0.tgz", + "integrity": "sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg==", "dev": true }, "concat-map": { @@ -1891,15 +1035,6 @@ "integrity": "sha1-wguW2MYXdIqvHBYCF2DNJ/y4y3U=", "dev": true }, - "convert-source-map": { - "version": "1.6.0", - "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.6.0.tgz", - "integrity": "sha512-eFu7XigvxdZ1ETfbgPBohgyQ/Z++C0eEhTor0qRwBw9unw+L0/6V8wkSuGgzdThkiS5lSpdptOQPD8Ak40a+7A==", - "dev": true, - "requires": { - "safe-buffer": "~5.1.1" - } - }, "copy-concurrently": { "version": "1.0.5", "resolved": "https://registry.npmjs.org/copy-concurrently/-/copy-concurrently-1.0.5.tgz", @@ -1920,42 +1055,12 @@ "integrity": "sha1-Z29us8OZl8LuGsOpJP1hJHSPV40=", "dev": true }, - "core-js": { - "version": "2.5.7", - "resolved": "https://registry.npmjs.org/core-js/-/core-js-2.5.7.tgz", - "integrity": "sha512-RszJCAxg/PP6uzXVXL6BsxSXx/B05oJAQ2vkJRjyjrEcNVycaqOmNb5OTxZPE3xa5gwZduqza6L9JOCenh/Ecw==", - "dev": true - }, "core-util-is": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=", "dev": true }, - "cosmiconfig": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-4.0.0.tgz", - "integrity": "sha512-6e5vDdrXZD+t5v0L8CrurPeybg4Fmf+FCSYxXKYVAqLUtyCSbuyqE059d0kDthTNRzKVjL7QMgNpEUlsoYH3iQ==", - "dev": true, - "requires": { - "is-directory": "^0.3.1", - "js-yaml": "^3.9.0", - "parse-json": "^4.0.0", - "require-from-string": "^2.0.1" - }, - "dependencies": { - "parse-json": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", - "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", - "dev": true, - "requires": { - "error-ex": "^1.3.1", - "json-parse-better-errors": "^1.0.1" - } - } - } - }, "create-ecdh": { "version": "4.0.3", "resolved": "https://registry.npmjs.org/create-ecdh/-/create-ecdh-4.0.3.tgz", @@ -2023,53 +1128,30 @@ } }, "css-loader": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/css-loader/-/css-loader-2.1.0.tgz", - "integrity": "sha512-MoOu+CStsGrSt5K2OeZ89q3Snf+IkxRfAIt9aAKg4piioTrhtP1iEFPu+OVn3Ohz24FO6L+rw9UJxBILiSBw5Q==", + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/css-loader/-/css-loader-2.1.1.tgz", + "integrity": "sha512-OcKJU/lt232vl1P9EEDamhoO9iKY3tIjY5GU+XDLblAykTdgs6Ux9P1hTHve8nFKy5KPpOXOsVI/hIwi3841+w==", "dev": true, "requires": { - "icss-utils": "^4.0.0", - "loader-utils": "^1.2.1", - "lodash": "^4.17.11", - "postcss": "^7.0.6", + "camelcase": "^5.2.0", + "icss-utils": "^4.1.0", + "loader-utils": "^1.2.3", + "normalize-path": "^3.0.0", + "postcss": "^7.0.14", "postcss-modules-extract-imports": "^2.0.0", - "postcss-modules-local-by-default": "^2.0.3", - "postcss-modules-scope": "^2.0.0", + "postcss-modules-local-by-default": "^2.0.6", + "postcss-modules-scope": "^2.1.0", "postcss-modules-values": "^2.0.0", "postcss-value-parser": "^3.3.0", "schema-utils": "^1.0.0" }, "dependencies": { - "ajv": { - "version": "6.8.1", - "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.8.1.tgz", - "integrity": "sha512-eqxCp82P+JfqL683wwsL73XmFs1eG6qjw+RD3YHx+Jll1r0jNd4dh8QG9NYAeNGA/hnZjeEDgtTskgJULbxpWQ==", - "dev": true, - "requires": { - "fast-deep-equal": "^2.0.1", - "fast-json-stable-stringify": "^2.0.0", - "json-schema-traverse": "^0.4.1", - "uri-js": "^4.2.2" - } - }, "big.js": { "version": "5.2.2", "resolved": "https://registry.npmjs.org/big.js/-/big.js-5.2.2.tgz", "integrity": "sha512-vyL2OymJxmarO8gxMr0mhChsO9QGwhynfuu4+MHTAW6czfq9humCB7rKpUjDd9YUiDPU4mzpyupFSvOClAwbmQ==", "dev": true }, - "fast-deep-equal": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", - "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", - "dev": true - }, - "json-schema-traverse": { - "version": "0.4.1", - "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", - "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", - "dev": true - }, "json5": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.1.tgz", @@ -2090,80 +1172,18 @@ "json5": "^1.0.1" } }, - "lodash": { - "version": "4.17.11", - "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.11.tgz", - "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg==", - "dev": true - }, "minimist": { "version": "1.2.0", "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", "dev": true - }, - "schema-utils": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", - "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", - "dev": true, - "requires": { - "ajv": "^6.1.0", - "ajv-errors": "^1.0.0", - "ajv-keywords": "^3.1.0" - } - } - } - }, - "css-selector-tokenizer": { - "version": "0.7.1", - "resolved": "https://registry.npmjs.org/css-selector-tokenizer/-/css-selector-tokenizer-0.7.1.tgz", - "integrity": "sha512-xYL0AMZJ4gFzJQsHUKa5jiWWi2vH77WVNg7JYRyewwj6oPh4yb/y6Y9ZCw9dsj/9UauMhtuxR+ogQd//EdEVNA==", - "dev": true, - "requires": { - "cssesc": "^0.1.0", - "fastparse": "^1.1.1", - "regexpu-core": "^1.0.0" - }, - "dependencies": { - "jsesc": { - "version": "0.5.0", - "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz", - "integrity": "sha1-597mbjXW/Bb3EP6R1c9p9w8IkR0=", - "dev": true - }, - "regexpu-core": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-1.0.0.tgz", - "integrity": "sha1-hqdj9Y7k18L2sQLkdkBQ3n7ZDGs=", - "dev": true, - "requires": { - "regenerate": "^1.2.1", - "regjsgen": "^0.2.0", - "regjsparser": "^0.1.4" - } - }, - "regjsgen": { - "version": "0.2.0", - "resolved": "https://registry.npmjs.org/regjsgen/-/regjsgen-0.2.0.tgz", - "integrity": "sha1-bAFq3qxVT3WCP+N6wFuS1aTtsfc=", - "dev": true - }, - "regjsparser": { - "version": "0.1.5", - "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.1.5.tgz", - "integrity": "sha1-fuj4Tcb6eS0/0K4ijSS9lJ6tIFw=", - "dev": true, - "requires": { - "jsesc": "~0.5.0" - } } } }, "cssesc": { - "version": "0.1.0", - "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-0.1.0.tgz", - "integrity": "sha1-yBSQPkViM3GgR3tAEJqq++6t27Q=", + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-3.0.0.tgz", + "integrity": "sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg==", "dev": true }, "currently-unhandled": { @@ -2197,20 +1217,12 @@ "dev": true }, "debug": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.0.tgz", - "integrity": "sha512-heNPJUJIqC+xB6ayLAMHaIrmN9HKa7aQO8MGqKpvCA+uJYVcvR6l5kgdrhRuwPFHU7P5/A1w0BjByPHwpfTDKg==", + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", "dev": true, "requires": { - "ms": "^2.1.1" - }, - "dependencies": { - "ms": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", - "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==", - "dev": true - } + "ms": "2.0.0" } }, "decamelize": { @@ -2273,12 +1285,6 @@ "kind-of": "^6.0.2" } }, - "isobject": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", - "dev": true - }, "kind-of": { "version": "6.0.2", "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", @@ -2314,6 +1320,12 @@ "minimalistic-assert": "^1.0.0" } }, + "detect-file": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/detect-file/-/detect-file-1.0.0.tgz", + "integrity": "sha1-8NZtA2cqglyxtzvbP+YjEMjlUrc=", + "dev": true + }, "diffie-hellman": { "version": "5.0.3", "resolved": "http://registry.npmjs.org/diffie-hellman/-/diffie-hellman-5.0.3.tgz", @@ -2337,9 +1349,9 @@ "integrity": "sha512-3VduRWLxx9hbVr42QieQN25mx/I61/mRdUSuxAmDGdDqZIN8qtP7tcKMa3KfpJjuGjOJGYYUzzeq6eGDnkzesA==" }, "duplexify": { - "version": "3.6.1", - "resolved": "https://registry.npmjs.org/duplexify/-/duplexify-3.6.1.tgz", - "integrity": "sha512-vM58DwdnKmty+FSPzT14K9JXb90H+j5emaR4KYbr2KTIz00WHGbWOe5ghQTx233ZCLZtrGDALzKwcjEtSt35mA==", + "version": "3.7.1", + "resolved": "https://registry.npmjs.org/duplexify/-/duplexify-3.7.1.tgz", + "integrity": "sha512-07z8uv2wMyS51kKhD1KsdXJg5WQ6t93RneqRxUHnskXVtlYYkLqM0gqStQZ3pj073g687jPCHrqNfCzawLYh5g==", "dev": true, "requires": { "end-of-stream": "^1.0.0", @@ -2358,12 +1370,6 @@ "safer-buffer": "^2.1.0" } }, - "electron-to-chromium": { - "version": "1.3.83", - "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.3.83.tgz", - "integrity": "sha512-DqJoDarxq50dcHsOOlMLNoy+qQitlMNbYb6wwbE0oUw2veHdRkpNrhmngiUYKMErdJ8SJ48rpJsZTQgy5SoEAA==", - "dev": true - }, "elliptic": { "version": "6.4.1", "resolved": "https://registry.npmjs.org/elliptic/-/elliptic-6.4.1.tgz", @@ -2459,21 +1465,15 @@ "dev": true }, "eslint-scope": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-4.0.0.tgz", - "integrity": "sha512-1G6UTDi7Jc1ELFwnR58HV4fK9OQK4S6N985f166xqXxpjU6plxFISJa2Ba9KCQuFa8RCnj/lSFJbHo7UFDBnUA==", + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-4.0.3.tgz", + "integrity": "sha512-p7VutNr1O/QrxysMo3E45FjYDTeXBy0iTltPFNSqKAIfjDSXC+4dj+qfyuD8bfAXrW/y6lW3O76VaYNPKfpKrg==", "dev": true, "requires": { "esrecurse": "^4.1.0", "estraverse": "^4.1.1" } }, - "esprima": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", - "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==", - "dev": true - }, "esrecurse": { "version": "4.2.1", "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", @@ -2489,16 +1489,10 @@ "integrity": "sha1-De4/7TH81GlhjOc0IJn8GvoL2xM=", "dev": true }, - "esutils": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.2.tgz", - "integrity": "sha1-Cr9PHKpbyx96nYrMbepPqqBLrJs=", - "dev": true - }, "events": { - "version": "1.1.1", - "resolved": "http://registry.npmjs.org/events/-/events-1.1.1.tgz", - "integrity": "sha1-nr23Y1rQmccNzEwqH1AEKI6L2SQ=", + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/events/-/events-3.0.0.tgz", + "integrity": "sha512-Dc381HFWJzEOhQ+d8pkNon++bk9h6cdAoAj4iE6Q4y6xgTzySWXlKn05/TVNpjnfRqi/X0EpJEJohPjNI3zpVA==", "dev": true }, "evp_bytestokey": { @@ -2512,13 +1506,13 @@ } }, "execa": { - "version": "0.10.0", - "resolved": "https://registry.npmjs.org/execa/-/execa-0.10.0.tgz", - "integrity": "sha512-7XOMnz8Ynx1gGo/3hyV9loYNPWM94jG3+3T3Y8tsfSstFmETmENCMU/A/zj8Lyaj1lkgEepKepvd6240tBRvlw==", + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/execa/-/execa-1.0.0.tgz", + "integrity": "sha512-adbxcyWV46qiHyvSp50TKt05tB4tK3HcmF7/nxfAdhnox83seTDbwnaqKO4sXRy7roHAIFqJP/Rw/AuEbX61LA==", "dev": true, "requires": { "cross-spawn": "^6.0.0", - "get-stream": "^3.0.0", + "get-stream": "^4.0.0", "is-stream": "^1.1.0", "npm-run-path": "^2.0.0", "p-finally": "^1.0.0", @@ -2542,21 +1536,47 @@ } }, "expand-brackets": { - "version": "0.1.5", - "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-0.1.5.tgz", - "integrity": "sha1-3wcoTjQqgHzXM6xa9yQR5YHRF3s=", + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-2.1.4.tgz", + "integrity": "sha1-t3c14xXOMPa27/D4OwQVGiJEliI=", "dev": true, "requires": { - "is-posix-bracket": "^0.1.0" + "debug": "^2.3.3", + "define-property": "^0.2.5", + "extend-shallow": "^2.0.1", + "posix-character-classes": "^0.1.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "dev": true, + "requires": { + "is-descriptor": "^0.1.0" + } + }, + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + } } }, - "expand-range": { - "version": "1.8.2", - "resolved": "https://registry.npmjs.org/expand-range/-/expand-range-1.8.2.tgz", - "integrity": "sha1-opnv/TNf4nIeuujiV+x5ZE/IUzc=", + "expand-tilde": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/expand-tilde/-/expand-tilde-2.0.2.tgz", + "integrity": "sha1-l+gBqgUt8CRU3kawK/YhZCzchQI=", "dev": true, "requires": { - "fill-range": "^2.1.0" + "homedir-polyfill": "^1.0.1" } }, "extend": { @@ -2587,12 +1607,74 @@ } }, "extglob": { - "version": "0.3.2", - "resolved": "https://registry.npmjs.org/extglob/-/extglob-0.3.2.tgz", - "integrity": "sha1-Lhj/PS9JqydlzskCPwEdqo2DSaE=", + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/extglob/-/extglob-2.0.4.tgz", + "integrity": "sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw==", "dev": true, "requires": { - "is-extglob": "^1.0.0" + "array-unique": "^0.3.2", + "define-property": "^1.0.0", + "expand-brackets": "^2.1.4", + "extend-shallow": "^2.0.1", + "fragment-cache": "^0.2.1", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + }, + "dependencies": { + "define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", + "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", + "dev": true, + "requires": { + "is-descriptor": "^1.0.0" + } + }, + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "dev": true, + "requires": { + "is-extendable": "^0.1.0" + } + }, + "is-accessor-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", + "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-data-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", + "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "dev": true, + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-descriptor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", + "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "dev": true, + "requires": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + } + }, + "kind-of": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", + "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", + "dev": true + } } }, "extsprintf": { @@ -2602,9 +1684,9 @@ "dev": true }, "fast-deep-equal": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-1.0.0.tgz", - "integrity": "sha1-liVqO8l1WV6zbYLpkp0GDYk0Of8=", + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", + "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", "dev": true }, "fast-json-stable-stringify": { @@ -2613,92 +1695,149 @@ "integrity": "sha1-1RQsDK7msRifh9OnYREGT4bIu/I=", "dev": true }, - "fastparse": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/fastparse/-/fastparse-1.1.2.tgz", - "integrity": "sha512-483XLLxTVIwWK3QTrMGRqUfUpoOs/0hbQrl2oz4J0pAcm3A3bu84wxTFqGqkJzewCLdME38xJLJAxBABfQT8sQ==", - "dev": true - }, "figgy-pudding": { "version": "3.5.1", "resolved": "https://registry.npmjs.org/figgy-pudding/-/figgy-pudding-3.5.1.tgz", "integrity": "sha512-vNKxJHTEKNThjfrdJwHc7brvM6eVevuO5nTj6ez8ZQ1qbXTvGthucRF7S4vf2cr71QVnT70V34v0S1DyQsti0w==", "dev": true }, - "filename-regex": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/filename-regex/-/filename-regex-2.0.1.tgz", - "integrity": "sha1-wcS5vuPglyXdsQa3XB4wH+LxiyY=", - "dev": true - }, "fill-range": { - "version": "2.2.4", - "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-2.2.4.tgz", - "integrity": "sha512-cnrcCbj01+j2gTG921VZPnHbjmdAf8oQV/iGeV2kZxGSyfYjjTyY79ErsK1WJWMpw6DaApEX72binqJE+/d+5Q==", + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz", + "integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=", "dev": true, "requires": { - "is-number": "^2.1.0", - "isobject": "^2.0.0", - "randomatic": "^3.0.0", - "repeat-element": "^1.1.2", - "repeat-string": "^1.5.2" + "extend-shallow": "^2.0.1", + "is-number": "^3.0.0", + "repeat-string": "^1.6.1", + "to-regex-range": "^2.1.0" }, "dependencies": { - "kind-of": { - "version": "6.0.2", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", - "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", - "dev": true - }, - "randomatic": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/randomatic/-/randomatic-3.0.0.tgz", - "integrity": "sha512-VdxFOIEY3mNO5PtSRkkle/hPJDHvQhK21oa73K4yAc9qmp6N429gAyF1gZMOTMeS0/AYzaV/2Trcef+NaIonSA==", + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", "dev": true, "requires": { - "is-number": "^4.0.0", - "kind-of": "^6.0.0", - "math-random": "^1.0.1" - }, - "dependencies": { - "is-number": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/is-number/-/is-number-4.0.0.tgz", - "integrity": "sha512-rSklcAIlf1OmFdyAqbnWTLVelsQ58uvZ66S/ZyawjWqIviTWCjg2PzVGw8WUA+nNuPTqb4wgA+NszrJ+08LlgQ==", - "dev": true - } + "is-extendable": "^0.1.0" } } } }, "find-cache-dir": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-1.0.0.tgz", - "integrity": "sha1-kojj6ePMN0hxfTnq3hfPcfww7m8=", + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-2.1.0.tgz", + "integrity": "sha512-Tq6PixE0w/VMFfCgbONnkiQIVol/JJL7nRMi20fqzA4NRs9AfeqMGeRdPi3wIhYkxjeBaWh2rxwapn5Tu3IqOQ==", "dev": true, "requires": { "commondir": "^1.0.1", - "make-dir": "^1.0.0", - "pkg-dir": "^2.0.0" + "make-dir": "^2.0.0", + "pkg-dir": "^3.0.0" } }, "find-up": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", - "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", + "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", "dev": true, "requires": { - "locate-path": "^2.0.0" + "locate-path": "^3.0.0" + } + }, + "findup-sync": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/findup-sync/-/findup-sync-2.0.0.tgz", + "integrity": "sha1-kyaxSIwi0aYIhlCoaQGy2akKLLw=", + "dev": true, + "requires": { + "detect-file": "^1.0.0", + "is-glob": "^3.1.0", + "micromatch": "^3.0.4", + "resolve-dir": "^1.0.1" + }, + "dependencies": { + "is-accessor-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", + "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-data-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", + "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-descriptor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", + "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "requires": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + } + }, + "is-glob": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz", + "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=", + "dev": true, + "requires": { + "is-extglob": "^2.1.0" + } + }, + "kind-of": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", + "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==" + } } }, "flush-write-stream": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/flush-write-stream/-/flush-write-stream-1.0.3.tgz", - "integrity": "sha512-calZMC10u0FMUqoiunI2AiGIIUtUIvifNwkHhNupZH4cbNnW1Itkoh/Nf5HFYmDrwWPjrUxpkZT0KhuCq0jmGw==", + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/flush-write-stream/-/flush-write-stream-1.1.1.tgz", + "integrity": "sha512-3Z4XhFZ3992uIq0XOqb9AreonueSYphE6oYbpt5+3u06JWklbsPkNv3ZKkP9Bz/r+1MWCaMoSQ28P85+1Yc77w==", "dev": true, "requires": { - "inherits": "^2.0.1", - "readable-stream": "^2.0.4" + "inherits": "^2.0.3", + "readable-stream": "^2.3.6" + }, + "dependencies": { + "process-nextick-args": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.0.tgz", + "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==", + "dev": true + }, + "readable-stream": { + "version": "2.3.6", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz", + "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", + "dev": true, + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "dev": true, + "requires": { + "safe-buffer": "~5.1.0" + } + } } }, "for-in": { @@ -2708,9 +1847,9 @@ "dev": true }, "for-own": { - "version": "0.1.5", - "resolved": "https://registry.npmjs.org/for-own/-/for-own-0.1.5.tgz", - "integrity": "sha1-UmXGgaTylNq78XyVCbZ2OqhFEM4=", + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/for-own/-/for-own-1.0.0.tgz", + "integrity": "sha1-xjMy9BXO3EsE2/5wz4NklMU8tEs=", "dev": true, "requires": { "for-in": "^1.0.1" @@ -2771,14 +1910,14 @@ "dev": true }, "fsevents": { - "version": "1.2.4", - "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.4.tgz", - "integrity": "sha512-z8H8/diyk76B7q5wg+Ud0+CqzcAF3mBBI/bA5ne5zrRUUIvNkJY//D3BqyH571KuAC4Nr7Rw7CjWX4r0y9DvNg==", + "version": "1.2.9", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.9.tgz", + "integrity": "sha512-oeyj2H3EjjonWcFjD5NvZNE9Rqe4UW+nQBU2HNeKw0koVLEFIhtyETyAakeAM3de7Z/SW5kcA+fZUait9EApnw==", "dev": true, "optional": true, "requires": { - "nan": "^2.9.2", - "node-pre-gyp": "^0.10.0" + "nan": "^2.12.1", + "node-pre-gyp": "^0.12.0" }, "dependencies": { "abbrev": { @@ -2790,7 +1929,8 @@ "ansi-regex": { "version": "2.1.1", "bundled": true, - "dev": true + "dev": true, + "optional": true }, "aproba": { "version": "1.2.0", @@ -2799,7 +1939,7 @@ "optional": true }, "are-we-there-yet": { - "version": "1.1.4", + "version": "1.1.5", "bundled": true, "dev": true, "optional": true, @@ -2825,7 +1965,7 @@ } }, "chownr": { - "version": "1.0.1", + "version": "1.1.1", "bundled": true, "dev": true, "optional": true @@ -2855,16 +1995,16 @@ "optional": true }, "debug": { - "version": "2.6.9", + "version": "4.1.1", "bundled": true, "dev": true, "optional": true, "requires": { - "ms": "2.0.0" + "ms": "^2.1.1" } }, "deep-extend": { - "version": "0.5.1", + "version": "0.6.0", "bundled": true, "dev": true, "optional": true @@ -2913,7 +2053,7 @@ } }, "glob": { - "version": "7.1.2", + "version": "7.1.3", "bundled": true, "dev": true, "optional": true, @@ -2933,12 +2073,12 @@ "optional": true }, "iconv-lite": { - "version": "0.4.21", + "version": "0.4.24", "bundled": true, "dev": true, "optional": true, "requires": { - "safer-buffer": "^2.1.0" + "safer-buffer": ">= 2.1.2 < 3" } }, "ignore-walk": { @@ -2999,19 +2139,21 @@ "minimist": { "version": "0.0.8", "bundled": true, - "dev": true + "dev": true, + "optional": true }, "minipass": { - "version": "2.2.4", + "version": "2.3.5", "bundled": true, "dev": true, + "optional": true, "requires": { - "safe-buffer": "^5.1.1", + "safe-buffer": "^5.1.2", "yallist": "^3.0.0" } }, "minizlib": { - "version": "1.1.0", + "version": "1.2.1", "bundled": true, "dev": true, "optional": true, @@ -3023,47 +2165,41 @@ "version": "0.5.1", "bundled": true, "dev": true, + "optional": true, "requires": { "minimist": "0.0.8" } }, "ms": { - "version": "2.0.0", + "version": "2.1.1", "bundled": true, "dev": true, "optional": true }, - "nan": { - "version": "2.10.0", - "resolved": "https://registry.npmjs.org/nan/-/nan-2.10.0.tgz", - "integrity": "sha512-bAdJv7fBLhWC+/Bls0Oza+mvTaNQtP+1RyhhhvD95pgUJz6XM5IzgmxOkItJ9tkoCiplvAnXI1tNmmUD/eScyA==", - "dev": true, - "optional": true - }, "needle": { - "version": "2.2.0", + "version": "2.3.0", "bundled": true, "dev": true, "optional": true, "requires": { - "debug": "^2.1.2", + "debug": "^4.1.0", "iconv-lite": "^0.4.4", "sax": "^1.2.4" } }, "node-pre-gyp": { - "version": "0.10.0", + "version": "0.12.0", "bundled": true, "dev": true, "optional": true, "requires": { "detect-libc": "^1.0.2", "mkdirp": "^0.5.1", - "needle": "^2.2.0", + "needle": "^2.2.1", "nopt": "^4.0.1", "npm-packlist": "^1.1.6", "npmlog": "^4.0.2", - "rc": "^1.1.7", + "rc": "^1.2.7", "rimraf": "^2.6.1", "semver": "^5.3.0", "tar": "^4" @@ -3080,13 +2216,13 @@ } }, "npm-bundled": { - "version": "1.0.3", + "version": "1.0.6", "bundled": true, "dev": true, "optional": true }, "npm-packlist": { - "version": "1.1.10", + "version": "1.4.1", "bundled": true, "dev": true, "optional": true, @@ -3163,12 +2299,12 @@ "optional": true }, "rc": { - "version": "1.2.7", + "version": "1.2.8", "bundled": true, "dev": true, "optional": true, "requires": { - "deep-extend": "^0.5.1", + "deep-extend": "^0.6.0", "ini": "~1.3.0", "minimist": "^1.2.0", "strip-json-comments": "~2.0.1" @@ -3198,18 +2334,19 @@ } }, "rimraf": { - "version": "2.6.2", + "version": "2.6.3", "bundled": true, "dev": true, "optional": true, "requires": { - "glob": "^7.0.5" + "glob": "^7.1.3" } }, "safe-buffer": { - "version": "5.1.1", + "version": "5.1.2", "bundled": true, - "dev": true + "dev": true, + "optional": true }, "safer-buffer": { "version": "2.1.2", @@ -3224,7 +2361,7 @@ "optional": true }, "semver": { - "version": "5.5.0", + "version": "5.7.0", "bundled": true, "dev": true, "optional": true @@ -3265,6 +2402,7 @@ "version": "3.0.1", "bundled": true, "dev": true, + "optional": true, "requires": { "ansi-regex": "^2.0.0" } @@ -3276,17 +2414,17 @@ "optional": true }, "tar": { - "version": "4.4.1", + "version": "4.4.8", "bundled": true, "dev": true, "optional": true, "requires": { - "chownr": "^1.0.1", + "chownr": "^1.1.1", "fs-minipass": "^1.2.5", - "minipass": "^2.2.4", - "minizlib": "^1.1.0", + "minipass": "^2.3.4", + "minizlib": "^1.1.1", "mkdirp": "^0.5.0", - "safe-buffer": "^5.1.1", + "safe-buffer": "^5.1.2", "yallist": "^3.0.2" } }, @@ -3297,30 +2435,32 @@ "optional": true }, "wide-align": { - "version": "1.1.2", + "version": "1.1.3", "bundled": true, "dev": true, "optional": true, "requires": { - "string-width": "^1.0.2" + "string-width": "^1.0.2 || 2" } }, "wrappy": { "version": "1.0.2", "bundled": true, - "dev": true + "dev": true, + "optional": true }, "yallist": { - "version": "3.0.2", + "version": "3.0.3", "bundled": true, - "dev": true + "dev": true, + "optional": true } } }, "fstream": { - "version": "1.0.11", - "resolved": "https://registry.npmjs.org/fstream/-/fstream-1.0.11.tgz", - "integrity": "sha1-XB+x8RdHcRTwYyoOtLcbPLD9MXE=", + "version": "1.0.12", + "resolved": "https://registry.npmjs.org/fstream/-/fstream-1.0.12.tgz", + "integrity": "sha512-WvJ193OHa0GHPEL+AycEJgxvBEwyfRkN1vhjca23OaPVMCaLCXTd5qAu82AjTcgP1UJmytkOKb63Ypde7raDIg==", "dev": true, "requires": { "graceful-fs": "^4.1.2", @@ -3373,10 +2513,13 @@ "dev": true }, "get-stream": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-3.0.0.tgz", - "integrity": "sha1-jpQ9E1jcN1VQVOy+LtsFqhdO3hQ=", - "dev": true + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz", + "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==", + "dev": true, + "requires": { + "pump": "^3.0.0" + } }, "get-value": { "version": "2.0.6", @@ -3407,36 +2550,50 @@ "path-is-absolute": "^1.0.0" } }, - "glob-base": { - "version": "0.3.0", - "resolved": "https://registry.npmjs.org/glob-base/-/glob-base-0.3.0.tgz", - "integrity": "sha1-27Fk9iIbHAscz4Kuoyi0l98Oo8Q=", - "dev": true, - "requires": { - "glob-parent": "^2.0.0", - "is-glob": "^2.0.0" - } - }, "glob-parent": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-2.0.0.tgz", - "integrity": "sha1-gTg9ctsFT8zPUzbaqQLxgvbtuyg=", + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz", + "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=", "dev": true, "requires": { - "is-glob": "^2.0.0" + "is-glob": "^3.1.0", + "path-dirname": "^1.0.0" + }, + "dependencies": { + "is-glob": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz", + "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=", + "dev": true, + "requires": { + "is-extglob": "^2.1.0" + } + } } }, - "global-modules-path": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/global-modules-path/-/global-modules-path-2.3.0.tgz", - "integrity": "sha512-HchvMJNYh9dGSCy8pOQ2O8u/hoXaL+0XhnrwH0RyLiSXMMTl9W3N6KUU73+JFOg5PGjtzl6VZzUQsnrpm7Szag==", - "dev": true + "global-modules": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/global-modules/-/global-modules-1.0.0.tgz", + "integrity": "sha512-sKzpEkf11GpOFuw0Zzjzmt4B4UZwjOcG757PPvrfhxcLFbq0wpsgpOqxpxtxFiCG4DtG93M6XRVbF2oGdev7bg==", + "dev": true, + "requires": { + "global-prefix": "^1.0.1", + "is-windows": "^1.0.1", + "resolve-dir": "^1.0.0" + } }, - "globals": { - "version": "11.9.0", - "resolved": "https://registry.npmjs.org/globals/-/globals-11.9.0.tgz", - "integrity": "sha512-5cJVtyXWH8PiJPVLZzzoIizXx944O4OmRro5MWKx5fT4MgcN7OfaMutPeaTdJCCURwbWdhhcCWcKIffPnmTzBg==", - "dev": true + "global-prefix": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/global-prefix/-/global-prefix-1.0.2.tgz", + "integrity": "sha1-2/dDxsFJklk8ZVVoy2btMsASLr4=", + "dev": true, + "requires": { + "expand-tilde": "^2.0.2", + "homedir-polyfill": "^1.0.1", + "ini": "^1.3.4", + "is-windows": "^1.0.1", + "which": "^1.2.14" + } }, "globule": { "version": "1.2.1", @@ -3470,12 +2627,12 @@ "dev": true }, "har-validator": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.0.tgz", - "integrity": "sha512-+qnmNjI4OfH2ipQ9VQOw23bBd/ibtfbVdK2fYbY4acTDqKTW/YDp9McimZdDbG8iV9fZizUqQMD5xvriB146TA==", + "version": "5.1.3", + "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.3.tgz", + "integrity": "sha512-sNvOCzEQNr/qrvJgc3UG/kD4QtlHycrzwS+6mfTrrSq97BvaYcPZZI1ZSqGSPR73Cxn4LKTD4PttRwfU7jWq5g==", "dev": true, "requires": { - "ajv": "^5.3.0", + "ajv": "^6.5.5", "har-schema": "^2.0.0" } }, @@ -3524,14 +2681,6 @@ "get-value": "^2.0.6", "has-values": "^1.0.0", "isobject": "^3.0.0" - }, - "dependencies": { - "isobject": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", - "dev": true - } } }, "has-values": { @@ -3544,26 +2693,6 @@ "kind-of": "^4.0.0" }, "dependencies": { - "is-number": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", - "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", - "dev": true, - "requires": { - "kind-of": "^3.0.2" - }, - "dependencies": { - "kind-of": { - "version": "3.2.2", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", - "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", - "dev": true, - "requires": { - "is-buffer": "^1.1.5" - } - } - } - }, "kind-of": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz", @@ -3586,9 +2715,9 @@ } }, "hash.js": { - "version": "1.1.5", - "resolved": "https://registry.npmjs.org/hash.js/-/hash.js-1.1.5.tgz", - "integrity": "sha512-eWI5HG9Np+eHV1KQhisXWwM+4EPPYe5dFX1UZZH7k/E3JzDEazVH+VGlZi6R94ZqImq+A3D1mCEtrFIfg/E7sA==", + "version": "1.1.7", + "resolved": "https://registry.npmjs.org/hash.js/-/hash.js-1.1.7.tgz", + "integrity": "sha512-taOaskGt4z4SOANNseOviYDvjEJinIkRgmp7LbKP2YTTmVxWBl87s/uzK9r+44BclBSp2X7K1hqeNfz9JbBeXA==", "dev": true, "requires": { "inherits": "^2.0.3", @@ -3606,6 +2735,15 @@ "minimalistic-crypto-utils": "^1.0.1" } }, + "homedir-polyfill": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/homedir-polyfill/-/homedir-polyfill-1.0.3.tgz", + "integrity": "sha512-eSmmWE5bZTK2Nou4g0AI3zZ9rswp7GRKoKXS1BLUkvPviOqs4YTN1djQIqrXy9k5gEtdLPy86JjRwsNM9tnDcA==", + "dev": true, + "requires": { + "parse-passwd": "^1.0.0" + } + }, "hosted-git-info": { "version": "2.7.1", "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.7.1.tgz", @@ -3636,18 +2774,18 @@ "dev": true }, "icss-utils": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/icss-utils/-/icss-utils-4.0.0.tgz", - "integrity": "sha512-bA/xGiwWM17qjllIs9X/y0EjsB7e0AV08F3OL8UPsoNkNRibIuu8f1eKTnQ8QO1DteKKTxTUAn+IEWUToIwGOA==", + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/icss-utils/-/icss-utils-4.1.1.tgz", + "integrity": "sha512-4aFq7wvWyMHKgxsH8QQtGpvbASCf+eM3wPRLI6R+MgAnTCZ6STYsRvttLvRWK0Nfif5piF394St3HeJDaljGPA==", "dev": true, "requires": { - "postcss": "^7.0.5" + "postcss": "^7.0.14" } }, "ieee754": { - "version": "1.1.12", - "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.1.12.tgz", - "integrity": "sha512-GguP+DRY+pJ3soyIiGPTvdiVXjZ+DbXOxGpXn3eMvNW4x4irjqXm4wHKscC+TfxSJ0yw/S1F24tqdMNsMZTiLA==", + "version": "1.1.13", + "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.1.13.tgz", + "integrity": "sha512-4vf7I2LYV/HaWerSo3XmlMkp5eZ83i+/CDluXi/IGTs/O1sejBNhTtnxzmRZfvOUqj7lZjqHkeTvpgSFDlWZTg==", "dev": true }, "iferr": { @@ -3656,24 +2794,6 @@ "integrity": "sha1-xg7taebY/bazEEofy8ocGS3FtQE=", "dev": true }, - "import-cwd": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/import-cwd/-/import-cwd-2.1.0.tgz", - "integrity": "sha1-qmzzbnInYShcs3HsZRn1PiQ1sKk=", - "dev": true, - "requires": { - "import-from": "^2.1.0" - } - }, - "import-from": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/import-from/-/import-from-2.1.0.tgz", - "integrity": "sha1-M1238qev/VOqpHHUuAId7ja387E=", - "dev": true, - "requires": { - "resolve-from": "^3.0.0" - } - }, "import-local": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/import-local/-/import-local-2.0.0.tgz", @@ -3682,60 +2802,6 @@ "requires": { "pkg-dir": "^3.0.0", "resolve-cwd": "^2.0.0" - }, - "dependencies": { - "find-up": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", - "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", - "dev": true, - "requires": { - "locate-path": "^3.0.0" - } - }, - "locate-path": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", - "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", - "dev": true, - "requires": { - "p-locate": "^3.0.0", - "path-exists": "^3.0.0" - } - }, - "p-limit": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.0.0.tgz", - "integrity": "sha512-fl5s52lI5ahKCernzzIyAP0QAZbGIovtVHGwpcu1Jr/EpzLVDI2myISHwGqK7m8uQFugVWSrbxH7XnhGtvEc+A==", - "dev": true, - "requires": { - "p-try": "^2.0.0" - } - }, - "p-locate": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", - "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", - "dev": true, - "requires": { - "p-limit": "^2.0.0" - } - }, - "p-try": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.0.0.tgz", - "integrity": "sha512-hMp0onDKIajHfIkdRk3P4CdCmErkYAxxDtP3Wx/4nZ3aGlau2VKh3mZpcuFkH27WQkL/3WBCPOktzA9ZOAnMQQ==", - "dev": true - }, - "pkg-dir": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-3.0.0.tgz", - "integrity": "sha512-/E57AYkoeQ25qkxMj5PBOVgF8Kiu/h7cYS30Z5+R7WaiCCBfLq58ZI/dSeaEKb9WVJV5n/03QwrN3IeWIFllvw==", - "dev": true, - "requires": { - "find-up": "^3.0.0" - } - } } }, "imurmurhash": { @@ -3759,6 +2825,12 @@ "repeating": "^2.0.0" } }, + "indexes-of": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/indexes-of/-/indexes-of-1.0.1.tgz", + "integrity": "sha1-8w9xbI4r00bHtn0985FVZqfAVgc=", + "dev": true + }, "indexof": { "version": "0.0.1", "resolved": "https://registry.npmjs.org/indexof/-/indexof-0.0.1.tgz", @@ -3781,20 +2853,17 @@ "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=", "dev": true }, - "interpret": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/interpret/-/interpret-1.1.0.tgz", - "integrity": "sha1-ftGxQQxqDg94z5XTuEQMY/eLhhQ=", + "ini": { + "version": "1.3.5", + "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.5.tgz", + "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==", "dev": true }, - "invariant": { - "version": "2.2.4", - "resolved": "https://registry.npmjs.org/invariant/-/invariant-2.2.4.tgz", - "integrity": "sha512-phJfQVBuaJM5raOpJjSfkiD6BpbCE4Ns//LaXl6wGYtUBY83nWS6Rf9tXm2e8VaK60JEjYldbPif/A2B1C2gNA==", - "dev": true, - "requires": { - "loose-envify": "^1.0.0" - } + "interpret": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/interpret/-/interpret-1.2.0.tgz", + "integrity": "sha512-mT34yGKMNceBQUoVn7iCDKDntA7SC6gycMAWzGx1z/CMCTV7b2AAtXlo3nRyHZ1FelRkQbQjprHSYGwzLtkVbw==", + "dev": true }, "invert-kv": { "version": "1.0.0", @@ -3829,7 +2898,8 @@ "is-buffer": { "version": "1.1.6", "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", - "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==" + "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==", + "dev": true }, "is-builtin-module": { "version": "1.0.0", @@ -3880,27 +2950,6 @@ } } }, - "is-directory": { - "version": "0.3.1", - "resolved": "https://registry.npmjs.org/is-directory/-/is-directory-0.3.1.tgz", - "integrity": "sha1-YTObbyR1/Hcv2cnYP1yFddwVSuE=", - "dev": true - }, - "is-dotfile": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/is-dotfile/-/is-dotfile-1.0.3.tgz", - "integrity": "sha1-pqLzL/0t+wT1yiXs0Pa4PPeYoeE=", - "dev": true - }, - "is-equal-shallow": { - "version": "0.1.3", - "resolved": "https://registry.npmjs.org/is-equal-shallow/-/is-equal-shallow-0.1.3.tgz", - "integrity": "sha1-IjgJj8Ih3gvPpdnqxMRdY4qhxTQ=", - "dev": true, - "requires": { - "is-primitive": "^2.0.0" - } - }, "is-extendable": { "version": "0.1.1", "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", @@ -3908,9 +2957,9 @@ "dev": true }, "is-extglob": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-1.0.0.tgz", - "integrity": "sha1-rEaBd8SUNAWgkvyPKXYMb/xiBsA=", + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", "dev": true }, "is-finite": { @@ -3932,23 +2981,29 @@ } }, "is-glob": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-2.0.1.tgz", - "integrity": "sha1-0Jb5JqPe1WAPP9/ZEZjLCIjC2GM=", + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", + "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", "dev": true, "requires": { - "is-extglob": "^1.0.0" + "is-extglob": "^2.1.1" } }, "is-number": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/is-number/-/is-number-2.1.0.tgz", - "integrity": "sha1-Afy7s5NGOlSPL0ZszhbezknbkI8=", + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", + "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", "dev": true, "requires": { "kind-of": "^3.0.2" } }, + "is-plain-obj": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-1.1.0.tgz", + "integrity": "sha1-caUMhCnfync8kqOQpKA7OfzVHT4=", + "dev": true + }, "is-plain-object": { "version": "2.0.4", "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz", @@ -3956,28 +3011,8 @@ "dev": true, "requires": { "isobject": "^3.0.1" - }, - "dependencies": { - "isobject": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", - "dev": true - } } }, - "is-posix-bracket": { - "version": "0.1.1", - "resolved": "https://registry.npmjs.org/is-posix-bracket/-/is-posix-bracket-0.1.1.tgz", - "integrity": "sha1-MzTceXdDaOkvAW5vvAqI9c1ua8Q=", - "dev": true - }, - "is-primitive": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/is-primitive/-/is-primitive-2.0.0.tgz", - "integrity": "sha1-IHurkWOEmcB7Kt8kCkGochADRXU=", - "dev": true - }, "is-regex": { "version": "1.0.4", "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.4.tgz", @@ -4020,6 +3055,12 @@ "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==", "dev": true }, + "is-wsl": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-wsl/-/is-wsl-1.1.0.tgz", + "integrity": "sha1-HxbkqiKwTRM2tmGIpmrzxgDDpm0=", + "dev": true + }, "isarray": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", @@ -4033,13 +3074,10 @@ "dev": true }, "isobject": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz", - "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", - "dev": true, - "requires": { - "isarray": "1.0.0" - } + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", + "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", + "dev": true }, "isstream": { "version": "0.1.2", @@ -4047,66 +3085,18 @@ "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=", "dev": true }, - "jquery": { - "version": "3.3.1", - "resolved": "https://registry.npmjs.org/jquery/-/jquery-3.3.1.tgz", - "integrity": "sha512-Ubldcmxp5np52/ENotGxlLe6aGMvmF4R8S6tZjsP6Knsaxd/xp3Zrh50cG93lR6nPXyUFwzN3ZSOQI0wRJNdGg==" - }, - "jquery-sortable": { - "version": "0.9.13", - "resolved": "https://registry.npmjs.org/jquery-sortable/-/jquery-sortable-0.9.13.tgz", - "integrity": "sha1-HL+2VQE6B0c3BXHwbiL1JKAP+6I=", - "requires": { - "jquery": "^2.1.2" - }, - "dependencies": { - "jquery": { - "version": "2.2.4", - "resolved": "https://registry.npmjs.org/jquery/-/jquery-2.2.4.tgz", - "integrity": "sha1-LInWiJterFIqfuoywUUhVZxsvwI=" - } - } - }, "js-base64": { - "version": "2.4.9", - "resolved": "https://registry.npmjs.org/js-base64/-/js-base64-2.4.9.tgz", - "integrity": "sha512-xcinL3AuDJk7VSzsHgb9DvvIXayBbadtMZ4HFPx8rUszbW1MuNMlwYVC4zzCZ6e1sqZpnNS5ZFYOhXqA39T7LQ==", + "version": "2.5.1", + "resolved": "https://registry.npmjs.org/js-base64/-/js-base64-2.5.1.tgz", + "integrity": "sha512-M7kLczedRMYX4L8Mdh4MzyAMM9O5osx+4FcOQuTvr3A9F2D9S5JXheN0ewNbrvK2UatkTRhL5ejGmGSjNMiZuw==", "dev": true }, - "js-levenshtein": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/js-levenshtein/-/js-levenshtein-1.1.4.tgz", - "integrity": "sha512-PxfGzSs0ztShKrUYPIn5r0MtyAhYcCwmndozzpz8YObbPnD1jFxzlBGbRnX2mIu6Z13xN6+PTu05TQFnZFlzow==", - "dev": true - }, - "js-tokens": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", - "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==", - "dev": true - }, - "js-yaml": { - "version": "3.12.1", - "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.12.1.tgz", - "integrity": "sha512-um46hB9wNOKlwkHgiuyEVAybXBjwFUV0Z/RaHJblRd9DXltue9FTYvzCr9ErQrK9Adz5MU4gHWVaNUfdmrC8qA==", - "dev": true, - "requires": { - "argparse": "^1.0.7", - "esprima": "^4.0.0" - } - }, "jsbn": { "version": "0.1.1", "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=", "dev": true }, - "jsesc": { - "version": "2.5.2", - "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", - "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==", - "dev": true - }, "json-parse-better-errors": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", @@ -4120,9 +3110,9 @@ "dev": true }, "json-schema-traverse": { - "version": "0.3.1", - "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.3.1.tgz", - "integrity": "sha1-NJptRMU6Ud6JtAgFxdXlm0F9M0A=", + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", + "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", "dev": true }, "json-stringify-safe": { @@ -4182,12 +3172,12 @@ } }, "livereload": { - "version": "0.7.0", - "resolved": "https://registry.npmjs.org/livereload/-/livereload-0.7.0.tgz", - "integrity": "sha512-PHnIGczQEvmCctDvRTWylA+1wSwE0/eFm+LkNhlmlAFus/aCRlVE97UOLOf6TUGLmZyfg7z7twG37ZiOgNJAyQ==", + "version": "0.8.0", + "resolved": "https://registry.npmjs.org/livereload/-/livereload-0.8.0.tgz", + "integrity": "sha512-Hi5Na6VIK3e8zlgOS50fu+iOTKWj5hM0BE7NKpZkwnfWTnktTjA38ZUXa2NlJww8/GrdVhpnxdqlLad5fkO27g==", "dev": true, "requires": { - "chokidar": "^1.7.0", + "chokidar": "^2.1.5", "opts": ">= 1.2.0", "ws": "^1.1.5" } @@ -4214,9 +3204,9 @@ } }, "loader-runner": { - "version": "2.3.1", - "resolved": "https://registry.npmjs.org/loader-runner/-/loader-runner-2.3.1.tgz", - "integrity": "sha512-By6ZFY7ETWOc9RFaAIb23IjJVcM4dvJC/N57nmdz9RSkMXvAXGI7SyVlAw3v8vjtDRlqThgVDVmTnr9fqMlxkw==", + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/loader-runner/-/loader-runner-2.4.0.tgz", + "integrity": "sha512-Jsmr89RcXGIwivFY21FcRrisYZfvLMTWx5kOLc+JTxtpBOG6xML0vzbc6SEQG2FO9/4Fc3wW4LVcB5DmGflaRw==", "dev": true }, "loader-utils": { @@ -4231,43 +3221,19 @@ } }, "locate-path": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", - "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", + "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", "dev": true, "requires": { - "p-locate": "^2.0.0", + "p-locate": "^3.0.0", "path-exists": "^3.0.0" } }, "lodash": { - "version": "4.17.10", - "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.10.tgz", - "integrity": "sha512-UejweD1pDoXu+AD825lWwp4ZGtSwgnpZxb3JDViD7StjQz+Nb/6l093lx4OQ0foGWNRoc19mWy7BzL+UAK2iVg==", - "dev": true - }, - "lodash.assign": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/lodash.assign/-/lodash.assign-4.2.0.tgz", - "integrity": "sha1-DZnzzNem0mHRm9rrkkUAXShYCOc=", - "dev": true - }, - "lodash.clonedeep": { - "version": "4.5.0", - "resolved": "https://registry.npmjs.org/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz", - "integrity": "sha1-4j8/nE+Pvd6HJSnBBxhXoIblzO8=", - "dev": true - }, - "lodash.debounce": { - "version": "4.0.8", - "resolved": "https://registry.npmjs.org/lodash.debounce/-/lodash.debounce-4.0.8.tgz", - "integrity": "sha1-gteb/zCmfEAF/9XiUVMArZyk168=", - "dev": true - }, - "lodash.mergewith": { - "version": "4.6.1", - "resolved": "https://registry.npmjs.org/lodash.mergewith/-/lodash.mergewith-4.6.1.tgz", - "integrity": "sha512-eWw5r+PYICtEBgrBE5hhlT6aAa75f411bgDz/ZL2KZqYV03USvucsxcHUIlGTDTECs1eunpI7HOV7U+WLDvNdQ==", + "version": "4.17.11", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.11.tgz", + "integrity": "sha512-cQKh8igo5QUhZ7lg38DYWAxMvjSAKG0A8wGSVimP07SIUEK2UO+arSRKbRZWtelMtN5V0Hkwh5ryOto/SshYIg==", "dev": true }, "lodash.tail": { @@ -4276,15 +3242,6 @@ "integrity": "sha1-0jM6NtnncXyK0vfKyv7HwytERmQ=", "dev": true }, - "loose-envify": { - "version": "1.4.0", - "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", - "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", - "dev": true, - "requires": { - "js-tokens": "^3.0.0 || ^4.0.0" - } - }, "loud-rejection": { "version": "1.6.0", "resolved": "https://registry.npmjs.org/loud-rejection/-/loud-rejection-1.6.0.tgz", @@ -4296,9 +3253,9 @@ } }, "lru-cache": { - "version": "4.1.3", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.3.tgz", - "integrity": "sha512-fFEhvcgzuIoJVUF8fYr5KR0YqxD238zgObTps31YdADwPPAp82a4M8TrckkWyx7ekNlf9aBcVn81cFwwXngrJA==", + "version": "4.1.5", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-4.1.5.tgz", + "integrity": "sha512-sWZlbEP2OsHNkXrMl5GYk/jKk70MBng6UU4YI/qGDYbgf6YbP4EvmqISbXCoJiRKs+1bSpFHVgQxvJ17F2li5g==", "dev": true, "requires": { "pseudomap": "^1.0.2", @@ -4306,18 +3263,33 @@ } }, "make-dir": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-1.3.0.tgz", - "integrity": "sha512-2w31R7SJtieJJnQtGc7RVL2StM2vGYVfqUOvUDxH6bC6aJTxPxTF0GnIgCyu7tjockiUWAYQRbxa7vKn34s5sQ==", + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-2.1.0.tgz", + "integrity": "sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==", "dev": true, "requires": { - "pify": "^3.0.0" + "pify": "^4.0.1", + "semver": "^5.6.0" + }, + "dependencies": { + "pify": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/pify/-/pify-4.0.1.tgz", + "integrity": "sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g==", + "dev": true + } } }, + "mamacro": { + "version": "0.0.3", + "resolved": "https://registry.npmjs.org/mamacro/-/mamacro-0.0.3.tgz", + "integrity": "sha512-qMEwh+UujcQ+kbz3T6V+wAmO2U8veoq2w+3wY8MquqwVA3jChfwY+Tk52GZKDfACEPjuZ7r2oJLejwpt8jtwTA==", + "dev": true + }, "map-age-cleaner": { - "version": "0.1.2", - "resolved": "https://registry.npmjs.org/map-age-cleaner/-/map-age-cleaner-0.1.2.tgz", - "integrity": "sha512-UN1dNocxQq44IhJyMI4TU8phc2m9BddacHRPRjKGLYaF0jqd3xLz0jS0skpAU9WgYyoR4gHtUpzytNBS385FWQ==", + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/map-age-cleaner/-/map-age-cleaner-0.1.3.tgz", + "integrity": "sha512-bJzx6nMoP6PDLPBFmg7+xRKeFZvFboMrGlxmNj9ClvX53KrmvM5bXFXEWjbz4cz1AFn+jWJ9z/DJSz7hrs0w3w==", "dev": true, "requires": { "p-defer": "^1.0.0" @@ -4361,12 +3333,6 @@ "resolved": "https://registry.npmjs.org/markdown-it-task-lists/-/markdown-it-task-lists-2.1.1.tgz", "integrity": "sha512-TxFAc76Jnhb2OUu+n3yz9RMu4CwGfaT788br6HhEDlvWfdeJcLUsxk1Hgw2yJio0OXsxv7pyIPmvECY7bMbluA==" }, - "math-random": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/math-random/-/math-random-1.0.1.tgz", - "integrity": "sha1-izqsWIuKZuSXXjzepn97sylgH6w=", - "dev": true - }, "md5.js": { "version": "1.3.5", "resolved": "https://registry.npmjs.org/md5.js/-/md5.js-1.3.5.tgz", @@ -4392,14 +3358,14 @@ "integrity": "sha1-/oWy7HWlkDfyrf7BAP1sYBdhFS4=" }, "mem": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/mem/-/mem-4.0.0.tgz", - "integrity": "sha512-WQxG/5xYc3tMbYLXoXPm81ET2WDULiU5FxbuIoNbJqLOOI8zehXFdZuiUEgfdrU2mVB1pxBZUGlYORSrpuJreA==", + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/mem/-/mem-4.3.0.tgz", + "integrity": "sha512-qX2bG48pTqYRVmDB37rn/6PT7LcR8T7oAX3bf99u1Tt1nzxYfxkgqDwUwolPlXweM0XzBOBFzSx4kfp7KP1s/w==", "dev": true, "requires": { "map-age-cleaner": "^0.1.1", - "mimic-fn": "^1.0.0", - "p-is-promise": "^1.1.0" + "mimic-fn": "^2.0.0", + "p-is-promise": "^2.0.0" } }, "memory-fs": { @@ -4445,24 +3411,32 @@ } }, "micromatch": { - "version": "2.3.11", - "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-2.3.11.tgz", - "integrity": "sha1-hmd8l9FyCzY0MdBNDRUpO9OMFWU=", + "version": "3.1.10", + "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz", + "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==", "dev": true, "requires": { - "arr-diff": "^2.0.0", - "array-unique": "^0.2.1", - "braces": "^1.8.2", - "expand-brackets": "^0.1.4", - "extglob": "^0.3.1", - "filename-regex": "^2.0.0", - "is-extglob": "^1.0.0", - "is-glob": "^2.0.1", - "kind-of": "^3.0.2", - "normalize-path": "^2.0.1", - "object.omit": "^2.0.0", - "parse-glob": "^3.0.4", - "regex-cache": "^0.4.2" + "arr-diff": "^4.0.0", + "array-unique": "^0.3.2", + "braces": "^2.3.1", + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "extglob": "^2.0.4", + "fragment-cache": "^0.2.1", + "kind-of": "^6.0.2", + "nanomatch": "^1.2.9", + "object.pick": "^1.3.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.2" + }, + "dependencies": { + "kind-of": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", + "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", + "dev": true + } } }, "miller-rabin": { @@ -4476,72 +3450,36 @@ } }, "mime-db": { - "version": "1.37.0", - "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.37.0.tgz", - "integrity": "sha512-R3C4db6bgQhlIhPU48fUtdVmKnflq+hRdad7IyKhtFj06VPNVdk2RhiYL3UjQIlso8L+YxAtFkobT0VK+S/ybg==", + "version": "1.40.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.40.0.tgz", + "integrity": "sha512-jYdeOMPy9vnxEqFRRo6ZvTZ8d9oPb+k18PKoYNYUe2stVEBPPwsln/qWzdbmaIvnhZ9v2P+CuecK+fpUfsV2mA==", "dev": true }, "mime-types": { - "version": "2.1.21", - "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.21.tgz", - "integrity": "sha512-3iL6DbwpyLzjR3xHSFNFeb9Nz/M8WDkX33t1GFQnFOllWk8pOrh/LSrB5OXlnlW5P9LH73X6loW/eogc+F5lJg==", + "version": "2.1.24", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.24.tgz", + "integrity": "sha512-WaFHS3MCl5fapm3oLxU4eYDw77IQM2ACcxQ9RIxfaC3ooc6PFuBMGZZsYpvoXS5D5QTWPieo1jjLdAm3TBP3cQ==", "dev": true, "requires": { - "mime-db": "~1.37.0" + "mime-db": "1.40.0" } }, "mimic-fn": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-1.2.0.tgz", - "integrity": "sha512-jf84uxzwiuiIVKiOLpfYk7N46TSy8ubTonmneY9vrpHNAnp0QBt2BxWV9dO3/j+BoVAb+a5G6YDPW3M5HOdMWQ==", + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", + "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", "dev": true }, "mini-css-extract-plugin": { - "version": "0.5.0", - "resolved": "https://registry.npmjs.org/mini-css-extract-plugin/-/mini-css-extract-plugin-0.5.0.tgz", - "integrity": "sha512-IuaLjruM0vMKhUUT51fQdQzBYTX49dLj8w68ALEAe2A4iYNpIC4eMac67mt3NzycvjOlf07/kYxJDc0RTl1Wqw==", + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/mini-css-extract-plugin/-/mini-css-extract-plugin-0.7.0.tgz", + "integrity": "sha512-RQIw6+7utTYn8DBGsf/LpRgZCJMpZt+kuawJ/fju0KiOL6nAaTBNmCJwS7HtwSCXfS47gCkmtBFS7HdsquhdxQ==", "dev": true, "requires": { "loader-utils": "^1.1.0", + "normalize-url": "1.9.1", "schema-utils": "^1.0.0", "webpack-sources": "^1.1.0" - }, - "dependencies": { - "ajv": { - "version": "6.8.1", - "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.8.1.tgz", - "integrity": "sha512-eqxCp82P+JfqL683wwsL73XmFs1eG6qjw+RD3YHx+Jll1r0jNd4dh8QG9NYAeNGA/hnZjeEDgtTskgJULbxpWQ==", - "dev": true, - "requires": { - "fast-deep-equal": "^2.0.1", - "fast-json-stable-stringify": "^2.0.0", - "json-schema-traverse": "^0.4.1", - "uri-js": "^4.2.2" - } - }, - "fast-deep-equal": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", - "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", - "dev": true - }, - "json-schema-traverse": { - "version": "0.4.1", - "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", - "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", - "dev": true - }, - "schema-utils": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", - "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", - "dev": true, - "requires": { - "ajv": "^6.1.0", - "ajv-errors": "^1.0.0", - "ajv-keywords": "^3.1.0" - } - } } }, "minimalistic-assert": { @@ -4587,18 +3525,6 @@ "pumpify": "^1.3.3", "stream-each": "^1.1.0", "through2": "^2.0.0" - }, - "dependencies": { - "pump": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", - "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", - "dev": true, - "requires": { - "end-of-stream": "^1.1.0", - "once": "^1.3.1" - } - } } }, "mixin-deep": { @@ -4666,12 +3592,13 @@ "ms": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", - "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=", + "dev": true }, "nan": { - "version": "2.11.1", - "resolved": "https://registry.npmjs.org/nan/-/nan-2.11.1.tgz", - "integrity": "sha512-iji6k87OSXa0CcrLl9z+ZiYSuR2o+c0bGuNmXdrhTQTakxytAFsC56SArGYoiHlJlFoHSnvmhpceZJaXkVuOtA==", + "version": "2.14.0", + "resolved": "https://registry.npmjs.org/nan/-/nan-2.14.0.tgz", + "integrity": "sha512-INOFj37C7k3AfaNTtX8RhsTw7qRy7eLET14cROi9+5HAVbbHuIWUHEauBv5qT4Av2tWasiTY1Jw6puUNqRJXQg==", "dev": true }, "nanomatch": { @@ -4693,18 +3620,6 @@ "to-regex": "^3.0.1" }, "dependencies": { - "arr-diff": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-4.0.0.tgz", - "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=", - "dev": true - }, - "array-unique": { - "version": "0.3.2", - "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.3.2.tgz", - "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=", - "dev": true - }, "kind-of": { "version": "6.0.2", "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", @@ -4754,9 +3669,9 @@ } }, "node-libs-browser": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/node-libs-browser/-/node-libs-browser-2.1.0.tgz", - "integrity": "sha512-5AzFzdoIMb89hBGMZglEegffzgRg+ZFoUmisQ8HI4j1KDdpx13J0taNp2y9xPbur6W61gepGDDotGBVQ7mfUCg==", + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/node-libs-browser/-/node-libs-browser-2.2.0.tgz", + "integrity": "sha512-5MQunG/oyOaBdttrL40dA7bUfPORLRWMUJLQtMg7nluxUvk5XwnLdL9twQHFAjRx/y7mIMkLKT9++qPbbk6BZA==", "dev": true, "requires": { "assert": "^1.1.1", @@ -4766,7 +3681,7 @@ "constants-browserify": "^1.0.0", "crypto-browserify": "^3.11.0", "domain-browser": "^1.1.1", - "events": "^1.0.0", + "events": "^3.0.0", "https-browserify": "^1.0.0", "os-browserify": "^0.3.0", "path-browserify": "0.0.0", @@ -4780,23 +3695,14 @@ "timers-browserify": "^2.0.4", "tty-browserify": "0.0.0", "url": "^0.11.0", - "util": "^0.10.3", + "util": "^0.11.0", "vm-browserify": "0.0.4" } }, - "node-releases": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-1.0.4.tgz", - "integrity": "sha512-GqRV9GcHw8JCRDaP/JoeNMNzEGzHAknMvIHqMb2VeTOmg1Cf9+ej8bkV12tHfzWHQMCkQ5zUFgwFUkfraynNCw==", - "dev": true, - "requires": { - "semver": "^5.3.0" - } - }, "node-sass": { - "version": "4.10.0", - "resolved": "https://registry.npmjs.org/node-sass/-/node-sass-4.10.0.tgz", - "integrity": "sha512-fDQJfXszw6vek63Fe/ldkYXmRYK/QS6NbvM3i5oEo9ntPDy4XX7BcKZyTKv+/kSSxRtXXc7l+MSwEmYc0CSy6Q==", + "version": "4.12.0", + "resolved": "https://registry.npmjs.org/node-sass/-/node-sass-4.12.0.tgz", + "integrity": "sha512-A1Iv4oN+Iel6EPv77/HddXErL2a+gZ4uBeZUy+a8O35CFYTXhgA8MgLCWBtwpGZdCvTvQ9d+bQxX/QC36GDPpQ==", "dev": true, "requires": { "async-foreach": "^0.1.3", @@ -4806,12 +3712,10 @@ "get-stdin": "^4.0.1", "glob": "^7.0.3", "in-publish": "^2.0.0", - "lodash.assign": "^4.2.0", - "lodash.clonedeep": "^4.3.2", - "lodash.mergewith": "^4.6.0", + "lodash": "^4.17.11", "meow": "^3.7.0", "mkdirp": "^0.5.1", - "nan": "^2.10.0", + "nan": "^2.13.2", "node-gyp": "^3.8.0", "npmlog": "^4.0.0", "request": "^2.88.0", @@ -4869,20 +3773,23 @@ } }, "normalize-path": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", - "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", + "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", + "dev": true + }, + "normalize-url": { + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-1.9.1.tgz", + "integrity": "sha1-LMDWazHqIwNkWENuNiDYWVTGbDw=", "dev": true, "requires": { - "remove-trailing-separator": "^1.0.1" + "object-assign": "^4.0.1", + "prepend-http": "^1.0.0", + "query-string": "^4.1.0", + "sort-keys": "^1.0.0" } }, - "normalize-range": { - "version": "0.1.2", - "resolved": "https://registry.npmjs.org/normalize-range/-/normalize-range-0.1.2.tgz", - "integrity": "sha1-LRDAa9/TEuqXd2laTShDlFa3WUI=", - "dev": true - }, "npm-run-all": { "version": "4.1.5", "resolved": "https://registry.npmjs.org/npm-run-all/-/npm-run-all-4.1.5.tgz", @@ -4984,12 +3891,6 @@ "set-blocking": "~2.0.0" } }, - "num2fraction": { - "version": "1.2.2", - "resolved": "https://registry.npmjs.org/num2fraction/-/num2fraction-1.2.2.tgz", - "integrity": "sha1-b2gragJ6Tp3fpFZM0lidHU5mnt4=", - "dev": true - }, "number-is-nan": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", @@ -5043,34 +3944,6 @@ "dev": true, "requires": { "isobject": "^3.0.0" - }, - "dependencies": { - "isobject": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", - "dev": true - } - } - }, - "object.getownpropertydescriptors": { - "version": "2.0.3", - "resolved": "https://registry.npmjs.org/object.getownpropertydescriptors/-/object.getownpropertydescriptors-2.0.3.tgz", - "integrity": "sha1-h1jIRvW0B62rDyNuCYbxSwUcqhY=", - "dev": true, - "requires": { - "define-properties": "^1.1.2", - "es-abstract": "^1.5.1" - } - }, - "object.omit": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/object.omit/-/object.omit-2.0.1.tgz", - "integrity": "sha1-Gpx0SCnznbuFjHbKNXmuKlTr0fo=", - "dev": true, - "requires": { - "for-own": "^0.1.4", - "is-extendable": "^0.1.1" } }, "object.pick": { @@ -5080,14 +3953,6 @@ "dev": true, "requires": { "isobject": "^3.0.1" - }, - "dependencies": { - "isobject": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", - "dev": true - } } }, "once": { @@ -5161,39 +4026,39 @@ "dev": true }, "p-is-promise": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/p-is-promise/-/p-is-promise-1.1.0.tgz", - "integrity": "sha1-nJRWmJ6fZYgBewQ01WCXZ1w9oF4=", + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/p-is-promise/-/p-is-promise-2.1.0.tgz", + "integrity": "sha512-Y3W0wlRPK8ZMRbNq97l4M5otioeA5lm1z7bkNkxCka8HSPjR0xRWmpCmc9utiaLP9Jb1eD8BgeIxTW4AIF45Pg==", "dev": true }, "p-limit": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", - "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.2.0.tgz", + "integrity": "sha512-pZbTJpoUsCzV48Mc9Nh51VbwO0X9cuPFE8gYwx9BTCt9SF8/b7Zljd2fVgOxhIF/HDTKgpVzs+GPhyKfjLLFRQ==", "dev": true, "requires": { - "p-try": "^1.0.0" + "p-try": "^2.0.0" } }, "p-locate": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", - "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", + "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", "dev": true, "requires": { - "p-limit": "^1.1.0" + "p-limit": "^2.0.0" } }, "p-try": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", - "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=", + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", + "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", "dev": true }, "pako": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/pako/-/pako-1.0.6.tgz", - "integrity": "sha512-lQe48YPsMJAig+yngZ87Lus+NF+3mtu7DVOBu6b/gHO1YpKwIj5AWjZ/TOS7i46HD/UixzWb1zeWDZfGZ3iYcg==", + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/pako/-/pako-1.0.10.tgz", + "integrity": "sha512-0DTvPVU3ed8+HNXOu5Bs+o//Mbdj9VNQMUOe9oKCwh8l0GNwpTDMKCWbRjgtD291AWnkAgkqA/LOnQS8AmS1tw==", "dev": true }, "parallel-transform": { @@ -5208,28 +4073,17 @@ } }, "parse-asn1": { - "version": "5.1.1", - "resolved": "http://registry.npmjs.org/parse-asn1/-/parse-asn1-5.1.1.tgz", - "integrity": "sha512-KPx7flKXg775zZpnp9SxJlz00gTd4BmJ2yJufSc44gMCRrRQ7NSzAcSJQfifuOLgW6bEi+ftrALtsgALeB2Adw==", + "version": "5.1.4", + "resolved": "https://registry.npmjs.org/parse-asn1/-/parse-asn1-5.1.4.tgz", + "integrity": "sha512-Qs5duJcuvNExRfFZ99HDD3z4mAi3r9Wl/FOjEOijlxwCZs7E7mW2vjTpgQ4J8LpTF8x5v+1Vn5UQFejmWT11aw==", "dev": true, "requires": { "asn1.js": "^4.0.0", "browserify-aes": "^1.0.0", "create-hash": "^1.1.0", "evp_bytestokey": "^1.0.0", - "pbkdf2": "^3.0.3" - } - }, - "parse-glob": { - "version": "3.0.4", - "resolved": "https://registry.npmjs.org/parse-glob/-/parse-glob-3.0.4.tgz", - "integrity": "sha1-ssN2z7EfNVE7rdFz7wu246OIORw=", - "dev": true, - "requires": { - "glob-base": "^0.3.0", - "is-dotfile": "^1.0.0", - "is-extglob": "^1.0.0", - "is-glob": "^2.0.0" + "pbkdf2": "^3.0.3", + "safe-buffer": "^5.1.1" } }, "parse-json": { @@ -5241,6 +4095,12 @@ "error-ex": "^1.2.0" } }, + "parse-passwd": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/parse-passwd/-/parse-passwd-1.0.0.tgz", + "integrity": "sha1-bVuTSkVpk7I9N/QKOC1vFmao5cY=", + "dev": true + }, "pascalcase": { "version": "0.1.1", "resolved": "https://registry.npmjs.org/pascalcase/-/pascalcase-0.1.1.tgz", @@ -5277,12 +4137,6 @@ "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=", "dev": true }, - "path-parse": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", - "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==", - "dev": true - }, "path-type": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/path-type/-/path-type-1.1.0.tgz", @@ -5349,12 +4203,12 @@ } }, "pkg-dir": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-2.0.0.tgz", - "integrity": "sha1-9tXREJ4Z1j7fQo4L1X4Sd3YVM0s=", + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-3.0.0.tgz", + "integrity": "sha512-/E57AYkoeQ25qkxMj5PBOVgF8Kiu/h7cYS30Z5+R7WaiCCBfLq58ZI/dSeaEKb9WVJV5n/03QwrN3IeWIFllvw==", "dev": true, "requires": { - "find-up": "^2.1.0" + "find-up": "^3.0.0" } }, "posix-character-classes": { @@ -5364,9 +4218,9 @@ "dev": true }, "postcss": { - "version": "7.0.14", - "resolved": "https://registry.npmjs.org/postcss/-/postcss-7.0.14.tgz", - "integrity": "sha512-NsbD6XUUMZvBxtQAJuWDJeeC4QFsmWsfozWxCJPWf3M55K9iu2iMDaKqyoOdTJ1R4usBXuxlVFAIo8rZPQD4Bg==", + "version": "7.0.16", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-7.0.16.tgz", + "integrity": "sha512-MOo8zNSlIqh22Uaa3drkdIAgUGEL+AD1ESiSdmElLUmE2uVDo1QloiT/IfW9qRw8Gw+Y/w69UVMGwbufMSftxA==", "dev": true, "requires": { "chalk": "^2.4.2", @@ -5407,65 +4261,6 @@ } } }, - "postcss-load-config": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/postcss-load-config/-/postcss-load-config-2.0.0.tgz", - "integrity": "sha512-V5JBLzw406BB8UIfsAWSK2KSwIJ5yoEIVFb4gVkXci0QdKgA24jLmHZ/ghe/GgX0lJ0/D1uUK1ejhzEY94MChQ==", - "dev": true, - "requires": { - "cosmiconfig": "^4.0.0", - "import-cwd": "^2.0.0" - } - }, - "postcss-loader": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/postcss-loader/-/postcss-loader-3.0.0.tgz", - "integrity": "sha512-cLWoDEY5OwHcAjDnkyRQzAXfs2jrKjXpO/HQFcc5b5u/r7aa471wdmChmwfnv7x2u840iat/wi0lQ5nbRgSkUA==", - "dev": true, - "requires": { - "loader-utils": "^1.1.0", - "postcss": "^7.0.0", - "postcss-load-config": "^2.0.0", - "schema-utils": "^1.0.0" - }, - "dependencies": { - "ajv": { - "version": "6.8.1", - "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.8.1.tgz", - "integrity": "sha512-eqxCp82P+JfqL683wwsL73XmFs1eG6qjw+RD3YHx+Jll1r0jNd4dh8QG9NYAeNGA/hnZjeEDgtTskgJULbxpWQ==", - "dev": true, - "requires": { - "fast-deep-equal": "^2.0.1", - "fast-json-stable-stringify": "^2.0.0", - "json-schema-traverse": "^0.4.1", - "uri-js": "^4.2.2" - } - }, - "fast-deep-equal": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", - "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", - "dev": true - }, - "json-schema-traverse": { - "version": "0.4.1", - "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", - "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", - "dev": true - }, - "schema-utils": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", - "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", - "dev": true, - "requires": { - "ajv": "^6.1.0", - "ajv-errors": "^1.0.0", - "ajv-keywords": "^3.1.0" - } - } - } - }, "postcss-modules-extract-imports": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/postcss-modules-extract-imports/-/postcss-modules-extract-imports-2.0.0.tgz", @@ -5476,24 +4271,24 @@ } }, "postcss-modules-local-by-default": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/postcss-modules-local-by-default/-/postcss-modules-local-by-default-2.0.4.tgz", - "integrity": "sha512-WvuSaTKXUqYJbnT7R3YrsNrHv/C5vRfr5VglS4bFOk0MYT4CLBfc/xgExA+x2RftlYgiBDvWmVs191Xv8S8gZQ==", + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/postcss-modules-local-by-default/-/postcss-modules-local-by-default-2.0.6.tgz", + "integrity": "sha512-oLUV5YNkeIBa0yQl7EYnxMgy4N6noxmiwZStaEJUSe2xPMcdNc8WmBQuQCx18H5psYbVxz8zoHk0RAAYZXP9gA==", "dev": true, "requires": { - "css-selector-tokenizer": "^0.7.0", "postcss": "^7.0.6", + "postcss-selector-parser": "^6.0.0", "postcss-value-parser": "^3.3.1" } }, "postcss-modules-scope": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/postcss-modules-scope/-/postcss-modules-scope-2.0.1.tgz", - "integrity": "sha512-7+6k9c3/AuZ5c596LJx9n923A/j3nF3ormewYBF1RrIQvjvjXe1xE8V8A1KFyFwXbvnshT6FBZFX0k/F1igneg==", + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/postcss-modules-scope/-/postcss-modules-scope-2.1.0.tgz", + "integrity": "sha512-91Rjps0JnmtUB0cujlc8KIKCsJXWjzuxGeT/+Q2i2HXKZ7nBUeF9YQTZZTNvHVoNYj1AthsjnGLtqDUE0Op79A==", "dev": true, "requires": { - "css-selector-tokenizer": "^0.7.0", - "postcss": "^7.0.6" + "postcss": "^7.0.6", + "postcss-selector-parser": "^6.0.0" } }, "postcss-modules-values": { @@ -5506,22 +4301,27 @@ "postcss": "^7.0.6" } }, + "postcss-selector-parser": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-6.0.2.tgz", + "integrity": "sha512-36P2QR59jDTOAiIkqEprfJDsoNrvwFei3eCqKd1Y0tUsBimsq39BLp7RD+JWny3WgB1zGhJX8XVePwm9k4wdBg==", + "dev": true, + "requires": { + "cssesc": "^3.0.0", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + } + }, "postcss-value-parser": { "version": "3.3.1", "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==", "dev": true }, - "preserve": { - "version": "0.2.0", - "resolved": "https://registry.npmjs.org/preserve/-/preserve-0.2.0.tgz", - "integrity": "sha1-gV7R9uvGWSb4ZbMQwHE7yzMVzks=", - "dev": true - }, - "private": { - "version": "0.1.8", - "resolved": "https://registry.npmjs.org/private/-/private-0.1.8.tgz", - "integrity": "sha512-VvivMrbvd2nKkiG38qjULzlc+4Vx4wm/whI9pQD35YrARNnhxeiRktSOhSukRLFNlzg6Br/cJPet5J/u19r/mg==", + "prepend-http": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-1.0.4.tgz", + "integrity": "sha1-1PRWKwzjaW5BrFLQ4ALlemNdxtw=", "dev": true }, "process": { @@ -5555,9 +4355,9 @@ "dev": true }, "psl": { - "version": "1.1.29", - "resolved": "https://registry.npmjs.org/psl/-/psl-1.1.29.tgz", - "integrity": "sha512-AeUmQ0oLN02flVHXWh9sSJF7mcdFq0ppid/JkErufc3hGIV/AMa8Fo9VgDo/cT2jFdOWoFvHp90qqBH54W+gjQ==", + "version": "1.1.32", + "resolved": "https://registry.npmjs.org/psl/-/psl-1.1.32.tgz", + "integrity": "sha512-MHACAkHpihU/REGGPLj4sEfc/XKW2bheigvHO1dUqjaKigMp1C8+WLQYRGgeKFMsw5PMfegZcaN8IDXK/cD0+g==", "dev": true }, "public-encrypt": { @@ -5583,9 +4383,9 @@ } }, "pump": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/pump/-/pump-2.0.1.tgz", - "integrity": "sha512-ruPMNRkN3MHP1cWJc9OWr+T/xDP0jhXYCLfJcBuX54hhfIBnaQmAUMfDcG4DM5UMWByBbJY69QSphm3jtDKIkA==", + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", + "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", "dev": true, "requires": { "end-of-stream": "^1.1.0", @@ -5601,6 +4401,18 @@ "duplexify": "^3.6.0", "inherits": "^2.0.3", "pump": "^2.0.0" + }, + "dependencies": { + "pump": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/pump/-/pump-2.0.1.tgz", + "integrity": "sha512-ruPMNRkN3MHP1cWJc9OWr+T/xDP0jhXYCLfJcBuX54hhfIBnaQmAUMfDcG4DM5UMWByBbJY69QSphm3jtDKIkA==", + "dev": true, + "requires": { + "end-of-stream": "^1.1.0", + "once": "^1.3.1" + } + } } }, "punycode": { @@ -5615,6 +4427,16 @@ "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==", "dev": true }, + "query-string": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/query-string/-/query-string-4.3.4.tgz", + "integrity": "sha1-u7aTucqRXCMlFbIosaArYJBD2+s=", + "dev": true, + "requires": { + "object-assign": "^4.1.0", + "strict-uri-encode": "^1.0.0" + } + }, "querystring": { "version": "0.2.0", "resolved": "https://registry.npmjs.org/querystring/-/querystring-0.2.0.tgz", @@ -5628,9 +4450,9 @@ "dev": true }, "randombytes": { - "version": "2.0.6", - "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.0.6.tgz", - "integrity": "sha512-CIQ5OFxf4Jou6uOKe9t1AOgqpeU5fd70A8NPdHSGeYXqXsPe6peOwI0cUl88RWZ6sP1vPMV3avd/R6cZ5/sP1A==", + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", + "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", "dev": true, "requires": { "safe-buffer": "^5.1.0" @@ -5704,15 +4526,14 @@ } }, "readdirp": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.1.0.tgz", - "integrity": "sha1-TtCtBg3zBzMAxIRANz9y0cxkLXg=", + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.2.1.tgz", + "integrity": "sha512-1JU/8q+VgFZyxwrJ+SVIOsh+KywWGpds3NTqikiKpDMZWScmAYyKIgqkO+ARvNWJfXeXR1zxz7aHF4u4CyH6vQ==", "dev": true, "requires": { - "graceful-fs": "^4.1.2", - "minimatch": "^3.0.2", - "readable-stream": "^2.0.2", - "set-immediate-shim": "^1.0.1" + "graceful-fs": "^4.1.11", + "micromatch": "^3.1.10", + "readable-stream": "^2.0.2" } }, "redent": { @@ -5725,45 +4546,6 @@ "strip-indent": "^1.0.1" } }, - "regenerate": { - "version": "1.4.0", - "resolved": "https://registry.npmjs.org/regenerate/-/regenerate-1.4.0.tgz", - "integrity": "sha512-1G6jJVDWrt0rK99kBjvEtziZNCICAuvIPkSiUFIQxVP06RCVpq3dmDo2oi6ABpYaDYaTRr67BEhL8r1wgEZZKg==", - "dev": true - }, - "regenerate-unicode-properties": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/regenerate-unicode-properties/-/regenerate-unicode-properties-7.0.0.tgz", - "integrity": "sha512-s5NGghCE4itSlUS+0WUj88G6cfMVMmH8boTPNvABf8od+2dhT9WDlWu8n01raQAJZMOK8Ch6jSexaRO7swd6aw==", - "dev": true, - "requires": { - "regenerate": "^1.4.0" - } - }, - "regenerator-runtime": { - "version": "0.11.1", - "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.11.1.tgz", - "integrity": "sha512-MguG95oij0fC3QV3URf4V2SDYGJhJnJGqvIIgdECeODCT98wSWDAJ94SSuVpYQUoTcGUIL6L4yNB7j1DFFHSBg==", - "dev": true - }, - "regenerator-transform": { - "version": "0.13.3", - "resolved": "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.13.3.tgz", - "integrity": "sha512-5ipTrZFSq5vU2YoGoww4uaRVAK4wyYC4TSICibbfEPOruUu8FFP7ErV0BjmbIOEpn3O/k9na9UEdYR/3m7N6uA==", - "dev": true, - "requires": { - "private": "^0.1.6" - } - }, - "regex-cache": { - "version": "0.4.4", - "resolved": "https://registry.npmjs.org/regex-cache/-/regex-cache-0.4.4.tgz", - "integrity": "sha512-nVIZwtCjkC9YgvWkpM55B5rBhBYRZhAaJbgcFYXXsHnbZ9UZI9nnVWYZpBlCqv9ho2eZryPnWrZGsOdPwVWXWQ==", - "dev": true, - "requires": { - "is-equal-shallow": "^0.1.3" - } - }, "regex-not": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/regex-not/-/regex-not-1.0.2.tgz", @@ -5774,43 +4556,6 @@ "safe-regex": "^1.1.0" } }, - "regexpu-core": { - "version": "4.2.0", - "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-4.2.0.tgz", - "integrity": "sha512-Z835VSnJJ46CNBttalHD/dB+Sj2ezmY6Xp38npwU87peK6mqOzOpV8eYktdkLTEkzzD+JsTcxd84ozd8I14+rw==", - "dev": true, - "requires": { - "regenerate": "^1.4.0", - "regenerate-unicode-properties": "^7.0.0", - "regjsgen": "^0.4.0", - "regjsparser": "^0.3.0", - "unicode-match-property-ecmascript": "^1.0.4", - "unicode-match-property-value-ecmascript": "^1.0.2" - } - }, - "regjsgen": { - "version": "0.4.0", - "resolved": "https://registry.npmjs.org/regjsgen/-/regjsgen-0.4.0.tgz", - "integrity": "sha512-X51Lte1gCYUdlwhF28+2YMO0U6WeN0GLpgpA7LK7mbdDnkQYiwvEpmpe0F/cv5L14EbxgrdayAG3JETBv0dbXA==", - "dev": true - }, - "regjsparser": { - "version": "0.3.0", - "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.3.0.tgz", - "integrity": "sha512-zza72oZBBHzt64G7DxdqrOo/30bhHkwMUoT0WqfGu98XLd7N+1tsy5MJ96Bk4MD0y74n629RhmrGW6XlnLLwCA==", - "dev": true, - "requires": { - "jsesc": "~0.5.0" - }, - "dependencies": { - "jsesc": { - "version": "0.5.0", - "resolved": "http://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz", - "integrity": "sha1-597mbjXW/Bb3EP6R1c9p9w8IkR0=", - "dev": true - } - } - }, "remove-trailing-separator": { "version": "1.1.0", "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz", @@ -5880,27 +4625,12 @@ "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=", "dev": true }, - "require-from-string": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/require-from-string/-/require-from-string-2.0.2.tgz", - "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==", - "dev": true - }, "require-main-filename": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-1.0.1.tgz", "integrity": "sha1-l/cXtp1IeE9fUmpsWqj/3aBVpNE=", "dev": true }, - "resolve": { - "version": "1.8.1", - "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.8.1.tgz", - "integrity": "sha512-AicPrAC7Qu1JxPCZ9ZgCZlY35QgFnNqc+0LtbRNxnVw4TXvjQ72wnuL9JQcEBgXkI9JM8MsT9kaQoHcpCRJOYA==", - "dev": true, - "requires": { - "path-parse": "^1.0.5" - } - }, "resolve-cwd": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-2.0.0.tgz", @@ -5910,6 +4640,16 @@ "resolve-from": "^3.0.0" } }, + "resolve-dir": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/resolve-dir/-/resolve-dir-1.0.1.tgz", + "integrity": "sha1-eaQGRMNivoLybv/nOcm7U4IEb0M=", + "dev": true, + "requires": { + "expand-tilde": "^2.0.0", + "global-modules": "^1.0.0" + } + }, "resolve-from": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-3.0.0.tgz", @@ -6004,26 +4744,14 @@ } }, "schema-utils": { - "version": "0.4.5", - "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-0.4.5.tgz", - "integrity": "sha512-yYrjb9TX2k/J1Y5UNy3KYdZq10xhYcF8nMpAW6o3hy6Q8WSIEf9lJHG/ePnOBfziPM3fvQwfOwa13U/Fh8qTfA==", + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", + "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", "dev": true, "requires": { "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", "ajv-keywords": "^3.1.0" - }, - "dependencies": { - "ajv": { - "version": "6.2.1", - "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.2.1.tgz", - "integrity": "sha1-KKarxJOiq+D7TIUHrK7bQ/pVBnE=", - "dev": true, - "requires": { - "fast-deep-equal": "^1.0.0", - "fast-json-stable-stringify": "^2.0.0", - "json-schema-traverse": "^0.3.0" - } - } } }, "scss-tokenizer": { @@ -6059,9 +4787,9 @@ "dev": true }, "serialize-javascript": { - "version": "1.5.0", - "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-1.5.0.tgz", - "integrity": "sha512-Ga8c8NjAAp46Br4+0oZ2WxJCwIzwP60Gq1YPgU+39PiTVxyed/iKE/zyZI6+UlVYH5Q4PaQdHhcegIFPZTUfoQ==", + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-1.7.0.tgz", + "integrity": "sha512-ke8UG8ulpFOxO8f8gRYabHQe/ZntKlcig2Mp+8+URDP1D8vJZ0KUt7LYo07q25Z/+JVSgpr/cui9PIp5H6/+nA==", "dev": true }, "set-blocking": { @@ -6070,12 +4798,6 @@ "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=", "dev": true }, - "set-immediate-shim": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/set-immediate-shim/-/set-immediate-shim-1.0.1.tgz", - "integrity": "sha1-SysbJ+uAip+NzEgaWOXlb1mfP2E=", - "dev": true - }, "set-value": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/set-value/-/set-value-2.0.0.tgz", @@ -6183,15 +4905,6 @@ "use": "^3.1.0" }, "dependencies": { - "debug": { - "version": "2.6.9", - "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", - "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", - "dev": true, - "requires": { - "ms": "2.0.0" - } - }, "define-property": { "version": "0.2.5", "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", @@ -6267,12 +4980,6 @@ "kind-of": "^6.0.2" } }, - "isobject": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", - "dev": true - }, "kind-of": { "version": "6.0.2", "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", @@ -6290,10 +4997,19 @@ "kind-of": "^3.2.0" } }, + "sort-keys": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/sort-keys/-/sort-keys-1.1.2.tgz", + "integrity": "sha1-RBttTTRnmPG05J6JIK37oOVD+a0=", + "dev": true, + "requires": { + "is-plain-obj": "^1.0.0" + } + }, "sortablejs": { - "version": "1.7.0", - "resolved": "https://registry.npmjs.org/sortablejs/-/sortablejs-1.7.0.tgz", - "integrity": "sha1-gKKyNwq9Vo4c7IwnETHvMKkE+ig=" + "version": "1.9.0", + "resolved": "https://registry.npmjs.org/sortablejs/-/sortablejs-1.9.0.tgz", + "integrity": "sha512-Ot6bYJ6PoqPmpsqQYXjn1+RKrY2NWQvQt/o4jfd/UYwVWndyO5EPO8YHbnm5HIykf8ENsm4JUrdAvolPT86yYA==" }, "source-list-map": { "version": "2.0.0", @@ -6321,9 +5037,9 @@ } }, "source-map-support": { - "version": "0.5.9", - "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.9.tgz", - "integrity": "sha512-gR6Rw4MvUlYy83vP0vxoVNzM6t8MUXqNuRsuBmBHQDu1Fh6X015FrLdgoDKcNdkwGubozq0P4N0Q37UyFVr1EA==", + "version": "0.5.12", + "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.12.tgz", + "integrity": "sha512-4h2Pbvyy15EE02G+JOZpUCmqWJuqrs+sEkzewTm++BPi7Hvn/HwcqLAcNxYAyI0x13CpPPn+kMjl+hplXMHITQ==", "dev": true, "requires": { "buffer-from": "^1.0.0", @@ -6383,9 +5099,9 @@ "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=" }, "sshpk": { - "version": "1.15.2", - "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.15.2.tgz", - "integrity": "sha512-Ra/OXQtuh0/enyl4ETZAfTaeksa6BXks5ZcjpSUNrjBr0DvrJKX+1fsKDPpT9TBXgHAFsa4510aNVgI8g/+SzA==", + "version": "1.16.1", + "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.16.1.tgz", + "integrity": "sha512-HXXqVUq7+pcKeLqqZj6mHFUMvXtOJt1uoUx09pFW6011inTMxqI8BA8PM95myrIyyKwdnzjdFjLiE6KBPVtJIg==", "dev": true, "requires": { "asn1": "~0.2.3", @@ -6439,9 +5155,9 @@ } }, "stream-browserify": { - "version": "2.0.1", - "resolved": "http://registry.npmjs.org/stream-browserify/-/stream-browserify-2.0.1.tgz", - "integrity": "sha1-ZiZu5fm9uZQKTkUUyvtDu3Hlyds=", + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/stream-browserify/-/stream-browserify-2.0.2.tgz", + "integrity": "sha512-nX6hmklHs/gr2FuxYDltq8fJA1GDlxKQCz8O/IM4atRqBH8OORmBNgfvW5gG10GT/qQ9u0CzIvr2X5Pkt6ntqg==", "dev": true, "requires": { "inherits": "~2.0.1", @@ -6509,6 +5225,12 @@ "integrity": "sha1-1cdSgl5TZ+eG944Y5EXqIjoVWVI=", "dev": true }, + "strict-uri-encode": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/strict-uri-encode/-/strict-uri-encode-1.1.0.tgz", + "integrity": "sha1-J5siXfHVgrH1TmWt3UNS4Y+qBxM=", + "dev": true + }, "string-width": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", @@ -6581,43 +5303,6 @@ "requires": { "loader-utils": "^1.1.0", "schema-utils": "^1.0.0" - }, - "dependencies": { - "ajv": { - "version": "6.8.1", - "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.8.1.tgz", - "integrity": "sha512-eqxCp82P+JfqL683wwsL73XmFs1eG6qjw+RD3YHx+Jll1r0jNd4dh8QG9NYAeNGA/hnZjeEDgtTskgJULbxpWQ==", - "dev": true, - "requires": { - "fast-deep-equal": "^2.0.1", - "fast-json-stable-stringify": "^2.0.0", - "json-schema-traverse": "^0.4.1", - "uri-js": "^4.2.2" - } - }, - "fast-deep-equal": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", - "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", - "dev": true - }, - "json-schema-traverse": { - "version": "0.4.1", - "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", - "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", - "dev": true - }, - "schema-utils": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", - "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", - "dev": true, - "requires": { - "ajv": "^6.1.0", - "ajv-errors": "^1.0.0", - "ajv-keywords": "^3.1.0" - } - } } }, "supports-color": { @@ -6630,230 +5315,125 @@ } }, "tapable": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/tapable/-/tapable-1.1.0.tgz", - "integrity": "sha512-IlqtmLVaZA2qab8epUXbVWRn3aB1imbDMJtjB3nu4X0NqPkcY/JH9ZtCBWKHWPxs8Svi9tyo8w2dBoi07qZbBA==", + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/tapable/-/tapable-1.1.3.tgz", + "integrity": "sha512-4WK/bYZmj8xLr+HUCODHGF1ZFzsYffasLUgEiMBY4fgtltdO6B4WJtlSbPaDTLpYTcGVwM2qLnFTICEcNxs3kA==", "dev": true }, "tar": { - "version": "2.2.1", - "resolved": "https://registry.npmjs.org/tar/-/tar-2.2.1.tgz", - "integrity": "sha1-jk0qJWwOIYXGsYrWlK7JaLg8sdE=", + "version": "2.2.2", + "resolved": "https://registry.npmjs.org/tar/-/tar-2.2.2.tgz", + "integrity": "sha512-FCEhQ/4rE1zYv9rYXJw/msRqsnmlje5jHP6huWeBZ704jUTy02c5AZyWujpMR1ax6mVw9NyJMfuK2CMDWVIfgA==", "dev": true, "requires": { "block-stream": "*", - "fstream": "^1.0.2", + "fstream": "^1.0.12", "inherits": "2" } }, "terser": { - "version": "3.10.12", - "resolved": "https://registry.npmjs.org/terser/-/terser-3.10.12.tgz", - "integrity": "sha512-3ODPC1eVt25EVNb04s/PkHxOmzKBQUF6bwwuR6h2DbEF8/j265Y1UkwNtOk9am/pRxfJ5HPapOlUlO6c16mKQQ==", + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/terser/-/terser-4.0.0.tgz", + "integrity": "sha512-dOapGTU0hETFl1tCo4t56FN+2jffoKyER9qBGoUFyZ6y7WLoKT0bF+lAYi6B6YsILcGF3q1C2FBh8QcKSCgkgA==", "dev": true, "requires": { - "commander": "~2.17.1", + "commander": "^2.19.0", "source-map": "~0.6.1", - "source-map-support": "~0.5.6" - }, - "dependencies": { - "commander": { - "version": "2.17.1", - "resolved": "https://registry.npmjs.org/commander/-/commander-2.17.1.tgz", - "integrity": "sha512-wPMUt6FnH2yzG95SA6mzjQOEKUU3aLaDEmzs1ti+1E9h+CsrZghRlqEM/EJ4KscsQVG8uNN4uVreUeT8+drlgg==", - "dev": true - } + "source-map-support": "~0.5.10" } }, "terser-webpack-plugin": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/terser-webpack-plugin/-/terser-webpack-plugin-1.1.0.tgz", - "integrity": "sha512-61lV0DSxMAZ8AyZG7/A4a3UPlrbOBo8NIQ4tJzLPAdGOQ+yoNC7l5ijEow27lBAL2humer01KLS6bGIMYQxKoA==", + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/terser-webpack-plugin/-/terser-webpack-plugin-1.3.0.tgz", + "integrity": "sha512-W2YWmxPjjkUcOWa4pBEv4OP4er1aeQJlSo2UhtCFQCuRXEHjOFscO8VyWHj9JLlA0RzQb8Y2/Ta78XZvT54uGg==", "dev": true, "requires": { - "cacache": "^11.0.2", + "cacache": "^11.3.2", "find-cache-dir": "^2.0.0", + "is-wsl": "^1.1.0", + "loader-utils": "^1.2.3", "schema-utils": "^1.0.0", - "serialize-javascript": "^1.4.0", + "serialize-javascript": "^1.7.0", "source-map": "^0.6.1", - "terser": "^3.8.1", - "webpack-sources": "^1.1.0", - "worker-farm": "^1.5.2" + "terser": "^4.0.0", + "webpack-sources": "^1.3.0", + "worker-farm": "^1.7.0" }, "dependencies": { - "ajv": { - "version": "6.5.5", - "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.5.5.tgz", - "integrity": "sha512-7q7gtRQDJSyuEHjuVgHoUa2VuemFiCMrfQc9Tc08XTAc4Zj/5U1buQJ0HU6i7fKjXU09SVgSmxa4sLvuvS8Iyg==", - "dev": true, - "requires": { - "fast-deep-equal": "^2.0.1", - "fast-json-stable-stringify": "^2.0.0", - "json-schema-traverse": "^0.4.1", - "uri-js": "^4.2.2" - } - }, - "cacache": { - "version": "11.3.1", - "resolved": "https://registry.npmjs.org/cacache/-/cacache-11.3.1.tgz", - "integrity": "sha512-2PEw4cRRDu+iQvBTTuttQifacYjLPhET+SYO/gEFMy8uhi+jlJREDAjSF5FWSdV/Aw5h18caHA7vMTw2c+wDzA==", - "dev": true, - "requires": { - "bluebird": "^3.5.1", - "chownr": "^1.0.1", - "figgy-pudding": "^3.1.0", - "glob": "^7.1.2", - "graceful-fs": "^4.1.11", - "lru-cache": "^4.1.3", - "mississippi": "^3.0.0", - "mkdirp": "^0.5.1", - "move-concurrently": "^1.0.1", - "promise-inflight": "^1.0.1", - "rimraf": "^2.6.2", - "ssri": "^6.0.0", - "unique-filename": "^1.1.0", - "y18n": "^4.0.0" - } - }, - "fast-deep-equal": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", - "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", + "big.js": { + "version": "5.2.2", + "resolved": "https://registry.npmjs.org/big.js/-/big.js-5.2.2.tgz", + "integrity": "sha512-vyL2OymJxmarO8gxMr0mhChsO9QGwhynfuu4+MHTAW6czfq9humCB7rKpUjDd9YUiDPU4mzpyupFSvOClAwbmQ==", "dev": true }, - "find-cache-dir": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-2.0.0.tgz", - "integrity": "sha512-LDUY6V1Xs5eFskUVYtIwatojt6+9xC9Chnlk/jYOOvn3FAFfSaWddxahDGyNHh0b2dMXa6YW2m0tk8TdVaXHlA==", + "json5": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.1.tgz", + "integrity": "sha512-aKS4WQjPenRxiQsC93MNfjx+nbF4PAdYzmd/1JIj8HYzqfbu86beTuNgXDzPknWk0n0uARlyewZo4s++ES36Ow==", "dev": true, "requires": { - "commondir": "^1.0.1", - "make-dir": "^1.0.0", - "pkg-dir": "^3.0.0" + "minimist": "^1.2.0" } }, - "find-up": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", - "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", + "loader-utils": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-1.2.3.tgz", + "integrity": "sha512-fkpz8ejdnEMG3s37wGL07iSBDg99O9D5yflE9RGNH3hRdx9SOwYfnGYdZOUIZitN8E+E2vkq3MUMYMvPYl5ZZA==", "dev": true, "requires": { - "locate-path": "^3.0.0" + "big.js": "^5.2.2", + "emojis-list": "^2.0.0", + "json5": "^1.0.1" } }, - "json-schema-traverse": { - "version": "0.4.1", - "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", - "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", - "dev": true - }, - "locate-path": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", - "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", - "dev": true, - "requires": { - "p-locate": "^3.0.0", - "path-exists": "^3.0.0" - } - }, - "mississippi": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/mississippi/-/mississippi-3.0.0.tgz", - "integrity": "sha512-x471SsVjUtBRtcvd4BzKE9kFC+/2TeWgKCgw0bZcw1b9l2X3QX5vCWgF+KaZaYm87Ss//rHnWryupDrgLvmSkA==", - "dev": true, - "requires": { - "concat-stream": "^1.5.0", - "duplexify": "^3.4.2", - "end-of-stream": "^1.1.0", - "flush-write-stream": "^1.0.0", - "from2": "^2.1.0", - "parallel-transform": "^1.1.0", - "pump": "^3.0.0", - "pumpify": "^1.3.3", - "stream-each": "^1.1.0", - "through2": "^2.0.0" - } - }, - "p-limit": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.0.0.tgz", - "integrity": "sha512-fl5s52lI5ahKCernzzIyAP0QAZbGIovtVHGwpcu1Jr/EpzLVDI2myISHwGqK7m8uQFugVWSrbxH7XnhGtvEc+A==", - "dev": true, - "requires": { - "p-try": "^2.0.0" - } - }, - "p-locate": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", - "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", - "dev": true, - "requires": { - "p-limit": "^2.0.0" - } - }, - "p-try": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.0.0.tgz", - "integrity": "sha512-hMp0onDKIajHfIkdRk3P4CdCmErkYAxxDtP3Wx/4nZ3aGlau2VKh3mZpcuFkH27WQkL/3WBCPOktzA9ZOAnMQQ==", - "dev": true - }, - "pkg-dir": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-3.0.0.tgz", - "integrity": "sha512-/E57AYkoeQ25qkxMj5PBOVgF8Kiu/h7cYS30Z5+R7WaiCCBfLq58ZI/dSeaEKb9WVJV5n/03QwrN3IeWIFllvw==", - "dev": true, - "requires": { - "find-up": "^3.0.0" - } - }, - "pump": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", - "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", - "dev": true, - "requires": { - "end-of-stream": "^1.1.0", - "once": "^1.3.1" - } - }, - "schema-utils": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", - "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", - "dev": true, - "requires": { - "ajv": "^6.1.0", - "ajv-errors": "^1.0.0", - "ajv-keywords": "^3.1.0" - } - }, - "ssri": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/ssri/-/ssri-6.0.1.tgz", - "integrity": "sha512-3Wge10hNcT1Kur4PDFwEieXSCMCJs/7WvSACcrMYrNp+b8kDL1/0wJch5Ni2WrtwEa2IO8OsVfeKIciKCDx/QA==", - "dev": true, - "requires": { - "figgy-pudding": "^3.5.1" - } - }, - "y18n": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.0.tgz", - "integrity": "sha512-r9S/ZyXu/Xu9q1tYlpsLIsa3EeLXXk0VwlxqTcFRfg9EhMW+17kbt9G0NrgCmhGb5vT2hyhJZLfDGx+7+5Uj/w==", + "minimist": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", + "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=", "dev": true } } }, "through2": { - "version": "2.0.3", - "resolved": "https://registry.npmjs.org/through2/-/through2-2.0.3.tgz", - "integrity": "sha1-AARWmzfHx0ujnEPzzteNGtlBQL4=", + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/through2/-/through2-2.0.5.tgz", + "integrity": "sha512-/mrRod8xqpA+IHSLyGCQ2s8SPHiCDEeQJSep1jqLYeEUClOFG2Qsh+4FU6G9VeqpZnGW/Su8LQGc4YKni5rYSQ==", "dev": true, "requires": { - "readable-stream": "^2.1.5", + "readable-stream": "~2.3.6", "xtend": "~4.0.1" + }, + "dependencies": { + "process-nextick-args": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.0.tgz", + "integrity": "sha512-MtEC1TqN0EU5nephaJ4rAtThHtC86dNN9qCuEhtshvpVBkAW5ZO7BASN9REnF9eoXGcRub+pFuKEpOHE+HbEMw==", + "dev": true + }, + "readable-stream": { + "version": "2.3.6", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.6.tgz", + "integrity": "sha512-tQtKA9WIAhBF3+VLAseyMqZeBjW0AHJoxOtYqSUZNJxauErmLbVm2FW1y+J/YA9dUrAC39ITejlZWhVIwawkKw==", + "dev": true, + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "dev": true, + "requires": { + "safe-buffer": "~5.1.0" + } + } } }, "timers-browserify": { @@ -6876,12 +5456,6 @@ "integrity": "sha1-fSKbH8xjfkZsoIEYCDanqr/4P0M=", "dev": true }, - "to-fast-properties": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", - "integrity": "sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4=", - "dev": true - }, "to-object-path": { "version": "0.3.0", "resolved": "https://registry.npmjs.org/to-object-path/-/to-object-path-0.3.0.tgz", @@ -6911,17 +5485,6 @@ "requires": { "is-number": "^3.0.0", "repeat-string": "^1.6.1" - }, - "dependencies": { - "is-number": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", - "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", - "dev": true, - "requires": { - "kind-of": "^3.0.2" - } - } } }, "tough-cookie": { @@ -6940,12 +5503,6 @@ "integrity": "sha1-WIeWa7WCpFA6QetST301ARgVphM=", "dev": true }, - "trim-right": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/trim-right/-/trim-right-1.0.1.tgz", - "integrity": "sha1-yy4SAwZ+DI3h9hQJS5/kVwTqYAM=", - "dev": true - }, "true-case-path": { "version": "1.0.3", "resolved": "https://registry.npmjs.org/true-case-path/-/true-case-path-1.0.3.tgz", @@ -6993,166 +5550,12 @@ "resolved": "https://registry.npmjs.org/uc.micro/-/uc.micro-1.0.5.tgz", "integrity": "sha512-JoLI4g5zv5qNyT09f4YAvEZIIV1oOjqnewYg5D38dkQljIzpPT296dbIGvKro3digYI1bkb7W6EP1y4uDlmzLg==" }, - "uglify-js": { - "version": "3.4.9", - "resolved": "https://registry.npmjs.org/uglify-js/-/uglify-js-3.4.9.tgz", - "integrity": "sha512-8CJsbKOtEbnJsTyv6LE6m6ZKniqMiFWmm9sRbopbkGs3gMPPfd3Fh8iIA4Ykv5MgaTbqHr4BaoGLJLZNhsrW1Q==", - "dev": true, - "requires": { - "commander": "~2.17.1", - "source-map": "~0.6.1" - } - }, - "uglifyjs-webpack-plugin": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/uglifyjs-webpack-plugin/-/uglifyjs-webpack-plugin-2.1.1.tgz", - "integrity": "sha512-TQEcyMNkObX/H+FfcKjiDgs5RcXX8vW2UUUrDTOfQgg3lrafztfeM5WAwXo+AzqozJK6NP9w98xNpG/dutzSsg==", - "dev": true, - "requires": { - "cacache": "^11.2.0", - "find-cache-dir": "^2.0.0", - "schema-utils": "^1.0.0", - "serialize-javascript": "^1.4.0", - "source-map": "^0.6.1", - "uglify-js": "^3.0.0", - "webpack-sources": "^1.1.0", - "worker-farm": "^1.5.2" - }, - "dependencies": { - "ajv": { - "version": "6.8.1", - "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.8.1.tgz", - "integrity": "sha512-eqxCp82P+JfqL683wwsL73XmFs1eG6qjw+RD3YHx+Jll1r0jNd4dh8QG9NYAeNGA/hnZjeEDgtTskgJULbxpWQ==", - "dev": true, - "requires": { - "fast-deep-equal": "^2.0.1", - "fast-json-stable-stringify": "^2.0.0", - "json-schema-traverse": "^0.4.1", - "uri-js": "^4.2.2" - } - }, - "fast-deep-equal": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", - "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", - "dev": true - }, - "find-cache-dir": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-2.0.0.tgz", - "integrity": "sha512-LDUY6V1Xs5eFskUVYtIwatojt6+9xC9Chnlk/jYOOvn3FAFfSaWddxahDGyNHh0b2dMXa6YW2m0tk8TdVaXHlA==", - "dev": true, - "requires": { - "commondir": "^1.0.1", - "make-dir": "^1.0.0", - "pkg-dir": "^3.0.0" - } - }, - "find-up": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", - "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", - "dev": true, - "requires": { - "locate-path": "^3.0.0" - } - }, - "json-schema-traverse": { - "version": "0.4.1", - "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", - "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", - "dev": true - }, - "locate-path": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", - "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", - "dev": true, - "requires": { - "p-locate": "^3.0.0", - "path-exists": "^3.0.0" - } - }, - "p-limit": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.1.0.tgz", - "integrity": "sha512-NhURkNcrVB+8hNfLuysU8enY5xn2KXphsHBaC2YmRNTZRc7RWusw6apSpdEj3jo4CMb6W9nrF6tTnsJsJeyu6g==", - "dev": true, - "requires": { - "p-try": "^2.0.0" - } - }, - "p-locate": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", - "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", - "dev": true, - "requires": { - "p-limit": "^2.0.0" - } - }, - "p-try": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.0.0.tgz", - "integrity": "sha512-hMp0onDKIajHfIkdRk3P4CdCmErkYAxxDtP3Wx/4nZ3aGlau2VKh3mZpcuFkH27WQkL/3WBCPOktzA9ZOAnMQQ==", - "dev": true - }, - "pkg-dir": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-3.0.0.tgz", - "integrity": "sha512-/E57AYkoeQ25qkxMj5PBOVgF8Kiu/h7cYS30Z5+R7WaiCCBfLq58ZI/dSeaEKb9WVJV5n/03QwrN3IeWIFllvw==", - "dev": true, - "requires": { - "find-up": "^3.0.0" - } - }, - "schema-utils": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", - "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", - "dev": true, - "requires": { - "ajv": "^6.1.0", - "ajv-errors": "^1.0.0", - "ajv-keywords": "^3.1.0" - } - } - } - }, "ultron": { "version": "1.0.2", "resolved": "https://registry.npmjs.org/ultron/-/ultron-1.0.2.tgz", "integrity": "sha1-rOEWq1V80Zc4ak6I9GhTeMiy5Po=", "dev": true }, - "unicode-canonical-property-names-ecmascript": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-1.0.4.tgz", - "integrity": "sha512-jDrNnXWHd4oHiTZnx/ZG7gtUTVp+gCcTTKr8L0HjlwphROEW3+Him+IpvC+xcJEFegapiMZyZe02CyuOnRmbnQ==", - "dev": true - }, - "unicode-match-property-ecmascript": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-1.0.4.tgz", - "integrity": "sha512-L4Qoh15vTfntsn4P1zqnHulG0LdXgjSO035fEpdtp6YxXhMT51Q6vgM5lYdG/5X3MjS+k/Y9Xw4SFCY9IkR0rg==", - "dev": true, - "requires": { - "unicode-canonical-property-names-ecmascript": "^1.0.4", - "unicode-property-aliases-ecmascript": "^1.0.4" - } - }, - "unicode-match-property-value-ecmascript": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-1.0.2.tgz", - "integrity": "sha512-Rx7yODZC1L/T8XKo/2kNzVAQaRE88AaMvI1EF/Xnj3GW2wzN6fop9DDWuFAKUVFH7vozkz26DzP0qyWLKLIVPQ==", - "dev": true - }, - "unicode-property-aliases-ecmascript": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-1.0.4.tgz", - "integrity": "sha512-2WSLa6OdYd2ng8oqiGIWnJqyFArvhn+5vgx5GTxMbUYjCYKUcuKS62YLFF0R/BDGlB1yzXjQOLtPAfHsgirEpg==", - "dev": true - }, "union-value": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/union-value/-/union-value-1.0.0.tgz", @@ -7188,6 +5591,12 @@ } } }, + "uniq": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/uniq/-/uniq-1.0.1.tgz", + "integrity": "sha1-sxxa6CVIRKOoKBVBzisEuGWnNP8=", + "dev": true + }, "unique-filename": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/unique-filename/-/unique-filename-1.1.1.tgz", @@ -7243,19 +5652,13 @@ "resolved": "https://registry.npmjs.org/has-values/-/has-values-0.1.4.tgz", "integrity": "sha1-bWHeldkd/Km5oCCJrThL/49it3E=", "dev": true - }, - "isobject": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", - "dev": true } } }, "upath": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/upath/-/upath-1.1.0.tgz", - "integrity": "sha512-bzpH/oBhoS/QI/YtbkqCg6VEiPYjSZtrHQM6/QnJS6OL9pKUFLqb3aFh4Scvwm45+7iAgiMkLhSbaZxUqmrprw==", + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/upath/-/upath-1.1.2.tgz", + "integrity": "sha512-kXpym8nmDmlCBr7nKdIx8P2jNBa+pBpIUFRnKJ4dr8htyYGJFokkr2ZvERRtUN+9SY+JqXouNgUPtv6JQva/2Q==", "dev": true }, "uri-js": { @@ -7306,9 +5709,9 @@ "dev": true }, "util": { - "version": "0.10.4", - "resolved": "https://registry.npmjs.org/util/-/util-0.10.4.tgz", - "integrity": "sha512-0Pm9hTQ3se5ll1XihRic3FDIku70C+iHUdT/W926rSgHV5QgXsYbKZN8MSC3tJtSkhuROzvsQjAaFENRXr+19A==", + "version": "0.11.1", + "resolved": "https://registry.npmjs.org/util/-/util-0.11.1.tgz", + "integrity": "sha512-HShAsny+zS2TZfaXxD9tYj4HQGlBezXZMZuM/S5PKLLoZkShZiGk9o5CzukI1LVHZvjdvZ2Sj1aW/Ndn2NB/HQ==", "dev": true, "requires": { "inherits": "2.0.3" @@ -7320,16 +5723,6 @@ "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=", "dev": true }, - "util.promisify": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/util.promisify/-/util.promisify-1.0.0.tgz", - "integrity": "sha512-i+6qA2MPhvoKLuxnJNpXAGhg7HphQOSUq2LKMZD0m15EiskXUkMvKdF4Uui0WYeCUGea+o2cw/ZuwehtfsrNkA==", - "dev": true, - "requires": { - "define-properties": "^1.1.2", - "object.getownpropertydescriptors": "^2.0.3" - } - }, "uuid": { "version": "3.3.2", "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.3.2.tgz", @@ -7337,9 +5730,9 @@ "dev": true }, "v8-compile-cache": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.0.2.tgz", - "integrity": "sha512-1wFuMUIM16MDJRCrpbpuEPTUGmM5QMUg0cr3KFwra2XgOgFcPGDQHDh3CszSCD2Zewc/dh/pamNEW8CbfDebUw==", + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.0.3.tgz", + "integrity": "sha512-CNmdbwQMBjwr9Gsmohvm0pbL954tJrNzf6gWL3K+QMQf00PF7ERGrEiLgjuU3mKreLC2MeGhUsNV9ybTbLgd3w==", "dev": true }, "validate-npm-package-license": { @@ -7373,16 +5766,16 @@ } }, "vue": { - "version": "2.5.17", - "resolved": "https://registry.npmjs.org/vue/-/vue-2.5.17.tgz", - "integrity": "sha512-mFbcWoDIJi0w0Za4emyLiW72Jae0yjANHbCVquMKijcavBGypqlF7zHRgMa5k4sesdv7hv2rB4JPdZfR+TPfhQ==" + "version": "2.6.10", + "resolved": "https://registry.npmjs.org/vue/-/vue-2.6.10.tgz", + "integrity": "sha512-ImThpeNU9HbdZL3utgMCq0oiMzAkt1mcgy3/E6zWC/G6AaQoeuFdsl9nDhTDU3X1R6FK7nsIUuRACVcjI+A2GQ==" }, "vuedraggable": { - "version": "2.16.0", - "resolved": "https://registry.npmjs.org/vuedraggable/-/vuedraggable-2.16.0.tgz", - "integrity": "sha512-fr9gcWKXMJlzbbtJcrQs4kU7qdOZqd4SEpAcx+r0nykbW8AygZN0aKVpadEtI53T8A2azhzCdXMvEqrLuKE2fA==", + "version": "2.21.0", + "resolved": "https://registry.npmjs.org/vuedraggable/-/vuedraggable-2.21.0.tgz", + "integrity": "sha512-UDp0epjaZikuInoJA9rlEIJaSTQThabq0R9x7TqBdl0qGVFKKzo6glP6ubfzWBmV4iRIfbSOs2DV06s3B5h5tA==", "requires": { - "sortablejs": "^1.7.0" + "sortablejs": "^1.9.0" } }, "watchpack": { @@ -7396,264 +5789,10 @@ "neo-async": "^2.5.0" }, "dependencies": { - "anymatch": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-2.0.0.tgz", - "integrity": "sha512-5teOsQWABXHHBFP9y3skS5P3d/WfWXpv3FUpy+LorMrNYaT9pI4oLMQX7jzQ2KklNpGpWHzdCXTDT2Y3XGlZBw==", - "dev": true, - "requires": { - "micromatch": "^3.1.4", - "normalize-path": "^2.1.1" - } - }, - "arr-diff": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-4.0.0.tgz", - "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=", - "dev": true - }, - "array-unique": { - "version": "0.3.2", - "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.3.2.tgz", - "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=", - "dev": true - }, - "braces": { - "version": "2.3.2", - "resolved": "https://registry.npmjs.org/braces/-/braces-2.3.2.tgz", - "integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==", - "dev": true, - "requires": { - "arr-flatten": "^1.1.0", - "array-unique": "^0.3.2", - "extend-shallow": "^2.0.1", - "fill-range": "^4.0.0", - "isobject": "^3.0.1", - "repeat-element": "^1.1.2", - "snapdragon": "^0.8.1", - "snapdragon-node": "^2.0.1", - "split-string": "^3.0.2", - "to-regex": "^3.0.1" - }, - "dependencies": { - "extend-shallow": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", - "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", - "dev": true, - "requires": { - "is-extendable": "^0.1.0" - } - } - } - }, - "chokidar": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-2.0.4.tgz", - "integrity": "sha512-z9n7yt9rOvIJrMhvDtDictKrkFHeihkNl6uWMmZlmL6tJtX9Cs+87oK+teBx+JIgzvbX3yZHT3eF8vpbDxHJXQ==", - "dev": true, - "requires": { - "anymatch": "^2.0.0", - "async-each": "^1.0.0", - "braces": "^2.3.0", - "fsevents": "^1.2.2", - "glob-parent": "^3.1.0", - "inherits": "^2.0.1", - "is-binary-path": "^1.0.0", - "is-glob": "^4.0.0", - "lodash.debounce": "^4.0.8", - "normalize-path": "^2.1.1", - "path-is-absolute": "^1.0.0", - "readdirp": "^2.0.0", - "upath": "^1.0.5" - } - }, - "debug": { - "version": "2.6.9", - "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", - "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", - "dev": true, - "requires": { - "ms": "2.0.0" - } - }, - "expand-brackets": { - "version": "2.1.4", - "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-2.1.4.tgz", - "integrity": "sha1-t3c14xXOMPa27/D4OwQVGiJEliI=", - "dev": true, - "requires": { - "debug": "^2.3.3", - "define-property": "^0.2.5", - "extend-shallow": "^2.0.1", - "posix-character-classes": "^0.1.0", - "regex-not": "^1.0.0", - "snapdragon": "^0.8.1", - "to-regex": "^3.0.1" - }, - "dependencies": { - "define-property": { - "version": "0.2.5", - "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", - "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", - "dev": true, - "requires": { - "is-descriptor": "^0.1.0" - } - }, - "extend-shallow": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", - "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", - "dev": true, - "requires": { - "is-extendable": "^0.1.0" - } - }, - "is-accessor-descriptor": { - "version": "0.1.6", - "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz", - "integrity": "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=", - "dev": true, - "requires": { - "kind-of": "^3.0.2" - }, - "dependencies": { - "kind-of": { - "version": "3.2.2", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", - "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", - "dev": true, - "requires": { - "is-buffer": "^1.1.5" - } - } - } - }, - "is-data-descriptor": { - "version": "0.1.4", - "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz", - "integrity": "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=", - "dev": true, - "requires": { - "kind-of": "^3.0.2" - }, - "dependencies": { - "kind-of": { - "version": "3.2.2", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", - "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", - "dev": true, - "requires": { - "is-buffer": "^1.1.5" - } - } - } - }, - "is-descriptor": { - "version": "0.1.6", - "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.6.tgz", - "integrity": "sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==", - "dev": true, - "requires": { - "is-accessor-descriptor": "^0.1.6", - "is-data-descriptor": "^0.1.4", - "kind-of": "^5.0.0" - } - }, - "kind-of": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-5.1.0.tgz", - "integrity": "sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw==", - "dev": true - } - } - }, - "extglob": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/extglob/-/extglob-2.0.4.tgz", - "integrity": "sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw==", - "dev": true, - "requires": { - "array-unique": "^0.3.2", - "define-property": "^1.0.0", - "expand-brackets": "^2.1.4", - "extend-shallow": "^2.0.1", - "fragment-cache": "^0.2.1", - "regex-not": "^1.0.0", - "snapdragon": "^0.8.1", - "to-regex": "^3.0.1" - }, - "dependencies": { - "define-property": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", - "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", - "dev": true, - "requires": { - "is-descriptor": "^1.0.0" - } - }, - "extend-shallow": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", - "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", - "dev": true, - "requires": { - "is-extendable": "^0.1.0" - } - } - } - }, - "fill-range": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz", - "integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=", - "dev": true, - "requires": { - "extend-shallow": "^2.0.1", - "is-number": "^3.0.0", - "repeat-string": "^1.6.1", - "to-regex-range": "^2.1.0" - }, - "dependencies": { - "extend-shallow": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", - "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", - "dev": true, - "requires": { - "is-extendable": "^0.1.0" - } - } - } - }, - "glob-parent": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz", - "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=", - "dev": true, - "requires": { - "is-glob": "^3.1.0", - "path-dirname": "^1.0.0" - }, - "dependencies": { - "is-glob": { - "version": "3.1.0", - "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz", - "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=", - "dev": true, - "requires": { - "is-extglob": "^2.1.0" - } - } - } - }, "is-accessor-descriptor": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", - "dev": true, "requires": { "kind-of": "^6.0.0" } @@ -7662,7 +5801,6 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", - "dev": true, "requires": { "kind-of": "^6.0.0" } @@ -7671,95 +5809,31 @@ "version": "1.0.2", "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", - "dev": true, "requires": { "is-accessor-descriptor": "^1.0.0", "is-data-descriptor": "^1.0.0", "kind-of": "^6.0.2" } }, - "is-extglob": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", - "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=", - "dev": true - }, - "is-glob": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.0.tgz", - "integrity": "sha1-lSHHaEXMJhCoUgPd8ICpWML/q8A=", - "dev": true, - "requires": { - "is-extglob": "^2.1.1" - } - }, - "is-number": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", - "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", - "dev": true, - "requires": { - "kind-of": "^3.0.2" - }, - "dependencies": { - "kind-of": { - "version": "3.2.2", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", - "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", - "dev": true, - "requires": { - "is-buffer": "^1.1.5" - } - } - } - }, - "isobject": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", - "dev": true - }, "kind-of": { "version": "6.0.2", "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", - "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", - "dev": true - }, - "micromatch": { - "version": "3.1.10", - "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz", - "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==", - "dev": true, - "requires": { - "arr-diff": "^4.0.0", - "array-unique": "^0.3.2", - "braces": "^2.3.1", - "define-property": "^2.0.2", - "extend-shallow": "^3.0.2", - "extglob": "^2.0.4", - "fragment-cache": "^0.2.1", - "kind-of": "^6.0.2", - "nanomatch": "^1.2.9", - "object.pick": "^1.3.0", - "regex-not": "^1.0.0", - "snapdragon": "^0.8.1", - "to-regex": "^3.0.2" - } + "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==" } } }, "webpack": { - "version": "4.26.1", - "resolved": "https://registry.npmjs.org/webpack/-/webpack-4.26.1.tgz", - "integrity": "sha512-i2oOvEvuvLLSuSCkdVrknaxAhtUZ9g+nLSoHCWV0gDzqGX2DXaCrMmMUpbRsTSSLrUqAI56PoEiyMUZIZ1msug==", + "version": "4.32.2", + "resolved": "https://registry.npmjs.org/webpack/-/webpack-4.32.2.tgz", + "integrity": "sha512-F+H2Aa1TprTQrpodRAWUMJn7A8MgDx82yQiNvYMaj3d1nv3HetKU0oqEulL9huj8enirKi8KvEXQ3QtuHF89Zg==", "dev": true, "requires": { - "@webassemblyjs/ast": "1.7.11", - "@webassemblyjs/helper-module-context": "1.7.11", - "@webassemblyjs/wasm-edit": "1.7.11", - "@webassemblyjs/wasm-parser": "1.7.11", - "acorn": "^5.6.2", - "acorn-dynamic-import": "^3.0.0", + "@webassemblyjs/ast": "1.8.5", + "@webassemblyjs/helper-module-context": "1.8.5", + "@webassemblyjs/wasm-edit": "1.8.5", + "@webassemblyjs/wasm-parser": "1.8.5", + "acorn": "^6.0.5", + "acorn-dynamic-import": "^4.0.0", "ajv": "^6.1.0", "ajv-keywords": "^3.1.0", "chrome-trace-event": "^1.0.0", @@ -7773,237 +5847,17 @@ "mkdirp": "~0.5.0", "neo-async": "^2.5.0", "node-libs-browser": "^2.0.0", - "schema-utils": "^0.4.4", + "schema-utils": "^1.0.0", "tapable": "^1.1.0", "terser-webpack-plugin": "^1.1.0", "watchpack": "^1.5.0", "webpack-sources": "^1.3.0" }, "dependencies": { - "ajv": { - "version": "6.5.5", - "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.5.5.tgz", - "integrity": "sha512-7q7gtRQDJSyuEHjuVgHoUa2VuemFiCMrfQc9Tc08XTAc4Zj/5U1buQJ0HU6i7fKjXU09SVgSmxa4sLvuvS8Iyg==", - "dev": true, - "requires": { - "fast-deep-equal": "^2.0.1", - "fast-json-stable-stringify": "^2.0.0", - "json-schema-traverse": "^0.4.1", - "uri-js": "^4.2.2" - } - }, - "arr-diff": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-4.0.0.tgz", - "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=", - "dev": true - }, - "array-unique": { - "version": "0.3.2", - "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.3.2.tgz", - "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=", - "dev": true - }, - "braces": { - "version": "2.3.2", - "resolved": "https://registry.npmjs.org/braces/-/braces-2.3.2.tgz", - "integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==", - "dev": true, - "requires": { - "arr-flatten": "^1.1.0", - "array-unique": "^0.3.2", - "extend-shallow": "^2.0.1", - "fill-range": "^4.0.0", - "isobject": "^3.0.1", - "repeat-element": "^1.1.2", - "snapdragon": "^0.8.1", - "snapdragon-node": "^2.0.1", - "split-string": "^3.0.2", - "to-regex": "^3.0.1" - }, - "dependencies": { - "extend-shallow": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", - "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", - "dev": true, - "requires": { - "is-extendable": "^0.1.0" - } - } - } - }, - "debug": { - "version": "2.6.9", - "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", - "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", - "dev": true, - "requires": { - "ms": "2.0.0" - } - }, - "expand-brackets": { - "version": "2.1.4", - "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-2.1.4.tgz", - "integrity": "sha1-t3c14xXOMPa27/D4OwQVGiJEliI=", - "dev": true, - "requires": { - "debug": "^2.3.3", - "define-property": "^0.2.5", - "extend-shallow": "^2.0.1", - "posix-character-classes": "^0.1.0", - "regex-not": "^1.0.0", - "snapdragon": "^0.8.1", - "to-regex": "^3.0.1" - }, - "dependencies": { - "define-property": { - "version": "0.2.5", - "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", - "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", - "dev": true, - "requires": { - "is-descriptor": "^0.1.0" - } - }, - "extend-shallow": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", - "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", - "dev": true, - "requires": { - "is-extendable": "^0.1.0" - } - }, - "is-accessor-descriptor": { - "version": "0.1.6", - "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz", - "integrity": "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=", - "dev": true, - "requires": { - "kind-of": "^3.0.2" - }, - "dependencies": { - "kind-of": { - "version": "3.2.2", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", - "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", - "dev": true, - "requires": { - "is-buffer": "^1.1.5" - } - } - } - }, - "is-data-descriptor": { - "version": "0.1.4", - "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz", - "integrity": "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=", - "dev": true, - "requires": { - "kind-of": "^3.0.2" - }, - "dependencies": { - "kind-of": { - "version": "3.2.2", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", - "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", - "dev": true, - "requires": { - "is-buffer": "^1.1.5" - } - } - } - }, - "is-descriptor": { - "version": "0.1.6", - "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.6.tgz", - "integrity": "sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==", - "dev": true, - "requires": { - "is-accessor-descriptor": "^0.1.6", - "is-data-descriptor": "^0.1.4", - "kind-of": "^5.0.0" - } - }, - "kind-of": { - "version": "5.1.0", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-5.1.0.tgz", - "integrity": "sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw==", - "dev": true - } - } - }, - "extglob": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/extglob/-/extglob-2.0.4.tgz", - "integrity": "sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw==", - "dev": true, - "requires": { - "array-unique": "^0.3.2", - "define-property": "^1.0.0", - "expand-brackets": "^2.1.4", - "extend-shallow": "^2.0.1", - "fragment-cache": "^0.2.1", - "regex-not": "^1.0.0", - "snapdragon": "^0.8.1", - "to-regex": "^3.0.1" - }, - "dependencies": { - "define-property": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", - "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", - "dev": true, - "requires": { - "is-descriptor": "^1.0.0" - } - }, - "extend-shallow": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", - "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", - "dev": true, - "requires": { - "is-extendable": "^0.1.0" - } - } - } - }, - "fast-deep-equal": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-2.0.1.tgz", - "integrity": "sha1-ewUhjd+WZ79/Nwv3/bLLFf3Qqkk=", - "dev": true - }, - "fill-range": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz", - "integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=", - "dev": true, - "requires": { - "extend-shallow": "^2.0.1", - "is-number": "^3.0.0", - "repeat-string": "^1.6.1", - "to-regex-range": "^2.1.0" - }, - "dependencies": { - "extend-shallow": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", - "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", - "dev": true, - "requires": { - "is-extendable": "^0.1.0" - } - } - } - }, "is-accessor-descriptor": { "version": "1.0.0", "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", - "dev": true, "requires": { "kind-of": "^6.0.0" } @@ -8012,7 +5866,6 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", - "dev": true, "requires": { "kind-of": "^6.0.0" } @@ -8021,100 +5874,36 @@ "version": "1.0.2", "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", - "dev": true, "requires": { "is-accessor-descriptor": "^1.0.0", "is-data-descriptor": "^1.0.0", "kind-of": "^6.0.2" } }, - "is-number": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", - "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", - "dev": true, - "requires": { - "kind-of": "^3.0.2" - }, - "dependencies": { - "kind-of": { - "version": "3.2.2", - "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", - "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", - "dev": true, - "requires": { - "is-buffer": "^1.1.5" - } - } - } - }, - "isobject": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", - "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=", - "dev": true - }, - "json-schema-traverse": { - "version": "0.4.1", - "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", - "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==", - "dev": true - }, "kind-of": { "version": "6.0.2", "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.2.tgz", - "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==", - "dev": true - }, - "micromatch": { - "version": "3.1.10", - "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz", - "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==", - "dev": true, - "requires": { - "arr-diff": "^4.0.0", - "array-unique": "^0.3.2", - "braces": "^2.3.1", - "define-property": "^2.0.2", - "extend-shallow": "^3.0.2", - "extglob": "^2.0.4", - "fragment-cache": "^0.2.1", - "kind-of": "^6.0.2", - "nanomatch": "^1.2.9", - "object.pick": "^1.3.0", - "regex-not": "^1.0.0", - "snapdragon": "^0.8.1", - "to-regex": "^3.0.2" - } - }, - "webpack-sources": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/webpack-sources/-/webpack-sources-1.3.0.tgz", - "integrity": "sha512-OiVgSrbGu7NEnEvQJJgdSFPl2qWKkWq5lHMhgiToIiN9w34EBnjYzSYs+VbL5KoYiLNtFFa7BZIKxRED3I32pA==", - "dev": true, - "requires": { - "source-list-map": "^2.0.0", - "source-map": "~0.6.1" - } + "integrity": "sha512-s5kLOcnH0XqDO+FvuaLX8DDjZ18CGFk7VygH40QoKPUQhW4e2rvM0rwUq0t8IQDOwYSeLK01U90OjzBTme2QqA==" } } }, "webpack-cli": { - "version": "3.1.2", - "resolved": "https://registry.npmjs.org/webpack-cli/-/webpack-cli-3.1.2.tgz", - "integrity": "sha512-Cnqo7CeqeSvC6PTdts+dywNi5CRlIPbLx1AoUPK2T6vC1YAugMG3IOoO9DmEscd+Dghw7uRlnzV1KwOe5IrtgQ==", + "version": "3.3.2", + "resolved": "https://registry.npmjs.org/webpack-cli/-/webpack-cli-3.3.2.tgz", + "integrity": "sha512-FLkobnaJJ+03j5eplxlI0TUxhGCOdfewspIGuvDVtpOlrAuKMFC57K42Ukxqs1tn8947/PM6tP95gQc0DCzRYA==", "dev": true, "requires": { "chalk": "^2.4.1", "cross-spawn": "^6.0.5", "enhanced-resolve": "^4.1.0", - "global-modules-path": "^2.3.0", + "findup-sync": "^2.0.0", + "global-modules": "^1.0.0", "import-local": "^2.0.0", "interpret": "^1.1.0", "loader-utils": "^1.1.0", "supports-color": "^5.5.0", "v8-compile-cache": "^2.0.2", - "yargs": "^12.0.2" + "yargs": "^12.0.5" }, "dependencies": { "ansi-regex": { @@ -8123,12 +5912,6 @@ "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", "dev": true }, - "camelcase": { - "version": "4.1.0", - "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-4.1.0.tgz", - "integrity": "sha1-1UVjW+HjPFQmScaRc+Xeas+uNN0=", - "dev": true - }, "cliui": { "version": "4.1.0", "resolved": "https://registry.npmjs.org/cliui/-/cliui-4.1.0.tgz", @@ -8153,24 +5936,6 @@ "which": "^1.2.9" } }, - "decamelize": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-2.0.0.tgz", - "integrity": "sha512-Ikpp5scV3MSYxY39ymh45ZLEecsTdv/Xj2CaQfI8RLMuwi7XvjX9H/fhraiSuU+C5w5NTDu4ZU72xNiZnurBPg==", - "dev": true, - "requires": { - "xregexp": "4.0.0" - } - }, - "find-up": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", - "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", - "dev": true, - "requires": { - "locate-path": "^3.0.0" - } - }, "invert-kv": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/invert-kv/-/invert-kv-2.0.0.tgz", @@ -8192,51 +5957,17 @@ "invert-kv": "^2.0.0" } }, - "locate-path": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", - "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", - "dev": true, - "requires": { - "p-locate": "^3.0.0", - "path-exists": "^3.0.0" - } - }, "os-locale": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/os-locale/-/os-locale-3.0.1.tgz", - "integrity": "sha512-7g5e7dmXPtzcP4bgsZ8ixDVqA7oWYuEz4lOSujeWyliPai4gfVDiFIcwBg3aGCPnmSGfzOKTK3ccPn0CKv3DBw==", + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/os-locale/-/os-locale-3.1.0.tgz", + "integrity": "sha512-Z8l3R4wYWM40/52Z+S265okfFj8Kt2cC2MKY+xNi3kFs+XGI7WXu/I309QQQYbRW4ijiZ+yxs9pqEhJh0DqW3Q==", "dev": true, "requires": { - "execa": "^0.10.0", + "execa": "^1.0.0", "lcid": "^2.0.0", "mem": "^4.0.0" } }, - "p-limit": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.0.0.tgz", - "integrity": "sha512-fl5s52lI5ahKCernzzIyAP0QAZbGIovtVHGwpcu1Jr/EpzLVDI2myISHwGqK7m8uQFugVWSrbxH7XnhGtvEc+A==", - "dev": true, - "requires": { - "p-try": "^2.0.0" - } - }, - "p-locate": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", - "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", - "dev": true, - "requires": { - "p-limit": "^2.0.0" - } - }, - "p-try": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.0.0.tgz", - "integrity": "sha512-hMp0onDKIajHfIkdRk3P4CdCmErkYAxxDtP3Wx/4nZ3aGlau2VKh3mZpcuFkH27WQkL/3WBCPOktzA9ZOAnMQQ==", - "dev": true - }, "string-width": { "version": "2.1.1", "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", @@ -8263,13 +5994,13 @@ "dev": true }, "yargs": { - "version": "12.0.2", - "resolved": "https://registry.npmjs.org/yargs/-/yargs-12.0.2.tgz", - "integrity": "sha512-e7SkEx6N6SIZ5c5H22RTZae61qtn3PYUE8JYbBFlK9sYmh3DMQ6E5ygtaG/2BW0JZi4WGgTR2IV5ChqlqrDGVQ==", + "version": "12.0.5", + "resolved": "https://registry.npmjs.org/yargs/-/yargs-12.0.5.tgz", + "integrity": "sha512-Lhz8TLaYnxq/2ObqHDql8dX8CJi97oHxrjUcYtzKbbykPtVW9WB+poxI+NM2UIzsMgNCZTIf0AQwsjK5yMAqZw==", "dev": true, "requires": { "cliui": "^4.0.0", - "decamelize": "^2.0.0", + "decamelize": "^1.2.0", "find-up": "^3.0.0", "get-caller-file": "^1.0.1", "os-locale": "^3.0.0", @@ -8279,24 +6010,25 @@ "string-width": "^2.0.0", "which-module": "^2.0.0", "y18n": "^3.2.1 || ^4.0.0", - "yargs-parser": "^10.1.0" + "yargs-parser": "^11.1.1" } }, "yargs-parser": { - "version": "10.1.0", - "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-10.1.0.tgz", - "integrity": "sha512-VCIyR1wJoEBZUqk5PA+oOBF6ypbwh5aNB3I50guxAL/quggdfs4TtNHQrSazFA3fYZ+tEqfs0zIGlv0c/rgjbQ==", + "version": "11.1.1", + "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-11.1.1.tgz", + "integrity": "sha512-C6kB/WJDiaxONLJQnF8ccx9SEeoTTLek8RVbaOIsrAUS8VrBEXfmeSnCZxygc+XC2sNMBIwOOnfcxiynjHsVSQ==", "dev": true, "requires": { - "camelcase": "^4.1.0" + "camelcase": "^5.0.0", + "decamelize": "^1.2.0" } } } }, "webpack-sources": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/webpack-sources/-/webpack-sources-1.1.0.tgz", - "integrity": "sha512-aqYp18kPphgoO5c/+NaUvEeACtZjMESmDChuD3NBciVpah3XpMEU9VAAtIaB1BsfJWWTSdv8Vv1m3T0aRk2dUw==", + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/webpack-sources/-/webpack-sources-1.3.0.tgz", + "integrity": "sha512-OiVgSrbGu7NEnEvQJJgdSFPl2qWKkWq5lHMhgiToIiN9w34EBnjYzSYs+VbL5KoYiLNtFFa7BZIKxRED3I32pA==", "dev": true, "requires": { "source-list-map": "^2.0.0", @@ -8328,9 +6060,9 @@ } }, "worker-farm": { - "version": "1.6.0", - "resolved": "https://registry.npmjs.org/worker-farm/-/worker-farm-1.6.0.tgz", - "integrity": "sha512-6w+3tHbM87WnSWnENBUvA2pxJPLhQUg5LKwUQHq3r+XPhIM+Gh2R5ycbwPCyuGbNg+lPgdcnQUhuC02kJCvffQ==", + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/worker-farm/-/worker-farm-1.7.0.tgz", + "integrity": "sha512-rvw3QTZc8lAxyVrqcSGVm5yP/IJ2UcB3U0graE3LCFoZ0Yn2x4EoVSqJKdB/T5M+FLcRPjz4TDacRf3OCfNUzw==", "dev": true, "requires": { "errno": "~0.1.7" @@ -8362,12 +6094,6 @@ "ultron": "1.0.x" } }, - "xregexp": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/xregexp/-/xregexp-4.0.0.tgz", - "integrity": "sha512-PHyM+sQouu7xspQQwELlGwwd05mXUFqwFYfqPO0cC7x4fxyHnnuetmQr6CjJiafIDoH4MogHb9dOoJzR/Y4rFg==", - "dev": true - }, "xtend": { "version": "4.0.1", "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.1.tgz", diff --git a/package.json b/package.json index 1cbfdb3e9..0d1afbb0c 100644 --- a/package.json +++ b/package.json @@ -10,34 +10,25 @@ "permissions": "chown -R $USER:$USER bootstrap/cache storage public/uploads" }, "devDependencies": { - "@babel/core": "^7.1.6", - "@babel/polyfill": "^7.0.0", - "@babel/preset-env": "^7.1.6", - "autoprefixer": "^9.4.7", - "babel-loader": "^8.0.4", - "css-loader": "^2.1.0", - "livereload": "^0.7.0", - "mini-css-extract-plugin": "^0.5.0", - "node-sass": "^4.10.0", + "css-loader": "^2.1.1", + "livereload": "^0.8.0", + "mini-css-extract-plugin": "^0.7.0", + "node-sass": "^4.12.0", "npm-run-all": "^4.1.5", - "postcss-loader": "^3.0.0", "sass-loader": "^7.1.0", "style-loader": "^0.23.1", - "uglifyjs-webpack-plugin": "^2.1.1", - "webpack": "^4.26.1", - "webpack-cli": "^3.1.2" + "webpack": "^4.32.2", + "webpack-cli": "^3.3.2" }, "dependencies": { - "axios": "^0.18.0", "clipboard": "^2.0.4", - "codemirror": "^5.42.0", + "codemirror": "^5.47.0", "dropzone": "^5.5.1", - "jquery": "^3.3.1", - "jquery-sortable": "^0.9.13", "markdown-it": "^8.4.2", "markdown-it-task-lists": "^2.1.1", - "vue": "^2.5.17", - "vuedraggable": "^2.16.0" + "sortablejs": "^1.9.0", + "vue": "^2.6.10", + "vuedraggable": "^2.21.0" }, "browser": { "vue": "vue/dist/vue.common.js" diff --git a/phpunit.xml b/phpunit.xml index 804afcf5d..53722a71b 100644 --- a/phpunit.xml +++ b/phpunit.xml @@ -34,6 +34,8 @@ + + diff --git a/public/index.php b/public/index.php index ad378d7e0..820576472 100644 --- a/public/index.php +++ b/public/index.php @@ -34,6 +34,7 @@ require __DIR__.'/../bootstrap/init.php'; */ $app = require_once __DIR__.'/../bootstrap/app.php'; +$app->alias('request', \BookStack\Http\Request::class); /* |-------------------------------------------------------------------------- @@ -50,7 +51,7 @@ $app = require_once __DIR__.'/../bootstrap/app.php'; $kernel = $app->make(Illuminate\Contracts\Http\Kernel::class); $response = $kernel->handle( - $request = Illuminate\Http\Request::capture() + $request = \BookStack\Http\Request::capture() ); $response->send(); diff --git a/public/libs/jq-color-picker/tiny-color-picker.min.js b/public/libs/jq-color-picker/tiny-color-picker.min.js deleted file mode 100644 index 84024073f..000000000 --- a/public/libs/jq-color-picker/tiny-color-picker.min.js +++ /dev/null @@ -1,4 +0,0 @@ -/*! tinyColorPicker - v1.0.0 2016-02-28 */ -// https://github.com/PitPik/tinyColorPicker -// http://www.dematte.at/tinyColorPicker/index.html?type=small#demo -!function(a,b){"object"==typeof exports?module.exports=b(a):"function"==typeof define&&define.amd?define([],function(){return b(a)}):a.Colors=b(a)}(this,function(a,b){"use strict";function c(a,c,d,f,g){if("string"==typeof c){var c=t.txt2color(c);d=c.type,n[d]=c[d],g=g!==b?g:c.alpha}else if(c)for(var h in c)a[d][h]=k(c[h]/l[d][h][1],0,1);return g!==b&&(a.alpha=k(+g,0,1)),e(d,f?a:b)}function d(a,b,c){var d=m.options.grey,e={};return e.RGB={r:a.r,g:a.g,b:a.b},e.rgb={r:b.r,g:b.g,b:b.b},e.alpha=c,e.equivalentGrey=Math.round(d.r*a.r+d.g*a.g+d.b*a.b),e.rgbaMixBlack=i(b,{r:0,g:0,b:0},c,1),e.rgbaMixWhite=i(b,{r:1,g:1,b:1},c,1),e.rgbaMixBlack.luminance=h(e.rgbaMixBlack,!0),e.rgbaMixWhite.luminance=h(e.rgbaMixWhite,!0),m.options.customBG&&(e.rgbaMixCustom=i(b,m.options.customBG,c,1),e.rgbaMixCustom.luminance=h(e.rgbaMixCustom,!0),m.options.customBG.luminance=h(m.options.customBG,!0)),e}function e(a,b){var c,e,k,o=b||n,p=t,q=m.options,r=l,s=o.RND,u="",v="",w={hsl:"hsv",rgb:a},x=s.rgb;if("alpha"!==a){for(var y in r)if(!r[y][y]){a!==y&&(v=w[y]||"rgb",o[y]=p[v+"2"+y](o[v])),s[y]||(s[y]={}),c=o[y];for(u in c)s[y][u]=Math.round(c[u]*r[y][u][1])}x=s.rgb,o.HEX=p.RGB2HEX(x),o.equivalentGrey=q.grey.r*o.rgb.r+q.grey.g*o.rgb.g+q.grey.b*o.rgb.b,o.webSave=e=f(x,51),o.webSmart=k=f(x,17),o.saveColor=x.r===e.r&&x.g===e.g&&x.b===e.b?"web save":x.r===k.r&&x.g===k.g&&x.b===k.b?"web smart":"",o.hueRGB=t.hue2RGB(o.hsv.h),b&&(o.background=d(x,o.rgb,o.alpha))}var z,A,B,C=o.rgb,D=o.alpha,E="luminance",F=o.background;return z=i(C,{r:0,g:0,b:0},D,1),z[E]=h(z,!0),o.rgbaMixBlack=z,A=i(C,{r:1,g:1,b:1},D,1),A[E]=h(A,!0),o.rgbaMixWhite=A,q.customBG&&(B=i(C,F.rgbaMixCustom,D,1),B[E]=h(B,!0),B.WCAG2Ratio=j(B[E],F.rgbaMixCustom[E]),o.rgbaMixBGMixCustom=B,B.luminanceDelta=Math.abs(B[E]-F.rgbaMixCustom[E]),B.hueDelta=g(F.rgbaMixCustom,B,!0)),o.RGBLuminance=h(x),o.HUELuminance=h(o.hueRGB),q.convertCallback&&q.convertCallback(o,a),o}function f(a,b){var c={},d=0,e=b/2;for(var f in a)d=a[f]%b,c[f]=a[f]+(d>e?b-d:-d);return c}function g(a,b,c){return(Math.max(a.r-b.r,b.r-a.r)+Math.max(a.g-b.g,b.g-a.g)+Math.max(a.b-b.b,b.b-a.b))*(c?255:1)/765}function h(a,b){for(var c=b?1:255,d=[a.r/c,a.g/c,a.b/c],e=m.options.luminance,f=d.length;f--;)d[f]=d[f]<=.03928?d[f]/12.92:Math.pow((d[f]+.055)/1.055,2.4);return e.r*d[0]+e.g*d[1]+e.b*d[2]}function i(a,c,d,e){var f={},g=d!==b?d:1,h=e!==b?e:1,i=g+h*(1-g);for(var j in a)f[j]=(a[j]*g+c[j]*h*(1-g))/i;return f.a=i,f}function j(a,b){var c=1;return c=a>=b?(a+.05)/(b+.05):(b+.05)/(a+.05),Math.round(100*c)/100}function k(a,b,c){return a>c?c:b>a?b:a}var l={rgb:{r:[0,255],g:[0,255],b:[0,255]},hsv:{h:[0,360],s:[0,100],v:[0,100]},hsl:{h:[0,360],s:[0,100],l:[0,100]},alpha:{alpha:[0,1]},HEX:{HEX:[0,16777215]}},m={},n={},o={r:.298954,g:.586434,b:.114612},p={r:.2126,g:.7152,b:.0722},q=function(a){this.colors={RND:{}},this.options={color:"rgba(204, 82, 37, 0.8)",grey:o,luminance:p,valueRanges:l},r(this,a||{})},r=function(a,d){var e,f=a.options;s(a);for(var g in d)d[g]!==b&&(f[g]=d[g]);e=f.customBG,f.customBG="string"==typeof e?t.txt2color(e).rgb:e,n=c(a.colors,f.color,b,!0)},s=function(a){m!==a&&(m=a,n=a.colors)};q.prototype.setColor=function(a,d,f){return s(this),a?c(this.colors,a,d,b,f):(f!==b&&(this.colors.alpha=k(f,0,1)),e(d))},q.prototype.setCustomBackground=function(a){return s(this),this.options.customBG="string"==typeof a?t.txt2color(a).rgb:a,c(this.colors,b,"rgb")},q.prototype.saveAsBackground=function(){return s(this),c(this.colors,b,"rgb",!0)};var t={txt2color:function(a){var b={},c=a.replace(/(?:#|\)|%)/g,"").split("("),d=(c[1]||"").split(/,\s*/),e=c[1]?c[0].substr(0,3):"rgb",f="";if(b.type=e,b[e]={},c[1])for(var g=3;g--;)f=e[g]||e.charAt(g),b[e][f]=+d[g]/l[e][f][1];else b.rgb=t.HEX2rgb(c[0]);return b.alpha=d[3]?+d[3]:1,b},RGB2HEX:function(a){return((a.r<16?"0":"")+a.r.toString(16)+(a.g<16?"0":"")+a.g.toString(16)+(a.b<16?"0":"")+a.b.toString(16)).toUpperCase()},HEX2rgb:function(a){return a=a.split(""),{r:parseInt(a[0]+a[a[3]?1:0],16)/255,g:parseInt(a[a[3]?2:1]+(a[3]||a[1]),16)/255,b:parseInt((a[4]||a[2])+(a[5]||a[2]),16)/255}},hue2RGB:function(a){var b=6*a,c=~~b%6,d=6===b?0:b-c;return{r:Math.round(255*[1,1-d,0,0,d,1][c]),g:Math.round(255*[d,1,1,1-d,0,0][c]),b:Math.round(255*[0,0,d,1,1,1-d][c])}},rgb2hsv:function(a){var b,c,d,e=a.r,f=a.g,g=a.b,h=0;return g>f&&(f=g+(g=f,0),h=-1),c=g,f>e&&(e=f+(f=e,0),h=-2/6-h,c=Math.min(f,g)),b=e-c,d=e?b/e:0,{h:1e-15>d?n&&n.hsl&&n.hsl.h||0:b?Math.abs(h+(f-g)/(6*b)):0,s:e?b/e:n&&n.hsv&&n.hsv.s||0,v:e}},hsv2rgb:function(a){var b=6*a.h,c=a.s,d=a.v,e=~~b,f=b-e,g=d*(1-c),h=d*(1-f*c),i=d*(1-(1-f)*c),j=e%6;return{r:[d,h,g,g,i,d][j],g:[i,d,d,h,g,g][j],b:[g,g,i,d,d,h][j]}},hsv2hsl:function(a){var b=(2-a.s)*a.v,c=a.s*a.v;return c=a.s?1>b?b?c/b:0:c/(2-b):0,{h:a.h,s:a.v||c?c:n&&n.hsl&&n.hsl.s||0,l:b/2}},rgb2hsl:function(a,b){var c=t.rgb2hsv(a);return t.hsv2hsl(b?c:n.hsv=c)},hsl2rgb:function(a){var b=6*a.h,c=a.s,d=a.l,e=.5>d?d*(1+c):d+c-c*d,f=d+d-e,g=e?(e-f)/e:0,h=~~b,i=b-h,j=e*g*i,k=f+j,l=e-j,m=h%6;return{r:[e,l,f,f,k,e][m],g:[k,e,e,l,f,f][m],b:[f,f,k,e,e,l][m]}}};return q}),function(a,b){"object"==typeof exports?module.exports=b(a,require("jquery"),require("colors")):"function"==typeof define&&define.amd?define(["jquery","colors"],function(c,d){return b(a,c,d)}):b(a,a.jQuery,a.Colors)}(this,function(a,b,c,d){"use strict";function e(a){return a.value||a.getAttribute("value")||b(a).css("background-color")||"#fff"}function f(a){return a=a.originalEvent&&a.originalEvent.touches?a.originalEvent.touches[0]:a,a.originalEvent?a.originalEvent:a}function g(a){return b(a.find(r.doRender)[0]||a[0])}function h(c){var d=b(this),f=d.offset(),h=b(a),j=r.gap;c?(s=g(d),s._colorMode=s.data("colorMode"),p.$trigger=d,(t||i()).css({left:(t[0]._left=f.left)-((t[0]._left=t[0]._left+t[0]._width-(h.scrollLeft()+h.width()))+j>0?t[0]._left+j:0),top:(t[0]._top=f.top+d.outerHeight())-((t[0]._top=t[0]._top+t[0]._height-(h.scrollTop()+h.height()))+j>0?t[0]._top+j:0)}).show(r.animationSpeed,function(){c!==!0&&(x._width=x.width(),u._width=u.width(),u._height=u.height(),q.setColor(e(s[0])),n(!0))})):b(t).hide(r.animationSpeed,function(){n(!1),p.$trigger=null})}function i(){return b("head").append('"),p.$UI=t=b(H).css({margin:r.margin}).appendTo("body").show(0,function(){var a=b(this);E=r.GPU&&a.css("perspective")!==d,u=b(".cp-xy-slider",this),v=b(".cp-xy-cursor",this),w=b(".cp-z-cursor",this),x=b(".cp-alpha",this).toggle(!!r.opacity),y=b(".cp-alpha-cursor",this),r.buildCallback.call(p,a),a.prepend("
").children().eq(0).css("width",a.children().eq(0).width()),this._width=this.offsetWidth,this._height=this.offsetHeight}).hide().on(C,".cp-xy-slider,.cp-z-slider,.cp-alpha",j)}function j(a){var c=this.className.replace(/cp-(.*?)(?:\s*|$)/,"$1").replace("-","_");(a.button||a.which)>1||(a.preventDefault&&a.preventDefault(),a.returnValue=!1,s._offset=b(this).offset(),(c="xy_slider"===c?k:"z_slider"===c?l:m)(a),n(),z.on(D,function(){z.off(".a")}).on(B,function(a){c(a),n()}))}function k(a){var b=f(a),c=b.pageX-s._offset.left,d=b.pageY-s._offset.top;q.setColor({s:c/u._width*100,v:100-d/u._height*100},"hsv")}function l(a){var b=f(a).pageY-s._offset.top;q.setColor({h:360-b/u._height*360},"hsv")}function m(a){var b=f(a).pageX-s._offset.left,c=b/x._width;q.setColor({},"rgb",c)}function n(a){var b=q.colors,c=b.hueRGB,e=b.RND.rgb,f=b.RND.hsl,g="#222",h="#ddd",i=s._colorMode,j=1!==b.alpha,k=F(100*b.alpha)/100,l=e.r+", "+e.g+", "+e.b,m="HEX"!==i||j?"rgb"===i||"HEX"===i&&j?j?"rgba("+l+", "+k+")":"rgb("+l+")":"hsl"+(j?"a(":"(")+f.h+", "+f.s+"%, "+f.l+"%"+(j?", "+k:"")+")":"#"+b.HEX,n=b.HUELuminance>.22?g:h,p=b.rgbaMixBlack.luminance>.22?g:h,r=(1-b.hsv.h)*u._height,t=b.hsv.s*u._width,z=(1-b.hsv.v)*u._height,A=k*x._width,B=E?"translate3d":"",C=s[0].value,D=s[0].hasAttribute("value")&&""===C&&a!==d;u._css={backgroundColor:"rgb("+c.r+","+c.g+","+c.b+")"},v._css={transform:B+"("+t+"px, "+z+"px, 0)",left:E?"":t,top:E?"":z,borderColor:b.RGBLuminance>.22?g:h},w._css={transform:B+"(0, "+r+"px, 0)",top:E?"":r,borderColor:"transparent "+n},x._css={backgroundColor:"rgb("+l+")"},y._css={transform:B+"("+A+"px, 0, 0)",left:E?"":A,borderColor:p+" transparent"},s._css={backgroundColor:D?"":m,color:D?"":b.rgbaMixBGMixCustom.luminance>.22?g:h},s.text=D?"":C!==m?m:"",a!==d?o(a):G(o)}function o(a){u.css(u._css),v.css(v._css),w.css(w._css),x.css(x._css),y.css(y._css),r.doRender&&s.css(s._css),s.text&&s.val(s.text),r.renderCallback.call(p,s,"boolean"==typeof a?a:d)}var p,q,r,s,t,u,v,w,x,y,z=b(document),A=b(),B="touchmove.a mousemove.a pointermove.a",C="touchstart.a mousedown.a pointerdown.a",D="touchend.a mouseup.a pointerup.a",E=!1,F=Math.round,G=a.requestAnimationFrame||a.webkitRequestAnimationFrame||function(a){a()},H='
',I=".cp-color-picker{position:absolute;overflow:hidden;padding:6px 6px 0;background-color:#444;color:#bbb;font-family:Arial,Helvetica,sans-serif;font-size:12px;font-weight:400;cursor:default;border-radius:5px}.cp-color-picker>div{position:relative;overflow:hidden}.cp-xy-slider{float:left;height:128px;width:128px;margin-bottom:6px;background:linear-gradient(to right,#FFF,rgba(255,255,255,0))}.cp-white{height:100%;width:100%;background:linear-gradient(rgba(0,0,0,0),#000)}.cp-xy-cursor{position:absolute;top:0;width:10px;height:10px;margin:-5px;border:1px solid #fff;border-radius:100%;box-sizing:border-box}.cp-z-slider{float:right;margin-left:6px;height:128px;width:20px;background:linear-gradient(red 0,#f0f 17%,#00f 33%,#0ff 50%,#0f0 67%,#ff0 83%,red 100%)}.cp-z-cursor{position:absolute;margin-top:-4px;width:100%;border:4px solid #fff;border-color:transparent #fff;box-sizing:border-box}.cp-alpha{clear:both;width:100%;height:16px;margin:6px 0;background:linear-gradient(to right,#444,rgba(0,0,0,0))}.cp-alpha-cursor{position:absolute;margin-left:-4px;height:100%;border:4px solid #fff;border-color:#fff transparent;box-sizing:border-box}",J=function(a){q=this.color=new c(a),r=q.options,p=this};return J.prototype={render:n,toggle:h},b.fn.colorPicker=function(c){var d=function(){};return c=b.extend({animationSpeed:150,GPU:!0,doRender:!0,customBG:"#FFF",opacity:!0,renderCallback:d,buildCallback:d,body:document.body,scrollResize:!0,gap:4},c),!p&&c.scrollResize&&b(a).on("resize.a scroll.a",function(){p.$trigger&&p.toggle.call(p.$trigger[0],!0)}),A=A.add(this),this.colorPicker=A.colorPicker=p||new J(c),b(c.body).off(".a").on(C,function(a){!A.add(t).find(a.target).add(A.filter(a.target))[0]&&h()}),this.on("focusin.a click.a",h).on("change.a",function(){q.setColor(this.value||"#FFF"),A.colorPicker.render(!0)}).each(function(){var a=e(this),d=a.split("("),f=g(b(this));f.data("colorMode",d[1]?d[0].substr(0,3):"HEX").attr("readonly",r.preventFocus),c.doRender&&f.css({"background-color":a,color:function(){return q.setColor(a).rgbaMixBGMixCustom.luminance>.22?"#222":"#ddd"}})})},b.fn.colorPicker.destroy=function(){A.add(r.body).off(".a"),p.toggle(!1),A=b()},b}); \ No newline at end of file diff --git a/public/libs/jquery-sortable/jquery-sortable.min.js b/public/libs/jquery-sortable/jquery-sortable.min.js deleted file mode 100644 index 4b483e5e8..000000000 --- a/public/libs/jquery-sortable/jquery-sortable.min.js +++ /dev/null @@ -1,19 +0,0 @@ -!function(d,B,m,f){function v(a,b){var c=Math.max(0,a[0]-b[0],b[0]-a[1]),e=Math.max(0,a[2]-b[1],b[1]-a[3]);return c+e}function w(a,b,c,e){var k=a.length;e=e?"offset":"position";for(c=c||0;k--;){var g=a[k].el?a[k].el:d(a[k]),l=g[e]();l.left+=parseInt(g.css("margin-left"),10);l.top+=parseInt(g.css("margin-top"),10);b[k]=[l.left-c,l.left+g.outerWidth()+c,l.top-c,l.top+g.outerHeight()+c]}}function p(a,b){var c=b.offset();return{left:a.left-c.left,top:a.top-c.top}}function x(a,b,c){b=[b.left,b.top];c= -c&&[c.left,c.top];for(var e,k=a.length,d=[];k--;)e=a[k],d[k]=[k,v(e,b),c&&v(e,c)];return d=d.sort(function(a,b){return b[1]-a[1]||b[2]-a[2]||b[0]-a[0]})}function q(a){this.options=d.extend({},n,a);this.containers=[];this.options.rootGroup||(this.scrollProxy=d.proxy(this.scroll,this),this.dragProxy=d.proxy(this.drag,this),this.dropProxy=d.proxy(this.drop,this),this.placeholder=d(this.options.placeholder),a.isValidTarget||(this.options.isValidTarget=f))}function t(a,b){this.el=a;this.options=d.extend({}, -z,b);this.group=q.get(this.options);this.rootGroup=this.options.rootGroup||this.group;this.handle=this.rootGroup.options.handle||this.rootGroup.options.itemSelector;var c=this.rootGroup.options.itemPath;this.target=c?this.el.find(c):this.el;this.target.on(r.start,this.handle,d.proxy(this.dragInit,this));this.options.drop&&this.group.containers.push(this)}var r,z={drag:!0,drop:!0,exclude:"",nested:!0,vertical:!0},n={afterMove:function(a,b,c){},containerPath:"",containerSelector:"ol, ul",distance:0, -delay:0,handle:"",itemPath:"",itemSelector:"li",bodyClass:"dragging",draggedClass:"dragged",isValidTarget:function(a,b){return!0},onCancel:function(a,b,c,e){},onDrag:function(a,b,c,e){a.css(b)},onDragStart:function(a,b,c,e){a.css({height:a.outerHeight(),width:a.outerWidth()});a.addClass(b.group.options.draggedClass);d("body").addClass(b.group.options.bodyClass)},onDrop:function(a,b,c,e){a.removeClass(b.group.options.draggedClass).removeAttr("style");d("body").removeClass(b.group.options.bodyClass)}, -onMousedown:function(a,b,c){if(!c.target.nodeName.match(/^(input|select|textarea)$/i))return c.preventDefault(),!0},placeholderClass:"placeholder",placeholder:'
  • ',pullPlaceholder:!0,serialize:function(a,b,c){a=d.extend({},a.data());if(c)return[b];b[0]&&(a.children=b);delete a.subContainers;delete a.sortable;return a},tolerance:0},s={},y=0,A={left:0,top:0,bottom:0,right:0};r={start:"touchstart.sortable mousedown.sortable",drop:"touchend.sortable touchcancel.sortable mouseup.sortable", -drag:"touchmove.sortable mousemove.sortable",scroll:"scroll.sortable"};q.get=function(a){s[a.group]||(a.group===f&&(a.group=y++),s[a.group]=new q(a));return s[a.group]};q.prototype={dragInit:function(a,b){this.$document=d(b.el[0].ownerDocument);var c=d(a.target).closest(this.options.itemSelector);c.length&&(this.item=c,this.itemContainer=b,!this.item.is(this.options.exclude)&&this.options.onMousedown(this.item,n.onMousedown,a)&&(this.setPointer(a),this.toggleListeners("on"),this.setupDelayTimer(), -this.dragInitDone=!0))},drag:function(a){if(!this.dragging){if(!this.distanceMet(a)||!this.delayMet)return;this.options.onDragStart(this.item,this.itemContainer,n.onDragStart,a);this.item.before(this.placeholder);this.dragging=!0}this.setPointer(a);this.options.onDrag(this.item,p(this.pointer,this.item.offsetParent()),n.onDrag,a);a=this.getPointer(a);var b=this.sameResultBox,c=this.options.tolerance;(!b||b.top-c>a.top||b.bottom+ca.left||b.right+c=this.options.distance},getPointer:function(a){var b= -a.originalEvent||a.originalEvent.touches&&a.originalEvent.touches[0];return{left:a.pageX||b.pageX,top:a.pageY||b.pageY}},setupDelayTimer:function(){var a=this;this.delayMet=!this.options.delay;this.delayMet||(clearTimeout(this._mouseDelayTimer),this._mouseDelayTimer=setTimeout(function(){a.delayMet=!0},this.options.delay))},scroll:function(a){this.clearDimensions();this.clearOffsetParent()},toggleListeners:function(a){var b=this;d.each(["drag","drop","scroll"],function(c,e){b.$document[a](r[e],b[e+ -"Proxy"])})},clearOffsetParent:function(){this.offsetParent=f},clearDimensions:function(){this.traverse(function(a){a._clearDimensions()})},traverse:function(a){a(this);for(var b=this.containers.length;b--;)this.containers[b].traverse(a)},_clearDimensions:function(){this.containerDimensions=f},_destroy:function(){s[this.options.group]=f}};t.prototype={dragInit:function(a){var b=this.rootGroup;!this.disabled&&!b.dragInitDone&&this.options.drag&&this.isValidDrag(a)&&b.dragInit(a,this)},isValidDrag:function(a){return 1== -a.which||"touchstart"==a.type&&1==a.originalEvent.touches.length},searchValidTarget:function(a,b){var c=x(this.getItemDimensions(),a,b),e=c.length,d=this.rootGroup,g=!d.options.isValidTarget||d.options.isValidTarget(d.item,this);if(!e&&g)return d.movePlaceholder(this,this.target,"append"),!0;for(;e--;)if(d=c[e][0],!c[e][1]&&this.hasChildGroup(d)){if(this.getContainerGroup(d).searchValidTarget(a,b))return!0}else if(g)return this.movePlaceholder(d,a),!0},movePlaceholder:function(a,b){var c=d(this.items[a]), -e=this.itemDimensions[a],k="after",g=c.outerWidth(),f=c.outerHeight(),h=c.offset(),h={left:h.left,right:h.left+g,top:h.top,bottom:h.top+f};this.options.vertical?b.top<=(e[2]+e[3])/2?(k="before",h.bottom-=f/2):h.top+=f/2:b.left<=(e[0]+e[1])/2?(k="before",h.right-=g/2):h.left+=g/2;this.hasChildGroup(a)&&(h=A);this.rootGroup.movePlaceholder(this,c,k,h)},getItemDimensions:function(){this.itemDimensions||(this.items=this.$getChildren(this.el,"item").filter(":not(."+this.group.options.placeholderClass+ -", ."+this.group.options.draggedClass+")").get(),w(this.items,this.itemDimensions=[],this.options.tolerance));return this.itemDimensions},getItemOffsetParent:function(){var a=this.el;return"relative"===a.css("position")||"absolute"===a.css("position")||"fixed"===a.css("position")?a:a.offsetParent()},hasChildGroup:function(a){return this.options.nested&&this.getContainerGroup(a)},getContainerGroup:function(a){var b=d.data(this.items[a],"subContainers");if(b===f){var c=this.$getChildren(this.items[a], -"container"),b=!1;c[0]&&(b=d.extend({},this.options,{rootGroup:this.rootGroup,group:y++}),b=c[m](b).data(m).group);d.data(this.items[a],"subContainers",b)}return b},$getChildren:function(a,b){var c=this.rootGroup.options,e=c[b+"Path"],c=c[b+"Selector"];a=d(a);e&&(a=a.find(e));return a.children(c)},_serialize:function(a,b){var c=this,e=this.$getChildren(a,b?"item":"container").not(this.options.exclude).map(function(){return c._serialize(d(this),!b)}).get();return this.rootGroup.options.serialize(a, -e,b)},traverse:function(a){d.each(this.items||[],function(b){(b=d.data(this,"subContainers"))&&b.traverse(a)});a(this)},_clearDimensions:function(){this.itemDimensions=f},_destroy:function(){var a=this;this.target.off(r.start,this.handle);this.el.removeData(m);this.options.drop&&(this.group.containers=d.grep(this.group.containers,function(b){return b!=a}));d.each(this.items||[],function(){d.removeData(this,"subContainers")})}};var u={enable:function(){this.traverse(function(a){a.disabled=!1})},disable:function(){this.traverse(function(a){a.disabled= -!0})},serialize:function(){return this._serialize(this.el,!0)},refresh:function(){this.traverse(function(a){a._clearDimensions()})},destroy:function(){this.traverse(function(a){a._destroy()})}};d.extend(t.prototype,u);d.fn[m]=function(a){var b=Array.prototype.slice.call(arguments,1);return this.map(function(){var c=d(this),e=c.data(m);if(e&&u[a])return u[a].apply(e,b)||this;e||a!==f&&"object"!==typeof a||c.data(m,new t(c,a));return this})}}(jQuery,window,"sortable"); diff --git a/readme.md b/readme.md index 940deb04c..6f0956eb5 100644 --- a/readme.md +++ b/readme.md @@ -3,6 +3,7 @@ [![GitHub release](https://img.shields.io/github/release/BookStackApp/BookStack.svg)](https://github.com/BookStackApp/BookStack/releases/latest) [![license](https://img.shields.io/badge/License-MIT-yellow.svg)](https://github.com/BookStackApp/BookStack/blob/master/LICENSE) [![Build Status](https://travis-ci.org/BookStackApp/BookStack.svg)](https://travis-ci.org/BookStackApp/BookStack) +[![Discord](https://img.shields.io/static/v1?label=Chat&message=Discord&color=738adb&logo=discord)](https://discord.gg/ztkBqR2) A platform for storing and organising information and documentation. General information and documentation for BookStack can be found at https://www.bookstackapp.com/. @@ -12,7 +13,7 @@ A platform for storing and organising information and documentation. General inf * [Admin Login](https://demo.bookstackapp.com/login?email=admin@example.com&password=password) * [BookStack Blog](https://www.bookstackapp.com/blog) -## Project Definition +## 📚 Project Definition BookStack is an opinionated wiki system that provides a pleasant and simple out of the box experience. New users to an instance should find the experience intuitive and only basic word-processing skills should be required to get involved in creating content on BookStack. The platform should provide advanced power features to those that desire it but they should not interfere with the core simple user experience. @@ -20,13 +21,11 @@ BookStack is not designed as an extensible platform to be used for purposes that In regards to development philosophy, BookStack has a relaxed, open & positive approach. At the end of the day this is free software developed and maintained by people donating their own free time. -## Road Map +## 🛣️ Road Map Below is a high-level road map view for BookStack to provide a sense of direction of where the project is going. This can change at any point and does not reflect many features and improvements that will also be included as part of the journey along this road map. For more granular detail of what will be included in upcoming releases you can review the project milestones as defined in the "Release Process" section below. -- **Design Revamp** *[(In Progress)](https://github.com/BookStackApp/BookStack/pull/1153)* - - *A more organised modern design to clean things up, make BookStack more efficient to use and increase mobile usability.* -- **Platform REST API** +- **Platform REST API** *(In Design)* - *A REST API covering, at minimum, control of core content models (Books, Chapters, Pages) for automation and platform extension.* - **Editor Alignment & Review** - *Review the page editors with goal of achieving increased interoperability & feature parity while also considering collaborative editing potential.* @@ -35,7 +34,7 @@ Below is a high-level road map view for BookStack to provide a sense of directio - **Installation & Deployment Process Revamp** - *Creation of a streamlined & secure process for users to deploy & update BookStack with reduced development requirements (No git or composer requirement).* -## Release Versioning & Process +## 🚀 Release Versioning & Process BookStack releases are each assigned a version number, such as "v0.25.2", in the format `v..`. A change only in the `patch` number indicates a fairly minor release that mainly contains fixes and therefore is very unlikely to cause breakages upon update. A change in the `feature` number indicates a release which will generally bring new features in addition to fixes and enhancements. These releases have a small chance of introducing breaking changes upon update so it's worth checking for any notes in the [update guide](https://www.bookstackapp.com/docs/admin/updates/). A change in the `phase` indicates a much large change in BookStack that will likely incur breakages requiring manual intervention. @@ -43,7 +42,7 @@ Each BookStack release will have a [milestone](https://github.com/BookStackApp/B For feature releases, and some patch releases, the release will be accompanied by a post on the [BookStack blog](https://www.bookstackapp.com/blog/) which will provide additional detail on features, changes & updates otherwise the [GitHub release page](https://github.com/BookStackApp/BookStack/releases) will show a list of changes. You can sign up to be alerted to new BookStack blogs posts (once per week maximum) [at this link](http://eepurl.com/cmmq5j). -## Development & Testing +## 🛠️ Development & Testing All development on BookStack is currently done on the master branch. When it's time for a release the master branch is merged into release with built & minified CSS & JS then tagged at its version. Here are the current development requirements: @@ -65,7 +64,7 @@ npm run production npm run dev ``` -BookStack has many integration tests that use Laravel's built-in testing capabilities which makes use of PHPUnit. To use you will need PHPUnit 6 installed and accessible via command line, Directly running the composer-installed version will not work. There is a `mysql_testing` database defined within the app config which is what is used by PHPUnit. This database is set with the following database name, user name and password defined as `bookstack-test`. You will have to create that database and credentials before testing. +BookStack has many integration tests that use Laravel's built-in testing capabilities which makes use of PHPUnit. There is a `mysql_testing` database defined within the app config which is what is used by PHPUnit. This database is set with the database name, user name and password all defined as `bookstack-test`. You will have to create that database and that set of credentials before testing. The testing database will also need migrating and seeding beforehand. This can be done with the following commands: @@ -74,9 +73,37 @@ php artisan migrate --database=mysql_testing php artisan db:seed --class=DummyContentSeeder --database=mysql_testing ``` -Once done you can run `phpunit` in the application root directory to run all tests. +Once done you can run `php vendor/bin/phpunit` in the application root directory to run all tests. -## Translations +### 📜 Code Standards + +PHP code within BookStack is generally to [PSR-2](http://www.php-fig.org/psr/psr-2/) standards. From the BookStack root folder you can run `./vendor/bin/phpcs` to check code is formatted correctly and `./vendor/bin/phpcbf` to auto-fix non-PSR-2 code. + +### 🐋 Development using Docker + +This repository ships with a Docker Compose configuration intended for development purposes. It'll build a PHP image with all needed extensions installed and start up a MySQL server and a Node image watching the UI assets. + +To get started, make sure you meet the following requirements: + +- Docker and Docker Compose are installed +- Your user is part of the `docker` group + +If all the conditions are met, you can proceed with the following steps: + +1. Install PHP/Composer dependencies with **`docker-compose run app composer install`** (first time can take a while because the image has to be built). +2. **Copy `.env.example` to `.env`** and change `APP_KEY` to a random 32 char string. +3. Make sure **port 8080 is unused** *or else* change `DEV_PORT` to a free port on your host. +4. **Run `chgrp -R docker storage`**. The development container will chown the `storage` directory to the `www-data` user inside the container so BookStack can write to it. You need to change the group to your host's `docker` group here to not lose access to the `storage` directory. +5. **Run `docker-compose up`** and wait until all database migrations have been done. +6. You can now login with `admin@admin.com` and `password` as password on `localhost:8080` (or another port if specified). + +If needed, You'll be able to run any artisan commands via docker-compose like so: + + ```shell script +docker-compose run app php artisan list +``` + +## 🌎 Translations All text strings can be found in the `resources/lang` folder where each language option has its own folder. To add a new language you should copy the `en` folder to an new folder (eg. `fr` for french) then go through and translate all text strings in those files, leaving the keys and file-names intact. If a language string is missing then the `en` translation will be used. To show the language option in the user preferences language drop-down you will need to add your language to the options found at the bottom of the `resources/lang/en/settings.php` file. A system-wide language can also be set in the `.env` file like so: `APP_LANG=en`. @@ -95,29 +122,15 @@ php resources/lang/check.php pt_BR Some strings have colon-prefixed variables in such as `:userName`. Leave these values as they are as they will be replaced at run-time. -## Contributing & Maintenance +## 🎁 Contributing, Issues & Pull Requests -Feel free to create issues to request new features or to report bugs and problems. Just please follow the template given when creating the issue. +Feel free to create issues to request new features or to report bugs & problems. Just please follow the template given when creating the issue. + +Pull requests are welcome. Unless a small tweak or language update, It may be best to open the pull request early or create an issue for your intended change to discuss how it will fit in to the project and plan out the merge. Pull requests should be created from the `master` branch since they will be merged back into `master` once done. Please do not build from or request a merge into the `release` branch as this is only for publishing releases. If you are looking to alter CSS or JavaScript content please edit the source files found in `resources/assets`. Any CSS or JS files within `public` are built from these source files and therefore should not be edited directly. The project's code of conduct [can be found here](https://github.com/BookStackApp/BookStack/blob/master/.github/CODE_OF_CONDUCT.md). -### Code Standards - -PHP code within BookStack is generally to [PSR-2](http://www.php-fig.org/psr/psr-2/) standards. From the BookStack root folder you can run `./vendor/bin/phpcs` to check code is formatted correctly and `./vendor/bin/phpcbf` to auto-fix non-PSR-2 code. - -### Pull Requests - -Pull requests are welcome. Unless a small tweak or language update, It may be best to open the pull request early or create an issue for your intended change to discuss how it will fit in to the project and plan out the merge. - -Pull requests should be created from the `master` branch since they will be merged back into `master` once done. Please do not build from or request a merge into the `release` branch as this is only for publishing releases. - -If you are looking to alter CSS or JavaScript content please edit the source files found in `resources/assets`. Any CSS or JS files within `public` are built from these source files and therefore should not be edited directly. - -## Website, Docs & Blog - -The website which contains the project docs & Blog can be found in the [BookStackApp/website](https://github.com/BookStackApp/website) repo. - -## Security +## 🔒 Security Security information for administering a BookStack instance can be found on the [documentation site here](https://www.bookstackapp.com/docs/admin/security/). @@ -125,28 +138,32 @@ If you'd like to be notified of new potential security concerns you can [sign-up If you would like to report a security concern in a more confidential manner than via a GitHub issue, You can directly email the lead maintainer [ssddanbrown](https://github.com/ssddanbrown). You will need to login to be able to see the email address on the [GitHub profile page](https://github.com/ssddanbrown). Alternatively you can send a DM via twitter to [@ssddanbrown](https://twitter.com/ssddanbrown). +## ♿ Accessibility -## License +We want BookStack to remain accessible to as many people as possible. We aim for at least WCAG 2.1 Level A standards where possible although we do not strictly test this upon each release. If you come across any accessibility issues please feel free to open an issue. -The BookStack source is provided under the MIT License. +## 🖥️ Website, Docs & Blog -## Attribution +The website which contains the project docs & Blog can be found in the [BookStackApp/website](https://github.com/BookStackApp/website) repo. + +## ⚖️ License + +The BookStack source is provided under the MIT License. The libraries used by, and included with, BookStack are provided under their own licenses. + +## 👪 Attribution The great people that have worked to build and improve BookStack can [be seen here](https://github.com/BookStackApp/BookStack/graphs/contributors). These are the great open-source projects used to help build BookStack: * [Laravel](http://laravel.com/) -* [jQuery](https://jquery.com/) * [TinyMCE](https://www.tinymce.com/) * [CodeMirror](https://codemirror.net) * [Vue.js](http://vuejs.org/) -* [Axios](https://github.com/mzabriskie/axios) -* [jQuery Sortable](https://johnny.github.io/jquery-sortable/) +* [Sortable](https://github.com/SortableJS/Sortable) & [Vue.Draggable](https://github.com/SortableJS/Vue.Draggable) * [Google Material Icons](https://material.io/icons/) * [Dropzone.js](http://www.dropzonejs.com/) * [clipboard.js](https://clipboardjs.com/) -* [TinyColorPicker](http://www.dematte.at/tinyColorPicker/index.html) * [markdown-it](https://github.com/markdown-it/markdown-it) and [markdown-it-task-lists](https://github.com/revin/markdown-it-task-lists) * [BarryVD](https://github.com/barryvdh) * [Debugbar](https://github.com/barryvdh/laravel-debugbar) diff --git a/resources/assets/icons/chevron-down.svg b/resources/assets/icons/chevron-down.svg new file mode 100644 index 000000000..f08dfafcb --- /dev/null +++ b/resources/assets/icons/chevron-down.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/resources/assets/icons/copy.svg b/resources/assets/icons/copy.svg index 45e34a39b..3a52e2314 100644 --- a/resources/assets/icons/copy.svg +++ b/resources/assets/icons/copy.svg @@ -1,4 +1,3 @@ - \ No newline at end of file diff --git a/resources/assets/icons/link.svg b/resources/assets/icons/link.svg index 94eea0ed8..3e8be1ce7 100644 --- a/resources/assets/icons/link.svg +++ b/resources/assets/icons/link.svg @@ -1,4 +1,3 @@ - \ No newline at end of file diff --git a/resources/assets/icons/template.svg b/resources/assets/icons/template.svg new file mode 100644 index 000000000..7c142124f --- /dev/null +++ b/resources/assets/icons/template.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/resources/assets/js/components/book-sort.js b/resources/assets/js/components/book-sort.js new file mode 100644 index 000000000..da2b28d8e --- /dev/null +++ b/resources/assets/js/components/book-sort.js @@ -0,0 +1,204 @@ +import Sortable from "sortablejs"; + +// Auto sort control +const sortOperations = { + name: function(a, b) { + const aName = a.getAttribute('data-name').trim().toLowerCase(); + const bName = b.getAttribute('data-name').trim().toLowerCase(); + return aName.localeCompare(bName); + }, + created: function(a, b) { + const aTime = Number(a.getAttribute('data-created')); + const bTime = Number(b.getAttribute('data-created')); + return bTime - aTime; + }, + updated: function(a, b) { + const aTime = Number(a.getAttribute('data-updated')); + const bTime = Number(b.getAttribute('data-updated')); + return bTime - aTime; + }, + chaptersFirst: function(a, b) { + const aType = a.getAttribute('data-type'); + const bType = b.getAttribute('data-type'); + if (aType === bType) { + return 0; + } + return (aType === 'chapter' ? -1 : 1); + }, + chaptersLast: function(a, b) { + const aType = a.getAttribute('data-type'); + const bType = b.getAttribute('data-type'); + if (aType === bType) { + return 0; + } + return (aType === 'chapter' ? 1 : -1); + }, +}; + +class BookSort { + + constructor(elem) { + this.elem = elem; + this.sortContainer = elem.querySelector('[book-sort-boxes]'); + this.input = elem.querySelector('[book-sort-input]'); + + const initialSortBox = elem.querySelector('.sort-box'); + this.setupBookSortable(initialSortBox); + this.setupSortPresets(); + + window.$events.listen('entity-select-confirm', this.bookSelect.bind(this)); + } + + /** + * Setup the handlers for the preset sort type buttons. + */ + setupSortPresets() { + let lastSort = ''; + let reverse = false; + const reversibleTypes = ['name', 'created', 'updated']; + + this.sortContainer.addEventListener('click', event => { + const sortButton = event.target.closest('.sort-box-options [data-sort]'); + if (!sortButton) return; + + event.preventDefault(); + const sortLists = sortButton.closest('.sort-box').querySelectorAll('ul'); + const sort = sortButton.getAttribute('data-sort'); + + reverse = (lastSort === sort) ? !reverse : false; + let sortFunction = sortOperations[sort]; + if (reverse && reversibleTypes.includes(sort)) { + sortFunction = function(a, b) { + return 0 - sortOperations[sort](a, b) + }; + } + + for (let list of sortLists) { + const directItems = Array.from(list.children).filter(child => child.matches('li')); + directItems.sort(sortFunction).forEach(sortedItem => { + list.appendChild(sortedItem); + }); + } + + lastSort = sort; + this.updateMapInput(); + }); + } + + /** + * Handle book selection from the entity selector. + * @param {Object} entityInfo + */ + bookSelect(entityInfo) { + const alreadyAdded = this.elem.querySelector(`[data-type="book"][data-id="${entityInfo.id}"]`) !== null; + if (alreadyAdded) return; + + const entitySortItemUrl = entityInfo.link + '/sort-item'; + window.$http.get(entitySortItemUrl).then(resp => { + const wrap = document.createElement('div'); + wrap.innerHTML = resp.data; + const newBookContainer = wrap.children[0]; + this.sortContainer.append(newBookContainer); + this.setupBookSortable(newBookContainer); + }); + } + + /** + * Setup the given book container element to have sortable items. + * @param {Element} bookContainer + */ + setupBookSortable(bookContainer) { + const sortElems = [bookContainer.querySelector('.sort-list')]; + sortElems.push(...bookContainer.querySelectorAll('.entity-list-item + ul')); + + const bookGroupConfig = { + name: 'book', + pull: ['book', 'chapter'], + put: ['book', 'chapter'], + }; + + const chapterGroupConfig = { + name: 'chapter', + pull: ['book', 'chapter'], + put: function(toList, fromList, draggedElem) { + return draggedElem.getAttribute('data-type') === 'page'; + } + }; + + for (let sortElem of sortElems) { + new Sortable(sortElem, { + group: sortElem.classList.contains('sort-list') ? bookGroupConfig : chapterGroupConfig, + animation: 150, + fallbackOnBody: true, + swapThreshold: 0.65, + onSort: this.updateMapInput.bind(this), + dragClass: 'bg-white', + ghostClass: 'primary-background-light', + }); + } + } + + /** + * Update the input with our sort data. + */ + updateMapInput() { + const pageMap = this.buildEntityMap(); + this.input.value = JSON.stringify(pageMap); + } + + /** + * Build up a mapping of entities with their ordering and nesting. + * @returns {Array} + */ + buildEntityMap() { + const entityMap = []; + const lists = this.elem.querySelectorAll('.sort-list'); + + for (let list of lists) { + const bookId = list.closest('[data-type="book"]').getAttribute('data-id'); + const directChildren = Array.from(list.children) + .filter(elem => elem.matches('[data-type="page"], [data-type="chapter"]')); + for (let i = 0; i < directChildren.length; i++) { + this.addBookChildToMap(directChildren[i], i, bookId, entityMap); + } + } + + return entityMap; + } + + /** + * Parse a sort item and add it to a data-map array. + * Parses sub0items if existing also. + * @param {Element} childElem + * @param {Number} index + * @param {Number} bookId + * @param {Array} entityMap + */ + addBookChildToMap(childElem, index, bookId, entityMap) { + const type = childElem.getAttribute('data-type'); + const parentChapter = false; + const childId = childElem.getAttribute('data-id'); + + entityMap.push({ + id: childId, + sort: index, + parentChapter: parentChapter, + type: type, + book: bookId + }); + + const subPages = childElem.querySelectorAll('[data-type="page"]'); + for (let i = 0; i < subPages.length; i++) { + entityMap.push({ + id: subPages[i].getAttribute('data-id'), + sort: i, + parentChapter: childId, + type: 'page', + book: bookId + }); + } + } + +} + +export default BookSort; \ No newline at end of file diff --git a/resources/assets/js/components/breadcrumb-listing.js b/resources/assets/js/components/breadcrumb-listing.js index 1e2fe9ea4..7f4344b17 100644 --- a/resources/assets/js/components/breadcrumb-listing.js +++ b/resources/assets/js/components/breadcrumb-listing.js @@ -7,14 +7,13 @@ class BreadcrumbListing { this.searchInput = elem.querySelector('input'); this.loadingElem = elem.querySelector('.loading-container'); this.entityListElem = elem.querySelector('.breadcrumb-listing-entity-list'); - this.toggleElem = elem.querySelector('[dropdown-toggle]'); // this.loadingElem.style.display = 'none'; const entityDescriptor = elem.getAttribute('breadcrumb-listing').split(':'); this.entityType = entityDescriptor[0]; this.entityId = Number(entityDescriptor[1]); - this.toggleElem.addEventListener('click', this.onShow.bind(this)); + this.elem.addEventListener('show', this.onShow.bind(this)); this.searchInput.addEventListener('input', this.onSearch.bind(this)); } @@ -28,6 +27,7 @@ class BreadcrumbListing { for (let listItem of listItems) { const match = !input || listItem.textContent.toLowerCase().includes(input); listItem.style.display = match ? 'flex' : 'none'; + listItem.classList.toggle('hidden', !match); } } @@ -39,7 +39,7 @@ class BreadcrumbListing { 'entity_type': this.entityType, }; - window.$http.get('/search/entity/siblings', {params}).then(resp => { + window.$http.get('/search/entity/siblings', params).then(resp => { this.entityListElem.innerHTML = resp.data; }).catch(err => { console.error(err); diff --git a/resources/assets/js/components/chapter-toggle.js b/resources/assets/js/components/chapter-toggle.js index 350c453ac..bfd0ac729 100644 --- a/resources/assets/js/components/chapter-toggle.js +++ b/resources/assets/js/components/chapter-toggle.js @@ -1,3 +1,4 @@ +import {slideUp, slideDown} from "../services/animations"; class ChapterToggle { @@ -9,56 +10,16 @@ class ChapterToggle { open() { const list = this.elem.parentNode.querySelector('.inset-list'); - this.elem.classList.add('open'); - list.style.display = 'block'; - list.style.maxHeight = ''; - const maxHeight = list.getBoundingClientRect().height + 10; - list.style.maxHeight = '0px'; - list.style.overflow = 'hidden'; - list.style.transition = 'max-height ease-in-out 240ms'; - - let transitionEndBound = onTransitionEnd.bind(this); - function onTransitionEnd() { - list.style.overflow = ''; - list.style.maxHeight = ''; - list.style.transition = ''; - list.style.display = `block`; - list.removeEventListener('transitionend', transitionEndBound); - } - - setTimeout(() => { - requestAnimationFrame(() => { - list.style.maxHeight = `${maxHeight}px`; - list.addEventListener('transitionend', transitionEndBound) - }); - }, 1); + this.elem.setAttribute('aria-expanded', 'true'); + slideDown(list, 240); } close() { const list = this.elem.parentNode.querySelector('.inset-list'); - - list.style.display = 'block'; this.elem.classList.remove('open'); - list.style.maxHeight = list.getBoundingClientRect().height + 'px'; - list.style.overflow = 'hidden'; - list.style.transition = 'max-height ease-in-out 240ms'; - - const transitionEndBound = onTransitionEnd.bind(this); - function onTransitionEnd() { - list.style.overflow = ''; - list.style.maxHeight = ''; - list.style.transition = ''; - list.style.display = 'none'; - list.removeEventListener('transitionend', transitionEndBound); - } - - setTimeout(() => { - requestAnimationFrame(() => { - list.style.maxHeight = `0px`; - list.addEventListener('transitionend', transitionEndBound) - }); - }, 1); + this.elem.setAttribute('aria-expanded', 'false'); + slideUp(list, 240); } click(event) { diff --git a/resources/assets/js/components/collapsible.js b/resources/assets/js/components/collapsible.js index a13b367d3..464f394c1 100644 --- a/resources/assets/js/components/collapsible.js +++ b/resources/assets/js/components/collapsible.js @@ -1,3 +1,5 @@ +import {slideDown, slideUp} from "../services/animations"; + /** * Collapsible * Provides some simple logic to allow collapsible sections. @@ -16,12 +18,14 @@ class Collapsible { open() { this.elem.classList.add('open'); - $(this.content).slideDown(400); + this.trigger.setAttribute('aria-expanded', 'true'); + slideDown(this.content, 300); } close() { this.elem.classList.remove('open'); - $(this.content).slideUp(400); + this.trigger.setAttribute('aria-expanded', 'false'); + slideUp(this.content, 300); } toggle() { diff --git a/resources/assets/js/components/custom-checkbox.js b/resources/assets/js/components/custom-checkbox.js new file mode 100644 index 000000000..65ce8c194 --- /dev/null +++ b/resources/assets/js/components/custom-checkbox.js @@ -0,0 +1,34 @@ + +class CustomCheckbox { + + constructor(elem) { + this.elem = elem; + this.checkbox = elem.querySelector('input[type=checkbox]'); + this.display = elem.querySelector('[role="checkbox"]'); + + this.checkbox.addEventListener('change', this.stateChange.bind(this)); + this.elem.addEventListener('keydown', this.onKeyDown.bind(this)); + } + + onKeyDown(event) { + const isEnterOrPress = event.keyCode === 32 || event.keyCode === 13; + if (isEnterOrPress) { + event.preventDefault(); + this.toggle(); + } + } + + toggle() { + this.checkbox.checked = !this.checkbox.checked; + this.checkbox.dispatchEvent(new Event('change')); + this.stateChange(); + } + + stateChange() { + const checked = this.checkbox.checked ? 'true' : 'false'; + this.display.setAttribute('aria-checked', checked); + } + +} + +export default CustomCheckbox; \ No newline at end of file diff --git a/resources/assets/js/components/dropdown.js b/resources/assets/js/components/dropdown.js index 3887e8432..4de1e239b 100644 --- a/resources/assets/js/components/dropdown.js +++ b/resources/assets/js/components/dropdown.js @@ -1,3 +1,5 @@ +import {onSelect} from "../services/dom"; + /** * Dropdown * Provides some simple logic to create simple dropdown menus. @@ -10,14 +12,16 @@ class DropDown { this.moveMenu = elem.hasAttribute('dropdown-move-menu'); this.toggle = elem.querySelector('[dropdown-toggle]'); this.body = document.body; + this.showing = false; this.setupListeners(); } - show(event) { + show(event = null) { this.hideAll(); this.menu.style.display = 'block'; this.menu.classList.add('anim', 'menuIn'); + this.toggle.setAttribute('aria-expanded', 'true'); if (this.moveMenu) { // Move to body to prevent being trapped within scrollable sections @@ -38,10 +42,17 @@ class DropDown { }); // Focus on first input if existing - let input = this.menu.querySelector('input'); + const input = this.menu.querySelector('input'); if (input !== null) input.focus(); - event.stopPropagation(); + this.showing = true; + + const showEvent = new Event('show'); + this.container.dispatchEvent(showEvent); + + if (event) { + event.stopPropagation(); + } } hideAll() { @@ -53,6 +64,7 @@ class DropDown { hide() { this.menu.style.display = 'none'; this.menu.classList.remove('anim', 'menuIn'); + this.toggle.setAttribute('aria-expanded', 'false'); if (this.moveMenu) { this.menu.style.position = ''; this.menu.style.left = ''; @@ -60,22 +72,78 @@ class DropDown { this.menu.style.width = ''; this.container.appendChild(this.menu); } + this.showing = false; + } + + getFocusable() { + return Array.from(this.menu.querySelectorAll('[tabindex],[href],button,input:not([type=hidden])')); + } + + focusNext() { + const focusable = this.getFocusable(); + const currentIndex = focusable.indexOf(document.activeElement); + let newIndex = currentIndex + 1; + if (newIndex >= focusable.length) { + newIndex = 0; + } + + focusable[newIndex].focus(); + } + + focusPrevious() { + const focusable = this.getFocusable(); + const currentIndex = focusable.indexOf(document.activeElement); + let newIndex = currentIndex - 1; + if (newIndex < 0) { + newIndex = focusable.length - 1; + } + + focusable[newIndex].focus(); } setupListeners() { // Hide menu on option click this.container.addEventListener('click', event => { - let possibleChildren = Array.from(this.menu.querySelectorAll('a')); - if (possibleChildren.indexOf(event.target) !== -1) this.hide(); + const possibleChildren = Array.from(this.menu.querySelectorAll('a')); + if (possibleChildren.includes(event.target)) { + this.hide(); + } }); - // Show dropdown on toggle click - this.toggle.addEventListener('click', this.show.bind(this)); - // Hide menu on enter press - this.container.addEventListener('keypress', event => { - if (event.keyCode !== 13) return true; + + onSelect(this.toggle, event => { + event.stopPropagation(); + this.show(event); + if (event instanceof KeyboardEvent) { + this.focusNext(); + } + }); + + // Keyboard navigation + const keyboardNavigation = event => { + if (event.key === 'ArrowDown' || event.key === 'ArrowRight') { + this.focusNext(); event.preventDefault(); + } else if (event.key === 'ArrowUp' || event.key === 'ArrowLeft') { + this.focusPrevious(); + event.preventDefault(); + } else if (event.key === 'Escape') { this.hide(); - return false; + this.toggle.focus(); + event.stopPropagation(); + } + }; + this.container.addEventListener('keydown', keyboardNavigation); + if (this.moveMenu) { + this.menu.addEventListener('keydown', keyboardNavigation); + } + + // Hide menu on enter press or escape + this.menu.addEventListener('keydown ', event => { + if (event.key === 'Enter') { + event.preventDefault(); + event.stopPropagation(); + this.hide(); + } }); } diff --git a/resources/assets/js/components/editor-toolbox.js b/resources/assets/js/components/editor-toolbox.js index 10678edfa..354bf0a86 100644 --- a/resources/assets/js/components/editor-toolbox.js +++ b/resources/assets/js/components/editor-toolbox.js @@ -23,6 +23,8 @@ class EditorToolbox { toggle() { this.elem.classList.toggle('open'); + const expanded = this.elem.classList.contains('open') ? 'true' : 'false'; + this.toggleButton.setAttribute('aria-expanded', expanded); } setActiveTab(tabName, openToolbox = false) { diff --git a/resources/assets/js/components/entity-permissions-editor.js b/resources/assets/js/components/entity-permissions-editor.js new file mode 100644 index 000000000..a821792a0 --- /dev/null +++ b/resources/assets/js/components/entity-permissions-editor.js @@ -0,0 +1,20 @@ + +class EntityPermissionsEditor { + + constructor(elem) { + this.permissionsTable = elem.querySelector('[permissions-table]'); + + // Handle toggle all event + this.restrictedCheckbox = elem.querySelector('[name=restricted]'); + this.restrictedCheckbox.addEventListener('change', this.updateTableVisibility.bind(this)); + } + + updateTableVisibility() { + this.permissionsTable.style.display = + this.restrictedCheckbox.checked + ? null + : 'none'; + } +} + +export default EntityPermissionsEditor; \ No newline at end of file diff --git a/resources/assets/js/components/expand-toggle.js b/resources/assets/js/components/expand-toggle.js index a6a389818..cce1b215c 100644 --- a/resources/assets/js/components/expand-toggle.js +++ b/resources/assets/js/components/expand-toggle.js @@ -1,3 +1,4 @@ +import {slideUp, slideDown} from "../services/animations"; class ExpandToggle { @@ -14,46 +15,11 @@ class ExpandToggle { } open(elemToToggle) { - elemToToggle.style.display = 'block'; - elemToToggle.style.height = ''; - let height = elemToToggle.getBoundingClientRect().height; - elemToToggle.style.height = '0px'; - elemToToggle.style.overflow = 'hidden'; - elemToToggle.style.transition = 'height ease-in-out 240ms'; - - let transitionEndBound = onTransitionEnd.bind(this); - function onTransitionEnd() { - elemToToggle.style.overflow = ''; - elemToToggle.style.height = ''; - elemToToggle.style.transition = ''; - elemToToggle.removeEventListener('transitionend', transitionEndBound); - } - - setTimeout(() => { - elemToToggle.style.height = `${height}px`; - elemToToggle.addEventListener('transitionend', transitionEndBound) - }, 1); + slideDown(elemToToggle, 200); } close(elemToToggle) { - elemToToggle.style.display = 'block'; - elemToToggle.style.height = elemToToggle.getBoundingClientRect().height + 'px'; - elemToToggle.style.overflow = 'hidden'; - elemToToggle.style.transition = 'all ease-in-out 240ms'; - - let transitionEndBound = onTransitionEnd.bind(this); - function onTransitionEnd() { - elemToToggle.style.overflow = ''; - elemToToggle.style.height = ''; - elemToToggle.style.transition = ''; - elemToToggle.style.display = 'none'; - elemToToggle.removeEventListener('transitionend', transitionEndBound); - } - - setTimeout(() => { - elemToToggle.style.height = `0px`; - elemToToggle.addEventListener('transitionend', transitionEndBound) - }, 1); + slideUp(elemToToggle, 200); } click(event) { diff --git a/resources/assets/js/components/index.js b/resources/assets/js/components/index.js index 355b96473..14cf08ae2 100644 --- a/resources/assets/js/components/index.js +++ b/resources/assets/js/components/index.js @@ -23,6 +23,12 @@ import listSortControl from "./list-sort-control"; import triLayout from "./tri-layout"; import breadcrumbListing from "./breadcrumb-listing"; import permissionsTable from "./permissions-table"; +import customCheckbox from "./custom-checkbox"; +import bookSort from "./book-sort"; +import settingAppColorPicker from "./setting-app-color-picker"; +import entityPermissionsEditor from "./entity-permissions-editor"; +import templateManager from "./template-manager"; +import newUserPassword from "./new-user-password"; const componentMapping = { 'dropdown': dropdown, @@ -50,6 +56,12 @@ const componentMapping = { 'tri-layout': triLayout, 'breadcrumb-listing': breadcrumbListing, 'permissions-table': permissionsTable, + 'custom-checkbox': customCheckbox, + 'book-sort': bookSort, + 'setting-app-color-picker': settingAppColorPicker, + 'entity-permissions-editor': entityPermissionsEditor, + 'template-manager': templateManager, + 'new-user-password': newUserPassword, }; window.components = {}; diff --git a/resources/assets/js/components/markdown-editor.js b/resources/assets/js/components/markdown-editor.js index 5fa16ef6e..7f3d4ef24 100644 --- a/resources/assets/js/components/markdown-editor.js +++ b/resources/assets/js/components/markdown-editor.js @@ -1,6 +1,7 @@ import MarkdownIt from "markdown-it"; import mdTasksLists from 'markdown-it-task-lists'; import code from '../services/code'; +import {debounce} from "../services/util"; import DrawIO from "../services/drawio"; @@ -17,6 +18,8 @@ class MarkdownEditor { this.markdown.use(mdTasksLists, {label: true}); this.display = this.elem.querySelector('.markdown-display'); + this.displayDoc = this.display.contentDocument; + this.displayStylesLoaded = false; this.input = this.elem.querySelector('textarea'); this.htmlInput = this.elem.querySelector('input[name=html]'); this.cm = code.markdownEditor(this.input); @@ -37,7 +40,7 @@ class MarkdownEditor { let lastClick = 0; // Prevent markdown display link click redirect - this.display.addEventListener('click', event => { + this.displayDoc.addEventListener('click', event => { let isDblClick = Date.now() - lastClick < 300; let link = event.target.closest('a'); @@ -90,28 +93,46 @@ class MarkdownEditor { }); this.codeMirrorSetup(); + this.listenForBookStackEditorEvents(); } // Update the input content and render the display. updateAndRender() { - let content = this.cm.getValue(); + const content = this.cm.getValue(); this.input.value = content; - let html = this.markdown.render(content); + const html = this.markdown.render(content); window.$events.emit('editor-html-change', html); window.$events.emit('editor-markdown-change', content); - this.display.innerHTML = html; + + // Set body content + this.displayDoc.body.className = 'page-content'; + this.displayDoc.body.innerHTML = html; this.htmlInput.value = html; + + // Copy styles from page head and set custom styles for editor + this.loadStylesIntoDisplay(); + } + + loadStylesIntoDisplay() { + if (this.displayStylesLoaded) return; + this.displayDoc.documentElement.className = 'markdown-editor-display'; + + this.displayDoc.head.innerHTML = ''; + const styles = document.head.querySelectorAll('style,link[rel=stylesheet]'); + for (let style of styles) { + const copy = style.cloneNode(true); + this.displayDoc.head.appendChild(copy); + } + + this.displayStylesLoaded = true; } onMarkdownScroll(lineCount) { - let elems = this.display.children; + const elems = this.displayDoc.body.children; if (elems.length <= lineCount) return; - let topElem = (lineCount === -1) ? elems[elems.length-1] : elems[lineCount]; - // TODO - Replace jQuery - $(this.display).animate({ - scrollTop: topElem.offsetTop - }, {queue: false, duration: 200, easing: 'linear'}); + const topElem = (lineCount === -1) ? elems[elems.length-1] : elems[lineCount]; + topElem.scrollIntoView({ block: 'start', inline: 'nearest', behavior: 'smooth'}); } codeMirrorSetup() { @@ -160,8 +181,7 @@ class MarkdownEditor { this.updateAndRender(); }); - // Handle scroll to sync display view - cm.on('scroll', instance => { + const onScrollDebounced = debounce((instance) => { // Thanks to http://liuhao.im/english/2015/11/10/the-sync-scroll-of-markdown-editor-in-javascript.html let scroll = instance.getScrollInfo(); let atEnd = scroll.top + scroll.clientHeight === scroll.height; @@ -176,6 +196,11 @@ class MarkdownEditor { let doc = parser.parseFromString(this.markdown.render(range), 'text/html'); let totalLines = doc.documentElement.querySelectorAll('body > *'); this.onMarkdownScroll(totalLines.length); + }, 100); + + // Handle scroll to sync display view + cm.on('scroll', instance => { + onScrollDebounced(instance); }); // Handle image paste @@ -197,16 +222,30 @@ class MarkdownEditor { } }); - // Handle images on drag-drop + // Handle image & content drag n drop cm.on('drop', (cm, event) => { - event.stopPropagation(); - event.preventDefault(); - let cursorPos = cm.coordsChar({left: event.pageX, top: event.pageY}); - cm.setCursor(cursorPos); - if (!event.dataTransfer || !event.dataTransfer.files) return; - for (let i = 0; i < event.dataTransfer.files.length; i++) { - uploadImage(event.dataTransfer.files[i]); + + const templateId = event.dataTransfer.getData('bookstack/template'); + if (templateId) { + const cursorPos = cm.coordsChar({left: event.pageX, top: event.pageY}); + cm.setCursor(cursorPos); + event.preventDefault(); + window.$http.get(`/templates/${templateId}`).then(resp => { + const content = resp.data.markdown || resp.data.html; + cm.replaceSelection(content); + }); } + + if (event.dataTransfer && event.dataTransfer.files && event.dataTransfer.files.length > 0) { + const cursorPos = cm.coordsChar({left: event.pageX, top: event.pageY}); + cm.setCursor(cursorPos); + event.stopPropagation(); + event.preventDefault(); + for (let i = 0; i < event.dataTransfer.files.length; i++) { + uploadImage(event.dataTransfer.files[i]); + } + } + }); // Helper to replace editor content @@ -459,6 +498,37 @@ class MarkdownEditor { }) } + listenForBookStackEditorEvents() { + + function getContentToInsert({html, markdown}) { + return markdown || html; + } + + // Replace editor content + window.$events.listen('editor::replace', (eventContent) => { + const markdown = getContentToInsert(eventContent); + this.cm.setValue(markdown); + }); + + // Append editor content + window.$events.listen('editor::append', (eventContent) => { + const cursorPos = this.cm.getCursor('from'); + const markdown = getContentToInsert(eventContent); + const content = this.cm.getValue() + '\n' + markdown; + this.cm.setValue(content); + this.cm.setCursor(cursorPos.line, cursorPos.ch); + }); + + // Prepend editor content + window.$events.listen('editor::prepend', (eventContent) => { + const cursorPos = this.cm.getCursor('from'); + const markdown = getContentToInsert(eventContent); + const content = markdown + '\n' + this.cm.getValue(); + this.cm.setValue(content); + const prependLineCount = markdown.split('\n').length; + this.cm.setCursor(cursorPos.line + prependLineCount, cursorPos.ch); + }); + } } export default MarkdownEditor ; diff --git a/resources/assets/js/components/new-user-password.js b/resources/assets/js/components/new-user-password.js new file mode 100644 index 000000000..9c4c21c14 --- /dev/null +++ b/resources/assets/js/components/new-user-password.js @@ -0,0 +1,28 @@ + +class NewUserPassword { + + constructor(elem) { + this.elem = elem; + this.inviteOption = elem.querySelector('input[name=send_invite]'); + + if (this.inviteOption) { + this.inviteOption.addEventListener('change', this.inviteOptionChange.bind(this)); + this.inviteOptionChange(); + } + } + + inviteOptionChange() { + const inviting = (this.inviteOption.value === 'true'); + const passwordBoxes = this.elem.querySelectorAll('input[type=password]'); + for (const input of passwordBoxes) { + input.disabled = inviting; + } + const container = this.elem.querySelector('#password-input-container'); + if (container) { + container.style.display = inviting ? 'none' : 'block'; + } + } + +} + +export default NewUserPassword; \ No newline at end of file diff --git a/resources/assets/js/components/overlay.js b/resources/assets/js/components/overlay.js index 1ba5efcea..ad6a01061 100644 --- a/resources/assets/js/components/overlay.js +++ b/resources/assets/js/components/overlay.js @@ -6,12 +6,22 @@ class Overlay { elem.addEventListener('click', event => { if (event.target === elem) return this.hide(); }); + + window.addEventListener('keyup', event => { + if (event.key === 'Escape') { + this.hide(); + } + }); + let closeButtons = elem.querySelectorAll('.popup-header-close'); for (let i=0; i < closeButtons.length; i++) { closeButtons[i].addEventListener('click', this.hide.bind(this)); } } + hide() { this.toggle(false); } + show() { this.toggle(true); } + toggle(show = true) { let start = Date.now(); let duration = 240; @@ -22,6 +32,9 @@ class Overlay { this.container.style.opacity = targetOpacity; if (elapsedTime > duration) { this.container.style.display = show ? 'flex' : 'none'; + if (show) { + this.focusOnBody(); + } this.container.style.opacity = ''; } else { requestAnimationFrame(setOpacity.bind(this)); @@ -31,8 +44,12 @@ class Overlay { requestAnimationFrame(setOpacity.bind(this)); } - hide() { this.toggle(false); } - show() { this.toggle(true); } + focusOnBody() { + const body = this.container.querySelector('.popup-body'); + if (body) { + body.focus(); + } + } } diff --git a/resources/assets/js/components/page-comments.js b/resources/assets/js/components/page-comments.js index 975ff5a82..cabce9139 100644 --- a/resources/assets/js/components/page-comments.js +++ b/resources/assets/js/components/page-comments.js @@ -1,4 +1,6 @@ import MarkdownIt from "markdown-it"; +import {scrollAndHighlightElement} from "../services/util"; + const md = new MarkdownIt({ html: false }); class PageComments { @@ -25,8 +27,8 @@ class PageComments { handleAction(event) { let actionElem = event.target.closest('[action]'); if (event.target.matches('a[href^="#"]')) { - let id = event.target.href.split('#')[1]; - window.scrollAndHighlight(document.querySelector('#' + id)); + const id = event.target.href.split('#')[1]; + scrollAndHighlightElement(document.querySelector('#' + id)); } if (actionElem === null) return; event.preventDefault(); @@ -132,7 +134,7 @@ class PageComments { this.formContainer.parentNode.style.display = 'block'; this.elem.querySelector('[comment-add-button-container]').style.display = 'none'; this.formInput.focus(); - window.scrollToElement(this.formInput); + this.formInput.scrollIntoView({behavior: "smooth"}); } hideForm() { diff --git a/resources/assets/js/components/page-display.js b/resources/assets/js/components/page-display.js index 513a07b8d..2be1c1c48 100644 --- a/resources/assets/js/components/page-display.js +++ b/resources/assets/js/components/page-display.js @@ -1,5 +1,7 @@ import Clipboard from "clipboard/dist/clipboard.min"; import Code from "../services/code"; +import * as DOM from "../services/dom"; +import {scrollAndHighlightElement} from "../services/util"; class PageDisplay { @@ -9,7 +11,6 @@ class PageDisplay { Code.highlight(); this.setupPointer(); - this.setupStickySidebar(); this.setupNavHighlighting(); // Check the hash on load @@ -19,167 +20,135 @@ class PageDisplay { } // Sidebar page nav click event - $('.sidebar-page-nav').on('click', 'a', event => { - window.components['tri-layout'][0].showContent(); - this.goToText(event.target.getAttribute('href').substr(1)); - }); + const sidebarPageNav = document.querySelector('.sidebar-page-nav'); + if (sidebarPageNav) { + DOM.onChildEvent(sidebarPageNav, 'a', 'click', (event, child) => { + event.preventDefault(); + window.components['tri-layout'][0].showContent(); + const contentId = child.getAttribute('href').substr(1); + this.goToText(contentId); + window.history.pushState(null, null, '#' + contentId); + }); + } } goToText(text) { - let idElem = document.getElementById(text); - $('.page-content [data-highlighted]').attr('data-highlighted', '').css('background-color', ''); + const idElem = document.getElementById(text); + + DOM.forEach('.page-content [data-highlighted]', elem => { + elem.removeAttribute('data-highlighted'); + elem.style.backgroundColor = null; + }); + if (idElem !== null) { - window.scrollAndHighlight(idElem); + scrollAndHighlightElement(idElem); } else { - $('.page-content').find(':contains("' + text + '")').smoothScrollTo(); + const textElem = DOM.findText('.page-content > div > *', text); + if (textElem) { + scrollAndHighlightElement(textElem); + } } } setupPointer() { - if (document.getElementById('pointer') === null) return; + let pointer = document.getElementById('pointer'); + if (!pointer) { + return; + } + // Set up pointer - let $pointer = $('#pointer').detach(); + pointer = pointer.parentNode.removeChild(pointer); + const pointerInner = pointer.querySelector('div.pointer'); + + // Instance variables let pointerShowing = false; - let $pointerInner = $pointer.children('div.pointer').first(); let isSelection = false; let pointerModeLink = true; let pointerSectionId = ''; // Select all contents on input click - $pointer.on('click', 'input', event => { - $(this).select(); + DOM.onChildEvent(pointer, 'input', 'click', (event, input) => { + input.select(); event.stopPropagation(); }); - $pointer.on('click focus', event => { + // Prevent closing pointer when clicked or focused + DOM.onEvents(pointer, ['click', 'focus'], event => { event.stopPropagation(); }); // Pointer mode toggle - $pointer.on('click', 'span.icon', event => { + DOM.onChildEvent(pointer, 'span.icon', 'click', (event, icon) => { event.stopPropagation(); - let $icon = $(event.currentTarget); pointerModeLink = !pointerModeLink; - $icon.find('[data-icon="include"]').toggle(!pointerModeLink); - $icon.find('[data-icon="link"]').toggle(pointerModeLink); + icon.querySelector('[data-icon="include"]').style.display = (!pointerModeLink) ? 'inline' : 'none'; + icon.querySelector('[data-icon="link"]').style.display = (pointerModeLink) ? 'inline' : 'none'; updatePointerContent(); }); // Set up clipboard - let clipboard = new Clipboard($pointer[0].querySelector('button')); + new Clipboard(pointer.querySelector('button')); // Hide pointer when clicking away - $(document.body).find('*').on('click focus', event => { + DOM.onEvents(document.body, ['click', 'focus'], event => { if (!pointerShowing || isSelection) return; - $pointer.detach(); + pointer = pointer.parentElement.removeChild(pointer); pointerShowing = false; }); - let updatePointerContent = ($elem) => { + let updatePointerContent = (element) => { let inputText = pointerModeLink ? window.baseUrl(`/link/${this.pageId}#${pointerSectionId}`) : `{{@${this.pageId}#${pointerSectionId}}}`; - if (pointerModeLink && inputText.indexOf('http') !== 0) inputText = window.location.protocol + "//" + window.location.host + inputText; + if (pointerModeLink && !inputText.startsWith('http')) { + inputText = window.location.protocol + "//" + window.location.host + inputText; + } - $pointer.find('input').val(inputText); + pointer.querySelector('input').value = inputText; - // update anchor if present - const $editAnchor = $pointer.find('#pointer-edit'); - if ($editAnchor.length !== 0 && $elem) { - const editHref = $editAnchor.data('editHref'); - const element = $elem[0]; + // Update anchor if present + const editAnchor = pointer.querySelector('#pointer-edit'); + if (editAnchor && element) { + const editHref = editAnchor.dataset.editHref; const elementId = element.id; // get the first 50 characters. - let queryContent = element.textContent && element.textContent.substring(0, 50); - $editAnchor[0].href = `${editHref}?content-id=${elementId}&content-text=${encodeURIComponent(queryContent)}`; + const queryContent = element.textContent && element.textContent.substring(0, 50); + editAnchor.href = `${editHref}?content-id=${elementId}&content-text=${encodeURIComponent(queryContent)}`; } }; // Show pointer when selecting a single block of tagged content - $('.page-content [id^="bkmrk"]').on('mouseup keyup', function (e) { - e.stopPropagation(); - let selection = window.getSelection(); - if (selection.toString().length === 0) return; + DOM.forEach('.page-content [id^="bkmrk"]', bookMarkElem => { + DOM.onEvents(bookMarkElem, ['mouseup', 'keyup'], event => { + event.stopPropagation(); + let selection = window.getSelection(); + if (selection.toString().length === 0) return; - // Show pointer and set link - let $elem = $(this); - pointerSectionId = $elem.attr('id'); - updatePointerContent($elem); + // Show pointer and set link + pointerSectionId = bookMarkElem.id; + updatePointerContent(bookMarkElem); - $elem.before($pointer); - $pointer.show(); - pointerShowing = true; + bookMarkElem.parentNode.insertBefore(pointer, bookMarkElem); + pointer.style.display = 'block'; + pointerShowing = true; + isSelection = true; - // Set pointer to sit near mouse-up position - let pointerLeftOffset = (e.pageX - $elem.offset().left - ($pointerInner.width() / 2)); - if (pointerLeftOffset < 0) pointerLeftOffset = 0; - let pointerLeftOffsetPercent = (pointerLeftOffset / $elem.width()) * 100; - $pointerInner.css('left', pointerLeftOffsetPercent + '%'); + // Set pointer to sit near mouse-up position + requestAnimationFrame(() => { + const bookMarkBounds = bookMarkElem.getBoundingClientRect(); + let pointerLeftOffset = (event.pageX - bookMarkBounds.left - 164); + if (pointerLeftOffset < 0) { + pointerLeftOffset = 0 + } + const pointerLeftOffsetPercent = (pointerLeftOffset / bookMarkBounds.width) * 100; - isSelection = true; - setTimeout(() => { - isSelection = false; - }, 100); - }); - } + pointerInner.style.left = pointerLeftOffsetPercent + '%'; - setupStickySidebar() { - // Make the sidebar stick in view on scroll - const $window = $(window); - const $sidebar = $("#sidebar .scroll-body"); - const $sidebarContainer = $sidebar.parent(); - const sidebarHeight = $sidebar.height() + 32; + setTimeout(() => { + isSelection = false; + }, 100); + }); - // Check the page is scrollable and the content is taller than the tree - const pageScrollable = ($(document).height() > ($window.height() + 40)) && (sidebarHeight < $('.page-content').height()); - - // Get current tree's width and header height - const headerHeight = $("#header").height() + $(".toolbar").height(); - let isFixed = $window.scrollTop() > headerHeight; - - // Fix the tree as a sidebar - function stickTree() { - $sidebar.width($sidebarContainer.width() + 15); - $sidebar.addClass("fixed"); - isFixed = true; - } - - // Un-fix the tree back into position - function unstickTree() { - $sidebar.css('width', 'auto'); - $sidebar.removeClass("fixed"); - isFixed = false; - } - - // Checks if the tree stickiness state should change - function checkTreeStickiness(skipCheck) { - let shouldBeFixed = $window.scrollTop() > headerHeight; - if (shouldBeFixed && (!isFixed || skipCheck)) { - stickTree(); - } else if (!shouldBeFixed && (isFixed || skipCheck)) { - unstickTree(); - } - } - // The event ran when the window scrolls - function windowScrollEvent() { - checkTreeStickiness(false); - } - - // If the page is scrollable and the window is wide enough listen to scroll events - // and evaluate tree stickiness. - if (pageScrollable && $window.width() > 1000) { - $window.on('scroll', windowScrollEvent); - checkTreeStickiness(true); - } - - // Handle window resizing and switch between desktop/mobile views - $window.on('resize', event => { - if (pageScrollable && $window.width() > 1000) { - $window.on('scroll', windowScrollEvent); - checkTreeStickiness(true); - } else { - $window.off('scroll', windowScrollEvent); - unstickTree(); - } + }); }); } @@ -222,10 +191,9 @@ class PageDisplay { } function toggleAnchorHighlighting(elementId, shouldHighlight) { - const anchorsToHighlight = pageNav.querySelectorAll('a[href="#' + elementId + '"]'); - for (let anchor of anchorsToHighlight) { + DOM.forEach('a[href="#' + elementId + '"]', anchor => { anchor.closest('li').classList.toggle('current-heading', shouldHighlight); - } + }); } } } diff --git a/resources/assets/js/components/setting-app-color-picker.js b/resources/assets/js/components/setting-app-color-picker.js new file mode 100644 index 000000000..6c0c0b31d --- /dev/null +++ b/resources/assets/js/components/setting-app-color-picker.js @@ -0,0 +1,56 @@ + +class SettingAppColorPicker { + + constructor(elem) { + this.elem = elem; + this.colorInput = elem.querySelector('input[type=color]'); + this.lightColorInput = elem.querySelector('input[name="setting-app-color-light"]'); + this.resetButton = elem.querySelector('[setting-app-color-picker-reset]'); + + this.colorInput.addEventListener('change', this.updateColor.bind(this)); + this.colorInput.addEventListener('input', this.updateColor.bind(this)); + this.resetButton.addEventListener('click', event => { + this.colorInput.value = '#206ea7'; + this.updateColor(); + }); + } + + /** + * Update the app colors as a preview, and create a light version of the color. + */ + updateColor() { + const hexVal = this.colorInput.value; + const rgb = this.hexToRgb(hexVal); + const rgbLightVal = 'rgba('+ [rgb.r, rgb.g, rgb.b, '0.15'].join(',') +')'; + + this.lightColorInput.value = rgbLightVal; + + const customStyles = document.getElementById('custom-styles'); + const oldColor = customStyles.getAttribute('data-color'); + const oldColorLight = customStyles.getAttribute('data-color-light'); + + customStyles.innerHTML = customStyles.innerHTML.split(oldColor).join(hexVal); + customStyles.innerHTML = customStyles.innerHTML.split(oldColorLight).join(rgbLightVal); + + customStyles.setAttribute('data-color', hexVal); + customStyles.setAttribute('data-color-light', rgbLightVal); + } + + /** + * Covert a hex color code to rgb components. + * @attribution https://stackoverflow.com/a/5624139 + * @param hex + * @returns {*} + */ + hexToRgb(hex) { + const result = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(hex); + return { + r: result ? parseInt(result[1], 16) : 0, + g: result ? parseInt(result[2], 16) : 0, + b: result ? parseInt(result[3], 16) : 0 + }; + } + +} + +export default SettingAppColorPicker; \ No newline at end of file diff --git a/resources/assets/js/components/shelf-sort.js b/resources/assets/js/components/shelf-sort.js index 86fb5e143..38e8ae8d3 100644 --- a/resources/assets/js/components/shelf-sort.js +++ b/resources/assets/js/components/shelf-sort.js @@ -1,25 +1,26 @@ -import "jquery-sortable"; +import Sortable from "sortablejs"; class ShelfSort { constructor(elem) { this.elem = elem; - this.sortGroup = this.initSortable(); this.input = document.getElementById('books-input'); + this.shelfBooksList = elem.querySelector('[shelf-sort-assigned-books]'); + + this.initSortable(); this.setupListeners(); } initSortable() { - const placeHolderContent = this.getPlaceholderHTML(); - // TODO - Load sortable at this point - return $('.scroll-box').sortable({ - group: 'shelf-books', - exclude: '.instruction,.scroll-box-placeholder', - containerSelector: 'div.scroll-box', - itemSelector: '.scroll-box-item', - placeholder: placeHolderContent, - onDrop: this.onDrop.bind(this) - }); + const scrollBoxes = this.elem.querySelectorAll('.scroll-box'); + for (let scrollBox of scrollBoxes) { + new Sortable(scrollBox, { + group: 'shelf-books', + ghostClass: 'primary-background-light', + animation: 150, + onSort: this.onChange.bind(this), + }); + } } setupListeners() { @@ -45,27 +46,11 @@ class ShelfSort { this.onChange(); } - onDrop($item, container, _super) { - this.onChange(); - _super($item, container); - } - onChange() { - const data = this.sortGroup.sortable('serialize').get(); - this.input.value = data[0].map(item => item.id).join(','); - const instruction = this.elem.querySelector('.scroll-box-item.instruction'); - instruction.parentNode.insertBefore(instruction, instruction.parentNode.children[0]); + const shelfBookElems = Array.from(this.shelfBooksList.querySelectorAll('[data-id]')); + this.input.value = shelfBookElems.map(elem => elem.getAttribute('data-id')).join(','); } - getPlaceholderHTML() { - const placeHolder = document.querySelector('.scroll-box-placeholder'); - placeHolder.style.display = 'block'; - const placeHolderContent = placeHolder.outerHTML; - placeHolder.style.display = 'none'; - return placeHolderContent; - } - - } export default ShelfSort; \ No newline at end of file diff --git a/resources/assets/js/components/template-manager.js b/resources/assets/js/components/template-manager.js new file mode 100644 index 000000000..d004a4307 --- /dev/null +++ b/resources/assets/js/components/template-manager.js @@ -0,0 +1,94 @@ +import * as DOM from "../services/dom"; + +class TemplateManager { + + constructor(elem) { + this.elem = elem; + this.list = elem.querySelector('[template-manager-list]'); + this.searching = false; + + // Template insert action buttons + DOM.onChildEvent(this.elem, '[template-action]', 'click', this.handleTemplateActionClick.bind(this)); + + // Template list pagination click + DOM.onChildEvent(this.elem, '.pagination a', 'click', this.handlePaginationClick.bind(this)); + + // Template list item content click + DOM.onChildEvent(this.elem, '.template-item-content', 'click', this.handleTemplateItemClick.bind(this)); + + // Template list item drag start + DOM.onChildEvent(this.elem, '.template-item', 'dragstart', this.handleTemplateItemDragStart.bind(this)); + + this.setupSearchBox(); + } + + handleTemplateItemClick(event, templateItem) { + const templateId = templateItem.closest('[template-id]').getAttribute('template-id'); + this.insertTemplate(templateId, 'replace'); + } + + handleTemplateItemDragStart(event, templateItem) { + const templateId = templateItem.closest('[template-id]').getAttribute('template-id'); + event.dataTransfer.setData('bookstack/template', templateId); + event.dataTransfer.setData('text/plain', templateId); + } + + handleTemplateActionClick(event, actionButton) { + event.stopPropagation(); + + const action = actionButton.getAttribute('template-action'); + const templateId = actionButton.closest('[template-id]').getAttribute('template-id'); + this.insertTemplate(templateId, action); + } + + async insertTemplate(templateId, action = 'replace') { + const resp = await window.$http.get(`/templates/${templateId}`); + const eventName = 'editor::' + action; + window.$events.emit(eventName, resp.data); + } + + async handlePaginationClick(event, paginationLink) { + event.preventDefault(); + const paginationUrl = paginationLink.getAttribute('href'); + const resp = await window.$http.get(paginationUrl); + this.list.innerHTML = resp.data; + } + + setupSearchBox() { + const searchBox = this.elem.querySelector('.search-box'); + const input = searchBox.querySelector('input'); + const submitButton = searchBox.querySelector('button'); + const cancelButton = searchBox.querySelector('button.search-box-cancel'); + + async function performSearch() { + const searchTerm = input.value; + const resp = await window.$http.get(`/templates`, { + search: searchTerm + }); + cancelButton.style.display = searchTerm ? 'block' : 'none'; + this.list.innerHTML = resp.data; + } + performSearch = performSearch.bind(this); + + // Searchbox enter press + searchBox.addEventListener('keypress', event => { + if (event.key === 'Enter') { + event.preventDefault(); + performSearch(); + } + }); + + // Submit button press + submitButton.addEventListener('click', event => { + performSearch(); + }); + + // Cancel button press + cancelButton.addEventListener('click', event => { + input.value = ''; + performSearch(); + }); + } +} + +export default TemplateManager; \ No newline at end of file diff --git a/resources/assets/js/components/toggle-switch.js b/resources/assets/js/components/toggle-switch.js index 3be67d5dc..b9b96afc5 100644 --- a/resources/assets/js/components/toggle-switch.js +++ b/resources/assets/js/components/toggle-switch.js @@ -6,12 +6,16 @@ class ToggleSwitch { this.input = elem.querySelector('input[type=hidden]'); this.checkbox = elem.querySelector('input[type=checkbox]'); - this.checkbox.addEventListener('change', this.onClick.bind(this)); + this.checkbox.addEventListener('change', this.stateChange.bind(this)); } - onClick(event) { - let checked = this.checkbox.checked; - this.input.value = checked ? 'true' : 'false'; + stateChange() { + this.input.value = (this.checkbox.checked ? 'true' : 'false'); + + // Dispatch change event from hidden input so they can be listened to + // like a normal checkbox. + const changeEvent = new Event('change'); + this.input.dispatchEvent(changeEvent); } } diff --git a/resources/assets/js/components/tri-layout.js b/resources/assets/js/components/tri-layout.js index 5cd49b74f..905ca03b1 100644 --- a/resources/assets/js/components/tri-layout.js +++ b/resources/assets/js/components/tri-layout.js @@ -74,14 +74,14 @@ class TriLayout { * Used by the page-display component. */ showContent() { - this.showTab('content'); + this.showTab('content', false); } /** * Show the given tab * @param tabName */ - showTab(tabName) { + showTab(tabName, scroll = true) { this.scrollCache[this.lastTabShown] = document.documentElement.scrollTop; // Set tab status @@ -96,12 +96,14 @@ class TriLayout { this.elem.classList.toggle('show-info', showInfo); // Set the scroll position from cache - const pageHeader = document.querySelector('header'); - const defaultScrollTop = pageHeader.getBoundingClientRect().bottom; - document.documentElement.scrollTop = this.scrollCache[tabName] || defaultScrollTop; - setTimeout(() => { + if (scroll) { + const pageHeader = document.querySelector('header'); + const defaultScrollTop = pageHeader.getBoundingClientRect().bottom; document.documentElement.scrollTop = this.scrollCache[tabName] || defaultScrollTop; - }, 50); + setTimeout(() => { + document.documentElement.scrollTop = this.scrollCache[tabName] || defaultScrollTop; + }, 50); + } this.lastTabShown = tabName; } diff --git a/resources/assets/js/components/wysiwyg-editor.js b/resources/assets/js/components/wysiwyg-editor.js index 614cfb80f..c03c0d2aa 100644 --- a/resources/assets/js/components/wysiwyg-editor.js +++ b/resources/assets/js/components/wysiwyg-editor.js @@ -168,23 +168,24 @@ function codePlugin() { }); } - function codeMirrorContainerToPre($codeMirrorContainer) { - let textArea = $codeMirrorContainer[0].querySelector('textarea'); - let code = textArea.textContent; - let lang = $codeMirrorContainer[0].getAttribute('data-lang'); + function codeMirrorContainerToPre(codeMirrorContainer) { + const textArea = codeMirrorContainer.querySelector('textarea'); + const code = textArea.textContent; + const lang = codeMirrorContainer.getAttribute('data-lang'); - $codeMirrorContainer.removeAttr('contentEditable'); - let $pre = $('
    ');
    -        $pre.append($('').each((index, elem) => {
    -            // Needs to be textContent since innerText produces BR:s
    -            elem.textContent = code;
    -        }).attr('class', `language-${lang}`));
    -        $codeMirrorContainer.replaceWith($pre);
    +        codeMirrorContainer.removeAttribute('contentEditable');
    +        const pre = document.createElement('pre');
    +        const codeElem = document.createElement('code');
    +        codeElem.classList.add(`language-${lang}`);
    +        codeElem.textContent = code;
    +        pre.appendChild(codeElem);
    +
    +        codeMirrorContainer.parentElement.replaceChild(pre, codeMirrorContainer);
         }
     
         window.tinymce.PluginManager.add('codeeditor', function(editor, url) {
     
    -        let $ = editor.$;
    +        const $ = editor.$;
     
             editor.addButton('codeeditor', {
                 text: 'Code block',
    @@ -198,10 +199,8 @@ function codePlugin() {
     
             // Convert
             editor.on('PreProcess', function (e) {
    -            $('div.CodeMirrorContainer', e.node).
    -            each((index, elem) => {
    -                let $elem = $(elem);
    -                codeMirrorContainerToPre($elem);
    +            $('div.CodeMirrorContainer', e.node).each((index, elem) => {
    +                codeMirrorContainerToPre(elem);
                 });
             });
     
    @@ -217,10 +216,10 @@ function codePlugin() {
                 $('.CodeMirrorContainer').filter((index ,elem) => {
                     return typeof elem.querySelector('.CodeMirror').CodeMirror === 'undefined';
                 }).each((index, elem) => {
    -                codeMirrorContainerToPre($(elem));
    +                codeMirrorContainerToPre(elem);
                 });
     
    -            let codeSamples = $('body > pre').filter((index, elem) => {
    +            const codeSamples = $('body > pre').filter((index, elem) => {
                     return elem.contentEditable !== "false";
                 });
     
    @@ -341,7 +340,7 @@ function drawIoPlugin() {
             });
     
             editor.on('SetContent', function () {
    -            let drawings = editor.$('body > div[drawio-diagram]');
    +            const drawings = editor.$('body > div[drawio-diagram]');
                 if (!drawings.length) return;
     
                 editor.undoManager.transact(function () {
    @@ -379,6 +378,27 @@ function customHrPlugin() {
     }
     
     
    +function listenForBookStackEditorEvents(editor) {
    +
    +    // Replace editor content
    +    window.$events.listen('editor::replace', ({html}) => {
    +        editor.setContent(html);
    +    });
    +
    +    // Append editor content
    +    window.$events.listen('editor::append', ({html}) => {
    +        const content = editor.getContent() + html;
    +        editor.setContent(content);
    +    });
    +
    +    // Prepend editor content
    +    window.$events.listen('editor::prepend', ({html}) => {
    +        const content = html + editor.getContent();
    +        editor.setContent(content);
    +    });
    +
    +}
    +
     class WysiwygEditor {
     
         constructor(elem) {
    @@ -472,9 +492,10 @@ class WysiwygEditor {
     
                     if (type === 'file') {
                         window.EntitySelectorPopup.show(function(entity) {
    -                        let originalField = win.document.getElementById(field_name);
    +                        const originalField = win.document.getElementById(field_name);
                             originalField.value = entity.link;
    -                        $(originalField).closest('.mce-form').find('input').eq(2).val(entity.name);
    +                        const mceForm = originalField.closest('.mce-form');
    +                        mceForm.querySelectorAll('input')[2].value = entity.name;
                         });
                     }
     
    @@ -553,6 +574,10 @@ class WysiwygEditor {
                         editor.focus();
                     }
     
    +                listenForBookStackEditorEvents(editor);
    +
    +                // TODO - Update to standardise across both editors
    +                // Use events within listenForBookStackEditorEvents instead (Different event signature)
                     window.$events.listen('editor-html-update', html => {
                         editor.setContent(html);
                         editor.selection.select(editor.getBody(), true);
    @@ -583,6 +608,18 @@ class WysiwygEditor {
                         let dom = editor.dom,
                             rng = tinymce.dom.RangeUtils.getCaretRangeFromPoint(event.clientX, event.clientY, editor.getDoc());
     
    +                    // Template insertion
    +                    const templateId = event.dataTransfer.getData('bookstack/template');
    +                    if (templateId) {
    +                        event.preventDefault();
    +                        window.$http.get(`/templates/${templateId}`).then(resp => {
    +                            editor.selection.setRng(rng);
    +                            editor.undoManager.transact(function () {
    +                                editor.execCommand('mceInsertContent', false, resp.data.html);
    +                            });
    +                        });
    +                    }
    +
                         // Don't allow anything to be dropped in a captioned image.
                         if (dom.getParent(rng.startContainer, '.mceTemp')) {
                             event.preventDefault();
    diff --git a/resources/assets/js/index.js b/resources/assets/js/index.js
    index f202c322e..e0c7b34e5 100644
    --- a/resources/assets/js/index.js
    +++ b/resources/assets/js/index.js
    @@ -1,6 +1,3 @@
    -// Global Polyfills
    -import "./services/dom-polyfills"
    -
     // Url retrieval function
     window.baseUrl = function(path) {
         let basePath = document.querySelector('meta[name="base-url"]').getAttribute('content');
    @@ -11,27 +8,24 @@ window.baseUrl = function(path) {
     
     // Set events and http services on window
     import Events from "./services/events"
    -import Http from "./services/http"
    -let httpInstance = Http();
    +import httpInstance from "./services/http"
    +const eventManager = new Events();
     window.$http = httpInstance;
    -window.$events = new Events();
    +window.$events = eventManager;
     
     // Translation setup
     // Creates a global function with name 'trans' to be used in the same way as Laravel's translation system
     import Translations from "./services/translations"
    -let translator = new Translations(window.translations);
    +const translator = new Translations();
     window.trans = translator.get.bind(translator);
     window.trans_choice = translator.getPlural.bind(translator);
     
    -// Load in global UI helpers and libraries including jQuery
    -import "./services/global-ui"
    -
    -// Set services on Vue
    +// Make services available to Vue instances
     import Vue from "vue"
     Vue.prototype.$http = httpInstance;
    -Vue.prototype.$events = window.$events;
    +Vue.prototype.$events = eventManager;
     
    -// Load vues and components
    +// Load Vues and components
     import vues from "./vues/vues"
     import components from "./components"
     vues();
    diff --git a/resources/assets/js/services/animations.js b/resources/assets/js/services/animations.js
    new file mode 100644
    index 000000000..8a3e9a57b
    --- /dev/null
    +++ b/resources/assets/js/services/animations.js
    @@ -0,0 +1,106 @@
    +/**
    + * Fade out the given element.
    + * @param {Element} element
    + * @param {Number} animTime
    + * @param {Function|null} onComplete
    + */
    +export function fadeOut(element, animTime = 400, onComplete = null) {
    +    animateStyles(element, {
    +        opacity: ['1', '0']
    +    }, animTime, () => {
    +        element.style.display = 'none';
    +        if (onComplete) onComplete();
    +    });
    +}
    +
    +/**
    + * Hide the element by sliding the contents upwards.
    + * @param {Element} element
    + * @param {Number} animTime
    + */
    +export function slideUp(element, animTime = 400) {
    +    const currentHeight = element.getBoundingClientRect().height;
    +    const computedStyles = getComputedStyle(element);
    +    const currentPaddingTop = computedStyles.getPropertyValue('padding-top');
    +    const currentPaddingBottom = computedStyles.getPropertyValue('padding-bottom');
    +    const animStyles = {
    +        height: [`${currentHeight}px`, '0px'],
    +        overflow: ['hidden', 'hidden'],
    +        paddingTop: [currentPaddingTop, '0px'],
    +        paddingBottom: [currentPaddingBottom, '0px'],
    +    };
    +
    +    animateStyles(element, animStyles, animTime, () => {
    +        element.style.display = 'none';
    +    });
    +}
    +
    +/**
    + * Show the given element by expanding the contents.
    + * @param {Element} element - Element to animate
    + * @param {Number} animTime - Animation time in ms
    + */
    +export function slideDown(element, animTime = 400) {
    +    element.style.display = 'block';
    +    const targetHeight = element.getBoundingClientRect().height;
    +    const computedStyles = getComputedStyle(element);
    +    const targetPaddingTop = computedStyles.getPropertyValue('padding-top');
    +    const targetPaddingBottom = computedStyles.getPropertyValue('padding-bottom');
    +    const animStyles = {
    +        height: ['0px', `${targetHeight}px`],
    +        overflow: ['hidden', 'hidden'],
    +        paddingTop: ['0px', targetPaddingTop],
    +        paddingBottom: ['0px', targetPaddingBottom],
    +    };
    +
    +    animateStyles(element, animStyles, animTime);
    +}
    +
    +/**
    + * Used in the function below to store references of clean-up functions.
    + * Used to ensure only one transitionend function exists at any time.
    + * @type {WeakMap}
    + */
    +const animateStylesCleanupMap = new WeakMap();
    +
    +/**
    + * Animate the css styles of an element using FLIP animation techniques.
    + * Styles must be an object where the keys are style properties, camelcase, and the values
    + * are an array of two items in the format [initialValue, finalValue]
    + * @param {Element} element
    + * @param {Object} styles
    + * @param {Number} animTime
    + * @param {Function} onComplete
    + */
    +function animateStyles(element, styles, animTime = 400, onComplete = null) {
    +    const styleNames = Object.keys(styles);
    +    for (let style of styleNames) {
    +        element.style[style] = styles[style][0];
    +    }
    +
    +    const cleanup = () => {
    +        for (let style of styleNames) {
    +            element.style[style] = null;
    +        }
    +        element.style.transition = null;
    +        element.removeEventListener('transitionend', cleanup);
    +        if (onComplete) onComplete();
    +    };
    +
    +    setTimeout(() => {
    +        requestAnimationFrame(() => {
    +            element.style.transition = `all ease-in-out ${animTime}ms`;
    +            for (let style of styleNames) {
    +                element.style[style] = styles[style][1];
    +            }
    +
    +            if (animateStylesCleanupMap.has(element)) {
    +                const oldCleanup = animateStylesCleanupMap.get(element);
    +                element.removeEventListener('transitionend', oldCleanup);
    +            }
    +
    +            element.addEventListener('transitionend', cleanup);
    +            animateStylesCleanupMap.set(element, cleanup);
    +        });
    +    }, 10);
    +}
    \ No newline at end of file
    diff --git a/resources/assets/js/services/dom-polyfills.js b/resources/assets/js/services/dom-polyfills.js
    deleted file mode 100644
    index d32af9118..000000000
    --- a/resources/assets/js/services/dom-polyfills.js
    +++ /dev/null
    @@ -1,22 +0,0 @@
    -/**
    - * Polyfills for DOM API's
    - */
    -
    -// https://developer.mozilla.org/en-US/docs/Web/API/Element/matches
    -if (!Element.prototype.matches) {
    -    Element.prototype.matches = Element.prototype.msMatchesSelector || Element.prototype.webkitMatchesSelector;
    -}
    -
    -// https://developer.mozilla.org/en-US/docs/Web/API/Element/closest#Browser_compatibility
    -if (!Element.prototype.closest) {
    -    Element.prototype.closest = function (s) {
    -        var el = this;
    -        var ancestor = this;
    -        if (!document.documentElement.contains(el)) return null;
    -        do {
    -            if (ancestor.matches(s)) return ancestor;
    -            ancestor = ancestor.parentElement;
    -        } while (ancestor !== null);
    -        return null;
    -    };
    -}
    \ No newline at end of file
    diff --git a/resources/assets/js/services/dom.js b/resources/assets/js/services/dom.js
    new file mode 100644
    index 000000000..966a4540e
    --- /dev/null
    +++ b/resources/assets/js/services/dom.js
    @@ -0,0 +1,75 @@
    +/**
    + * Run the given callback against each element that matches the given selector.
    + * @param {String} selector
    + * @param {Function} callback
    + */
    +export function forEach(selector, callback) {
    +    const elements = document.querySelectorAll(selector);
    +    for (let element of elements) {
    +        callback(element);
    +    }
    +}
    +
    +/**
    + * Helper to listen to multiple DOM events
    + * @param {Element} listenerElement
    + * @param {Array} events
    + * @param {Function} callback
    + */
    +export function onEvents(listenerElement, events, callback) {
    +    for (let eventName of events) {
    +        listenerElement.addEventListener(eventName, callback);
    +    }
    +}
    +
    +/**
    + * Helper to run an action when an element is selected.
    + * A "select" is made to be accessible, So can be a click, space-press or enter-press.
    + * @param listenerElement
    + * @param callback
    + */
    +export function onSelect(listenerElement, callback) {
    +    listenerElement.addEventListener('click', callback);
    +    listenerElement.addEventListener('keydown', (event) => {
    +        if (event.key === 'Enter' || event.key === ' ') {
    +            event.preventDefault();
    +            callback(event);
    +        }
    +    });
    +}
    +
    +/**
    + * Set a listener on an element for an event emitted by a child
    + * matching the given childSelector param.
    + * Used in a similar fashion to jQuery's $('listener').on('eventName', 'childSelector', callback)
    + * @param {Element} listenerElement
    + * @param {String} childSelector
    + * @param {String} eventName
    + * @param {Function} callback
    + */
    +export function onChildEvent(listenerElement, childSelector, eventName, callback) {
    +    listenerElement.addEventListener(eventName, function(event) {
    +        const matchingChild = event.target.closest(childSelector);
    +        if (matchingChild) {
    +            callback.call(matchingChild, event, matchingChild);
    +        }
    +    });
    +}
    +
    +/**
    + * Look for elements that match the given selector and contain the given text.
    + * Is case insensitive and returns the first result or null if nothing is found.
    + * @param {String} selector
    + * @param {String} text
    + * @returns {Element}
    + */
    +export function findText(selector, text) {
    +    const elements = document.querySelectorAll(selector);
    +    text = text.toLowerCase();
    +    for (let element of elements) {
    +        if (element.textContent.toLowerCase().includes(text)) {
    +            return element;
    +        }
    +    }
    +    return null;
    +}
    \ No newline at end of file
    diff --git a/resources/assets/js/services/global-ui.js b/resources/assets/js/services/global-ui.js
    deleted file mode 100644
    index 948e8e880..000000000
    --- a/resources/assets/js/services/global-ui.js
    +++ /dev/null
    @@ -1,58 +0,0 @@
    -// Global jQuery Config & Extensions
    -
    -import jQuery from "jquery"
    -window.jQuery = window.$ = jQuery;
    -
    -/**
    - * Scroll the view to a specific element.
    - * @param {HTMLElement} element
    - */
    -window.scrollToElement = function(element) {
    -    if (!element) return;
    -    let offset = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop;
    -    let top = element.getBoundingClientRect().top + offset;
    -    $('html, body').animate({
    -        scrollTop: top - 60 // Adjust to change final scroll position top margin
    -    }, 300);
    -};
    -
    -/**
    - * Scroll and highlight an element.
    - * @param {HTMLElement} element
    - */
    -window.scrollAndHighlight = function(element) {
    -    if (!element) return;
    -    window.scrollToElement(element);
    -    let color = document.getElementById('custom-styles').getAttribute('data-color-light');
    -    let initColor = window.getComputedStyle(element).getPropertyValue('background-color');
    -    element.style.backgroundColor = color;
    -    setTimeout(() => {
    -        element.classList.add('selectFade');
    -        element.style.backgroundColor = initColor;
    -    }, 10);
    -    setTimeout(() => {
    -        element.classList.remove('selectFade');
    -        element.style.backgroundColor = '';
    -    }, 3000);
    -};
    -
    -// Smooth scrolling
    -jQuery.fn.smoothScrollTo = function () {
    -    if (this.length === 0) return;
    -    window.scrollToElement(this[0]);
    -    return this;
    -};
    -
    -// Making contains text expression not worry about casing
    -jQuery.expr[":"].contains = $.expr.createPseudo(function (arg) {
    -    return function (elem) {
    -        return $(elem).text().toUpperCase().indexOf(arg.toUpperCase()) >= 0;
    -    };
    -});
    -
    -// Detect IE for css
    -if(navigator.userAgent.indexOf('MSIE')!==-1
    -    || navigator.appVersion.indexOf('Trident/') > 0
    -    || navigator.userAgent.indexOf('Safari') !== -1){
    -    document.body.classList.add('flexbox-support');
    -}
    \ No newline at end of file
    diff --git a/resources/assets/js/services/http.js b/resources/assets/js/services/http.js
    index 1e50fe2ae..06cc6a04f 100644
    --- a/resources/assets/js/services/http.js
    +++ b/resources/assets/js/services/http.js
    @@ -1,21 +1,146 @@
    -import axios from "axios"
     
    -function instance() {
    -    let axiosInstance = axios.create({
    -        headers: {
    -            'X-CSRF-TOKEN': document.querySelector('meta[name=token]').getAttribute('content'),
    -            'baseURL': window.baseUrl('')
    -        }
    +/**
    + * Perform a HTTP GET request.
    + * Can easily pass query parameters as the second parameter.
    + * @param {String} url
    + * @param {Object} params
    + * @returns {Promise<{headers: Headers, original: Response, data: (Object|String), redirected: boolean, statusText: string, url: string, status: number}>}
    + */
    +async function get(url, params = {}) {
    +    return request(url, {
    +        method: 'GET',
    +        params,
         });
    -    axiosInstance.interceptors.request.use(resp => {
    -        return resp;
    -    }, err => {
    -        if (typeof err.response === "undefined" || typeof err.response.data === "undefined") return Promise.reject(err);
    -        if (typeof err.response.data.error !== "undefined") window.$events.emit('error', err.response.data.error);
    -        if (typeof err.response.data.message !== "undefined") window.$events.emit('error', err.response.data.message);
    -    });
    -    return axiosInstance;
     }
     
    +/**
    + * Perform a HTTP POST request.
    + * @param {String} url
    + * @param {Object} data
    + * @returns {Promise<{headers: Headers, original: Response, data: (Object|String), redirected: boolean, statusText: string, url: string, status: number}>}
    + */
    +async function post(url, data = null) {
    +    return dataRequest('POST', url, data);
    +}
     
    -export default instance;
    \ No newline at end of file
    +/**
    + * Perform a HTTP PUT request.
    + * @param {String} url
    + * @param {Object} data
    + * @returns {Promise<{headers: Headers, original: Response, data: (Object|String), redirected: boolean, statusText: string, url: string, status: number}>}
    + */
    +async function put(url, data = null) {
    +    return dataRequest('PUT', url, data);
    +}
    +
    +/**
    + * Perform a HTTP PATCH request.
    + * @param {String} url
    + * @param {Object} data
    + * @returns {Promise<{headers: Headers, original: Response, data: (Object|String), redirected: boolean, statusText: string, url: string, status: number}>}
    + */
    +async function patch(url, data = null) {
    +    return dataRequest('PATCH', url, data);
    +}
    +
    +/**
    + * Perform a HTTP DELETE request.
    + * @param {String} url
    + * @param {Object} data
    + * @returns {Promise<{headers: Headers, original: Response, data: (Object|String), redirected: boolean, statusText: string, url: string, status: number}>}
    + */
    +async function performDelete(url, data = null) {
    +    return dataRequest('DELETE', url, data);
    +}
    +
    +/**
    + * Perform a HTTP request to the back-end that includes data in the body.
    + * Parses the body to JSON if an object, setting the correct headers.
    + * @param {String} method
    + * @param {String} url
    + * @param {Object} data
    + * @returns {Promise<{headers: Headers, original: Response, data: (Object|String), redirected: boolean, statusText: string, url: string, status: number}>}
    + */
    +async function dataRequest(method, url, data = null) {
    +    const options = {
    +        method: method,
    +        body: data,
    +    };
    +
    +    if (typeof data === 'object') {
    +        options.headers = {'Content-Type': 'application/json'};
    +        options.body = JSON.stringify(data);
    +    }
    +
    +    return request(url, options)
    +}
    +
    +/**
    + * Create a new HTTP request, setting the required CSRF information
    + * to communicate with the back-end. Parses & formats the response.
    + * @param {String} url
    + * @param {Object} options
    + * @returns {Promise<{headers: Headers, original: Response, data: (Object|String), redirected: boolean, statusText: string, url: string, status: number}>}
    + */
    +async function request(url, options = {}) {
    +    if (!url.startsWith('http')) {
    +        url = window.baseUrl(url);
    +    }
    +
    +    if (options.params) {
    +        const urlObj = new URL(url);
    +        for (let paramName of Object.keys(options.params)) {
    +            const value = options.params[paramName];
    +            if (typeof value !== 'undefined' && value !== null) {
    +                urlObj.searchParams.set(paramName, value);
    +            }
    +        }
    +        url = urlObj.toString();
    +    }
    +
    +    const csrfToken = document.querySelector('meta[name=token]').getAttribute('content');
    +    options = Object.assign({}, options, {
    +        'credentials': 'same-origin',
    +    });
    +    options.headers = Object.assign({}, options.headers || {}, {
    +        'baseURL': window.baseUrl(''),
    +        'X-CSRF-TOKEN': csrfToken,
    +    });
    +
    +    const response = await fetch(url, options);
    +    const content = await getResponseContent(response);
    +    return {
    +        data: content,
    +        headers: response.headers,
    +        redirected: response.redirected,
    +        status: response.status,
    +        statusText: response.statusText,
    +        url: response.url,
    +        original: response,
    +    }
    +}
    +
    +/**
    + * Get the content from a fetch response.
    + * Checks the content-type header to determine the format.
    + * @param response
    + * @returns {Promise}
    + */
    +async function getResponseContent(response) {
    +    const responseContentType = response.headers.get('Content-Type');
    +    const subType = responseContentType.split('/').pop();
    +
    +    if (subType === 'javascript' || subType === 'json') {
    +        return await response.json();
    +    }
    +
    +    return await response.text();
    +}
    +
    +export default {
    +    get: get,
    +    post: post,
    +    put: put,
    +    patch: patch,
    +    delete: performDelete,
    +};
    \ No newline at end of file
    diff --git a/resources/assets/js/services/translations.js b/resources/assets/js/services/translations.js
    index 06b44a580..b595a05e6 100644
    --- a/resources/assets/js/services/translations.js
    +++ b/resources/assets/js/services/translations.js
    @@ -10,7 +10,20 @@ class Translator {
          * @param translations
          */
         constructor(translations) {
    -        this.store = translations;
    +        this.store = new Map();
    +        this.parseTranslations();
    +    }
    +
    +    /**
    +     * Parse translations out of the page and place into the store.
    +     */
    +    parseTranslations() {
    +        const translationMetaTags = document.querySelectorAll('meta[name="translation"]');
    +        for (let tag of translationMetaTags) {
    +            const key = tag.getAttribute('key');
    +            const value = tag.getAttribute('value');
    +            this.store.set(key, value);
    +        }
         }
     
         /**
    @@ -20,7 +33,7 @@ class Translator {
          * @returns {*}
          */
         get(key, replacements) {
    -        let text = this.getTransText(key);
    +        const text = this.getTransText(key);
             return this.performReplacements(text, replacements);
         }
     
    @@ -33,26 +46,24 @@ class Translator {
          * @returns {*}
          */
         getPlural(key, count, replacements) {
    -        let text = this.getTransText(key);
    -        let splitText = text.split('|');
    +        const text = this.getTransText(key);
    +        const splitText = text.split('|');
    +        const exactCountRegex = /^{([0-9]+)}/;
    +        const rangeRegex = /^\[([0-9]+),([0-9*]+)]/;
             let result = null;
    -        let exactCountRegex = /^{([0-9]+)}/;
    -        let rangeRegex = /^\[([0-9]+),([0-9*]+)]/;
    -
    -        for (let i = 0, len = splitText.length; i < len; i++) {
    -            let t = splitText[i];
     
    +        for (let t of splitText) {
                 // Parse exact matches
    -            let exactMatches = t.match(exactCountRegex);
    +            const exactMatches = t.match(exactCountRegex);
                 if (exactMatches !== null && Number(exactMatches[1]) === count) {
                     result = t.replace(exactCountRegex, '').trim();
                     break;
                 }
     
                 // Parse range matches
    -            let rangeMatches = t.match(rangeRegex);
    +            const rangeMatches = t.match(rangeRegex);
                 if (rangeMatches !== null) {
    -                let rangeStart = Number(rangeMatches[1]);
    +                const rangeStart = Number(rangeMatches[1]);
                     if (rangeStart <= count && (rangeMatches[2] === '*' || Number(rangeMatches[2]) >= count)) {
                         result = t.replace(rangeRegex, '').trim();
                         break;
    @@ -64,7 +75,10 @@ class Translator {
                 result = (count === 1) ? splitText[0] : splitText[1];
             }
     
    -        if (result === null) result = splitText[0];
    +        if (result === null) {
    +            result = splitText[0];
    +        }
    +
             return this.performReplacements(result, replacements);
         }
     
    @@ -74,14 +88,10 @@ class Translator {
          * @returns {String|Object}
          */
         getTransText(key) {
    -        let splitKey = key.split('.');
    -        let value = splitKey.reduce((a, b) => {
    -            return a !== undefined ? a[b] : a;
    -        }, this.store);
    +        const value = this.store.get(key);
     
             if (value === undefined) {
    -            console.log(`Translation with key "${key}" does not exist`);
    -            value = key;
    +            console.warn(`Translation with key "${key}" does not exist`);
             }
     
             return value;
    @@ -95,10 +105,10 @@ class Translator {
          */
         performReplacements(string, replacements) {
             if (!replacements) return string;
    -        let replaceMatches = string.match(/:([\S]+)/g);
    +        const replaceMatches = string.match(/:([\S]+)/g);
             if (replaceMatches === null) return string;
             replaceMatches.forEach(match => {
    -            let key = match.substring(1);
    +            const key = match.substring(1);
                 if (typeof replacements[key] === 'undefined') return;
                 string = string.replace(match, replacements[key]);
             });
    diff --git a/resources/assets/js/services/util.js b/resources/assets/js/services/util.js
    new file mode 100644
    index 000000000..b2f291872
    --- /dev/null
    +++ b/resources/assets/js/services/util.js
    @@ -0,0 +1,48 @@
    +
    +
    +/**
    + * Returns a function, that, as long as it continues to be invoked, will not
    + * be triggered. The function will be called after it stops being called for
    + * N milliseconds. If `immediate` is passed, trigger the function on the
    + * leading edge, instead of the trailing.
    + * @attribution https://davidwalsh.name/javascript-debounce-function
    + * @param func
    + * @param wait
    + * @param immediate
    + * @returns {Function}
    + */
    +export function debounce(func, wait, immediate) {
    +    let timeout;
    +    return function() {
    +        const context = this, args = arguments;
    +        const later = function() {
    +            timeout = null;
    +            if (!immediate) func.apply(context, args);
    +        };
    +        const callNow = immediate && !timeout;
    +        clearTimeout(timeout);
    +        timeout = setTimeout(later, wait);
    +        if (callNow) func.apply(context, args);
    +    };
    +};
    +
    +/**
    + * Scroll and highlight an element.
    + * @param {HTMLElement} element
    + */
    +export function scrollAndHighlightElement(element) {
    +    if (!element) return;
    +    element.scrollIntoView({behavior: 'smooth'});
    +
    +    const color = document.getElementById('custom-styles').getAttribute('data-color-light');
    +    const initColor = window.getComputedStyle(element).getPropertyValue('background-color');
    +    element.style.backgroundColor = color;
    +    setTimeout(() => {
    +        element.classList.add('selectFade');
    +        element.style.backgroundColor = initColor;
    +    }, 10);
    +    setTimeout(() => {
    +        element.classList.remove('selectFade');
    +        element.style.backgroundColor = '';
    +    }, 3000);
    +}
    \ No newline at end of file
    diff --git a/resources/assets/js/vues/code-editor.js b/resources/assets/js/vues/code-editor.js
    index d6f9965a8..c6df6b1a5 100644
    --- a/resources/assets/js/vues/code-editor.js
    +++ b/resources/assets/js/vues/code-editor.js
    @@ -3,10 +3,10 @@ import codeLib from "../services/code";
     const methods = {
         show() {
             if (!this.editor) this.editor = codeLib.popupEditor(this.$refs.editor, this.language);
    -        this.$refs.overlay.style.display = 'flex';
    +        this.$refs.overlay.components.overlay.show();
         },
         hide() {
    -        this.$refs.overlay.style.display = 'none';
    +        this.$refs.overlay.components.overlay.hide();
         },
         updateEditorMode(language) {
             codeLib.setMode(this.editor, language);
    diff --git a/resources/assets/js/vues/components/autosuggest.js b/resources/assets/js/vues/components/autosuggest.js
    index 4fe183f02..b809313cb 100644
    --- a/resources/assets/js/vues/components/autosuggest.js
    +++ b/resources/assets/js/vues/components/autosuggest.js
    @@ -6,6 +6,7 @@ const template = `
                 @input="inputUpdate($event.target.value)" @focus="inputUpdate($event.target.value)"
                 @blur="inputBlur"
                 @keydown="inputKeydown"
    +            :aria-label="placeholder"
             />
             
    • { + return this.$http.get(this.url, params).then(resp => { ajaxCache[cacheKey] = resp.data; return resp.data; }); diff --git a/resources/assets/js/vues/components/dropzone.js b/resources/assets/js/vues/components/dropzone.js index 9d3d22b4d..1c045727f 100644 --- a/resources/assets/js/vues/components/dropzone.js +++ b/resources/assets/js/vues/components/dropzone.js @@ -1,14 +1,14 @@ import DropZone from "dropzone"; +import { fadeOut } from "../../services/animations"; const template = ` -
      -
      {{placeholder}}
      +
      +
      `; const props = ['placeholder', 'uploadUrl', 'uploadedTo']; -// TODO - Remove jQuery usage function mounted() { const container = this.$el; const _this = this; @@ -37,7 +37,7 @@ function mounted() { dz.on('success', function (file, data) { _this.$emit('success', {file, data}); - $(file.previewElement).fadeOut(400, function () { + fadeOut(file.previewElement, 800, () => { dz.removeFile(file); }); }); @@ -46,7 +46,8 @@ function mounted() { _this.$emit('error', {file, errorMessage, xhr}); function setMessage(message) { - $(file.previewElement).find('[data-dz-errormessage]').text(message); + const messsageEl = file.previewElement.querySelector('[data-dz-errormessage]'); + messsageEl.textContent = message; } if (xhr && xhr.status === 413) { diff --git a/resources/assets/js/vues/image-manager.js b/resources/assets/js/vues/image-manager.js index dd1d9d17a..6df12d16d 100644 --- a/resources/assets/js/vues/image-manager.js +++ b/resources/assets/js/vues/image-manager.js @@ -57,14 +57,14 @@ const methods = { }, async fetchData() { - let query = { + const params = { page, search: this.searching ? this.searchTerm : null, uploaded_to: this.uploadedTo || null, filter_type: this.filter, }; - const {data} = await this.$http.get(baseUrl, {params: query}); + const {data} = await this.$http.get(baseUrl, params); this.images = this.images.concat(data.images); this.hasMore = data.has_more; page++; diff --git a/resources/assets/js/vues/page-editor.js b/resources/assets/js/vues/page-editor.js index 864a3a906..fbf2857a4 100644 --- a/resources/assets/js/vues/page-editor.js +++ b/resources/assets/js/vues/page-editor.js @@ -69,8 +69,8 @@ let methods = { autoSave = window.setInterval(() => { // Return if manually saved recently to prevent bombarding the server if (Date.now() - lastSave < (1000 * autoSaveFrequency)/2) return; - let newTitle = document.getElementById('name').value.trim(); - let newHtml = this.editorHTML; + const newTitle = document.getElementById('name').value.trim(); + const newHtml = this.editorHTML; if (newTitle !== currentContent.title || newHtml !== currentContent.html) { currentContent.html = newHtml; @@ -84,18 +84,18 @@ let methods = { saveDraft() { if (!this.draftsEnabled) return; - let data = { + const data = { name: document.getElementById('name').value.trim(), html: this.editorHTML }; if (this.editorType === 'markdown') data.markdown = this.editorMarkdown; - let url = window.baseUrl(`/ajax/page/${this.pageId}/save-draft`); + const url = window.baseUrl(`/ajax/page/${this.pageId}/save-draft`); window.$http.put(url, data).then(response => { draftErroring = false; if (!this.isNewDraft) this.isUpdateDraft = true; - this.draftNotifyChange(`${response.data.message } ${Dates.utcTimeStampToLocalTime(response.data.timestamp)}`); + this.draftNotifyChange(`${response.data.message} ${Dates.utcTimeStampToLocalTime(response.data.timestamp)}`); lastSave = Date.now(); }, errorRes => { if (draftErroring) return; diff --git a/resources/assets/js/vues/tag-manager.js b/resources/assets/js/vues/tag-manager.js index e0dab595a..65233cbb6 100644 --- a/resources/assets/js/vues/tag-manager.js +++ b/resources/assets/js/vues/tag-manager.js @@ -1,7 +1,7 @@ import draggable from 'vuedraggable'; import autosuggest from './components/autosuggest'; -let data = { +const data = { entityId: false, entityType: null, tags: [], @@ -10,7 +10,7 @@ let data = { const components = {draggable, autosuggest}; const directives = {}; -let methods = { +const methods = { addEmptyTag() { this.tags.push({name: '', value: '', key: Math.random().toString(36).substring(7)}); diff --git a/resources/assets/sass/_blocks.scss b/resources/assets/sass/_blocks.scss index 032b1cbeb..2cb17a18d 100644 --- a/resources/assets/sass/_blocks.scss +++ b/resources/assets/sass/_blocks.scss @@ -83,6 +83,10 @@ line-height: 1; } +.card.border-card { + border: 1px solid #DDD; +} + .card.drag-card { border: 1px solid #DDD; border-radius: 4px; @@ -164,11 +168,6 @@ } } -.bookshelf-grid-item .grid-card-content h2 a { - color: $color-bookshelf; - fill: $color-bookshelf; -} - .book-grid-item .grid-card-footer { p.small { font-size: .8em; diff --git a/resources/assets/sass/_buttons.scss b/resources/assets/sass/_buttons.scss index eb7a09342..e3d9e17ca 100644 --- a/resources/assets/sass/_buttons.scss +++ b/resources/assets/sass/_buttons.scss @@ -1,29 +1,9 @@ button { + background-color: transparent; + border: 0; font-size: 100%; } -@mixin generate-button-colors($textColor, $backgroundColor) { - background-color: $backgroundColor; - color: $textColor; - fill: $textColor; - border: 1px solid $backgroundColor; - &:hover { - background-color: lighten($backgroundColor, 8%); - color: $textColor; - } - &:active { - background-color: darken($backgroundColor, 8%); - } - &:focus { - background-color: lighten($backgroundColor, 4%); - box-shadow: $bs-light; - color: $textColor; - } -} - -// Button Specific Variables -$button-border-radius: 2px; - .button { text-decoration: none; font-size: 0.85rem; @@ -34,34 +14,54 @@ $button-border-radius: 2px; display: inline-block; font-weight: 400; outline: 0; - border-radius: $button-border-radius; + border-radius: 2px; cursor: pointer; - transition: background-color ease-in-out 120ms, box-shadow ease-in-out 120ms; + transition: background-color ease-in-out 120ms, + filter ease-in-out 120ms, + box-shadow ease-in-out 120ms; box-shadow: none; - background-color: $primary; + background-color: var(--color-primary); color: #FFF; fill: #FFF; text-transform: uppercase; - border: 1px solid $primary; + border: 1px solid var(--color-primary); vertical-align: top; - &:hover, &:focus { + &:hover, &:focus, &:active { + background-color: var(--color-primary); text-decoration: none; + color: #FFFFFF; + } + &:hover { + box-shadow: $bs-light; + filter: brightness(110%); + } + &:focus { + outline: 1px dotted currentColor; + outline-offset: -$-xs; + box-shadow: none; + filter: brightness(90%); } &:active { - background-color: darken($primary, 8%); + outline: 0; } } -.button.primary { - @include generate-button-colors(#FFFFFF, $primary); -} + .button.outline { background-color: transparent; - color: #888; - fill: #888; - border: 1px solid #DDD; + color: #666; + fill: currentColor; + border: 1px solid #CCC; &:hover, &:focus, &:active { + border: 1px solid #CCC; box-shadow: none; - background-color: #EEE; + background-color: #F2F2F2; + filter: none; + } + &:active { + border-color: #BBB; + background-color: #DDD; + color: #666; + box-shadow: inset 0 0 2px rgba(0, 0, 0, 0.1); } } @@ -83,12 +83,18 @@ $button-border-radius: 2px; user-select: none; font-size: 0.75rem; line-height: 1.4em; - &:focus, &:active { + color: var(--color-primary); + fill: var(--color-primary); + &:active { outline: 0; } &:hover { text-decoration: none; } + &:hover, &:focus { + color: var(--color-primary); + fill: var(--color-primary); + } } .button.block { @@ -118,6 +124,7 @@ $button-border-radius: 2px; .button[disabled] { background-color: #BBB; cursor: default; + border-color: #CCC; &:hover { background-color: #BBB; cursor: default; diff --git a/resources/assets/sass/_colors.scss b/resources/assets/sass/_colors.scss index 4dfc9d4c3..8623d374a 100644 --- a/resources/assets/sass/_colors.scss +++ b/resources/assets/sass/_colors.scss @@ -1,3 +1,13 @@ +/** + * Background colors + */ + +.primary-background { + background-color: var(--color-primary) !important; +} +.primary-background-light { + background-color: var(--color-primary-light); +} /* * Status text colors @@ -21,52 +31,51 @@ * Style text colors */ .text-primary, .text-primary:hover, .text-primary-hover:hover { - color: $primary !important; - fill: $primary !important; + color: var(--color-primary) !important; + fill: var(--color-primary) !important; } .text-muted { - color: lighten($text-dark, 26%) !important; - fill: lighten($text-dark, 26%) !important; - &.small, .small { - color: lighten($text-dark, 32%) !important; - fill: lighten($text-dark, 32%) !important; - } + color: #575757 !important; + fill: #575757 !important; } /* * Entity text colors */ .text-bookshelf, .text-bookshelf:hover { - color: $color-bookshelf; - fill: $color-bookshelf; + color: var(--color-bookshelf); + fill: var(--color-bookshelf); } .text-book, .text-book:hover { - color: $color-book; - fill: $color-book; + color: var(--color-book); + fill: var(--color-book); } .text-page, .text-page:hover { - color: $color-page; - fill: $color-page; + color: var(--color-page); + fill: var(--color-page); } .text-page.draft, .text-page.draft:hover { - color: $color-page-draft; - fill: $color-page-draft; + color: var(--color-page-draft); + fill: var(--color-page-draft); } .text-chapter, .text-chapter:hover { - color: $color-chapter; - fill: $color-chapter; + color: var(--color-chapter); + fill: var(--color-chapter); } /* - * Entity background colors + * Standard & Entity background colors */ +.bg-white { + background-color: #FFFFFF; +} .bg-book { - background-color: $color-book; + background-color: var(--color-book); } .bg-chapter { - background-color: $color-chapter; + background-color: var(--color-chapter); } .bg-shelf { - background-color: $color-bookshelf; + background-color: var(--color-bookshelf); } \ No newline at end of file diff --git a/resources/assets/sass/_components.scss b/resources/assets/sass/_components.scss index 039ac4dc8..0172956a7 100644 --- a/resources/assets/sass/_components.scss +++ b/resources/assets/sass/_components.scss @@ -115,6 +115,9 @@ .popup-content { overflow-y: auto; } + &:focus { + outline: 0; + } } .popup-footer button, .popup-header-close { @@ -147,9 +150,6 @@ padding: 8px $-m; } } -.popup-footer { - margin-top: 1px; -} body.flexbox-support #entity-selector-wrap .popup-body .form-group { height: 444px; min-height: 444px; @@ -579,6 +579,20 @@ body.flexbox-support #entity-selector-wrap .popup-body .form-group { } } +.nav-tabs { + text-align: center; + a, .tab-item { + padding: $-m; + display: inline-block; + color: #666; + fill: #666; + cursor: pointer; + &.selected { + border-bottom: 2px solid var(--color-primary); + } + } +} + .image-picker .none { display: none; } @@ -620,7 +634,7 @@ body.flexbox-support #entity-selector-wrap .popup-body .form-group { opacity: 0; transition: opacity ease-in-out 120ms; } - &:hover .actions { + &:hover .actions, &:focus-within .actions { opacity: 1; } } @@ -637,7 +651,6 @@ body.flexbox-support #entity-selector-wrap .popup-body .form-group { } a { color: #666; } span { - color: #888; padding-left: $-xxs; } } @@ -655,4 +668,32 @@ body.flexbox-support #entity-selector-wrap .popup-body .form-group { } .permissions-table tr:hover [permissions-table-toggle-all-in-row] { display: inline; +} + +.template-item { + cursor: pointer; + position: relative; + &:hover, .template-item-actions button:hover { + background-color: #F2F2F2; + } + .template-item-actions { + position: absolute; + top: 0; + right: 0; + width: 50px; + height: 100%; + display: flex; + flex-direction: column; + border-left: 1px solid #DDD; + } + .template-item-actions button { + cursor: pointer; + flex: 1; + background: #FFF; + border: 0; + border-top: 1px solid #DDD; + } + .template-item-actions button:first-child { + border-top: 0; + } } \ No newline at end of file diff --git a/resources/assets/sass/_forms.scss b/resources/assets/sass/_forms.scss index a177129ef..64308b29e 100644 --- a/resources/assets/sass/_forms.scss +++ b/resources/assets/sass/_forms.scss @@ -20,7 +20,8 @@ background: url(); } &:focus { - outline: 0; + border-color: var(--color-primary); + outline: 1px solid var(--color-primary); } } @@ -92,16 +93,18 @@ } .markdown-display { - padding: 0 $-m 0; margin-left: -1px; - overflow-y: scroll; - &.page-content { - margin: 0 auto; - width: 100%; - max-width: 100%; +} + +.markdown-editor-display { + background-color: #FFFFFF; + body { + background-color: #FFFFFF; + padding-left: 16px; + padding-right: 16px; } [drawio-diagram]:hover { - outline: 2px solid $primary; + outline: 2px solid var(--color-primary); } } @@ -158,7 +161,8 @@ table.form-table { } } -input[type="text"], input[type="number"], input[type="email"], input[type="date"], input[type="search"], input[type="url"], input[type="password"], select, textarea { +input[type="text"], input[type="number"], input[type="email"], input[type="date"], input[type="search"], input[type="url"], +input[type="color"], input[type="password"], select, textarea { @extend .input-base; } @@ -166,6 +170,10 @@ input[type=date] { width: 190px; } +input[type=color] { + height: 60px; +} + .toggle-switch { user-select: none; display: inline-grid; @@ -264,6 +272,9 @@ input[type=date] { margin-left: -$-m; margin-right: -$-m; padding: $-s $-m; + display: block; + width: calc(100% + 32px); + text-align: left; } .collapse-title, .collapse-title label { cursor: pointer; @@ -337,16 +348,16 @@ div[editor-type="markdown"] .title-input.page-title input[type="text"] { button { background-color: transparent; border: none; - color: $primary; + fill: #666; padding: 0; cursor: pointer; position: absolute; left: 8px; - top: 9.5px; + top: 9px; } input { display: block; - padding-left: $-l; + padding-left: $-l + 4px; width: 300px; max-width: 100%; } @@ -375,3 +386,18 @@ div[editor-type="markdown"] .title-input.page-title input[type="text"] { background-color: #BBB; max-width: 100%; } + +.custom-file-input { + overflow: hidden; + padding: 0; + position: absolute; + white-space: nowrap; + width: 1px; + height: 1px; + border: 0; + clip: rect(0, 0, 0, 0); +} +.custom-file-input:focus + label { + border-color: var(--color-primary); + outline: 1px solid var(--color-primary); +} \ No newline at end of file diff --git a/resources/assets/sass/_header.scss b/resources/assets/sass/_header.scss index c4ca4607a..687ddd8d2 100644 --- a/resources/assets/sass/_header.scss +++ b/resources/assets/sass/_header.scss @@ -16,9 +16,8 @@ header .grid { header { position: relative; display: block; - z-index: 6; + z-index: 11; top: 0; - background-color: $primary-dark; color: #fff; fill: #fff; border-bottom: 1px solid #DDD; @@ -47,9 +46,7 @@ header { } .user-name { vertical-align: top; - padding-top: $-m; position: relative; - top: -3px; display: inline-block; cursor: pointer; > * { @@ -73,6 +70,9 @@ header { } } +.header *, .primary-background * { + outline-color: #FFF; +} .header-search { @@ -88,6 +88,10 @@ header .search-box { color: #EEE; z-index: 2; padding-left: 40px; + &:focus { + outline: none; + border: 1px solid rgba(255, 255, 255, 0.6); + } } button { fill: #EEE; @@ -103,12 +107,6 @@ header .search-box { ::-moz-placeholder { /* Firefox 19+ */ color: #DDD; } - :-ms-input-placeholder { /* IE 10+ */ - color: #DDD; - } - :-moz-placeholder { /* Firefox 18- */ - color: #DDD; - } @include between($l, $xl) { max-width: 200px; } @@ -243,7 +241,7 @@ header .search-box { line-height: 0.8; margin: -2px 0 0; } - &:hover { + &:hover, &:focus-within { opacity: 1; } } @@ -372,18 +370,4 @@ header .search-box { .action-buttons .dropdown-container:last-child a { padding-left: $-xs; } -} - -.nav-tabs { - text-align: center; - a, .tab-item { - padding: $-m; - display: inline-block; - color: #666; - fill: #666; - cursor: pointer; - &.selected { - border-bottom: 2px solid $primary; - } - } } \ No newline at end of file diff --git a/resources/assets/sass/_html.scss b/resources/assets/sass/_html.scss index 7c3a3c49b..de48c8ed1 100644 --- a/resources/assets/sass/_html.scss +++ b/resources/assets/sass/_html.scss @@ -1,5 +1,10 @@ * { box-sizing: border-box; + outline-color: #444444; +} + +*:focus { + outline-style: dotted; } html { diff --git a/resources/assets/sass/_layout.scss b/resources/assets/sass/_layout.scss index d9fff3c41..1a7ff2cab 100644 --- a/resources/assets/sass/_layout.scss +++ b/resources/assets/sass/_layout.scss @@ -116,6 +116,7 @@ body.flexbox { min-height: 0; max-width: 100%; position: relative; + overflow-y: hidden; } .flex { @@ -219,12 +220,19 @@ body.flexbox { @include smaller-than($xxl) { .tri-layout-container { grid-template-areas: "c b b" - "a b b"; + "a b b" + ". b b"; grid-template-columns: 1fr 3fr; - grid-template-rows: max-content min-content; + grid-template-rows: min-content min-content 1fr; padding-right: $-l; } } +@include between($l, $xxl) { + .tri-layout-left { + position: sticky; + top: $-m; + } +} @include larger-than($xxl) { .tri-layout-left-contents, .tri-layout-right-contents { padding: $-m; @@ -294,13 +302,17 @@ body.flexbox { .tri-layout-mobile-tabs { display: none; } - .tri-layout-left-contents > div, .tri-layout-right-contents > div { + .tri-layout-left-contents > *, .tri-layout-right-contents > * { opacity: 0.6; transition: opacity ease-in-out 120ms; &:hover { opacity: 1; } + &:focus-within { + opacity: 1; + } } + } @include smaller-than($m) { diff --git a/resources/assets/sass/_lists.scss b/resources/assets/sass/_lists.scss index cafbfa781..7c7cc4b35 100644 --- a/resources/assets/sass/_lists.scss +++ b/resources/assets/sass/_lists.scss @@ -59,6 +59,8 @@ .chapter-expansion-toggle { border-radius: 0 4px 4px 0; padding: $-xs $-m; + width: 100%; + text-align: left; } .chapter-expansion-toggle:hover { background-color: rgba(0, 0, 0, 0.06); @@ -108,7 +110,7 @@ padding-left: $nav-indent; } .h2 { - padding-left: $nav-indent; + padding-left: $nav-indent * 1.5; } .h3 { padding-left: $nav-indent * 2; @@ -230,9 +232,20 @@ } .sort-box { margin-bottom: $-m; - border: 2px solid rgba($color-book, 0.6); padding: $-m $-xl; - border-radius: 4px; + position: relative; + &::before { + content: ''; + border-radius: 4px; + opacity: 0.5; + border: 2px solid var(--color-book); + display: block; + top: 0; + bottom: 0; + left: 0; + right: 0; + position: absolute; + } } .sort-box-options { display: flex; @@ -264,12 +277,9 @@ border: 1px solid #DDD; margin-top: -1px; min-height: 38px; - &.text-chapter { - border-left: 2px solid $color-chapter; - } - &.text-page { - border-left: 2px solid $color-page; - } + } + li.text-page, li.text-chapter { + border-left: 2px solid currentColor; } li:first-child { margin-top: $-xs; @@ -287,8 +297,6 @@ display: grid; grid-template-columns: min-content 1fr; grid-column-gap: $-m; - color: #888; - fill: #888; font-size: 0.9em; } .card .activity-list-item { @@ -361,8 +369,8 @@ ul.pagination { margin-top: 0; } .page.draft .text-page { - color: $color-page-draft; - fill: $color-page-draft; + color: var(--color-page-draft); + fill: var(--color-page-draft); } > .dropdown-container { display: block; @@ -416,6 +424,11 @@ ul.pagination { background-color: transparent; border-color: rgba(0, 0, 0, 0.1); } + &:focus { + background-color: #eee; + outline: 1px dotted #666; + outline-offset: -2px; + } } .entity-list-item-path-sep { @@ -551,11 +564,16 @@ ul.pagination { display: block; padding: $-xs $-m; color: #555; - fill: #555; + fill: currentColor; white-space: nowrap; - &:hover { + &:hover, &:focus { text-decoration: none; - background-color: #EEE; + background-color: var(--color-primary-light); + color: var(--color-primary); + } + &:focus { + outline: 1px solid var(--color-primary); + outline-offset: -2px; } svg { margin-right: $-s; diff --git a/resources/assets/sass/_pages.scss b/resources/assets/sass/_pages.scss index c58f6ef47..86db8782e 100755 --- a/resources/assets/sass/_pages.scss +++ b/resources/assets/sass/_pages.scss @@ -20,6 +20,10 @@ } } +body.mce-fullscreen .page-editor .edit-area { + z-index: 12; +} + @include smaller-than($s) { .page-edit-toolbar { overflow-x: scroll; @@ -141,10 +145,12 @@ } .pointer { border: 1px solid #CCC; - display: inline-block; + display: flex; + align-items: center; + justify-items: center; padding: $-s $-s; border-radius: 4px; - box-shadow: 0 0 8px 1px rgba(212, 209, 209, 0.35); + box-shadow: 0 0 12px 1px rgba(212, 209, 209, 0.3); position: absolute; top: -60px; background-color:#FFF; @@ -171,13 +177,6 @@ border-right: 1px solid #CCC; z-index: 56; } - input { - background-color: #FFF; - border: 1px solid #DDD; - color: #666; - width: 172px; - z-index: 40; - } input, button, a { position: relative; border-radius: 0; @@ -186,14 +185,20 @@ vertical-align: top; padding: 5px 16px; } - > i { - color: #888; - font-size: 18px; - padding-top: 4px; + input { + background-color: #FFF; + border: 1px solid #DDD; + color: #666; + width: 172px; + z-index: 40; + padding: 5px 10px; } span.icon { + fill: #444; cursor: pointer; user-select: none; + display: inline-block; + line-height: 1; } .input-group .button { line-height: 1; @@ -201,11 +206,8 @@ box-shadow: none; } a.button { - margin: 0 0 0 0; - - &:hover { - fill: #fff; - } + margin: 0; + color: #FFF; } .svg-icon { width: 1.2em; @@ -256,15 +258,15 @@ padding: 0; margin: 0; } - .tabs > span { + .tabs > button { display: block; cursor: pointer; padding: $-s $-m; - font-size: 13.5px; + font-size: 16px; line-height: 1.6; border-bottom: 1px solid rgba(255, 255, 255, 0.3); } - &.open .tabs > span.active { + &.open .tabs > button.active { fill: #444; background-color: rgba(0, 0, 0, 0.1); } diff --git a/resources/assets/sass/_text.scss b/resources/assets/sass/_text.scss index 1a613898e..315f08c34 100644 --- a/resources/assets/sass/_text.scss +++ b/resources/assets/sass/_text.scss @@ -90,14 +90,14 @@ h2.list-heading { * Link styling */ a { - color: $primary; + color: var(--color-primary); + fill: var(--color-primary); cursor: pointer; text-decoration: none; - transition: color ease-in-out 80ms; + transition: filter ease-in-out 80ms; line-height: 1.6; &:hover { text-decoration: underline; - color: darken($primary, 20%); } &.icon { display: inline-block; @@ -106,6 +106,10 @@ a { position: relative; display: inline-block; } + &:focus img:only-child { + outline: 2px dashed var(--color-primary); + outline-offset: 2px; + } } .blended-links a { @@ -195,7 +199,7 @@ pre { blockquote { display: block; position: relative; - border-left: 4px solid $primary; + border-left: 4px solid var(--color-primary); background-color: #F8F8F8; padding: $-s $-m $-s $-xl; &:before { @@ -239,7 +243,6 @@ pre code { } span.highlight { - //background-color: rgba($primary, 0.2); font-weight: bold; padding: 2px 4px; } @@ -329,6 +332,12 @@ li.checkbox-item, li.task-list-item { overflow-wrap: break-word; } +.limit-text { + white-space: nowrap; + overflow: hidden; + text-overflow: ellipsis; +} + /** * Grouping */ diff --git a/resources/assets/sass/_tinymce.scss b/resources/assets/sass/_tinymce.scss index 1596feb76..27c3b28d0 100644 --- a/resources/assets/sass/_tinymce.scss +++ b/resources/assets/sass/_tinymce.scss @@ -47,6 +47,8 @@ display: flex !important; flex-direction: column; align-items: stretch; + -webkit-overflow-scrolling:touch; + overflow:auto; iframe { flex: 1; } @@ -59,6 +61,7 @@ .page-content.mce-content-body { padding-top: 16px; + outline: none; } // Fix to prevent 'No color' option from not being clickable. diff --git a/resources/assets/sass/_variables.scss b/resources/assets/sass/_variables.scss index 041b70edf..2d4d3970a 100644 --- a/resources/assets/sass/_variables.scss +++ b/resources/assets/sass/_variables.scss @@ -41,21 +41,21 @@ $fs-m: 14px; $fs-s: 12px; // Colours -$primary: #0288D1; -$primary-dark: #0288D1; -$secondary: #cf4d03; +:root { + --color-primary: #206ea7; + --color-primary-light: rgba(32,110,167,0.15); + + --color-page: #206ea7; + --color-page-draft: #7e50b1; + --color-chapter: #af4d0d; + --color-book: #077b70; + --color-bookshelf: #a94747; +} + $positive: #0f7d15; $negative: #ab0f0e; -$info: $primary; -$warning: $secondary; -$primary-faded: rgba(21, 101, 192, 0.15); - -// Item Colors -$color-bookshelf: #af5a5a; -$color-book: #009688; -$color-chapter: #d7804a; -$color-page: $primary; -$color-page-draft: #9A60DA; +$info: #0288D1; +$warning: #cf4d03; // Text colours $text-dark: #444; diff --git a/resources/assets/sass/print-styles.scss b/resources/assets/sass/print-styles.scss index 44107f2d4..296afbe76 100644 --- a/resources/assets/sass/print-styles.scss +++ b/resources/assets/sass/print-styles.scss @@ -4,39 +4,32 @@ header { display: none; } -body { +html, body { font-size: 12px; + background-color: #FFF; } .page-content { margin: 0 auto; } -.flex-fill { - display: block; -} - -.flex.sidebar + .flex.content { - border-left: none; -} - .print-hidden { - display: none; + display: none !important; } -.print-full-width { - width: 100%; - float: none; +.tri-layout-container { + grid-template-columns: 1fr; + grid-template-areas: "b"; + margin-left: 0; + margin-right: 0; display: block; } -h2 { - font-size: 2em; - line-height: 1; - margin-top: 0.6em; - margin-bottom: 0.3em; +.card { + box-shadow: none; } -.comments-container { - display: none; +.content-wrap.card { + padding-left: 0; + padding-right: 0; } \ No newline at end of file diff --git a/resources/assets/sass/styles.scss b/resources/assets/sass/styles.scss index 3fbbcf1da..8f1fef70c 100644 --- a/resources/assets/sass/styles.scss +++ b/resources/assets/sass/styles.scss @@ -75,17 +75,17 @@ $loadingSize: 10px; animation-iteration-count: infinite; animation-timing-function: cubic-bezier(.62, .28, .23, .99); margin-right: 4px; - background-color: $color-page; + background-color: var(--color-page); animation-delay: 0.3s; } > div:first-child { left: -($loadingSize+$-xs); - background-color: $color-book; + background-color: var(--color-book); animation-delay: 0s; } > div:last-of-type { left: $loadingSize+$-xs; - background-color: $color-chapter; + background-color: var(--color-chapter); animation-delay: 0.6s; } > span { @@ -99,7 +99,7 @@ $loadingSize: 10px; // Back to top link $btt-size: 40px; [back-to-top] { - background-color: $primary; + background-color: var(--color-primary); position: fixed; bottom: $-m; right: $-l; @@ -187,7 +187,7 @@ $btt-size: 40px; margin-bottom: 0; } .entity-list-item.selected { - background-color: rgba(0, 0, 0, 0.15) !important; + background-color: rgba(0, 0, 0, 0.05) !important; } .loading { height: 400px; @@ -216,12 +216,23 @@ $btt-size: 40px; .scroll-box-item { padding: $-xs $-m; border-bottom: 1px solid #DDD; + border-top: 1px solid #DDD; + margin-top: -1px; &:last-child { border-bottom: 0; } } } +.scroll-box[data-instruction]:before { + content: attr(data-instruction); + padding: $-xs $-m; + border-bottom: 1px solid #DDD; + display: block; + font-size: 0.75rem; + color: #666; +} + .fullscreen { border:0; position:fixed; @@ -249,7 +260,7 @@ $btt-size: 40px; .list-sort-label { font-weight: bold; display: inline-block; - color: #888; + color: #555; } .list-sort-type { text-align: left; diff --git a/resources/lang/de/activities.php b/resources/lang/de/activities.php index be2eb54b8..35b2c9f8a 100644 --- a/resources/lang/de/activities.php +++ b/resources/lang/de/activities.php @@ -17,7 +17,6 @@ return [ 'page_restore' => 'stellt Seite wieder her', 'page_restore_notification' => 'Die Seite wurde erfolgreich wiederhergestellt.', 'page_move' => 'verschiebt Seite', - 'page_move_notification' => 'Die Seite wurde erfolgreich verschoben.', // Chapters 'chapter_create' => 'erstellt Kapitel', diff --git a/resources/lang/de/auth.php b/resources/lang/de/auth.php index 7b1ebec6e..46d4070b8 100644 --- a/resources/lang/de/auth.php +++ b/resources/lang/de/auth.php @@ -30,6 +30,8 @@ return [ 'remember_me' => 'Angemeldet bleiben', 'ldap_email_hint' => 'Bitte geben Sie eine E-Mail-Adresse ein, um diese mit dem Account zu nutzen.', 'create_account' => 'Account registrieren', + 'already_have_account' => 'Bereits ein Konto erstellt?', + 'dont_have_account' => 'Noch kein Konto erstellt?', 'social_login' => 'Mit Sozialem Netzwerk anmelden', 'social_registration' => 'Mit Sozialem Netzwerk registrieren', 'social_registration_text' => 'Mit einer dieser Dienste registrieren oder anmelden', diff --git a/resources/lang/de/common.php b/resources/lang/de/common.php index 5579a488a..97b48ce4d 100644 --- a/resources/lang/de/common.php +++ b/resources/lang/de/common.php @@ -10,6 +10,7 @@ return [ 'save' => 'Speichern', 'continue' => 'Weiter', 'select' => 'Auswählen', + 'toggle_all' => 'Alle umschalten', 'more' => 'Mehr', /** @@ -26,6 +27,7 @@ return [ */ 'actions' => 'Aktionen', 'view' => 'Anzeigen', + 'view_all' => 'Alle anzeigen', 'create' => 'Anlegen', 'update' => 'Aktualisieren', 'edit' => 'Bearbeiten', @@ -40,6 +42,11 @@ return [ 'remove' => 'Entfernen', 'add' => 'Hinzufügen', + // Sort Options + 'sort_name' => 'Name', + 'sort_created_at' => 'Erstellungsdatum', + 'sort_updated_at' => 'Aktualisierungsdatum', + /** * Misc */ @@ -52,6 +59,7 @@ return [ 'details' => 'Details', 'grid_view' => 'Gitteransicht', 'list_view' => 'Listenansicht', + 'default' => 'Voreinstellung', /** * Header @@ -59,6 +67,10 @@ return [ 'view_profile' => 'Profil ansehen', 'edit_profile' => 'Profil bearbeiten', + // Layout tabs + 'tab_info' => 'Info', + 'tab_content' => 'Inhalt', + /** * Email Content */ diff --git a/resources/lang/de/entities.php b/resources/lang/de/entities.php index 07a92e2c7..d67419543 100644 --- a/resources/lang/de/entities.php +++ b/resources/lang/de/entities.php @@ -8,6 +8,7 @@ return [ 'recently_updated_pages' => 'Kürzlich aktualisierte Seiten', 'recently_created_chapters' => 'Kürzlich angelegte Kapitel', 'recently_created_books' => 'Kürzlich angelegte Bücher', + 'recently_created_shelves' => 'Kürzlich angelegte Regale', 'recently_update' => 'Kürzlich aktualisiert', 'recently_viewed' => 'Kürzlich angesehen', 'recent_activity' => 'Kürzliche Aktivität', @@ -49,28 +50,32 @@ return [ 'search_content_type' => 'Inhaltstyp', 'search_exact_matches' => 'Exakte Treffer', 'search_tags' => 'Nach Schlagwort suchen', + 'search_options' => 'Optionen', 'search_viewed_by_me' => 'Schon von mir angesehen', 'search_not_viewed_by_me' => 'Noch nicht von mir angesehen', 'search_permissions_set' => 'Berechtigungen gesetzt', 'search_created_by_me' => 'Von mir erstellt', 'search_updated_by_me' => 'Von mir aktualisiert', + 'search_date_options' => 'Datums Optionen', 'search_updated_before' => 'Aktualisiert vor', 'search_updated_after' => 'Aktualisiert nach', 'search_created_before' => 'Erstellt vor', 'search_created_after' => 'Erstellt nach', 'search_set_date' => 'Datum auswählen', 'search_update' => 'Suche aktualisieren', - + /* * Shelves */ 'shelf' => 'Regal', 'shelves' => 'Regale', + 'x_shelves' => ':count Regal|:count Regale', 'shelves_long' => 'Bücherregal', 'shelves_empty' => 'Es wurden noch keine Regale angelegt', 'shelves_create' => 'Erzeuge ein Regal', 'shelves_popular' => 'Beliebte Regale', 'shelves_new' => 'Kürzlich erstellte Regale', + 'shelves_new_action' => 'Neues Regal', 'shelves_popular_empty' => 'Die beliebtesten Regale werden hier angezeigt.', 'shelves_new_empty' => 'Die neusten Regale werden hier angezeigt.', 'shelves_save' => 'Regal speichern', @@ -92,7 +97,7 @@ return [ 'shelves_copy_permissions' => 'Berechtigungen kopieren', 'shelves_copy_permissions_explain' => 'Hiermit werden die Berechtigungen des aktuellen Regals auf alle enthaltenen Bücher übertragen. Überprüfen Sie vor der Aktivierung, ob alle Berechtigungsänderungen am aktuellen Regal gespeichert wurden.', 'shelves_copy_permission_success' => 'Regal-Berechtigungen wurden zu :count Büchern kopiert', - + /** * Books */ @@ -103,6 +108,7 @@ return [ 'books_popular' => 'Beliebte Bücher', 'books_recent' => 'Kürzlich angesehene Bücher', 'books_new' => 'Neue Bücher', + 'books_new_action' => 'Neues Buch', 'books_popular_empty' => 'Die beliebtesten Bücher werden hier angezeigt.', 'books_new_empty' => 'Die neusten Bücher werden hier angezeigt.', 'books_create' => 'Neues Buch erstellen', @@ -118,7 +124,6 @@ return [ 'books_permissions_updated' => 'Buch-Berechtigungen aktualisiert', 'books_empty_contents' => 'Es sind noch keine Seiten oder Kapitel zu diesem Buch hinzugefügt worden.', 'books_empty_create_page' => 'Neue Seite anlegen', - 'books_empty_or' => 'oder', 'books_empty_sort_current_book' => 'Aktuelles Buch sortieren', 'books_empty_add_chapter' => 'Neues Kapitel hinzufügen', 'books_permissions_active' => 'Buch-Berechtigungen aktiv', @@ -126,6 +131,11 @@ return [ 'books_navigation' => 'Buchnavigation', 'books_sort' => 'Buchinhalte sortieren', 'books_sort_named' => 'Buch ":bookName" sortieren', + 'books_sort_name' => 'Sortieren nach Namen', + 'books_sort_created' => 'Sortieren nach Erstellungsdatum', + 'books_sort_updated' => 'Sortieren nach Aktualisierungsdatum', + 'books_sort_chapters_first' => 'Kapitel zuerst', + 'books_sort_chapters_last' => 'Kapitel zuletzt', 'books_sort_show_other' => 'Andere Bücher anzeigen', 'books_sort_save' => 'Neue Reihenfolge speichern', /** @@ -232,6 +242,7 @@ return [ 'page_tags' => 'Seiten-Schlagwörter', 'chapter_tags' => 'Kapitel-Schlagwörter', 'book_tags' => 'Buch-Schlagwörter', + 'shelf_tags' => 'Regal-Schlagwörter', 'tag' => 'Schlagwort', 'tags' => 'Schlagwörter', 'tag_value' => 'Inhalt (Optional)', @@ -270,6 +281,7 @@ return [ 'profile_not_created_pages' => ':userName hat noch keine Seiten erstellt.', 'profile_not_created_chapters' => ':userName hat noch keine Kapitel erstellt.', 'profile_not_created_books' => ':userName hat noch keine Bücher erstellt.', + 'profile_not_created_shelves' => ':userName hat noch keine Regale erstellt.', /** * Comments */ @@ -294,6 +306,7 @@ return [ * Revision */ 'revision_delete_confirm' => 'Sind Sie sicher, dass Sie diese Revision löschen wollen?', + 'revision_restore_confirm' => 'Sind Sie sicher, dass Sie diese Revision wiederherstellen wollen? Der aktuelle Seiteninhalt wird ersetzt.', 'revision_delete_success' => 'Revision gelöscht', 'revision_cannot_delete_latest' => 'Die letzte Version kann nicht gelöscht werden.' ]; diff --git a/resources/lang/de/errors.php b/resources/lang/de/errors.php index dc95d1d2b..362641bc8 100644 --- a/resources/lang/de/errors.php +++ b/resources/lang/de/errors.php @@ -30,6 +30,7 @@ return [ 'cannot_get_image_from_url' => 'Bild konnte nicht von der URL :url geladen werden.', 'cannot_create_thumbs' => 'Der Server kann keine Vorschau-Bilder erzeugen. Bitte prüfen Sie, ob die GD PHP-Erweiterung installiert ist.', 'server_upload_limit' => 'Der Server verbietet das Hochladen von Dateien mit dieser Dateigröße. Bitte versuchen Sie es mit einer kleineren Datei.', + 'uploaded' => 'Der Server verbietet das Hochladen von Dateien mit dieser Dateigröße. Bitte versuchen Sie es mit einer kleineren Datei.', 'image_upload_error' => 'Beim Hochladen des Bildes trat ein Fehler auf.', 'image_upload_type_error' => 'Der Bildtyp der hochgeladenen Datei ist ungültig.', 'file_upload_timeout' => 'Der Upload der Datei ist abgelaufen.', @@ -43,6 +44,7 @@ return [ // Entities 'entity_not_found' => 'Eintrag nicht gefunden', 'book_not_found' => 'Buch nicht gefunden', + 'bookshelf_not_found' => 'Regal nicht gefunden', 'page_not_found' => 'Seite nicht gefunden', 'chapter_not_found' => 'Kapitel nicht gefunden', 'selected_book_not_found' => 'Das gewählte Buch wurde nicht gefunden.', @@ -55,6 +57,8 @@ return [ 'role_cannot_be_edited' => 'Diese Rolle kann nicht bearbeitet werden.', 'role_system_cannot_be_deleted' => 'Dies ist eine Systemrolle und kann nicht gelöscht werden', 'role_registration_default_cannot_delete' => 'Diese Rolle kann nicht gelöscht werden, solange sie als Standardrolle für neue Registrierungen gesetzt ist', + 'role_cannot_remove_only_admin' => 'Dieser Benutzer ist der einzige Benutzer, welchem die Administratorrolle zugeordnet ist. Ordnen Sie die Administratorrolle einem anderen Benutzer zu, bevor Sie versuchen, sie hier zu entfernen.', + // Comments 'comment_list' => 'Beim Abrufen der Kommentare ist ein Fehler aufgetreten.', 'cannot_add_comment_to_draft' => 'Du kannst keine Kommentare zu einem Entwurf hinzufügen.', diff --git a/resources/lang/de/settings.php b/resources/lang/de/settings.php index 0a8d50d05..11050924e 100644 --- a/resources/lang/de/settings.php +++ b/resources/lang/de/settings.php @@ -11,10 +11,16 @@ return [ /** * App settings */ - 'app_settings' => 'Anwendungseinstellungen', + 'app_customization' => 'Personalisierung', + 'app_features_security' => 'Funktionen & Sicherheit', 'app_name' => 'Anwendungsname', 'app_name_desc' => 'Dieser Name wird im Header und in E-Mails angezeigt.', 'app_name_header' => 'Anwendungsname im Header anzeigen?', + 'app_public_access' => 'Öffentlicher Zugriff', + 'app_public_access_desc' => 'Wenn Sie diese Option aktivieren, können Besucher, die nicht angemeldet sind, auf Inhalte in Ihrer BookStack-Instanz zugreifen.', + 'app_public_access_desc_guest' => 'Der Zugang für öffentliche Besucher kann über den Benutzer "Guest" gesteuert werden.', + 'app_public_access_toggle' => 'Öffentlichen Zugriff erlauben', + 'app_public_viewing' => 'Öffentliche Ansicht erlauben?', 'app_secure_images' => 'Erhöhte Sicherheit für hochgeladene Bilder aktivieren?', 'app_secure_images_desc' => 'Aus Leistungsgründen sind alle Bilder öffentlich sichtbar. Diese Option fügt zufällige, schwer zu eratene, Zeichenketten zu Bild-URLs hinzu. Stellen sie sicher, dass Verzeichnisindizes deaktiviert sind, um einen einfachen Zugriff zu verhindern.', @@ -28,22 +34,25 @@ return [ 'app_primary_color_desc' => "Dies sollte ein HEX Wert sein.\nWenn Sie nicht eingeben, wird die Anwendung auf die Standardfarbe zurückgesetzt.", 'app_homepage' => 'Startseite der Anwendung', 'app_homepage_desc' => 'Wählen Sie eine Seite als Startseite aus, die statt der Standardansicht angezeigt werden soll. Seitenberechtigungen werden für die ausgewählten Seiten ignoriert.', - 'app_homepage_default' => 'Ausgewählte Startseite', - 'app_homepage_books' => 'Oder wähle die Buch-Übersicht als Startseite. Das wird die Seiten-Auswahl überschreiben.', + 'app_homepage_select' => 'Wählen Sie eine Seite aus', 'app_disable_comments' => 'Kommentare deaktivieren', + 'app_disable_comments_toggle' => 'Kommentare deaktivieren', 'app_disable_comments_desc' => 'Deaktiviert Kommentare über alle Seiten in der Anwendung. Vorhandene Kommentare werden nicht angezeigt.', /** * Registration settings */ 'reg_settings' => 'Registrierungseinstellungen', - 'reg_allow' => 'Registrierung erlauben?', + 'reg_enable' => 'Registrierung erlauben?', + 'reg_enable_toggle' => 'Registrierung erlauben', + 'reg_enable_desc' => 'Wenn die Registrierung erlaubt ist, kann sich der Benutzer als Anwendungsbenutzer anmelden. Bei der Registrierung erhält er eine einzige, voreingestellte Benutzerrolle.', 'reg_default_role' => 'Standard-Benutzerrolle nach Registrierung', - 'reg_confirm_email' => 'Bestätigung per E-Mail erforderlich?', + 'reg_email_confirmation' => 'Bestätigung per E-Mail', + 'reg_email_confirmation_toggle' => 'Bestätigung per E-Mail erforderlich', 'reg_confirm_email_desc' => 'Falls die Einschränkung für Domains genutzt wird, ist die Bestätigung per E-Mail zwingend erforderlich und der untenstehende Wert wird ignoriert.', 'reg_confirm_restrict_domain' => 'Registrierung auf bestimmte Domains einschränken', 'reg_confirm_restrict_domain_desc' => "Fügen sie eine durch Komma getrennte Liste von Domains hinzu, auf die die Registrierung eingeschränkt werden soll. Benutzern wird eine E-Mail gesendet, um ihre E-Mail Adresse zu bestätigen, bevor sie diese Anwendung nutzen können.\nHinweis: Benutzer können ihre E-Mail Adresse nach erfolgreicher Registrierung ändern.", 'reg_confirm_restrict_domain_placeholder' => 'Keine Einschränkung gesetzt', - + /** * Maintenance settings */ @@ -74,6 +83,7 @@ return [ 'role_details' => 'Rollendetails', 'role_name' => 'Rollenname', 'role_desc' => 'Kurzbeschreibung der Rolle', + 'role_external_auth_id' => 'Externe Authentifizierungs-IDs', 'role_system' => 'System-Berechtigungen', 'role_manage_users' => 'Benutzer verwalten', 'role_manage_roles' => 'Rollen und Rollen-Berechtigungen verwalten', @@ -82,6 +92,7 @@ return [ 'role_manage_settings' => 'Globaleinstellungen verwalten', 'role_asset' => 'Berechtigungen', 'role_asset_desc' => 'Diese Berechtigungen gelten für den Standard-Zugriff innerhalb des Systems. Berechtigungen für Bücher, Kapitel und Seiten überschreiben diese Berechtigungenen.', + 'role_asset_admins' => 'Administratoren erhalten automatisch Zugriff auf alle Inhalte, aber diese Optionen können Oberflächenoptionen ein- oder ausblenden.', 'role_all' => 'Alle', 'role_own' => 'Eigene', 'role_controlled_by_asset' => 'Berechtigungen werden vom Uploadziel bestimmt', @@ -96,8 +107,15 @@ return [ 'user_profile' => 'Benutzerprofil', 'users_add_new' => 'Benutzer hinzufügen', 'users_search' => 'Benutzer suchen', + 'users_details' => 'Benutzerdetails', + 'users_details_desc' => 'Legen Sie für diesen Benutzer einen Anzeigenamen und eine E-Mail-Adresse fest. Die E-Mail-Adresse wird bei der Anmeldung verwendet.', + 'users_details_desc_no_email' => 'Legen Sie für diesen Benutzer einen Anzeigenamen fest, damit andere ihn erkennen können.', 'users_role' => 'Benutzerrollen', + 'users_role_desc' => 'Wählen Sie aus, welchen Rollen dieser Benutzer zugeordnet werden soll. Wenn ein Benutzer mehreren Rollen zugeordnet ist, werden die Berechtigungen dieser Rollen gestapelt und er erhält alle Fähigkeiten der zugewiesenen Rollen.', + 'users_password' => 'Benutzerpasswort', + 'users_password_desc' => 'Legen Sie ein Passwort fest, mit dem Sie sich anmelden möchten. Diese muss mindestens 5 Zeichen lang sein.', 'users_external_auth_id' => 'Externe Authentifizierungs-ID', + 'users_external_auth_id_desc' => 'Dies ist die ID, die verwendet wird, um diesen Benutzer bei der Kommunikation mit Ihrem LDAP-System abzugleichen.', 'users_password_warning' => 'Füllen Sie die folgenden Felder nur aus, wenn Sie Ihr Passwort ändern möchten:', 'users_system_public' => 'Dieser Benutzer repräsentiert alle unangemeldeten Benutzer, die diese Seite betrachten. Er kann nicht zum Anmelden benutzt werden, sondern wird automatisch zugeordnet.', 'users_delete' => 'Benutzer löschen', @@ -111,6 +129,7 @@ return [ 'users_avatar' => 'Benutzer-Bild', 'users_avatar_desc' => 'Das Bild sollte eine Auflösung von 256x256px haben.', 'users_preferred_language' => 'Bevorzugte Sprache', + 'users_preferred_language_desc' => 'Diese Option ändert die Sprache, die für die Benutzeroberfläche der Anwendung verwendet wird. Dies hat keinen Einfluss auf von Benutzern erstellte Inhalte.', 'users_social_accounts' => 'Social-Media Konten', 'users_social_accounts_info' => 'Hier können Sie andere Social-Media-Konten für eine schnellere und einfachere Anmeldung verknüpfen. Wenn Sie ein Social-Media Konto lösen, bleibt der Zugriff erhalten. Entfernen Sie in diesem Falle die Berechtigung in Ihren Profil-Einstellungen des verknüpften Social-Media-Kontos.', 'users_social_connect' => 'Social-Media-Konto verknüpfen', diff --git a/resources/lang/de/validation.php b/resources/lang/de/validation.php index 5ac4b1b27..84faeebb7 100644 --- a/resources/lang/de/validation.php +++ b/resources/lang/de/validation.php @@ -38,6 +38,7 @@ return [ 'filled' => ':attribute ist erforderlich.', 'exists' => ':attribute ist ungültig.', 'image' => ':attribute muss ein Bild sein.', + 'image_extension' => ':attribute muss eine gültige und unterstützte Bild-Dateiendung haben.', 'in' => ':attribute ist ungültig.', 'integer' => ':attribute muss eine Zahl sein.', 'ip' => ':attribute muss eine valide IP-Adresse sein.', @@ -54,6 +55,7 @@ return [ 'string' => ':attribute muss mindestens :min Zeichen lang sein.', 'array' => ':attribute muss mindesten :min Elemente enthalten.', ], + 'no_double_extension' => ':attribute darf nur eine gültige Dateiendung', 'not_in' => ':attribute ist ungültig.', 'numeric' => ':attribute muss eine Zahl sein.', 'regex' => ':attribute ist in einem ungültigen Format.', @@ -74,6 +76,7 @@ return [ 'timezone' => ':attribute muss eine valide zeitzone sein.', 'unique' => ':attribute wird bereits verwendet.', 'url' => ':attribute ist kein valides Format.', + 'uploaded' => 'Die Datei konnte nicht hochgeladen werden. Der Server akzeptiert möglicherweise keine Dateien dieser Größe.', /* |-------------------------------------------------------------------------- @@ -90,6 +93,9 @@ return [ 'attribute-name' => [ 'rule-name' => 'custom-message', ], + 'password-confirm' => [ + 'required_with' => 'Passwortbestätigung erforderlich', + ], ], /* diff --git a/resources/lang/en/auth.php b/resources/lang/en/auth.php index 1065945c0..37346097f 100644 --- a/resources/lang/en/auth.php +++ b/resources/lang/en/auth.php @@ -64,4 +64,14 @@ return [ 'email_not_confirmed_click_link' => 'Please click the link in the email that was sent shortly after you registered.', 'email_not_confirmed_resend' => 'If you cannot find the email you can re-send the confirmation email by submitting the form below.', 'email_not_confirmed_resend_button' => 'Resend Confirmation Email', + + // User Invite + 'user_invite_email_subject' => 'You have been invited to join :appName!', + 'user_invite_email_greeting' => 'An account has been created for you on :appName.', + 'user_invite_email_text' => 'Click the button below to set an account password and gain access:', + 'user_invite_email_action' => 'Set Account Password', + 'user_invite_page_welcome' => 'Welcome to :appName!', + 'user_invite_page_text' => 'To finalise your account and gain access you need to set a password which will be used to log-in to :appName on future visits.', + 'user_invite_page_confirm_button' => 'Confirm Password', + 'user_invite_success' => 'Password set, you now have access to :appName!' ]; \ No newline at end of file diff --git a/resources/lang/en/common.php b/resources/lang/en/common.php index ed880afcf..1807217a3 100644 --- a/resources/lang/en/common.php +++ b/resources/lang/en/common.php @@ -40,6 +40,10 @@ return [ 'add' => 'Add', // Sort Options + 'sort_options' => 'Sort Options', + 'sort_direction_toggle' => 'Sort Direction Toggle', + 'sort_ascending' => 'Sort Ascending', + 'sort_descending' => 'Sort Descending', 'sort_name' => 'Name', 'sort_created_at' => 'Created Date', 'sort_updated_at' => 'Updated Date', @@ -55,8 +59,10 @@ return [ 'grid_view' => 'Grid View', 'list_view' => 'List View', 'default' => 'Default', + 'breadcrumb' => 'Breadcrumb', // Header + 'profile_menu' => 'Profile Menu', 'view_profile' => 'View Profile', 'edit_profile' => 'Edit Profile', diff --git a/resources/lang/en/entities.php b/resources/lang/en/entities.php index abcd2cf23..6bbc723b0 100644 --- a/resources/lang/en/entities.php +++ b/resources/lang/en/entities.php @@ -176,7 +176,7 @@ return [ 'pages_delete_confirm' => 'Are you sure you want to delete this page?', 'pages_delete_draft_confirm' => 'Are you sure you want to delete this draft page?', 'pages_editing_named' => 'Editing Page :pageName', - 'pages_edit_toggle_header' => 'Toggle header', + 'pages_edit_draft_options' => 'Draft Options', 'pages_edit_save_draft' => 'Save Draft', 'pages_edit_draft' => 'Edit Page Draft', 'pages_editing_draft' => 'Editing Draft', @@ -234,6 +234,7 @@ return [ ], 'pages_draft_discarded' => 'Draft discarded, The editor has been updated with the current page content', 'pages_specific' => 'Specific Page', + 'pages_is_template' => 'Page Template', // Editor Sidebar 'page_tags' => 'Page Tags', @@ -242,9 +243,11 @@ return [ 'shelf_tags' => 'Shelf Tags', 'tag' => 'Tag', 'tags' => 'Tags', + 'tag_name' => 'Tag Name', 'tag_value' => 'Tag Value (Optional)', 'tags_explain' => "Add some tags to better categorise your content. \n You can assign a value to a tag for more in-depth organisation.", 'tags_add' => 'Add another tag', + 'tags_remove' => 'Remove this tag', 'attachments' => 'Attachments', 'attachments_explain' => 'Upload some files or attach some links to display on your page. These are visible in the page sidebar.', 'attachments_explain_instant_save' => 'Changes here are saved instantly.', @@ -270,6 +273,12 @@ return [ 'attachments_file_uploaded' => 'File successfully uploaded', 'attachments_file_updated' => 'File successfully updated', 'attachments_link_attached' => 'Link successfully attached to page', + 'templates' => 'Templates', + 'templates_set_as_template' => 'Page is a template', + 'templates_explain_set_as_template' => 'You can set this page as a template so its contents be utilized when creating other pages. Other users will be able to use this template if they have view permissions for this page.', + 'templates_replace_content' => 'Replace page content', + 'templates_append_content' => 'Append to page content', + 'templates_prepend_content' => 'Prepend to page content', // Profile View 'profile_user_for_x' => 'User for :time', diff --git a/resources/lang/en/errors.php b/resources/lang/en/errors.php index b91a0c3e1..c3b47744d 100644 --- a/resources/lang/en/errors.php +++ b/resources/lang/en/errors.php @@ -27,6 +27,7 @@ return [ 'social_account_register_instructions' => 'If you do not yet have an account, You can register an account using the :socialAccount option.', 'social_driver_not_found' => 'Social driver not found', 'social_driver_not_configured' => 'Your :socialAccount social settings are not configured correctly.', + 'invite_token_expired' => 'This invitation link has expired. You can instead try to reset your account password.', // System 'path_not_writable' => 'File path :filePath could not be uploaded to. Ensure it is writable to the server.', diff --git a/resources/lang/en/settings.php b/resources/lang/en/settings.php index e6c24f5a1..bb542a588 100755 --- a/resources/lang/en/settings.php +++ b/resources/lang/en/settings.php @@ -29,6 +29,7 @@ return [ 'app_editor_desc' => 'Select which editor will be used by all users to edit pages.', 'app_custom_html' => 'Custom HTML Head Content', 'app_custom_html_desc' => 'Any content added here will be inserted into the bottom of the section of every page. This is handy for overriding styles or adding analytics code.', + 'app_custom_html_disabled_notice' => 'Custom HTML head content is disabled on this settings page to ensure any breaking changes can be reverted.', 'app_logo' => 'Application Logo', 'app_logo_desc' => 'This image should be 43px in height.
      Large images will be scaled down.', 'app_primary_color' => 'Application Primary Color', @@ -84,6 +85,7 @@ return [ 'role_manage_roles' => 'Manage roles & role permissions', 'role_manage_entity_permissions' => 'Manage all book, chapter & page permissions', 'role_manage_own_entity_permissions' => 'Manage permissions on own book, chapter & pages', + 'role_manage_page_templates' => 'Manage page templates', 'role_manage_settings' => 'Manage app settings', 'role_asset' => 'Asset Permissions', 'role_asset_desc' => 'These permissions control default access to the assets within the system. Permissions on Books, Chapters and Pages will override these permissions.', @@ -107,7 +109,9 @@ return [ 'users_role' => 'User Roles', 'users_role_desc' => 'Select which roles this user will be assigned to. If a user is assigned to multiple roles the permissions from those roles will stack and they will receive all abilities of the assigned roles.', 'users_password' => 'User Password', - 'users_password_desc' => 'Set a password used to log-in to the application. This must be at least 5 characters long.', + 'users_password_desc' => 'Set a password used to log-in to the application. This must be at least 6 characters long.', + 'users_send_invite_text' => 'You can choose to send this user an invitation email which allows them to set their own password otherwise you can set their password yourself.', + 'users_send_invite_option' => 'Send user invite email', 'users_external_auth_id' => 'External Authentication ID', 'users_external_auth_id_desc' => 'This is the ID used to match this user when communicating with your LDAP system.', 'users_password_warning' => 'Only fill the below if you would like to change your password.', @@ -125,7 +129,7 @@ return [ 'users_preferred_language' => 'Preferred Language', 'users_preferred_language_desc' => 'This option will change the language used for the user-interface of the application. This will not affect any user-created content.', 'users_social_accounts' => 'Social Accounts', - 'users_social_accounts_info' => 'Here you can connect your other accounts for quicker and easier login. Disconnecting an account here does not previously authorized access. Revoke access from your profile settings on the connected social account.', + 'users_social_accounts_info' => 'Here you can connect your other accounts for quicker and easier login. Disconnecting an account here does not revoke previously authorized access. Revoke access from your profile settings on the connected social account.', 'users_social_connect' => 'Connect Account', 'users_social_disconnect' => 'Disconnect Account', 'users_social_connected' => ':socialAccount account was successfully attached to your profile.', @@ -155,7 +159,8 @@ return [ 'ru' => 'Русский', 'uk' => 'Українська', 'zh_CN' => '简体中文', - 'zh_TW' => '繁體中文' + 'zh_TW' => '繁體中文', + 'hu' => 'Magyar' ] //!//////////////////////////////// ]; diff --git a/resources/lang/fr/auth.php b/resources/lang/fr/auth.php index 934dd56da..c9ce6a4d7 100644 --- a/resources/lang/fr/auth.php +++ b/resources/lang/fr/auth.php @@ -32,6 +32,8 @@ return [ 'remember_me' => 'Se souvenir de moi', 'ldap_email_hint' => "Merci d'entrer une adresse e-mail pour ce compte", 'create_account' => 'Créer un compte', + 'already_have_account' => 'Vous avez déjà un compte?', + 'dont_have_account' => 'Vous n\'avez pas de compte?', 'social_login' => 'Social Login', 'social_registration' => 'Enregistrement Social', 'social_registration_text' => "S'inscrire et se connecter avec un réseau social", @@ -73,4 +75,4 @@ return [ 'email_not_confirmed_click_link' => 'Merci de cliquer sur le lien dans l\'e-mail qui vous a été envoyé après l\'enregistrement.', 'email_not_confirmed_resend' => 'Si vous ne retrouvez plus l\'e-mail, vous pouvez renvoyer un e-mail de confirmation en utilisant le formulaire ci-dessous.', 'email_not_confirmed_resend_button' => 'Renvoyez l\'e-mail de confirmation', -]; \ No newline at end of file +]; diff --git a/resources/lang/fr/common.php b/resources/lang/fr/common.php index 3bff2841b..1cf6e716f 100644 --- a/resources/lang/fr/common.php +++ b/resources/lang/fr/common.php @@ -10,6 +10,7 @@ return [ 'save' => 'Enregistrer', 'continue' => 'Continuer', 'select' => 'Sélectionner', + 'toggle_all' => 'Tout sélectionner', 'more' => 'Montrer plus', /** @@ -19,13 +20,14 @@ return [ 'description' => 'Description', 'role' => 'Rôle', 'cover_image' => 'Image de couverture', - 'cover_image_description' => 'Cette image doit être environ 300x170px.', + 'cover_image_description' => 'Cette image doit être environ 440x250px.', /** * Actions */ 'actions' => 'Actions', 'view' => 'Voir', + 'view_all' => 'Tout afficher', 'create' => 'Créer', 'update' => 'Modifier', 'edit' => 'Editer', @@ -40,6 +42,13 @@ return [ 'remove' => 'Enlever', 'add' => 'Ajouter', + /** + * Sort Options + */ + 'sort_name' => 'Nom', + 'sort_created_at' => 'Date de création', + 'sort_updated_at' => 'Date de mise à jour', + /** * Misc */ @@ -65,4 +74,4 @@ return [ */ 'email_action_help' => 'Si vous rencontrez des problèmes pour cliquer sur le bouton ":actionText", copiez et collez l\'adresse ci-dessous dans votre navigateur :', 'email_rights' => 'Tous droits réservés', -]; \ No newline at end of file +]; diff --git a/resources/lang/fr/entities.php b/resources/lang/fr/entities.php index b07a5c465..4ba1a36e3 100644 --- a/resources/lang/fr/entities.php +++ b/resources/lang/fr/entities.php @@ -9,6 +9,7 @@ return [ 'recently_updated_pages' => 'Pages mises à jour récemment', 'recently_created_chapters' => 'Chapitres créés récemment', 'recently_created_books' => 'Livres créés récemment', + 'recently_created_shelves' => 'Étagères créés récemment', 'recently_update' => 'Mis à jour récemment', 'recently_viewed' => 'Vus récemment', 'recent_activity' => 'Activité récente', @@ -71,11 +72,13 @@ return [ */ 'shelf' => 'Étagère', 'shelves' => 'Étagères', + 'x_shelves' => ':count Étagère|:count Étagères', 'shelves_long' => 'Étagères', 'shelves_empty' => 'Aucune étagère n\'a été créée', 'shelves_create' => 'Créer une nouvelle étagère', 'shelves_popular' => 'Étagères populaires', 'shelves_new' => 'Nouvelles Étagères', + 'shelves_new_action' => 'Nouvelle Étagère', 'shelves_popular_empty' => 'Les étagères les plus populaires apparaîtront ici.', 'shelves_new_empty' => 'Les étagères les plus récentes apparaitront ici.', 'shelves_save' => 'Enregistrer l\'étagère', @@ -108,6 +111,7 @@ return [ 'books_popular' => 'Livres populaires', 'books_recent' => 'Livres récents', 'books_new' => 'Nouveaux livres', + 'books_new_action' => 'Nouveau livre', 'books_popular_empty' => 'Les livres les plus populaires apparaîtront ici.', 'books_new_empty' => 'Les livres les plus récents apparaitront ici.', 'books_create' => 'Créer un nouveau livre', @@ -131,6 +135,11 @@ return [ 'books_navigation' => 'Navigation dans le livre', 'books_sort' => 'Trier les contenus du livre', 'books_sort_named' => 'Trier le livre :bookName', + 'books_sort_name' => 'Trier par le nom', + 'books_sort_created' => 'Trier par la date de création', + 'books_sort_updated' => 'Trier par la date de mise à jour', + 'books_sort_chapters_first' => 'Les chapitres en premier', + 'books_sort_chapters_last' => 'Les chapitres en dernier', 'books_sort_show_other' => 'Afficher d\'autres livres', 'books_sort_save' => 'Enregistrer l\'ordre', @@ -281,6 +290,7 @@ return [ 'profile_not_created_pages' => ':userName n\'a pas créé de page', 'profile_not_created_chapters' => ':userName n\'a pas créé de chapitre', 'profile_not_created_books' => ':userName n\'a pas créé de livre', + 'profile_not_created_shelves' => ':userName n\'a pas créé d\'étagère', /** * Comments @@ -308,4 +318,4 @@ return [ 'revision_delete_confirm' => 'Êtes-vous sûr de vouloir supprimer cette révision?', 'revision_delete_success' => 'Révision supprimée', 'revision_cannot_delete_latest' => 'Impossible de supprimer la dernière révision.' -]; \ No newline at end of file +]; diff --git a/resources/lang/fr/settings.php b/resources/lang/fr/settings.php index 4251fe87d..f978114c5 100644 --- a/resources/lang/fr/settings.php +++ b/resources/lang/fr/settings.php @@ -16,12 +16,18 @@ return [ * App settings */ - 'app_settings' => 'Préférences de l\'application', + 'app_customization' => 'Personnalisation', + 'app_features_security' => 'Fonctionnalités et sécurité', 'app_name' => 'Nom de l\'application', 'app_name_desc' => 'Ce nom est affiché dans l\'en-tête et les e-mails.', 'app_name_header' => 'Afficher le nom dans l\'en-tête ?', + 'app_public_access' => 'Accès public', + 'app_public_access_desc' => 'L\'activation de cette option permettra aux visiteurs, qui ne sont pas connectés, d\'accéder au contenu de votre instance BookStack.', + 'app_public_access_desc_guest' => 'L\'accès pour les visiteurs publics peut être contrôlé par l\'utilisateur "Guest".', + 'app_public_access_toggle' => 'Autoriser l\'accès public', 'app_public_viewing' => 'Accepter le visionnage public des pages ?', 'app_secure_images' => 'Activer l\'ajout d\'image sécurisé ?', + 'app_secure_images_toggle' => 'Activer l\'ajout d\'image sécurisé', 'app_secure_images_desc' => 'Pour des questions de performances, toutes les images sont publiques. Cette option ajoute une chaîne aléatoire difficile à deviner dans les URLs des images.', 'app_editor' => 'Editeur des pages', 'app_editor_desc' => 'Sélectionnez l\'éditeur qui sera utilisé pour modifier les pages.', @@ -35,6 +41,7 @@ return [ 'app_homepage_desc' => 'Choisissez une page à afficher sur la page d\'accueil au lieu de la vue par défaut. Les permissions sont ignorées pour les pages sélectionnées.', 'app_homepage_select' => 'Choisissez une page', 'app_disable_comments' => 'Désactiver les commentaires', + 'app_disable_comments_toggle' => 'Désactiver les commentaires', 'app_disable_comments_desc' => 'Désactive les commentaires sur toutes les pages de l\'application. Les commentaires existants ne sont pas affichés.', /** @@ -42,9 +49,12 @@ return [ */ 'reg_settings' => 'Préférence pour l\'inscription', - 'reg_allow' => 'Accepter l\'inscription ?', + 'reg_enable' => 'Activer l\'inscription', + 'reg_enable_toggle' => 'Activer l\'inscription', + 'reg_enable_desc' => 'Lorsque l\'inscription est activée, l\'utilisateur pourra s\'enregistrer en tant qu\'utilisateur de l\'application. Lors de l\'inscription, ils se voient attribuer un rôle par défaut.', 'reg_default_role' => 'Rôle par défaut lors de l\'inscription', - 'reg_confirm_email' => 'Obliger la confirmation par e-mail ?', + 'reg_email_confirmation' => 'Confirmation de l\'e-mail', + 'reg_email_confirmation_toggle' => 'Obliger la confirmation par e-mail ?', 'reg_confirm_email_desc' => 'Si la restriction de domaine est activée, la confirmation sera automatiquement obligatoire et cette valeur sera ignorée.', 'reg_confirm_restrict_domain' => 'Restreindre l\'inscription à un domaine', 'reg_confirm_restrict_domain_desc' => 'Entrez une liste de domaines acceptés lors de l\'inscription, séparés par une virgule. Les utilisateurs recevront un e-mail de confirmation à cette adresse.
      Les utilisateurs pourront changer leur adresse après inscription s\'ils le souhaitent.', @@ -107,8 +117,15 @@ return [ 'user_profile' => 'Profil d\'utilisateur', 'users_add_new' => 'Ajouter un nouvel utilisateur', 'users_search' => 'Chercher les utilisateurs', - 'users_role' => 'Rôles des utilisateurs', + 'users_details' => 'Informations de l\'utilisateur', + 'users_details_desc' => 'Définissez un nom et une adresse e-mail pour cet utilisateur. L\'adresse e-mail sera utilisée pour se connecter à l\'application.', + 'users_details_desc_no_email' => 'Définissez un nom d\'affichage pour cet utilisateur afin que les autres puissent le reconnaître.', + 'users_role' => 'Rôles de l\'utilisateur', + 'users_role_desc' => 'Sélectionnez les rôles auxquels cet utilisateur sera affecté. Si un utilisateur est affecté à plusieurs rôles, les permissions de ces rôles s\'empileront et ils recevront toutes les capacités des rôles affectés.', + 'users_password' => 'Mot de passe de l\'utilisateur', + 'users_password_desc' => 'Définissez un mot de passe utilisé pour vous connecter à l\'application. Il doit comporter au moins 5 caractères.', 'users_external_auth_id' => 'Identifiant d\'authentification externe', + 'users_external_auth_id_desc' => 'Il s\'agit de l\'identifiant utilisé pour appairer cet utilisateur lors de la communication avec votre système LDAP.', 'users_password_warning' => 'Remplissez ce formulaire uniquement si vous souhaitez changer de mot de passe:', 'users_system_public' => 'Cet utilisateur représente les invités visitant votre instance. Il est assigné automatiquement aux invités.', 'users_delete' => 'Supprimer un utilisateur', @@ -122,6 +139,7 @@ return [ 'users_avatar' => 'Avatar de l\'utilisateur', 'users_avatar_desc' => 'Cette image doit être un carré d\'environ 256px.', 'users_preferred_language' => 'Langue préférée', + 'users_preferred_language_desc' => 'Cette option changera la langue utilisée pour l\'interface utilisateur de l\'application. Ceci n\'affectera aucun contenu créé par l\'utilisateur.', 'users_social_accounts' => 'Comptes sociaux', 'users_social_accounts_info' => 'Vous pouvez connecter des réseaux sociaux à votre compte pour vous connecter plus rapidement. Déconnecter un compte n\'enlèvera pas les accès autorisés précédemment sur votre compte de réseau social.', 'users_social_connect' => 'Connecter le compte', diff --git a/resources/lang/fr/validation.php b/resources/lang/fr/validation.php index 9204f4e2d..4be55df4f 100644 --- a/resources/lang/fr/validation.php +++ b/resources/lang/fr/validation.php @@ -38,6 +38,7 @@ return [ 'filled' => ':attribute est un champ requis.', 'exists' => 'L\'attribut :attribute est invalide.', 'image' => ':attribute doit être une image.', + 'image_extension' => ':attribute doit avoir une extension d\'image valide et supportée.', 'in' => 'L\'attribut :attribute est invalide.', 'integer' => ':attribute doit être un chiffre entier.', 'ip' => ':attribute doit être une adresse IP valide.', @@ -54,6 +55,7 @@ return [ 'string' => ':attribute doit contenir au moins :min caractères.', 'array' => ':attribute doit contenir au moins :min éléments.', ], + 'no_double_extension' => ':attribute ne doit avoir qu\'une seule extension de fichier.', 'not_in' => 'L\'attribut sélectionné :attribute est invalide.', 'numeric' => ':attribute doit être un nombre.', 'regex' => ':attribute a un format invalide.', @@ -74,6 +76,7 @@ return [ 'timezone' => ':attribute doit être une zone valide.', 'unique' => ':attribute est déjà utilisé.', 'url' => ':attribute a un format invalide.', + 'uploaded' => 'Le fichier n\'a pas pu être envoyé. Le serveur peut ne pas accepter des fichiers de cette taille.', /* |-------------------------------------------------------------------------- diff --git a/resources/lang/hu/activities.php b/resources/lang/hu/activities.php new file mode 100644 index 000000000..575e9e509 --- /dev/null +++ b/resources/lang/hu/activities.php @@ -0,0 +1,48 @@ + 'létrehozta az oldalt:', + 'page_create_notification' => 'Oldal sikeresen létrehozva', + 'page_update' => 'frissítette az oldalt:', + 'page_update_notification' => 'Oldal sikeresen frissítve', + 'page_delete' => 'törölte az oldalt:', + 'page_delete_notification' => 'Oldal sikeresen törölve', + 'page_restore' => 'visszaállította az oldalt:', + 'page_restore_notification' => 'Oldal sikeresen visszaállítva', + 'page_move' => 'áthelyezte az oldalt:', + + // Chapters + 'chapter_create' => 'létrehozta a fejezetet:', + 'chapter_create_notification' => 'Fejezet sikeresen létrehozva', + 'chapter_update' => 'frissítette a fejezetet:', + 'chapter_update_notification' => 'Fejezet sikeresen frissítve', + 'chapter_delete' => 'törölte a fejezetet:', + 'chapter_delete_notification' => 'Fejezet sikeresen törölve', + 'chapter_move' => 'áthelyezte a fejezetet:', + + // Books + 'book_create' => 'létrehozott egy könyvet:', + 'book_create_notification' => 'Könyv sikeresen létrehozva', + 'book_update' => 'frissítette a könyvet:', + 'book_update_notification' => 'Könyv sikeresen frissítve', + 'book_delete' => 'törölte a könyvet:', + 'book_delete_notification' => 'Könyv sikeresen törölve', + 'book_sort' => 'átrendezte a könyvet:', + 'book_sort_notification' => 'Könyv sikeresen újrarendezve', + + // Bookshelves + 'bookshelf_create' => 'létrehozta a könyvespolcot:', + 'bookshelf_create_notification' => 'Könyvespolc sikeresen létrehozva', + 'bookshelf_update' => 'frissítette a könyvespolcot:', + 'bookshelf_update_notification' => 'Könyvespolc sikeresen frissítve', + 'bookshelf_delete' => 'törölte a könyvespolcot:', + 'bookshelf_delete_notification' => 'Könyvespolc sikeresen törölve', + + // Other + 'commented_on' => 'megjegyzést fűzött hozzá:', +]; diff --git a/resources/lang/hu/auth.php b/resources/lang/hu/auth.php new file mode 100644 index 000000000..a1809b0de --- /dev/null +++ b/resources/lang/hu/auth.php @@ -0,0 +1,67 @@ + 'Ezek a hitelesítő adatok nem egyeznek a rögzítettekkel.', + 'throttle' => 'Túl sok bejelentkezési próbálkozás. :seconds múlva lehet újra megpróbálni.', + + // Login & Register + 'sign_up' => 'Regisztráció', + 'log_in' => 'Bejelentkezés', + 'log_in_with' => 'Bejelentkezés ezzel: :socialDriver', + 'sign_up_with' => 'Regisztráció ezzel: :socialDriver', + 'logout' => 'Kijelentkezés', + + 'name' => 'Név', + 'username' => 'Felhasználónév', + 'email' => 'Email', + 'password' => 'Jelszó', + 'password_confirm' => 'Jelszó megerősítése', + 'password_hint' => 'Öt karakternél hosszabbnak kell lennie', + 'forgot_password' => 'Elfelejtett jelszó?', + 'remember_me' => 'Emlékezzen rám', + 'ldap_email_hint' => 'A fiókhoz használt email cím megadása.', + 'create_account' => 'Fiók létrehozása', + 'already_have_account' => 'Korábban volt beállítva fiók?', + 'dont_have_account' => 'Még nincs beállítva fiók?', + 'social_login' => 'Közösségi bejelentkezés', + 'social_registration' => 'Közösségi regisztráció', + 'social_registration_text' => 'Regisztráció és bejelentkezés másik szolgáltatással.', + + 'register_thanks' => 'Köszönjük a regisztrációt!', + 'register_confirm' => 'Ellenőrizni kell a megadott email címet és a megerősítő gombra kell kattintani :appName eléréséhez.', + 'registrations_disabled' => 'A regisztráció jelenleg le van tiltva', + 'registration_email_domain_invalid' => 'Ebből az email tartományról nem lehet hozzáférni ehhez az alkalmazáshoz', + 'register_success' => 'Köszönjük a regisztrációt! A regisztráció és a bejelentkezés megtörtént.', + + + // Password Reset + 'reset_password' => 'Jelszó visszaállítása', + 'reset_password_send_instructions' => 'Meg kell adni az email címet amire egy jelszó visszaállító hivatkozás lesz elküldve.', + 'reset_password_send_button' => 'Visszaállító hivatkozás elküldése', + 'reset_password_sent_success' => 'Jelszó visszaállító hivatkozás elküldve :email címre.', + 'reset_password_success' => 'A jelszó sikeresen visszaállítva.', + 'email_reset_subject' => ':appName jelszó visszaállítása', + 'email_reset_text' => 'Ezt az emailt azért küldtük mert egy jelszó visszaállításra vonatkozó kérést kaptunk ebből a fiókból.', + 'email_reset_not_requested' => 'Ha nem történt jelszó visszaállításra vonatkozó kérés, akkor nincs szükség további intézkedésre.', + + + // Email Confirmation + 'email_confirm_subject' => ':appName alkalmazásban beállított email címet meg kell erősíteni', + 'email_confirm_greeting' => ':appName köszöni a csatlakozást!', + 'email_confirm_text' => 'Az email címet a lenti gombra kattintva lehet megerősíteni:', + 'email_confirm_action' => 'Email megerősítése', + 'email_confirm_send_error' => 'Az email megerősítés kötelező, de a rendszer nem tudta elküldeni az emailt. Fel kell venni a kapcsolatot az adminisztrátorral és meg kell győződni róla, hogy az email beállítások megfelelőek.', + 'email_confirm_success' => 'Az email cím megerősítve!', + 'email_confirm_resent' => 'Megerősítő email újraküldve. Ellenőrizni kell a bejövő üzeneteket.', + + 'email_not_confirmed' => 'Az email cím nincs megerősítve', + 'email_not_confirmed_text' => 'Az email cím még nincs megerősítve.', + 'email_not_confirmed_click_link' => 'Rá kell kattintani a regisztráció után nem sokkal elküldött emailben található hivatkozásra.', + 'email_not_confirmed_resend' => 'Ha nem érkezik meg a megerősítő email, a lenti űrlap beküldésével újra lehet küldeni.', + 'email_not_confirmed_resend_button' => 'Megerősítő email újraküldése', +]; diff --git a/resources/lang/hu/common.php b/resources/lang/hu/common.php new file mode 100644 index 000000000..4e72d5f94 --- /dev/null +++ b/resources/lang/hu/common.php @@ -0,0 +1,70 @@ + 'Mégsem', + 'confirm' => 'Megerősítés', + 'back' => 'Vissza', + 'save' => 'Mentés', + 'continue' => 'Tovább', + 'select' => 'Kiválasztás', + 'toggle_all' => 'Összes átkapcsolása', + 'more' => 'Több', + + // Form Labels + 'name' => 'Név', + 'description' => 'Leírás', + 'role' => 'Szerepkör', + 'cover_image' => 'Borítókép', + 'cover_image_description' => 'A kép méretének kb. 440x250px-nek kell lennie.', + + // Actions + 'actions' => 'Műveletek', + 'view' => 'Megtekintés', + 'view_all' => 'Összes megtekintése', + 'create' => 'Létrehozás', + 'update' => 'Frissítés', + 'edit' => 'Szerkesztés', + 'sort' => 'Rendezés', + 'move' => 'Áthelyezés', + 'copy' => 'Másolás', + 'reply' => 'Válasz', + 'delete' => 'Törlés', + 'search' => 'Keresés', + 'search_clear' => 'Keresés törlése', + 'reset' => 'Visszaállítás', + 'remove' => 'Eltávolítás', + 'add' => 'Hozzáadás', + + // Sort Options + 'sort_name' => 'Név', + 'sort_created_at' => 'Létrehozás dátuma', + 'sort_updated_at' => 'Frissítés dátuma', + + // Misc + 'deleted_user' => 'Törölt felhasználó', + 'no_activity' => 'Nincs megjeleníthető aktivitás', + 'no_items' => 'Nincsenek elérhető elemek', + 'back_to_top' => 'Oldal eleje', + 'toggle_details' => 'Részletek átkapcsolása', + 'toggle_thumbnails' => 'Bélyegképek átkapcsolása', + 'details' => 'Részletek', + 'grid_view' => 'Rács nézet', + 'list_view' => 'Lista nézet', + 'default' => 'Alapértelmezés szerinti', + + // Header + 'view_profile' => 'Profil megtekintése', + 'edit_profile' => 'Profil szerkesztése', + + // Layout tabs + 'tab_info' => 'Információ', + 'tab_content' => 'Tartalom', + + // Email Content + 'email_action_help' => 'Probléma esetén a lenti ":actionText" gombra kell kattintani, majd ki kell másolni a lenti webcímet és be kell illeszteni egy böngészőbe:', + 'email_rights' => 'Minden jog fenntartva', +]; diff --git a/resources/lang/hu/components.php b/resources/lang/hu/components.php new file mode 100644 index 000000000..1f98df2df --- /dev/null +++ b/resources/lang/hu/components.php @@ -0,0 +1,33 @@ + 'Kép kiválasztása', + 'image_all' => 'Összes', + 'image_all_title' => 'Összes kép megtekintése', + 'image_book_title' => 'A könyv feltöltött képek megtekintése', + 'image_page_title' => 'Az oldalra feltöltött képek megtekintése', + 'image_search_hint' => 'Keresés kép neve alapján', + 'image_uploaded' => 'Feltöltve ekkor: :uploadedDate', + 'image_load_more' => 'Több betöltése', + 'image_image_name' => 'Kép neve', + 'image_delete_used' => 'Ez a kép a lenti oldalakon van használatban.', + 'image_delete_confirm' => 'A kép törléséhez ismét rá kell kattintani a törlésre.', + 'image_select_image' => 'Kép kiválasztása', + 'image_dropzone' => 'Képek feltöltése ejtéssel vagy kattintással', + 'images_deleted' => 'Képek törölve', + 'image_preview' => 'Kép előnézete', + 'image_upload_success' => 'Kép sikeresen feltöltve', + 'image_update_success' => 'Kép részletei sikeresen frissítve', + 'image_delete_success' => 'Kép sikeresen törölve', + 'image_upload_remove' => 'Eltávolítás', + + // Code Editor + 'code_editor' => 'Kód szerkesztése', + 'code_language' => 'Kód nyelve', + 'code_content' => 'Kód tartalom', + 'code_save' => 'Kód mentése', +]; diff --git a/resources/lang/hu/entities.php b/resources/lang/hu/entities.php new file mode 100644 index 000000000..5bd865dd5 --- /dev/null +++ b/resources/lang/hu/entities.php @@ -0,0 +1,305 @@ + 'Legutóbb létrehozott', + 'recently_created_pages' => 'Legutóbb létrehozott oldalak', + 'recently_updated_pages' => 'Legutóbb frissített oldalak', + 'recently_created_chapters' => 'Legutóbb létrehozott fejezetek', + 'recently_created_books' => 'Legutóbb létrehozott könyvek', + 'recently_created_shelves' => 'Legutóbb létrehozott polcok', + 'recently_update' => 'Legutóbb frissített', + 'recently_viewed' => 'Legutóbb megtekintett', + 'recent_activity' => 'Legutóbbi tevékenység', + 'create_now' => 'Létrehozás most', + 'revisions' => 'Változatok', + 'meta_revision' => 'Változat #:revisionCount', + 'meta_created' => 'Létrehozva :timeLength', + 'meta_created_name' => ':user hozta létre :timeLength', + 'meta_updated' => 'Frissítve :timeLength', + 'meta_updated_name' => ':user frissítette :timeLength', + 'entity_select' => 'Entitás kiválasztása', + 'images' => 'Képek', + 'my_recent_drafts' => 'Legutóbbi vázlataim', + 'my_recently_viewed' => 'Általam legutóbb megtekintett', + 'no_pages_viewed' => 'Még nincsenek általam megtekintett oldalak', + 'no_pages_recently_created' => 'Nincsenek legutóbb létrehozott oldalak', + 'no_pages_recently_updated' => 'Nincsenek legutóbb frissített oldalak', + 'export' => 'Exportálás', + 'export_html' => 'Webfájlt tartalmaz', + 'export_pdf' => 'PDF fájl', + 'export_text' => 'Egyszerű szövegfájl', + + // Permissions and restrictions + 'permissions' => 'Jogosultságok', + 'permissions_intro' => 'Ha engedélyezett, ezek a jogosultságok elsőbbséget élveznek bármely beállított szerepkör jogosultsággal szemben.', + 'permissions_enable' => 'Egyéni jogosultságok engedélyezése', + 'permissions_save' => 'Jogosultságok mentése', + + // Search + 'search_results' => 'Keresési eredmények', + 'search_total_results_found' => ':count találat|összesen :count találat', + 'search_clear' => 'Keresés törlése', + 'search_no_pages' => 'Nincsenek a keresésnek megfelelő oldalak', + 'search_for_term' => ':term keresése', + 'search_more' => 'További eredmények', + 'search_filters' => 'Keresési szűrők', + 'search_content_type' => 'Tartalomtípus', + 'search_exact_matches' => 'Pontos egyezések', + 'search_tags' => 'Címke keresések', + 'search_options' => 'Beállítások', + 'search_viewed_by_me' => 'Általam megtekintett', + 'search_not_viewed_by_me' => 'Általam nem megtekintett', + 'search_permissions_set' => 'Jogosultságok beállítva', + 'search_created_by_me' => 'Általam létrehozott', + 'search_updated_by_me' => 'Általam frissített', + 'search_date_options' => 'Dátum beállítások', + 'search_updated_before' => 'Frissítve ez előtt', + 'search_updated_after' => 'Frissítve ez után', + 'search_created_before' => 'Létrehozva ez előtt', + 'search_created_after' => 'Létrehozva ez után', + 'search_set_date' => 'Dátum beállítása', + 'search_update' => 'Keresés frissítése', + + // Shelves + 'shelf' => 'Polc', + 'shelves' => 'Polcok', + 'x_shelves' => ':count polc|:count polcok', + 'shelves_long' => 'Könyvespolcok', + 'shelves_empty' => 'Nincsenek könyvespolcok létrehozva', + 'shelves_create' => 'Új polc létrehozása', + 'shelves_popular' => 'Népszerű polcok', + 'shelves_new' => 'Új polcok', + 'shelves_new_action' => 'Új polc', + 'shelves_popular_empty' => 'A legnépszerűbb polcok itt fognak megjelenni.', + 'shelves_new_empty' => 'A legutoljára létrehozott polcok itt fognak megjelenni.', + 'shelves_save' => 'Polc mentése', + 'shelves_books' => 'Könyvek ezen a polcon', + 'shelves_add_books' => 'Könyvek hozzáadása ehhez a polchoz', + 'shelves_drag_books' => 'Könyveket áthúzással lehet elhelyezni ezen a polcon', + 'shelves_empty_contents' => 'Ehhez a polchoz nincsenek könyvek rendelve', + 'shelves_edit_and_assign' => 'Polc szerkesztése könyvek hozzárendeléséhez', + 'shelves_edit_named' => ':name könyvespolc szerkesztése', + 'shelves_edit' => 'Könyvespolc szerkesztése', + 'shelves_delete' => 'Könyvespolc törlése', + 'shelves_delete_named' => ':name könyvespolc törlése', + 'shelves_delete_explain' => "':name'. nevű könyvespolc ezzel le lesz törölve. A benne található könyvek nem lesznek törölve.", + 'shelves_delete_confirmation' => 'Biztosan törölhető ez a könyvespolc?', + 'shelves_permissions' => 'Könyvespolc jogosultság', + 'shelves_permissions_updated' => 'Könyvespolc jogosultságok frissítve', + 'shelves_permissions_active' => 'Könyvespolc jogosultságok aktívak', + 'shelves_copy_permissions_to_books' => 'Jogosultság másolása könyvekre', + 'shelves_copy_permissions' => 'Jogosultság másolása', + 'shelves_copy_permissions_explain' => 'Ez alkalmazni fogja ennek a könyvespolcnak az aktuális jogosultság beállításait az összes benne található könyvön. Aktiválás előtt ellenőrizni kell, hogy a könyvespolc jogosultságain végzett összes módosítás el lett mentve.', + 'shelves_copy_permission_success' => 'Könyvespolc jogosultságok átmásolva :count könyvre', + + // Books + 'book' => 'Könyv', + 'books' => 'Könyvek', + 'x_books' => ':count könyv|:count könyv', + 'books_empty' => 'Nincsenek könyvek létrehozva', + 'books_popular' => 'Népszerű könyvek', + 'books_recent' => 'Legutóbbi könyvek', + 'books_new' => 'Új könyvek', + 'books_new_action' => 'Új könyv', + 'books_popular_empty' => 'A legnépszerűbb könyvek itt fognak megjelenni.', + 'books_new_empty' => 'A legutoljára létrehozott könyvek itt fognak megjelenni.', + 'books_create' => 'Új könyv létrehozása', + 'books_delete' => 'Könyv törlése', + 'books_delete_named' => ':bookName könyv törlése', + 'books_delete_explain' => '\':bookName\' nevű könyv törölve lesz. Minden oldal és fejezet el lesz távolítva.', + 'books_delete_confirmation' => 'Biztosan törölhető ez a könyv?', + 'books_edit' => 'Könyv szerkesztése', + 'books_edit_named' => ':bookName könyv szerkesztése', + 'books_form_book_name' => 'Könyv neve', + 'books_save' => 'Könyv mentése', + 'books_permissions' => 'Könyv jogosultságok', + 'books_permissions_updated' => 'Könyv jogosultságok frissítve', + 'books_empty_contents' => 'Ehhez a könyvhöz nincsenek oldalak vagy fejezetek létrehozva.', + 'books_empty_create_page' => 'Új oldal létrehozása', + 'books_empty_sort_current_book' => 'Aktuális könyv rendezése', + 'books_empty_add_chapter' => 'Fejezet hozzáadása', + 'books_permissions_active' => 'Könyv jogosultságok aktívak', + 'books_search_this' => 'Keresés ebben a könyvben', + 'books_navigation' => 'Könyv navigáció', + 'books_sort' => 'Könyv tartalmak rendezése', + 'books_sort_named' => ':bookName könyv rendezése', + 'books_sort_name' => 'Rendezés név szerint', + 'books_sort_created' => 'Rendezés létrehozás dátuma szerint', + 'books_sort_updated' => 'Rendezés frissítés dátuma szerint', + 'books_sort_chapters_first' => 'Fejezetek elől', + 'books_sort_chapters_last' => 'Fejezetek hátul', + 'books_sort_show_other' => 'Egyéb könyvek mutatása', + 'books_sort_save' => 'Új elrendezés mentése', + + // Chapters + 'chapter' => 'Fejezet', + 'chapters' => 'Fejezetek', + 'x_chapters' => ':count fejezet|:count fejezetek', + 'chapters_popular' => 'Népszerű fejezetek', + 'chapters_new' => 'Új fejezet', + 'chapters_create' => 'Új fejezet létrehozása', + 'chapters_delete' => 'Fejezet törlése', + 'chapters_delete_named' => ':chapterName fejezet törlése', + 'chapters_delete_explain' => '\':chapterName\' nevű fejezet törölve lesz. Minden oldal el lesz távolítva és közvetlenül a szülő könyvhöz lesz hozzáadva.', + 'chapters_delete_confirm' => 'Biztosan törölhető ez a fejezet?', + 'chapters_edit' => 'Fejezet szerkesztése', + 'chapters_edit_named' => ':chapterName fejezet szerkesztése', + 'chapters_save' => 'Fejezet mentése', + 'chapters_move' => 'Fejezet áthelyezése', + 'chapters_move_named' => ':chapterName fejezet áthelyezése', + 'chapter_move_success' => 'Fejezet áthelyezve :bookName könyvbe', + 'chapters_permissions' => 'Fejezet jogosultságok', + 'chapters_empty' => 'Jelenleg nincsenek oldalak ebben a fejezetben.', + 'chapters_permissions_active' => 'Fejezet jogosultságok aktívak', + 'chapters_permissions_success' => 'Fejezet jogosultságok frissítve', + 'chapters_search_this' => 'Keresés ebben a fejezetben', + + // Pages + 'page' => 'Oldal', + 'pages' => 'Oldalak', + 'x_pages' => ':count oldal|:count oldalak', + 'pages_popular' => 'Népszerű oldalak', + 'pages_new' => 'Új oldal', + 'pages_attachments' => 'Csatolmányok', + 'pages_navigation' => 'Oldal navigáció', + 'pages_delete' => 'Oldal törlése', + 'pages_delete_named' => ':pageName oldal törlése', + 'pages_delete_draft_named' => ':pageName vázlat oldal törlése', + 'pages_delete_draft' => 'Vázlat oldal törlése', + 'pages_delete_success' => 'Oldal törölve', + 'pages_delete_draft_success' => 'Vázlat oldal törölve', + 'pages_delete_confirm' => 'Biztosan törölhető ez az oldal?', + 'pages_delete_draft_confirm' => 'Biztosan törölhető ez a vázlatoldal?', + 'pages_editing_named' => ':pageName oldal szerkesztése', + 'pages_edit_toggle_header' => 'Fejléc átkapcsolása', + 'pages_edit_save_draft' => 'Vázlat mentése', + 'pages_edit_draft' => 'Oldal vázlat szerkesztése', + 'pages_editing_draft' => 'Vázlat szerkesztése', + 'pages_editing_page' => 'Oldal szerkesztése', + 'pages_edit_draft_save_at' => 'Vázlat elmentve:', + 'pages_edit_delete_draft' => 'Vázlat törlése', + 'pages_edit_discard_draft' => 'Vázlat elvetése', + 'pages_edit_set_changelog' => 'Változásnapló beállítása', + 'pages_edit_enter_changelog_desc' => 'A végrehajtott módosítások rövid leírása', + 'pages_edit_enter_changelog' => 'Változásnapló megadása', + 'pages_save' => 'Oldal mentése', + 'pages_title' => 'Oldal címe', + 'pages_name' => 'Oldal neve', + 'pages_md_editor' => 'Szerkesztő', + 'pages_md_preview' => 'Előnézet', + 'pages_md_insert_image' => 'Kép beillesztése', + 'pages_md_insert_link' => 'Entitás hivatkozás beillesztése', + 'pages_md_insert_drawing' => 'Rajz beillesztése', + 'pages_not_in_chapter' => 'Az oldal nincs fejezetben', + 'pages_move' => 'Oldal áthelyezése', + 'pages_move_success' => 'Oldal áthelyezve ide: ":parentName"', + 'pages_copy' => 'Oldal másolása', + 'pages_copy_desination' => 'Másolás célja', + 'pages_copy_success' => 'Oldal sikeresen lemásolva', + 'pages_permissions' => 'Oldal jogosultságok', + 'pages_permissions_success' => 'Oldal jogosultságok frissítve', + 'pages_revision' => 'Változat', + 'pages_revisions' => 'Oldal változatai', + 'pages_revisions_named' => ':pageName oldal változatai', + 'pages_revision_named' => ':pageName oldal változata', + 'pages_revisions_created_by' => 'Létrehozta:', + 'pages_revisions_date' => 'Változat dátuma', + 'pages_revisions_number' => '#', + 'pages_revisions_numbered' => 'Változat #:id', + 'pages_revisions_numbered_changes' => '#:id változat módosításai', + 'pages_revisions_changelog' => 'Változásnapló', + 'pages_revisions_changes' => 'Módosítások', + 'pages_revisions_current' => 'Aktuális verzió', + 'pages_revisions_preview' => 'Előnézet', + 'pages_revisions_restore' => 'Visszaállítás', + 'pages_revisions_none' => 'Ennek az oldalnak nincsenek változatai', + 'pages_copy_link' => 'Hivatkozás másolása', + 'pages_edit_content_link' => 'Tartalom szerkesztése', + 'pages_permissions_active' => 'Oldal jogosultságok aktívak', + 'pages_initial_revision' => 'Kezdeti közzététel', + 'pages_initial_name' => 'Új oldal', + 'pages_editing_draft_notification' => 'A jelenleg szerkesztett vázlat legutóbb ekkor volt elmentve: :timeDiff.', + 'pages_draft_edited_notification' => 'Ezt az oldalt azóta már frissítették. Javasolt ennek a vázlatnak az elvetése.', + 'pages_draft_edit_active' => [ + 'start_a' => ':count felhasználók kezdte el szerkeszteni ezt az oldalt', + 'start_b' => ':userName elkezdte szerkeszteni ezt az oldalt', + 'time_a' => 'mióta az oldal utoljára frissítve volt', + 'time_b' => 'az utolsó :minCount percben', + 'message' => ':start :time. Ügyeljen arra, hogy ne írjuk felül egymás frissítéseit!', + ], + 'pages_draft_discarded' => 'Vázlat elvetve, a szerkesztő frissítve lesz az oldal aktuális tartalmával', + 'pages_specific' => 'Egy bizonyos oldal', + + // Editor Sidebar + 'page_tags' => 'Oldal címkék', + 'chapter_tags' => 'Fejezet címkék', + 'book_tags' => 'Könyv címkék', + 'shelf_tags' => 'Polc címkék', + 'tag' => 'Címke', + 'tags' => 'Címkék', + 'tag_value' => 'Címke érték (nem kötelező)', + 'tags_explain' => "Címkék hozzáadása a tartalom jobb kategorizálásához.\nA mélyebb szervezettség megvalósításához hozzá lehet rendelni egy értéket a címkéhez.", + 'tags_add' => 'Másik címke hozzáadása', + 'attachments' => 'Csatolmányok', + 'attachments_explain' => 'Az oldalon megjelenő fájlok feltöltése vagy hivatkozások csatolása. Az oldal oldalsávjában fognak megjelenni.', + 'attachments_explain_instant_save' => 'Az itt történt módosítások azonnal el lesznek mentve.', + 'attachments_items' => 'Csatolt elemek', + 'attachments_upload' => 'Fájlfeltöltés', + 'attachments_link' => 'Hivatkozás csatolása', + 'attachments_set_link' => 'Hivatkozás beállítása', + 'attachments_delete_confirm' => 'A csatolmány törléséhez ismét rá kell kattintani a törlésre.', + 'attachments_dropzone' => 'Fájlok csatolása ejtéssel vagy kattintással', + 'attachments_no_files' => 'Nincsenek fájlok feltöltve', + 'attachments_explain_link' => 'Fájl feltöltése helyett hozzá lehet kapcsolni egy hivatkozást. Ez egy hivatkozás lesz egy másik oldalra vagy egy fájlra a felhőben.', + 'attachments_link_name' => 'Hivatkozás neve', + 'attachment_link' => 'Csatolmány hivatkozás', + 'attachments_link_url' => 'Hivatkozás fájlra', + 'attachments_link_url_hint' => 'Weboldal vagy fájl webcíme', + 'attach' => 'Csatolás', + 'attachments_edit_file' => 'Fájl szerkesztése', + 'attachments_edit_file_name' => 'Fájl neve', + 'attachments_edit_drop_upload' => 'Feltöltés és felülírás ejtéssel vagy kattintással', + 'attachments_order_updated' => 'Csatolmány sorrend frissítve', + 'attachments_updated_success' => 'Csatolmány részletei frissítve', + 'attachments_deleted' => 'Csatolmány törölve', + 'attachments_file_uploaded' => 'Fájl sikeresen feltöltve', + 'attachments_file_updated' => 'Fájl sikeresen frissítve', + 'attachments_link_attached' => 'Hivatkozás sikeresen hozzácsatolva az oldalhoz', + + // Profile View + 'profile_user_for_x' => 'Felhasználó ez óta: :time', + 'profile_created_content' => 'Létrehozott tartalom', + 'profile_not_created_pages' => ':userName még nem hozott létre oldalt', + 'profile_not_created_chapters' => ':userName még nem hozott létre fejezetet', + 'profile_not_created_books' => ':userName még nem hozott létre könyvet', + 'profile_not_created_shelves' => ':userName még nem hozott létre polcot', + + // Comments + 'comment' => 'Megjegyzés', + 'comments' => 'Megjegyzések', + 'comment_add' => 'Megjegyzés hozzáadása', + 'comment_placeholder' => 'Megjegyzés írása', + 'comment_count' => '{0} Nincs megjegyzés|{1} 1 megjegyzés|[2,*] :count megjegyzés', + 'comment_save' => 'Megjegyzés mentése', + 'comment_saving' => 'Megjegyzés mentése...', + 'comment_deleting' => 'Megjegyzés törlése...', + 'comment_new' => 'Új megjegyzés', + 'comment_created' => 'megjegyzést fűzött hozzá :createDiff', + 'comment_updated' => 'Frissítve :updateDiff :username által', + 'comment_deleted_success' => 'Megjegyzés törölve', + 'comment_created_success' => 'Megjegyzés hozzáadva', + 'comment_updated_success' => 'Megjegyzés frissítve', + 'comment_delete_confirm' => 'Biztosan törölhető ez a megjegyzés?', + 'comment_in_reply_to' => 'Válasz erre: :commentId', + + // Revision + 'revision_delete_confirm' => 'Biztosan törölhető ez a változat?', + 'revision_restore_confirm' => 'Biztosan visszaállítható ez a változat? A oldal jelenlegi tartalma le lesz cserélve.', + 'revision_delete_success' => 'Változat törölve', + 'revision_cannot_delete_latest' => 'A legutolsó változat nem törölhető.' +]; \ No newline at end of file diff --git a/resources/lang/hu/errors.php b/resources/lang/hu/errors.php new file mode 100644 index 000000000..679142804 --- /dev/null +++ b/resources/lang/hu/errors.php @@ -0,0 +1,84 @@ + 'Nincs jogosultság a kért oldal eléréséhez.', + 'permissionJson' => 'Nincs jogosultság a kért művelet végrehajtásához.', + + // Auth + 'error_user_exists_different_creds' => ':email címmel már létezik felhasználó, de más hitelesítő adatokkal.', + 'email_already_confirmed' => 'Az email cím már meg van erősítve, meg lehet próbálni a bejelentkezést.', + 'email_confirmation_invalid' => 'A megerősítő vezérjel nem érvényes vagy használva volt. Meg kell próbálni újraregisztrálni.', + 'email_confirmation_expired' => 'A megerősítő vezérjel lejárt. Egy új megerősítő email lett elküldve.', + 'ldap_fail_anonymous' => 'Nem sikerült az LDAP elérése névtelen csatlakozással', + 'ldap_fail_authed' => 'Az LDAP hozzáférés nem sikerült a megadott DN és jelszó beállításokkal', + 'ldap_extension_not_installed' => 'LDAP PHP kiterjesztés nincs telepítve', + 'ldap_cannot_connect' => 'Nem lehet kapcsolódni az LDAP kiszolgálóhoz, a kezdeti kapcsolatfelvétel nem sikerült', + 'social_no_action_defined' => 'Nincs művelet meghatározva', + 'social_login_bad_response' => "Hiba történt :socialAccount bejelentkezés közben:\n:error", + 'social_account_in_use' => ':socialAccount fiók már használatban van. :socialAccount opción keresztül érdemes megpróbálni a bejelentkezést.', + 'social_account_email_in_use' => ':email email cím már használatban van. Ha már van fiók létrehozva, :egy socialAccount fiókot hozzá lehet csatolni a profil beállításainál.', + 'social_account_existing' => ':socialAccount már hozzá van kapcsolva a fiókhoz.', + 'social_account_already_used_existing' => ':socialAccount fiókot már egy másik felhasználó használja.', + 'social_account_not_used' => ':socialAccount fiók nincs felhasználóhoz kapcsolva. A hozzákapcsolást a profil oldalon lehet elvégezni. ', + 'social_account_register_instructions' => ':socialAccount beállítása használatával is lehet fiókot regisztrálni, ha még nem volt fiók létrehozva.', + 'social_driver_not_found' => 'Közösségi meghajtó nem található', + 'social_driver_not_configured' => ':socialAccount közösségi beállítások nem megfelelőek.', + + // System + 'path_not_writable' => ':filePath elérési út nem tölthető fel. Ellenőrizni kell, hogy az útvonal a kiszolgáló számára írható.', + 'cannot_get_image_from_url' => 'Nem lehet lekérni a képet innen: :url', + 'cannot_create_thumbs' => 'A kiszolgáló nem tud létrehozni bélyegképeket. Ellenőrizni kell, hogy telepítve van-a a GD PHP kiterjesztés.', + 'server_upload_limit' => 'A kiszolgáló nem engedélyez ilyen méretű feltöltéseket. Kisebb fájlmérettel kell próbálkozni.', + 'uploaded' => 'A kiszolgáló nem engedélyez ilyen méretű feltöltéseket. Kisebb fájlmérettel kell próbálkozni.', + 'image_upload_error' => 'Hiba történt a kép feltöltése közben', + 'image_upload_type_error' => 'A feltöltött kép típusa érvénytelen', + 'file_upload_timeout' => 'A fáj feltöltése időtúllépést okozott.', + + // Attachments + 'attachment_page_mismatch' => 'Oldal eltárás csatolmány frissítése közben', + 'attachment_not_found' => 'Csatolmány nem található', + + // Pages + 'page_draft_autosave_fail' => 'Nem sikerült a vázlat mentése. Mentés előtt meg kell róla győződni, hogy van internetkapcsolat', + 'page_custom_home_deletion' => 'Nem lehet oldalt törölni ha kezdőlapnak van beállítva', + + // Entities + 'entity_not_found' => 'Entitás nem található', + 'bookshelf_not_found' => 'Könyvespolc nem található', + 'book_not_found' => 'Könyv nem található', + 'page_not_found' => 'Oldal nem található', + 'chapter_not_found' => 'Fejezet nem található', + 'selected_book_not_found' => 'A kiválasztott könyv nem található', + 'selected_book_chapter_not_found' => 'A kiválasztott könyv vagy fejezet nem található', + 'guests_cannot_save_drafts' => 'Vendégek nem menthetnek el vázlatokat', + + // Users + 'users_cannot_delete_only_admin' => 'Nem lehet törölni az egyetlen adminisztrátort', + 'users_cannot_delete_guest' => 'A vendég felhasználót nem lehet törölni', + + // Roles + 'role_cannot_be_edited' => 'Ezt a szerepkört nem lehet szerkeszteni', + 'role_system_cannot_be_deleted' => 'Ez a szerepkör egy rendszer szerepkör ezért nem törölhető', + 'role_registration_default_cannot_delete' => 'Ezt a szerepkört nem lehet törölni amíg alapértelmezés szerinti regisztrációs szerepkörnek van beállítva', + 'role_cannot_remove_only_admin' => 'Ez a felhasználó az egyetlen, az adminisztrátor szerepkörhöz rendelt felhasználó. Eltávolítása előtt az adminisztrátor szerepkört át kell ruházni egy másik felhasználóra.', + + // Comments + 'comment_list' => 'Hiba történt a megjegyzések lekérése közben.', + 'cannot_add_comment_to_draft' => 'Vázlathoz nem lehet megjegyzéseket fűzni.', + 'comment_add' => 'Hiba történt a megjegyzés hozzáadása / frissítése közben.', + 'comment_delete' => 'Hiba történt a megjegyzés törlése közben.', + 'empty_comment' => 'Üres megjegyzést nem lehet hozzáadni.', + + // Error pages + '404_page_not_found' => 'Oldal nem található', + 'sorry_page_not_found' => 'Sajnáljuk, a keresett oldal nem található.', + 'return_home' => 'Vissza a kezdőlapra', + 'error_occurred' => 'Hiba örtént', + 'app_down' => ':appName jelenleg nem üzemel', + 'back_soon' => 'Hamarosan újra elérhető lesz.', + +]; diff --git a/resources/lang/hu/pagination.php b/resources/lang/hu/pagination.php new file mode 100644 index 000000000..87be04cf4 --- /dev/null +++ b/resources/lang/hu/pagination.php @@ -0,0 +1,12 @@ + '« Előző', + 'next' => 'Következő »', + +]; diff --git a/resources/lang/hu/passwords.php b/resources/lang/hu/passwords.php new file mode 100644 index 000000000..bacc08b08 --- /dev/null +++ b/resources/lang/hu/passwords.php @@ -0,0 +1,15 @@ + 'A jelszónak legalább hat karakterből kell állnia és egyeznie kell a megerősítéssel.', + 'user' => "Nem található felhasználó ezzel az e-mail címmel.", + 'token' => 'Ez a jelszó visszaállító vezérjel érvénytelen.', + 'sent' => 'E-mailben elküldtük a jelszó visszaállító hivatkozást!', + 'reset' => 'A jelszó visszaállítva!', + +]; diff --git a/resources/lang/hu/settings.php b/resources/lang/hu/settings.php new file mode 100644 index 000000000..efebb4a10 --- /dev/null +++ b/resources/lang/hu/settings.php @@ -0,0 +1,161 @@ + 'Beállítások', + 'settings_save' => 'Beállítások mentése', + 'settings_save_success' => 'Beállítások elmentve', + + // App Settings + 'app_customization' => 'Személyre szabás', + 'app_features_security' => 'Jellemzők és biztonság', + 'app_name' => 'Alkalmazás neve', + 'app_name_desc' => 'Ez a név meg fog jelenni a fejlécben és minden a rendszer által küldött emailben.', + 'app_name_header' => 'Név mutatása a fejlécben', + 'app_public_access' => 'Nyilvános hozzáférés', + 'app_public_access_desc' => 'Ha engedélyezett, a nem bejelentkezett felhasználók is hozzá tudnak férni a BookStack példány tartalmaihoz.', + 'app_public_access_desc_guest' => 'A nyilvános látogatók hozzáférése a "Guest" felhasználón keresztül irányítható.', + 'app_public_access_toggle' => 'Nyilvános hozzáférés engedélyezése', + 'app_public_viewing' => 'Nyilvános megtekintés engedélyezve?', + 'app_secure_images' => 'Magasabb biztonságú képfeltöltés', + 'app_secure_images_toggle' => 'Magasabb biztonságú képfeltöltés engedélyezése', + 'app_secure_images_desc' => 'Teljesítmény optimalizálási okokból minden kép nyilvános. Ez a beállítás egy véletlenszerű, nehezen kitalálható karakterláncot illeszt a képek útvonalának elejére. Meg kell győződni róla, hogy a könnyű hozzáférés megakadályozása érdekében a könyvtár indexek nincsenek engedélyezve.', + 'app_editor' => 'Oldalszerkesztő', + 'app_editor_desc' => 'Annak kiválasztása, hogy a felhasználók melyik szerkesztőt használhatják az oldalak szerkesztéséhez.', + 'app_custom_html' => 'Egyéni HTML fejléc tartalom', + 'app_custom_html_desc' => 'Az itt hozzáadott bármilyen tartalom be lesz illesztve minden oldal szekciójának aljára. Ez hasznos a stílusok felülírásához van analitikai kódok hozzáadásához.', + 'app_logo' => 'Alkalmazás logó', + 'app_logo_desc' => 'A képnek 43px magasnak kell lennie.
      A nagy képek át lesznek méretezve.', + 'app_primary_color' => 'Alkalmazás elsődleges színe', + 'app_primary_color_desc' => 'Hexadecimális értéknek kell lennie.
      Az alapértelmezés szerinti szín visszaállításához üresen kell hagyni.', + 'app_homepage' => 'Alkalmazás kezdőlapja', + 'app_homepage_desc' => 'A kezdőlapon az alapértelmezés szerinti nézet helyett megjelenő nézet kiválasztása. A kiválasztott oldalakon figyelmen kívül lesznek hagyva az oldal engedélyek.', + 'app_homepage_select' => 'Egy oldal kiválasztása', + 'app_disable_comments' => 'Megjegyzések letiltása', + 'app_disable_comments_toggle' => 'Megjegyzések letiltása', + 'app_disable_comments_desc' => 'Megjegyzések letiltása az alkalmazás összes oldalán.
      A már létező megjegyzések el lesznek rejtve.', + + // Registration Settings + 'reg_settings' => 'Regisztráció', + 'reg_enable' => 'Regisztráció engedélyezése', + 'reg_enable_toggle' => 'Regisztráció engedélyezése', + 'reg_enable_desc' => 'Ha a regisztráció engedélyezett, akkor a felhasználó képes lesz bejelentkezni mint az alkalmazás egy felhasználója. Regisztráció után egy egyszerű, alapértelmezés szerinti felhasználói szerepkör lesz hozzárendelve.', + 'reg_default_role' => 'Regisztráció utáni alapértelmezett felhasználói szerepkör', + 'reg_email_confirmation' => 'Email megerősítés', + 'reg_email_confirmation_toggle' => 'Email megerősítés szükséges', + 'reg_confirm_email_desc' => 'Ha a tartomány korlátozás be van állítva, akkor email megerősítés szükséges és ez a beállítás figyelmen kívül lesz hagyva.', + 'reg_confirm_restrict_domain' => 'Tartomány korlátozás', + 'reg_confirm_restrict_domain_desc' => 'Azoknak az email tartományoknak a vesszővel elválasztott listája, melyekre a regisztráció korlátozva lesz. A felhasználók egy emailt fognak kapni, hogy megerősítsék az email címüket mielőtt használni kezdhetnék az alkalmazást.
      Fontos tudni, hogy a felhasználók a sikeres regisztráció után megváltoztathatják az email címüket.', + 'reg_confirm_restrict_domain_placeholder' => 'Nincs beállítva korlátozás', + + // Maintenance settings + 'maint' => 'Karbantartás', + 'maint_image_cleanup' => 'Képek tisztítása', + 'maint_image_cleanup_desc' => "Végigolvassa az oldalakat és a tartalmak változatait, hogy leellenőrizze jelenleg mely képek és rajzok vannak használatban, és mely képek szerepelnek többször. A futtatása előtt feltétlen készíteni kell egy teljes adatbázis és lemezkép mentést.", + 'maint_image_cleanup_ignore_revisions' => 'Képek figyelmen kívül hagyása a változatokban', + 'maint_image_cleanup_run' => 'Tisztítás futtatása', + 'maint_image_cleanup_warning' => ':count potenciálisan nem használt képet találtam. Biztosan törölhetőek ezek a képek?', + 'maint_image_cleanup_success' => ':count potenciálisan nem használt kép megtalálva és törölve!', + 'maint_image_cleanup_nothing_found' => 'Nincsenek nem használt képek, semmi sem lett törölve!', + + // Role Settings + 'roles' => 'Szerepkörök', + 'role_user_roles' => 'Felhasználói szerepkörök', + 'role_create' => 'Új szerepkör létrehozása', + 'role_create_success' => 'Szerepkör sikeresen létrehozva', + 'role_delete' => 'Szerepkör törlése', + 'role_delete_confirm' => 'Ez törölni fogja \':roleName\' szerepkört.', + 'role_delete_users_assigned' => 'Ehhez a szerepkörhöz :userCount felhasználó van hozzárendelve. Ha a felhasználókat át kell helyezni ebből a szerepkörből, akkor ki kell választani egy új szerepkört.', + 'role_delete_no_migration' => "Nincs felhasználó áthelyezés", + 'role_delete_sure' => 'Biztosan törölhető ez a szerepkör?', + 'role_delete_success' => 'Szerepkör sikeresen törölve', + 'role_edit' => 'Szerepkör szerkesztése', + 'role_details' => 'Szerepkör részletei', + 'role_name' => 'Szerepkör neve', + 'role_desc' => 'Szerepkör rövid leírása', + 'role_external_auth_id' => 'Külső hitelesítés azonosítók', + 'role_system' => 'Rendszer jogosultságok', + 'role_manage_users' => 'Felhasználók kezelése', + 'role_manage_roles' => 'Szerepkörök és szerepkör engedélyek kezelése', + 'role_manage_entity_permissions' => 'Minden könyv, fejezet és oldalengedély kezelése', + 'role_manage_own_entity_permissions' => 'Saját könyv, fejezet és oldalak engedélyeinek kezelése', + 'role_manage_settings' => 'Alkalmazás beállításainak kezelése', + 'role_asset' => 'Eszköz jogosultságok', + 'role_asset_desc' => 'Ezek a jogosultság vezérlik a alapértelmezés szerinti hozzáférést a rendszerben található eszközökhöz. A könyvek, fejezetek és oldalak jogosultságai felülírják ezeket a jogosultságokat.', + 'role_asset_admins' => 'Az adminisztrátorok automatikusan hozzáférést kapnak minden tartalomhoz, de ezek a beállítások megjeleníthetnek vagy elrejthetnek felhasználói felület beállításokat.', + 'role_all' => 'Összes', + 'role_own' => 'Saját', + 'role_controlled_by_asset' => 'Az általuk feltöltött eszköz által ellenőrzött', + 'role_save' => 'Szerepkör mentése', + 'role_update_success' => 'Szerepkör sikeresen frissítve', + 'role_users' => 'Felhasználók ebben a szerepkörben', + 'role_users_none' => 'Jelenleg nincsenek felhasználók hozzárendelve ehhez a szerepkörhöz', + + // Users + 'users' => 'Felhasználók', + 'user_profile' => 'Felhasználói profil', + 'users_add_new' => 'Új felhasználó hozzáadása', + 'users_search' => 'Felhasználók keresése', + 'users_details' => 'Felhasználó részletei', + 'users_details_desc' => 'Egy megjelenítendő név és email cím beállítása ennek a felhasználónak. Az email cím az alkalmazásba történő bejelentkezéshez lesz használva.', + 'users_details_desc_no_email' => 'Egy megjelenítendő név beállítása ennek a felhasználónak amiről mások felismerik.', + 'users_role' => 'Felhasználói szerepkörök', + 'users_role_desc' => 'A felhasználó melyik szerepkörhöz lesz rendelve. Ha a felhasználó több szerepkörhöz van rendelve, akkor ezeknek a szerepköröknek a jogosultságai összeadódnak, és a a felhasználó a hozzárendelt szerepkörök minden képességét megkapja.', + 'users_password' => 'Felhasználó jelszava', + 'users_password_desc' => 'Az alkalmazásba bejelentkezéshez használható jelszó beállítása. Legalább 5 karakter hosszúnak kell lennie.', + 'users_external_auth_id' => 'Külső hitelesítés azonosítója', + 'users_external_auth_id_desc' => 'Ez az azonosító lesz használva a felhasználó ellenőrzéséhez mikor az LDAP rendszerrel kommunikál.', + 'users_password_warning' => 'A lenti mezőket csak a jelszó módosításához kell kitölteni.', + 'users_system_public' => 'Ez a felhasználó bármelyik, a példányt megtekintő felhasználót képviseli. Nem lehet vele bejelentkezni de automatikusan hozzá lesz rendelve.', + 'users_delete' => 'Felhasználó törlése', + 'users_delete_named' => ':userName felhasználó törlése', + 'users_delete_warning' => '\':userName\' felhasználó teljesen törölve lesz a rendszerből.', + 'users_delete_confirm' => 'Biztosan törölhető ez a felhasználó?', + 'users_delete_success' => 'Felhasználó sikeresen eltávolítva', + 'users_edit' => 'Felhasználó szerkesztése', + 'users_edit_profile' => 'Profil szerkesztése', + 'users_edit_success' => 'Felhasználó sikeresen frissítve', + 'users_avatar' => 'Avatar használata', + 'users_avatar_desc' => 'A felhasználót ábrázoló kép kiválasztása. Kb. 256px méretű négyzetes képnek kell lennie.', + 'users_preferred_language' => 'Előnyben részesített nyelv', + 'users_preferred_language_desc' => 'Ez a beállítás megváltoztatja az alkalmazás felhasználói felületén használt nyelvet. Nincs hatása a felhasználók által létrehozott tartalomra.', + 'users_social_accounts' => 'Közösségi fiókok', + 'users_social_accounts_info' => 'Itt lehet egyéb fiókokat hozzákapcsolni a gyorsabb és könnyebb bejelentkezés érdekében. Itt olyan fiókot lehet lecsatlakoztatni, melynek korábban nem volt engedélyezett hozzáférése. Visszavonja a hozzáférést a csatlakoztatott szociális fiók profilbeállításaiból.', + 'users_social_connect' => 'Fiók csatlakoztatása', + 'users_social_disconnect' => 'Fiók lecsatlakoztatása', + 'users_social_connected' => ':socialAccount fiók sikeresen csatlakoztatva a profilhoz.', + 'users_social_disconnected' => ':socialAccount fiók sikeresen lecsatlakoztatva a profilról.', + + //! Since these labels are already localized this array does not need to be + //! translated in the language-specific files. + //! DELETE BELOW IF COPIED FROM EN + //!//////////////////////////////// + 'language_select' => [ + 'en' => 'English', + 'ar' => 'العربية', + 'de' => 'Deutsch (Sie)', + 'de_informal' => 'Deutsch (Du)', + 'es' => 'Español', + 'es_AR' => 'Español Argentina', + 'fr' => 'Français', + 'nl' => 'Nederlands', + 'pt_BR' => 'Português do Brasil', + 'sk' => 'Slovensky', + 'cs' => 'Česky', + 'sv' => 'Svenska', + 'kr' => '한국어', + 'ja' => '日本語', + 'pl' => 'Polski', + 'it' => 'Italian', + 'ru' => 'Русский', + 'uk' => 'Українська', + 'zh_CN' => '简体中文', + 'zh_TW' => '繁體中文' + ] + //!//////////////////////////////// +]; diff --git a/resources/lang/hu/validation.php b/resources/lang/hu/validation.php new file mode 100644 index 000000000..68a444643 --- /dev/null +++ b/resources/lang/hu/validation.php @@ -0,0 +1,85 @@ + ':attribute elfogadott kell legyen.', + 'active_url' => ':attribute nem érvényes webcím.', + 'after' => ':attribute dátumnak :date utáninak kell lennie.', + 'alpha' => ':attribute csak betűket tartalmazhat.', + 'alpha_dash' => ':attribute csak betűket, számokat és kötőjeleket tartalmazhat.', + 'alpha_num' => ':attribute csak betűket és számokat tartalmazhat.', + 'array' => ':attribute tömb kell legyen.', + 'before' => ':attribute dátumnak :date előttinek kell lennie.', + 'between' => [ + 'numeric' => ':attribute értékének :min és :max között kell lennie.', + 'file' => ':attribute értékének :min és :max kilobájt között kell lennie.', + 'string' => ':attribute hosszának :min és :max karakter között kell lennie.', + 'array' => ':attribute mennyiségének :min és :max elem között kell lennie.', + ], + 'boolean' => ':attribute mezőnek igaznak vagy hamisnak kell lennie.', + 'confirmed' => ':attribute megerősítés nem egyezik.', + 'date' => ':attribute nem érvényes dátum.', + 'date_format' => ':attribute nem egyezik :format formátummal.', + 'different' => ':attribute és :other értékének különböznie kell.', + 'digits' => ':attribute :digits számból kell álljon.', + 'digits_between' => ':attribute hosszának :min és :max számjegy között kell lennie.', + 'email' => ':attribute érvényes email cím kell legyen.', + 'filled' => ':attribute mező kötelező.', + 'exists' => 'A kiválasztott :attribute érvénytelen.', + 'image' => ':attribute kép kell legyen.', + 'image_extension' => 'A :attribute kép kiterjesztése érvényes és támogatott kell legyen.', + 'in' => 'A kiválasztott :attribute érvénytelen.', + 'integer' => ':attribute egész szám kell legyen.', + 'ip' => ':attribute érvényes IP cím kell legyen.', + 'max' => [ + 'numeric' => ':attribute nem lehet nagyobb mint :max.', + 'file' => ':attribute nem lehet nagyobb mint :max kilobájt.', + 'string' => ':attribute nem lehet nagyobb mint :max karakter.', + 'array' => ':attribute mennyisége nem lehet több mint :max elem.', + ], + 'mimes' => 'A :attribute típusa csak :values lehet.', + 'min' => [ + 'numeric' => ':attribute legalább :min kell legyen.', + 'file' => ':attribute legalább :min kilobájt kell legyen.', + 'string' => ':attribute legalább :min karakter kell legyen.', + 'array' => ':attribute legalább :min elem kell legyen.', + ], + 'no_double_extension' => ':attribute csak egy fájlkiterjesztéssel rendelkezhet.', + 'not_in' => 'A kiválasztott :attribute érvénytelen.', + 'numeric' => ':attribute szám kell legyen.', + 'regex' => ':attribute formátuma érvénytelen.', + 'required' => ':attribute mező kötelező.', + 'required_if' => ':attribute mező kötelező ha :other értéke :value.', + 'required_with' => ':attribute mező kötelező ha :values be van állítva.', + 'required_with_all' => ':attribute mező kötelező ha van :value.', + 'required_without' => ':attribute mező kötelező ha :values nincs beállítva.', + 'required_without_all' => ':attribute mező kötelező ha egyik :values sincs beállítva.', + 'same' => ':attribute és :other értékének egyeznie kell.', + 'size' => [ + 'numeric' => ':attribute :size méretű kell legyen.', + 'file' => ':attribute :size kilobájt méretű kell legyen.', + 'string' => ':attribute :size karakter kell legyen.', + 'array' => ':attribute : size elemet kell tartalmazzon.', + ], + 'string' => ':attribute karaktersorozatnak kell legyen.', + 'timezone' => ':attribute érvényes zóna kell legyen.', + 'unique' => ':attribute már elkészült.', + 'url' => ':attribute formátuma érvénytelen.', + 'uploaded' => 'A fájlt nem lehet feltölteni. A kiszolgáló nem fogad el ilyen méretű fájlokat.', + + // Custom validation lines + 'custom' => [ + 'password-confirm' => [ + 'required_with' => 'Jelszó megerősítés szükséges', + ], + ], + + // Custom validation attributes + 'attributes' => [], +]; diff --git a/resources/lang/pt_BR/activities.php b/resources/lang/pt_BR/activities.php index 03ff80c9f..91417cc8b 100644 --- a/resources/lang/pt_BR/activities.php +++ b/resources/lang/pt_BR/activities.php @@ -1,12 +1,10 @@ 'página criada', 'page_create_notification' => 'Página criada com sucesso', diff --git a/resources/lang/pt_BR/auth.php b/resources/lang/pt_BR/auth.php index 73228f21a..20dc690af 100644 --- a/resources/lang/pt_BR/auth.php +++ b/resources/lang/pt_BR/auth.php @@ -1,21 +1,15 @@ 'As credenciais fornecidas não puderam ser validadas em nossos registros..', 'throttle' => 'Muitas tentativas de login. Por favor, tente novamente em :seconds segundos.', - /** - * Login & Register - */ + // Login & Register 'sign_up' => 'Registrar-se', 'log_in' => 'Entrar', 'log_in_with' => 'Entrar com :socialDriver', @@ -32,6 +26,8 @@ return [ 'remember_me' => 'Lembrar de mim', 'ldap_email_hint' => 'Por favor, digite um e-mail para essa conta.', 'create_account' => 'Criar conta', + 'already_have_account' => 'Você já possui uma conta?', + 'dont_have_account' => 'Não possui uma conta?', 'social_login' => 'Login social', 'social_registration' => 'Registro social', 'social_registration_text' => 'Registre e entre usando outro serviço.', @@ -43,23 +39,18 @@ return [ 'register_success' => 'Obrigado por se registrar! Você agora encontra-se registrado e logado..', - /** - * Password Reset - */ + // Password Reset 'reset_password' => 'Resetar senha', 'reset_password_send_instructions' => 'Digite seu e-mail abaixo e o sistema enviará uma mensagem com o link de reset de senha.', 'reset_password_send_button' => 'Enviar o link de reset de senha', 'reset_password_sent_success' => 'Um link de reset de senha foi enviado para :email.', 'reset_password_success' => 'Sua senha foi resetada com sucesso.', - 'email_reset_subject' => 'Resetar a senha de :appName', 'email_reset_text' => 'Você recebeu esse e-mail pois recebemos uma solicitação de reset de senha para sua conta.', 'email_reset_not_requested' => 'Caso não tenha sido você a solicitar o reset de senha, ignore esse e-mail.', - /** - * Email Confirmation - */ + // Email Confirmation 'email_confirm_subject' => 'Confirme seu e-mail para :appName', 'email_confirm_greeting' => 'Obrigado por se registrar em :appName!', 'email_confirm_text' => 'Por favor, confirme seu endereço de e-mail clicando no botão abaixo:', diff --git a/resources/lang/pt_BR/common.php b/resources/lang/pt_BR/common.php index 0741541eb..c6750a954 100644 --- a/resources/lang/pt_BR/common.php +++ b/resources/lang/pt_BR/common.php @@ -1,31 +1,30 @@ 'Cancelar', 'confirm' => 'Confirmar', 'back' => 'Voltar', 'save' => 'Salvar', 'continue' => 'Continuar', 'select' => 'Selecionar', + 'toggle_all' => 'Alternar Tudo', 'more' => 'Mais', - /** - * Form Labels - */ + // Form Labels 'name' => 'Nome', 'description' => 'Descrição', 'role' => 'Regra', 'cover_image' => 'Imagem de capa', 'cover_image_description' => 'Esta imagem deve ser aproximadamente 300x170px.', - /** - * Actions - */ + // Actions 'actions' => 'Ações', 'view' => 'Visualizar', + 'view_all' => 'Ver Tudo', 'create' => 'Criar', 'update' => 'Atualizar', 'edit' => 'Editar', @@ -40,9 +39,12 @@ return [ 'remove' => 'Remover', 'add' => 'Adicionar', - /** - * Misc - */ + // Sort Options + 'sort_name' => 'Nome', + 'sort_created_at' => 'Data de Criação', + 'sort_updated_at' => 'Data de Atualização', + + // Misc 'deleted_user' => 'Usuário excluído', 'no_activity' => 'Nenhuma atividade a mostrar', 'no_items' => 'Nenhum item disponível', @@ -54,15 +56,15 @@ return [ 'list_view' => 'Visualização em Lista', 'default' => 'Padrão', - /** - * Header - */ + // Header 'view_profile' => 'Visualizar Perfil', 'edit_profile' => 'Editar Perfil', - /** - * Email Content - */ + // Layout tabs + 'tab_info' => 'Info', + 'tab_content' => 'Conteúdo', + + // Email Content 'email_action_help' => 'Se você estiver tendo problemas ao clicar o botão ":actionText", copie e cole a URL abaixo no seu navegador:', 'email_rights' => 'Todos os direitos reservados', ]; \ No newline at end of file diff --git a/resources/lang/pt_BR/components.php b/resources/lang/pt_BR/components.php index 4ea4d88c5..b9f1c3a38 100644 --- a/resources/lang/pt_BR/components.php +++ b/resources/lang/pt_BR/components.php @@ -1,9 +1,10 @@ 'Selecionar imagem', 'image_all' => 'Todos', 'image_all_title' => 'Visualizar todas as imagens', @@ -24,9 +25,7 @@ return [ 'image_delete_success' => 'Imagem excluída com sucesso', 'image_upload_remove' => 'Remover', - /** - * Code editor - */ + // Code editor 'code_editor' => 'Editar Código', 'code_language' => 'Linguagem do Código', 'code_content' => 'Código', diff --git a/resources/lang/pt_BR/entities.php b/resources/lang/pt_BR/entities.php index 9e6678146..7ce5ef01e 100644 --- a/resources/lang/pt_BR/entities.php +++ b/resources/lang/pt_BR/entities.php @@ -1,17 +1,20 @@ 'Recentemente criado', - 'recently_created_pages' => 'Páginas recentemente criadas', - 'recently_updated_pages' => 'Páginas recentemente atualizadas', - 'recently_created_chapters' => 'Capítulos recentemente criados', - 'recently_created_books' => 'Livros recentemente criados', - 'recently_update' => 'Recentemente atualizado', - 'recently_viewed' => 'Recentemente visualizado', - 'recent_activity' => 'Atividade recente', + // Shared + 'recently_created' => 'Recentemente Criado', + 'recently_created_pages' => 'Páginas Recentemente Criadas', + 'recently_updated_pages' => 'Páginas Recentemente Atualizadas', + 'recently_created_chapters' => 'Capítulos Recentemente Criados', + 'recently_created_books' => 'Livros Recentemente Criados', + 'recently_created_shelves' => 'Prateleiras Recentemente Criadas', + 'recently_update' => 'Recentemente Atualizado', + 'recently_viewed' => 'Recentemente Visualizado', + 'recent_activity' => 'Atividade Recente', 'create_now' => 'Criar um agora', 'revisions' => 'Revisões', 'meta_revision' => 'Revisão #:revisionCount', @@ -31,17 +34,13 @@ return [ 'export_pdf' => 'Arquivo PDF', 'export_text' => 'Arquivo Texto', - /** - * Permissions and restrictions - */ + // Permissions and restrictions 'permissions' => 'Permissões', 'permissions_intro' => 'Uma vez habilitado, as permissões terão prioridade sobre outro conjunto de permissões.', 'permissions_enable' => 'Habilitar Permissões Customizadas', 'permissions_save' => 'Salvar Permissões', - /** - * Search - */ + // Search 'search_results' => 'Resultado(s) da Pesquisa', 'search_total_results_found' => ':count resultado encontrado|:count resultados encontrados', 'search_clear' => 'Limpar Pesquisa', @@ -66,16 +65,16 @@ return [ 'search_set_date' => 'Definir data', 'search_update' => 'Refazer Pesquisa', - /** - * Shelves - */ + // Shelves 'shelf' => 'Prateleira', 'shelves' => 'Prateleiras', + 'x_shelves' => ':count Prateleira|:count Prateleiras', 'shelves_long' => 'Prateleiras de Livros', 'shelves_empty' => 'Nenhuma prateleira foi criada', - 'shelves_create' => 'Criar nova Prateleira', - 'shelves_popular' => 'Prateleiras populares', - 'shelves_new' => 'Prateleiras novas', + 'shelves_create' => 'Criar Nova Prateleira', + 'shelves_popular' => 'Prateleiras Populares', + 'shelves_new' => 'Prateleiras Novas', + 'shelves_new_action' => 'Nova Prateleira', 'shelves_popular_empty' => 'As prateleiras mais populares aparecerão aqui.', 'shelves_new_empty' => 'As prateleiras criadas mais recentemente aparecerão aqui.', 'shelves_save' => 'Salvar Prateleira', @@ -98,16 +97,15 @@ return [ 'shelves_copy_permissions_explain' => 'Isto aplicará as configurações de permissões atuais desta prateleira de livros a todos os livros contidos nela. Antes de ativar, assegure-se de que quaisquer alterações nas permissões desta prateleira de livros tenham sido salvas.', 'shelves_copy_permission_success' => 'Permissões da prateleira de livros copiada para :count livros', - /** - * Books - */ + // Books 'book' => 'Livro', 'books' => 'Livros', 'x_books' => ':count Livro|:count Livros', 'books_empty' => 'Nenhum livro foi criado', - 'books_popular' => 'Livros populares', - 'books_recent' => 'Livros recentes', - 'books_new' => 'Livros novos', + 'books_popular' => 'Livros Populares', + 'books_recent' => 'Livros Recentes', + 'books_new' => 'Livros Novos', + 'books_new_action' => 'Novo Livro', 'books_popular_empty' => 'Os livros mais populares aparecerão aqui.', 'books_new_empty' => 'Os livros criados mais recentemente aparecerão aqui.', 'books_create' => 'Criar novo Livro', @@ -123,45 +121,45 @@ return [ 'books_permissions_updated' => 'Permissões do Livro Atualizadas', 'books_empty_contents' => 'Nenhuma página ou capítulo criado para esse livro.', 'books_empty_create_page' => 'Criar uma nova página', - 'books_empty_or' => 'ou', 'books_empty_sort_current_book' => 'Ordenar o livro atual', 'books_empty_add_chapter' => 'Adicionar um capítulo', - 'books_permissions_active' => 'Permissões do Livro ativadas', + 'books_permissions_active' => 'Permissões do Livro Ativadas', 'books_search_this' => 'Pesquisar esse livro', 'books_navigation' => 'Navegação do Livro', - 'books_sort' => 'Ordenar conteúdos do Livro', + 'books_sort' => 'Ordenar Conteúdos do Livro', 'books_sort_named' => 'Ordenar Livro :bookName', - 'books_sort_show_other' => 'Mostrar outros livros', - 'books_sort_save' => 'Salvar nova ordenação', + 'books_sort_name' => 'Ordernar por Nome', + 'books_sort_created' => 'Ordenar por Data de Criação', + 'books_sort_updated' => 'Ordenar por Data de Atualização', + 'books_sort_chapters_first' => 'Capítulos Primeiro', + 'books_sort_chapters_last' => 'Capítulos por Último', + 'books_sort_show_other' => 'Mostrar Outros Livros', + 'books_sort_save' => 'Salvar Nova Ordenação', - /** - * Chapters - */ + // Chapters 'chapter' => 'Capítulo', 'chapters' => 'Capítulos', 'x_chapters' => ':count Capítulo|:count Capítulos', 'chapters_popular' => 'Capítulos Populares', 'chapters_new' => 'Novo Capítulo', - 'chapters_create' => 'Criar novo Capítulo', + 'chapters_create' => 'Criar Novo Capítulo', 'chapters_delete' => 'Excluír Capítulo', 'chapters_delete_named' => 'Excluir Capítulo :chapterName', 'chapters_delete_explain' => 'A ação vai excluír o capítulo de nome \':chapterName\'. Todas as páginas do capítulo serão removidas e adicionadas diretamente ao livro pai.', 'chapters_delete_confirm' => 'Tem certeza que deseja excluír o capítulo?', 'chapters_edit' => 'Editar Capítulo', - 'chapters_edit_named' => 'Editar capítulo :chapterName', + 'chapters_edit_named' => 'Editar Capítulo :chapterName', 'chapters_save' => 'Salvar Capítulo', 'chapters_move' => 'Mover Capítulo', 'chapters_move_named' => 'Mover Capítulo :chapterName', 'chapter_move_success' => 'Capítulo movido para :bookName', 'chapters_permissions' => 'Permissões do Capítulo', 'chapters_empty' => 'Nenhuma página existente nesse capítulo.', - 'chapters_permissions_active' => 'Permissões de Capítulo ativadas', - 'chapters_permissions_success' => 'Permissões de Capítulo atualizadas', + 'chapters_permissions_active' => 'Permissões de Capítulo Ativadas', + 'chapters_permissions_success' => 'Permissões de Capítulo Atualizadas', 'chapters_search_this' => 'Pesquisar este Capítulo', - /** - * Pages - */ + // Pages 'page' => 'Página', 'pages' => 'Páginas', 'x_pages' => ':count Página|:count Páginas', @@ -178,7 +176,6 @@ return [ 'pages_delete_confirm' => 'Tem certeza que deseja excluir a página?', 'pages_delete_draft_confirm' => 'Tem certeza que deseja excluir o rascunho de página?', 'pages_editing_named' => 'Editando a Página :pageName', - 'pages_edit_toggle_header' => 'Alternar cabeçalho', 'pages_edit_save_draft' => 'Salvar Rascunho', 'pages_edit_draft' => 'Editar rascunho de Página', 'pages_editing_draft' => 'Editando Rascunho', @@ -212,7 +209,9 @@ return [ 'pages_revisions_created_by' => 'Criado por', 'pages_revisions_date' => 'Data da Revisão', 'pages_revisions_number' => '#', + 'pages_revisions_numbered' => 'Revisão #:id', 'pages_revisions_changelog' => 'Changelog', + 'pages_revisions_numbered_changes' => 'Alterações da Revisão #:id', 'pages_revisions_changes' => 'Mudanças', 'pages_revisions_current' => 'Versão atual', 'pages_revisions_preview' => 'Preview', @@ -235,9 +234,7 @@ return [ 'pages_draft_discarded' => 'Rascunho descartado. O editor foi atualizado com a página atualizada', 'pages_specific' => 'Página Específica', - /** - * Editor sidebar - */ + // Editor sidebar 'page_tags' => 'Tags de Página', 'chapter_tags' => 'Tags de Capítulo', 'book_tags' => 'Tags de Livro', @@ -273,18 +270,15 @@ return [ 'attachments_file_updated' => 'Arquivo atualizado com sucesso', 'attachments_link_attached' => 'Link anexado com sucesso à página', - /** - * Profile View - */ + // Profile View 'profile_user_for_x' => 'Usuário por :time', 'profile_created_content' => 'Conteúdo Criado', 'profile_not_created_pages' => ':userName não criou páginas', 'profile_not_created_chapters' => ':userName não criou capítulos', 'profile_not_created_books' => ':userName não criou livros', + 'profile_not_created_shelves' => ':userName não criou prateleiras', - /** - * Comments - */ + // Comments 'comment' => 'Comentário', 'comments' => 'Comentários', 'comment_add' => 'Adicionar Comentário', @@ -302,10 +296,9 @@ return [ 'comment_delete_confirm' => 'Você tem certeza de que quer deletar este comentário?', 'comment_in_reply_to' => 'Em resposta à :commentId', - /** - * Revision - */ + // Revision 'revision_delete_confirm' => 'Tem certeza de que deseja excluir esta revisão?', + 'revision_restore_confirm' => 'Tem certeza que deseja restaurar esta revisão? O conteúdo atual da página será substituído.', 'revision_delete_success' => 'Revisão excluída', 'revision_cannot_delete_latest' => 'Não é possível excluir a revisão mais recente.' ]; \ No newline at end of file diff --git a/resources/lang/pt_BR/errors.php b/resources/lang/pt_BR/errors.php index 023254182..c5b1a9f92 100644 --- a/resources/lang/pt_BR/errors.php +++ b/resources/lang/pt_BR/errors.php @@ -1,11 +1,9 @@ 'Você não tem permissões para acessar a página requerida.', 'permissionJson' => 'Você não tem permissão para realizar a ação requerida.', @@ -66,6 +64,7 @@ return [ 'role_cannot_be_edited' => 'Esse perfil não pode ser editado', 'role_system_cannot_be_deleted' => 'Esse perfil é um perfil de sistema e não pode ser excluído', 'role_registration_default_cannot_delete' => 'Esse perfil não poderá se excluído enquando estiver registrado como o perfil padrão', + 'role_cannot_remove_only_admin' => 'Este usuário é o único usuário atribuído ao perfil de administrador. Atribua o perfil de administrador a outro usuário antes de tentar removê-lo aqui.', // comments 'comment_list' => 'Ocorreu um erro ao buscar os comentários.', @@ -81,4 +80,5 @@ return [ 'error_occurred' => 'Um erro ocorreu', 'app_down' => ':appName está fora do ar no momento', 'back_soon' => 'Voltaremos em seguida.', + ]; diff --git a/resources/lang/pt_BR/pagination.php b/resources/lang/pt_BR/pagination.php index 6a32f34ac..3ae5dd3e0 100644 --- a/resources/lang/pt_BR/pagination.php +++ b/resources/lang/pt_BR/pagination.php @@ -1,18 +1,11 @@ '« Anterior', 'next' => 'Próximo »', diff --git a/resources/lang/pt_BR/passwords.php b/resources/lang/pt_BR/passwords.php index f75c24ea5..61a49f57a 100644 --- a/resources/lang/pt_BR/passwords.php +++ b/resources/lang/pt_BR/passwords.php @@ -1,18 +1,11 @@ 'Senhas devem ter ao menos 6 caraceres e combinar com os atributos mínimos para a senha.', 'user' => "Não pudemos encontrar um usuário com o e-mail fornecido.", 'token' => 'O token de reset de senha é inválido.', diff --git a/resources/lang/pt_BR/settings.php b/resources/lang/pt_BR/settings.php index aab2c2591..4bb8f37e0 100644 --- a/resources/lang/pt_BR/settings.php +++ b/resources/lang/pt_BR/settings.php @@ -1,32 +1,35 @@ 'Configurações', 'settings_save' => 'Salvar Configurações', 'settings_save_success' => 'Configurações Salvas', - /** - * App settings - */ - - 'app_settings' => 'Configurações do App', + // App Settings + 'app_customization' => 'Customização', + 'app_features_security' => 'Recursos & Segurança', 'app_name' => 'Nome da Aplicação', 'app_name_desc' => 'Esse nome será mostrado no cabeçalho e em e-mails.', 'app_name_header' => 'Mostrar o nome da Aplicação no cabeçalho?', + 'app_public_access' => 'Acesso Público', + 'app_public_access_desc' => 'Habilitar esta opção irá permitir que visitantes, que não estão logados, acessem o conteúdo em sua instância do BookStack.', + 'app_public_access_desc_guest' => 'O acesso de visitantes públicos pode ser controlado através do usuário "Convidado".', + 'app_public_access_toggle' => 'Permitir acesso público', 'app_public_viewing' => 'Permitir visualização pública?', 'app_secure_images' => 'Permitir upload de imagens com maior segurança?', + 'app_secure_images_toggle' => 'Habilitar uploads de imagem de maior segurança', 'app_secure_images_desc' => 'Por questões de performance, todas as imagens são públicas. Essa opção adiciona uma string randômica na frente da imagem. Certifique-se de que os índices do diretórios permitem o acesso fácil.', 'app_editor' => 'Editor de Página', 'app_editor_desc' => 'Selecione qual editor a ser usado pelos usuários para editar páginas.', 'app_custom_html' => 'Conteúdo para tag HTML HEAD customizado', 'app_custom_html_desc' => 'Quaisquer conteúdos aqui inseridos serão inseridos no final da seção do HTML de cada página. Essa é uma maneira útil de sobrescrever estilos e adicionar códigos de análise de site.', + 'app_custom_html_disabled_notice' => 'O conteúdo personalizado do head do HTML está desabilitado nesta página de configurações para garantir que quaisquer alterações significativas possam ser revertidas.', 'app_logo' => 'Logo da Aplicação', 'app_logo_desc' => 'A imagem deve ter 43px de altura.
      Imagens mais largas devem ser reduzidas.', 'app_primary_color' => 'Cor primária da Aplicação', @@ -34,26 +37,24 @@ return [ 'app_homepage' => 'Página incial', 'app_homepage_desc' => 'Selecione a página para ser usada como página inicial em vez da padrão. Permissões da página serão ignoradas.', 'app_homepage_select' => 'Selecione uma página', - 'app_disable_comments' => 'Desativar comentários', + 'app_disable_comments' => 'Desativar Comentários', + 'app_disable_comments_toggle' => 'Desativar comentários', 'app_disable_comments_desc' => 'Desativar comentários em todas as páginas no aplicativo. Os comentários existentes não são exibidos.', - /** - * Registration settings - */ - - 'reg_settings' => 'Parâmetros de Registro', - 'reg_allow' => 'Permitir Registro?', + // Registration settings + 'reg_settings' => 'Registro', + 'reg_enable' => 'Habilitar Registro', + 'reg_enable_toggle' => 'Habilitar registro', + 'reg_enable_desc' => 'Quando o registro é habilitado, o usuário poderá se registrar como usuário do aplicativo. No registro, eles recebem um único perfil padrão.', 'reg_default_role' => 'Perfil padrão para usuários após o registro', - 'reg_confirm_email' => 'Requerer confirmação por e-mail?', + 'reg_email_confirmation' => 'Confirmação de E-mail', + 'reg_email_confirmation_toggle' => 'Requer confirmação de e-mail', 'reg_confirm_email_desc' => 'Se restrições de domínio são usadas a confirmação por e-mail será requerida e o valor abaixo será ignorado.', 'reg_confirm_restrict_domain' => 'Restringir registro ao domínio', 'reg_confirm_restrict_domain_desc' => 'Entre com uma lista de domínios de e-mails separados por vírgula para os quais você deseja restringir os registros. Será enviado um e-mail de confirmação para o usuário validar o e-mail antes de ser permitido interação com a aplicação.
      Note que os usuários serão capazes de alterar o e-mail cadastrado após o sucesso na confirmação do registro.', 'reg_confirm_restrict_domain_placeholder' => 'Nenhuma restrição configurada', - /** - * Maintenance settings - */ - + // Maintenance settings 'maint' => 'Manutenção', 'maint_image_cleanup' => 'Limpeza de Imagens', 'maint_image_cleanup_desc' => "Examina páginas & revisa o conteúdo para verificar quais imagens e desenhos estão atualmente em uso e quais imagens são redundantes. Certifique-se de criar um backup completo do banco de dados e imagens antes de executar isso.", @@ -63,10 +64,7 @@ return [ 'maint_image_cleanup_success' => ':count imagens potencialmente não utilizadas foram encontradas e excluídas!', 'maint_image_cleanup_nothing_found' => 'Nenhuma imagem não utilizada foi encontrada, nada foi excluído!', - /** - * Role settings - */ - + // Role settings 'roles' => 'Perfis', 'role_user_roles' => 'Perfis de Usuário', 'role_create' => 'Criar novo Perfil', @@ -99,16 +97,20 @@ return [ 'role_users' => 'Usuários neste Perfil', 'role_users_none' => 'Nenhum usuário está atualmente atrelado a esse Perfil', - /** - * Users - */ - + // Users 'users' => 'Usuários', - 'user_profile' => 'Perfil de Usuário', + 'user_profile' => 'Perfil do Usuário', 'users_add_new' => 'Adicionar Novo Usuário', 'users_search' => 'Pesquisar Usuários', - 'users_role' => 'Perfis de Usuário', + 'users_details' => 'Detalhes do Usuário', + 'users_details_desc' => 'Defina um nome de exibição e um endereço de e-mail para este usuário. O endereço de e-mail será usado para fazer login na aplicação.', + 'users_details_desc_no_email' => 'Defina um nome de exibição para este usuário para que outros usuários possam reconhecê-lo', + 'users_role' => 'Perfis do Usuário', + 'users_role_desc' => 'Selecione os perfis para os quais este usuário será atribuído. Se um usuário for atribuído a multiplos perfis, as permissões destes perfis serão empilhadas e eles receberão todas as habilidades dos perfis atribuídos.', + 'users_password' => 'Senha do Usuário', + 'users_password_desc' => 'Defina uma senha usada para fazer login na aplicação. Esta deve ter pelo menos 5 caracteres.', 'users_external_auth_id' => 'ID de Autenticação Externa', + 'users_external_auth_id_desc' => 'Este é o ID usado para corresponder a este usuário ao se comunicar com seu sistema LDAP.', 'users_password_warning' => 'Preencha os dados abaixo caso queira modificar a sua senha:', 'users_system_public' => 'Esse usuário representa quaisquer convidados que visitam o aplicativo. Ele não pode ser usado para login.', 'users_delete' => 'Excluir Usuário', @@ -122,12 +124,14 @@ return [ 'users_avatar' => 'Imagem de Usuário', 'users_avatar_desc' => 'Essa imagem deve ser um quadrado com aproximadamente 256px de altura e largura.', 'users_preferred_language' => 'Linguagem de Preferência', + 'users_preferred_language_desc' => 'Esta opção irá alterar o idioma usado para a interface de usuário da aplicação. Isto não afetará nenhum conteúdo criado pelo usuário.', 'users_social_accounts' => 'Contas Sociais', 'users_social_accounts_info' => 'Aqui você pode conectar outras contas para acesso mais rápido. Desconectar uma conta não retira a possibilidade de acesso usando-a. Para revogar o acesso ao perfil através da conta social, você deverá fazê-lo na sua conta social.', 'users_social_connect' => 'Contas conectadas', 'users_social_disconnect' => 'Desconectar Conta', 'users_social_connected' => 'Conta :socialAccount foi conectada com sucesso ao seu perfil.', 'users_social_disconnected' => 'Conta :socialAccount foi desconectada com sucesso de seu perfil.', + ]; diff --git a/resources/lang/pt_BR/validation.php b/resources/lang/pt_BR/validation.php index 451dbe99c..3d4b51f03 100644 --- a/resources/lang/pt_BR/validation.php +++ b/resources/lang/pt_BR/validation.php @@ -1,18 +1,13 @@ 'O :attribute deve ser aceito.', 'active_url' => 'O :attribute não é uma URL válida.', 'after' => 'O :attribute deve ser uma data posterior à data :date.', @@ -38,6 +33,7 @@ return [ 'filled' => 'O campo :attribute é requerido.', 'exists' => 'O atributo :attribute selecionado não é válido.', 'image' => 'O campo :attribute deve ser uma imagem.', + 'image_extension' => 'O campo :attribute deve ter uma extensão de imagem válida & suportada.', 'in' => 'The selected :attribute is invalid.', 'integer' => 'O campo :attribute deve ser um número inteiro.', 'ip' => 'O campo :attribute deve ser um IP válido.', @@ -54,6 +50,7 @@ return [ 'string' => 'O valor para o campo :attribute não deve ter menos que :min caracteres.', 'array' => 'O valor para o campo :attribute não deve ter menos que :min itens.', ], + 'no_double_extension' => 'O campo :attribute deve ter apenas uma extensão de arquivo.', 'not_in' => 'O campo selecionado :attribute é inválido.', 'numeric' => 'O campo :attribute deve ser um número.', 'regex' => 'O formato do campo :attribute é inválido.', @@ -74,35 +71,15 @@ return [ 'timezone' => 'O campo :attribute deve conter uma timezone válida.', 'unique' => 'Já existe um campo/dado de nome :attribute.', 'url' => 'O formato da URL :attribute é inválido.', + 'uploaded' => 'O arquivo não pôde ser carregado. O servidor pode não aceitar arquivos deste tamanho.', - /* - |-------------------------------------------------------------------------- - | Custom Validation Language Lines - |-------------------------------------------------------------------------- - | - | Here you may specify custom validation messages for attributes using the - | convention "attribute.rule" to name the lines. This makes it quick to - | specify a specific custom language line for a given attribute rule. - | - */ - + // Custom validation lines 'custom' => [ 'password-confirm' => [ 'required_with' => 'Confirmação de senha requerida', ], ], - /* - |-------------------------------------------------------------------------- - | Custom Validation Attributes - |-------------------------------------------------------------------------- - | - | The following language lines are used to swap attribute place-holders - | with something more reader friendly such as E-Mail Address instead - | of "email". This simply helps us make messages a little cleaner. - | - */ - + // Custom validation attributes 'attributes' => [], - ]; diff --git a/resources/views/auth/forms/login/standard.blade.php b/resources/views/auth/forms/login/standard.blade.php index ea63cf7ac..dc6081637 100644 --- a/resources/views/auth/forms/login/standard.blade.php +++ b/resources/views/auth/forms/login/standard.blade.php @@ -7,6 +7,6 @@ @include('form.password', ['name' => 'password', 'tabindex' => 1]) - {{ trans('auth.forgot_password') }} + {{ trans('auth.forgot_password') }}
      diff --git a/resources/views/auth/invite-set-password.blade.php b/resources/views/auth/invite-set-password.blade.php new file mode 100644 index 000000000..fbe62f21e --- /dev/null +++ b/resources/views/auth/invite-set-password.blade.php @@ -0,0 +1,27 @@ +@extends('simple-layout') + +@section('content') + +
      +
      +

      {{ trans('auth.user_invite_page_welcome', ['appName' => setting('app-name')]) }}

      +

      {{ trans('auth.user_invite_page_text', ['appName' => setting('app-name')]) }}

      + +
      + {!! csrf_field() !!} + +
      + + @include('form.password', ['name' => 'password', 'placeholder' => trans('auth.password_hint')]) +
      + +
      + +
      + +
      + +
      +
      + +@stop diff --git a/resources/views/auth/login.blade.php b/resources/views/auth/login.blade.php index 51b47f5c7..438339e92 100644 --- a/resources/views/auth/login.blade.php +++ b/resources/views/auth/login.blade.php @@ -9,7 +9,7 @@

      {{ title_case(trans('auth.log_in')) }}

      -
      + {!! csrf_field() !!}
      @@ -22,12 +22,13 @@ 'name' => 'remember', 'checked' => false, 'value' => 'on', + 'tabindex' => 1, 'label' => trans('auth.remember_me'), ])
      - +
      @@ -37,7 +38,7 @@
      @foreach($socialDrivers as $driver => $name) diff --git a/resources/views/auth/passwords/email.blade.php b/resources/views/auth/passwords/email.blade.php index de4edff0a..8273ed235 100644 --- a/resources/views/auth/passwords/email.blade.php +++ b/resources/views/auth/passwords/email.blade.php @@ -7,7 +7,7 @@

      {{ trans('auth.reset_password_send_instructions') }}

      - + {!! csrf_field() !!}
      @@ -16,7 +16,7 @@
      - +
      diff --git a/resources/views/auth/passwords/reset.blade.php b/resources/views/auth/passwords/reset.blade.php index fa6ad5b9a..930544cde 100644 --- a/resources/views/auth/passwords/reset.blade.php +++ b/resources/views/auth/passwords/reset.blade.php @@ -6,7 +6,7 @@

      {{ trans('auth.reset_password') }}

      -
      + {!! csrf_field() !!} @@ -26,7 +26,7 @@
      - +
      diff --git a/resources/views/auth/register.blade.php b/resources/views/auth/register.blade.php index 38904f63b..60ceba93c 100644 --- a/resources/views/auth/register.blade.php +++ b/resources/views/auth/register.blade.php @@ -8,7 +8,7 @@

      {{ title_case(trans('auth.sign_up')) }}

      -
      + {!! csrf_field() !!}
      @@ -28,10 +28,10 @@
      - +
      @@ -42,7 +42,7 @@
      @foreach($socialDrivers as $driver => $name)
      - + @icon('auth/' . $driver) {{ trans('auth.sign_up_with', ['socialDriver' => $name]) }} diff --git a/resources/views/auth/user-unconfirmed.blade.php b/resources/views/auth/user-unconfirmed.blade.php index 54bf6eda3..85473685b 100644 --- a/resources/views/auth/user-unconfirmed.blade.php +++ b/resources/views/auth/user-unconfirmed.blade.php @@ -13,7 +13,7 @@ {{ trans('auth.email_not_confirmed_resend') }}

      - + {!! csrf_field() !!}
      @@ -24,7 +24,7 @@ @endif
      - +
      diff --git a/resources/views/base.blade.php b/resources/views/base.blade.php index 367a2cd8b..075481620 100644 --- a/resources/views/base.blade.php +++ b/resources/views/base.blade.php @@ -1,37 +1,40 @@ - + {{ isset($pageTitle) ? $pageTitle . ' | ' : '' }}{{ setting('app-name') }} - + - - - @yield('head') + + @include('partials.custom-styles') @include('partials.custom-head') @stack('head') + + + @stack('translations') + @include('partials.notifications') @include('common.header') -
      +
      @yield('content') -
      +
      -
      + -
      +

      {{ trans('entities.books_create') }}

      -
      + @include('books.form')
      -
      +
      @stop \ No newline at end of file diff --git a/resources/views/books/delete.blade.php b/resources/views/books/delete.blade.php index 2860e8bcd..be3f742cb 100644 --- a/resources/views/books/delete.blade.php +++ b/resources/views/books/delete.blade.php @@ -23,7 +23,7 @@ {!! csrf_field() !!} {{ trans('common.cancel') }} - +
      diff --git a/resources/views/books/edit.blade.php b/resources/views/books/edit.blade.php index 2e51ed6e9..400fd6e81 100644 --- a/resources/views/books/edit.blade.php +++ b/resources/views/books/edit.blade.php @@ -14,12 +14,12 @@ ]])
      -
      +

      {{ trans('entities.books_edit') }}

      @include('books.form', ['model' => $book])
      -
      +
    @stop \ No newline at end of file diff --git a/resources/views/books/export.blade.php b/resources/views/books/export.blade.php index 61c16c72d..4a7c45e0b 100644 --- a/resources/views/books/export.blade.php +++ b/resources/views/books/export.blade.php @@ -1,5 +1,5 @@ - + {{ $book->name }} diff --git a/resources/views/books/form.blade.php b/resources/views/books/form.blade.php index 4edec240a..8960b4135 100644 --- a/resources/views/books/form.blade.php +++ b/resources/views/books/form.blade.php @@ -11,15 +11,15 @@
    -
    - -
    +

    {{ trans('common.cover_image_description') }}

    @include('components.image-picker', [ - 'defaultImage' => baseUrl('/book_default_cover.png'), - 'currentImage' => (isset($model) && $model->cover) ? $model->getBookCover() : baseUrl('/book_default_cover.png') , + 'defaultImage' => url('/book_default_cover.png'), + 'currentImage' => (isset($model) && $model->cover) ? $model->getBookCover() : url('/book_default_cover.png') , 'name' => 'image', 'imageClass' => 'cover' ]) @@ -27,15 +27,15 @@
    -
    +
    +
    @include('components.tag-manager', ['entity' => isset($book)?$book:null, 'entityType' => 'chapter'])
    - {{ trans('common.cancel') }} - + {{ trans('common.cancel') }} +
    \ No newline at end of file diff --git a/resources/views/books/index.blade.php b/resources/views/books/index.blade.php index 61d998489..b9bd987a9 100644 --- a/resources/views/books/index.blade.php +++ b/resources/views/books/index.blade.php @@ -37,7 +37,7 @@
    {{ trans('common.actions') }}
    @if($currentUser->can('book-create-all')) - + @icon('add') {{ trans('entities.books_create') }} diff --git a/resources/views/books/list.blade.php b/resources/views/books/list.blade.php index 93d927ec7..871d931f1 100644 --- a/resources/views/books/list.blade.php +++ b/resources/views/books/list.blade.php @@ -1,5 +1,5 @@ -
    +

    {{ trans('entities.books') }}

    @@ -28,7 +28,7 @@ @else

    {{ trans('entities.books_empty') }}

    @if(userCan('books-create-all')) - @icon('edit'){{ trans('entities.create_now') }} + @icon('edit'){{ trans('entities.create_now') }} @endif @endif -
    \ No newline at end of file +
    \ No newline at end of file diff --git a/resources/views/books/permissions.blade.php b/resources/views/books/permissions.blade.php index 64322cf85..b387ed6c7 100644 --- a/resources/views/books/permissions.blade.php +++ b/resources/views/books/permissions.blade.php @@ -14,10 +14,10 @@ ]])
    -
    +

    {{ trans('entities.books_permissions') }}

    @include('form.entity-permissions', ['model' => $book]) -
    +
    @stop diff --git a/resources/views/books/show.blade.php b/resources/views/books/show.blade.php index b709b29dc..cbafdb436 100644 --- a/resources/views/books/show.blade.php +++ b/resources/views/books/show.blade.php @@ -14,7 +14,7 @@ ]])
    -
    +

    {{$book->name}}

    {!! nl2br(e($book->description)) !!}

    @@ -53,7 +53,7 @@
    @include('partials.entity-dashboard-search-results') -
    + @stop @@ -121,17 +121,7 @@
    - + @include('partials.entity-export-menu', ['entity' => $book]) diff --git a/resources/views/books/sort.blade.php b/resources/views/books/sort.blade.php index 23259a593..642b88c87 100644 --- a/resources/views/books/sort.blade.php +++ b/resources/views/books/sort.blade.php @@ -16,188 +16,34 @@
    -
    +

    {{ trans('entities.books_sort') }}

    -
    +
    @include('books.sort-box', ['book' => $book, 'bookChildren' => $bookChildren])
    {!! csrf_field() !!} - +
    {{ trans('common.cancel') }} - +
    -
    +

    {{ trans('entities.books_sort_show_other') }}

    @include('components.entity-selector', ['name' => 'books_list', 'selectorSize' => 'compact', 'entityTypes' => 'book', 'entityPermission' => 'update', 'showAdd' => true]) -
    +
    @stop - -@section('scripts') - - -@stop diff --git a/resources/views/chapters/child-menu.blade.php b/resources/views/chapters/child-menu.blade.php index 36c7f9a24..6137c34e8 100644 --- a/resources/views/chapters/child-menu.blade.php +++ b/resources/views/chapters/child-menu.blade.php @@ -1,10 +1,11 @@
    -

    + +

    -
    +

    {{ trans('entities.chapters_create') }}

    @include('chapters.form')
    -
    +
    @stop \ No newline at end of file diff --git a/resources/views/chapters/delete.blade.php b/resources/views/chapters/delete.blade.php index 3444ee0fb..60f8c9933 100644 --- a/resources/views/chapters/delete.blade.php +++ b/resources/views/chapters/delete.blade.php @@ -27,7 +27,7 @@
    {{ trans('common.cancel') }} - +
    diff --git a/resources/views/chapters/edit.blade.php b/resources/views/chapters/edit.blade.php index d282fe1dd..d8bb056f6 100644 --- a/resources/views/chapters/edit.blade.php +++ b/resources/views/chapters/edit.blade.php @@ -15,13 +15,13 @@ ]]) -
    +

    {{ trans('entities.chapters_edit') }}

    @include('chapters.form', ['model' => $chapter])
    -
    + diff --git a/resources/views/chapters/export.blade.php b/resources/views/chapters/export.blade.php index 2830855b4..580c123cc 100644 --- a/resources/views/chapters/export.blade.php +++ b/resources/views/chapters/export.blade.php @@ -1,5 +1,5 @@ - + {{ $chapter->name }} diff --git a/resources/views/chapters/form.blade.php b/resources/views/chapters/form.blade.php index 31d8597de..cd240e685 100644 --- a/resources/views/chapters/form.blade.php +++ b/resources/views/chapters/form.blade.php @@ -12,9 +12,9 @@
    -
    - -
    +
    @include('components.tag-manager', ['entity' => isset($chapter)?$chapter:null, 'entityType' => 'chapter'])
    @@ -22,5 +22,5 @@
    {{ trans('common.cancel') }} - +
    diff --git a/resources/views/chapters/list-item.blade.php b/resources/views/chapters/list-item.blade.php index fd463e07a..7e2e0e1c5 100644 --- a/resources/views/chapters/list-item.blade.php +++ b/resources/views/chapters/list-item.blade.php @@ -11,7 +11,9 @@
    @icon('page')
    -
    @icon('caret-right') {{ trans_choice('entities.x_pages', $chapter->pages->count()) }}
    +
    @include('partials.entity-list', ['entities' => $chapter->pages]) diff --git a/resources/views/chapters/move.blade.php b/resources/views/chapters/move.blade.php index 7f3de1322..8663dca50 100644 --- a/resources/views/chapters/move.blade.php +++ b/resources/views/chapters/move.blade.php @@ -15,7 +15,7 @@ ]])
    -
    +

    {{ trans('entities.chapters_move') }}

    @@ -27,11 +27,11 @@
    {{ trans('common.cancel') }} - +
    -
    + diff --git a/resources/views/chapters/permissions.blade.php b/resources/views/chapters/permissions.blade.php index cb5808e7d..48c954dc9 100644 --- a/resources/views/chapters/permissions.blade.php +++ b/resources/views/chapters/permissions.blade.php @@ -15,10 +15,10 @@ ]])
    -
    +

    {{ trans('entities.chapters_permissions') }}

    @include('form.entity-permissions', ['model' => $chapter]) -
    +
    @stop diff --git a/resources/views/chapters/show.blade.php b/resources/views/chapters/show.blade.php index 0915f9a16..105cda760 100644 --- a/resources/views/chapters/show.blade.php +++ b/resources/views/chapters/show.blade.php @@ -8,14 +8,14 @@ @section('body') -
    + -
    +

    {{ $chapter->name }}

    {!! nl2br(e($chapter->description)) !!}

    @@ -50,7 +50,7 @@
    @include('partials.entity-dashboard-search-results') -
    + @stop @@ -123,17 +123,7 @@
    - + @include('partials.entity-export-menu', ['entity' => $chapter])
    @stop diff --git a/resources/views/comments/comment.blade.php b/resources/views/comments/comment.blade.php index a85503178..5fbdfa500 100644 --- a/resources/views/comments/comment.blade.php +++ b/resources/views/comments/comment.blade.php @@ -1,8 +1,8 @@
    -
    -
    - #{{$comment->local_id}} +
    +
    + #{{$comment->local_id}}    @if ($comment->createdBy) {{ $comment->createdBy->name }} @@ -21,17 +21,17 @@
    @if(userCan('comment-update', $comment)) - + @endif @if(userCan('comment-create-all')) - + @endif @if(userCan('comment-delete', $comment)) @endif @@ -61,7 +61,7 @@
    - +