/** * SPDX-FileCopyrightText: 2016 Nextcloud GmbH and Nextcloud contributors * SPDX-License-Identifier: AGPL-3.0-or-later */ import $ from 'jquery' import { translate as t } from '@nextcloud/l10n' import { linkTo } from '@nextcloud/router' import { getToken } from './OC/requesttoken.js' import getURLParameter from './Util/get-url-parameter.js' import './jquery/showpassword.js' import 'jquery-ui/ui/widgets/button.js' import 'jquery-ui/themes/base/theme.css' import 'jquery-ui/themes/base/button.css' import 'strengthify' import 'strengthify/strengthify.css' window.addEventListener('DOMContentLoaded', function() { const dbtypes = { sqlite: !!$('#hasSQLite').val(), mysql: !!$('#hasMySQL').val(), postgresql: !!$('#hasPostgreSQL').val(), oracle: !!$('#hasOracle').val(), } $('#selectDbType').buttonset() // change links inside an info box back to their default appearance $('#selectDbType p.info a').button('destroy') if ($('#hasSQLite').val()) { $('#use_other_db').hide() $('#use_oracle_db').hide() } else { $('#sqliteInformation').hide() } $('#adminlogin').change(function() { $('#adminlogin').val($.trim($('#adminlogin').val())) }) $('#sqlite').click(function() { $('#use_other_db').slideUp(250) $('#use_oracle_db').slideUp(250) $('#sqliteInformation').show() $('#dbname').attr('pattern', '[0-9a-zA-Z$_-]+') }) $('#mysql,#pgsql').click(function() { $('#use_other_db').slideDown(250) $('#use_oracle_db').slideUp(250) $('#sqliteInformation').hide() $('#dbname').attr('pattern', '[0-9a-zA-Z$_-]+') }) $('#oci').click(function() { $('#use_other_db').slideDown(250) $('#use_oracle_db').show(250) $('#sqliteInformation').hide() $('#dbname').attr('pattern', '[0-9a-zA-Z$_-.]+') }) $('#showAdvanced').click(function(e) { e.preventDefault() $('#datadirContent').slideToggle(250) $('#databaseBackend').slideToggle(250) $('#databaseField').slideToggle(250) }) $('form').submit(function() { // Save form parameters const post = $(this).serializeArray() // Show spinner while finishing setup $('.float-spinner').show(250) // Disable inputs $('input[type="submit"]').attr('disabled', 'disabled').val($('input[type="submit"]').data('finishing')) $('input', this).addClass('ui-state-disabled').attr('disabled', 'disabled') // only disable buttons if they are present if ($('#selectDbType').find('.ui-button').length > 0) { $('#selectDbType').buttonset('disable') } $('.strengthify-wrapper, .tipsy') .css('filter', 'alpha(opacity=30)') .css('opacity', 0.3) // Create the form const form = $('
') form.attr('action', $(this).attr('action')) form.attr('method', 'POST') for (let i = 0; i < post.length; i++) { const input = $('') input.attr(post[i]) form.append(input) } // Add redirect_url const redirectURL = getURLParameter('redirect_url') if (redirectURL) { const redirectURLInput = $('') redirectURLInput.attr({ name: 'redirect_url', value: redirectURL, }) form.append(redirectURLInput) } // Submit the form form.appendTo(document.body) form.submit() return false }) // Expand latest db settings if page was reloaded on error const currentDbType = $('input[type="radio"]:checked').val() if (currentDbType === undefined) { $('input[type="radio"]').first().click() } if ( currentDbType === 'sqlite' || (dbtypes.sqlite && currentDbType === undefined) ) { $('#datadirContent').hide(250) $('#databaseBackend').hide(250) $('#databaseField').hide(250) $('.float-spinner').hide(250) } $('#adminpass').strengthify({ zxcvbn: linkTo('core', 'vendor/zxcvbn/dist/zxcvbn.js'), titles: [ t('core', 'Very weak password'), t('core', 'Weak password'), t('core', 'So-so password'), t('core', 'Good password'), t('core', 'Strong password'), ], drawTitles: true, nonce: btoa(getToken()), }) $('#dbpass').showPassword().keyup() $('.toggle-password').click(function(event) { event.preventDefault() const currentValue = $(this).parent().children('input').attr('type') if (currentValue === 'password') { $(this).parent().children('input').attr('type', 'text') } else { $(this).parent().children('input').attr('type', 'password') } }) })