mirror of
https://github.com/nextcloud/server.git
synced 2026-06-05 06:44:47 -04:00
Merge pull request #57499 from nextcloud/feat/migrate-user-ldap-renew
Some checks are pending
CodeQL Advanced / Analyze (actions) (push) Waiting to run
CodeQL Advanced / Analyze (javascript-typescript) (push) Waiting to run
Integration sqlite / changes (push) Waiting to run
Integration sqlite / integration-sqlite (master, 8.4, main, --tags ~@large files_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, capabilities_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, collaboration_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, comments_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, dav_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, federation_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, file_conversions) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, files_reminders) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, filesdrop_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, ldap_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, openldap_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, openldap_numerical_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, remoteapi_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, routing_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, setup_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, sharees_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, sharing_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, theming_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, videoverification_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite-summary (push) Blocked by required conditions
Psalm static code analysis / static-code-analysis (push) Waiting to run
Psalm static code analysis / static-code-analysis-security (push) Waiting to run
Psalm static code analysis / static-code-analysis-ocp (push) Waiting to run
Psalm static code analysis / static-code-analysis-ncu (push) Waiting to run
Some checks are pending
CodeQL Advanced / Analyze (actions) (push) Waiting to run
CodeQL Advanced / Analyze (javascript-typescript) (push) Waiting to run
Integration sqlite / changes (push) Waiting to run
Integration sqlite / integration-sqlite (master, 8.4, main, --tags ~@large files_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, capabilities_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, collaboration_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, comments_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, dav_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, federation_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, file_conversions) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, files_reminders) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, filesdrop_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, ldap_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, openldap_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, openldap_numerical_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, remoteapi_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, routing_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, setup_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, sharees_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, sharing_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, theming_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite (master, 8.4, main, videoverification_features) (push) Blocked by required conditions
Integration sqlite / integration-sqlite-summary (push) Blocked by required conditions
Psalm static code analysis / static-code-analysis (push) Waiting to run
Psalm static code analysis / static-code-analysis-security (push) Waiting to run
Psalm static code analysis / static-code-analysis-ocp (push) Waiting to run
Psalm static code analysis / static-code-analysis-ncu (push) Waiting to run
refactor(user_ldap): migrate jQuery UI of password renewal to Vue
This commit is contained in:
commit
ac3d09d817
209 changed files with 393 additions and 1218 deletions
|
|
@ -1,148 +0,0 @@
|
|||
/**
|
||||
* SPDX-FileCopyrightText: 2017 Nextcloud GmbH and Nextcloud contributors
|
||||
* SPDX-License-Identifier: AGPL-3.0-or-later
|
||||
*/
|
||||
#personal-show + label {
|
||||
inset-inline-start: 230px !important;
|
||||
margin-top: 8px !important;
|
||||
box-sizing: border-box;
|
||||
}
|
||||
|
||||
#renewpassword .strengthify-wrapper {
|
||||
inset-inline-start: 10px;
|
||||
margin-top: 65px;
|
||||
position: absolute;
|
||||
width: 219px;
|
||||
}
|
||||
|
||||
#cancel-container p.info {
|
||||
margin-top: 10px;
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
#renewpassword .title {
|
||||
background-color: transparent;
|
||||
}
|
||||
|
||||
.tooltip {
|
||||
position:absolute;
|
||||
display:block;
|
||||
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen-Sans, Ubuntu, Cantarell, 'Helvetica Neue', Arial, sans-serif, 'Apple Color Emoji', 'Segoe UI Emoji', 'Segoe UI Symbol';
|
||||
font-style:normal;
|
||||
font-weight:400;
|
||||
letter-spacing:normal;
|
||||
line-break:auto;
|
||||
line-height:1.6;
|
||||
text-align:start;
|
||||
text-decoration:none;
|
||||
text-shadow:none;
|
||||
text-transform:none;
|
||||
white-space:normal;
|
||||
word-break:normal;
|
||||
word-spacing:normal;
|
||||
word-wrap:normal;
|
||||
font-size:12px;
|
||||
opacity:0;
|
||||
z-index:100000;
|
||||
filter:drop-shadow(0 1px 10px rgba(77, 77, 77, 0.75));
|
||||
}
|
||||
|
||||
.tooltip.in {
|
||||
opacity:1
|
||||
}
|
||||
|
||||
.tooltip.top {
|
||||
margin-top:-3px;
|
||||
padding:10px 0
|
||||
}
|
||||
|
||||
.tooltip.bottom {
|
||||
margin-top:3px;
|
||||
padding:10px 0
|
||||
}
|
||||
|
||||
.tooltip.right {
|
||||
margin-inline-start:3px;
|
||||
padding:0 10px
|
||||
}
|
||||
|
||||
.tooltip.right .tooltip-arrow {
|
||||
top:50%;
|
||||
inset-inline-start:0;
|
||||
margin-top:-10px;
|
||||
border-width:10px 10px 10px 0;
|
||||
border-inline-end-color:#fff
|
||||
}
|
||||
|
||||
.tooltip.left {
|
||||
margin-inline-start:-3px;
|
||||
padding:0 5px
|
||||
}
|
||||
|
||||
.tooltip.left .tooltip-arrow {
|
||||
top:50%;
|
||||
inset-inline-end:0;
|
||||
margin-top:-10px;
|
||||
border-width:10px 0 10px 10px;
|
||||
border-inline-start-color:#fff
|
||||
}
|
||||
|
||||
.tooltip.top .tooltip-arrow,.tooltip.top-left .tooltip-arrow,.tooltip.top-right .tooltip-arrow {
|
||||
bottom:0;
|
||||
border-width:10px 10px 0;
|
||||
border-top-color:#fff
|
||||
}
|
||||
|
||||
.tooltip.top .tooltip-arrow {
|
||||
inset-inline-start:50%;
|
||||
margin-inline-start:-10px
|
||||
}
|
||||
|
||||
.tooltip.top-left .tooltip-arrow {
|
||||
inset-inline-end:10px;
|
||||
margin-bottom:-10px
|
||||
}
|
||||
|
||||
.tooltip.top-right .tooltip-arrow {
|
||||
inset-inline-start:10px;
|
||||
margin-bottom:-10px
|
||||
}
|
||||
|
||||
.tooltip.bottom .tooltip-arrow,.tooltip.bottom-left .tooltip-arrow,.tooltip.bottom-right .tooltip-arrow {
|
||||
top:0;
|
||||
border-width:0 10px 10px;
|
||||
border-bottom-color:#fff
|
||||
}
|
||||
|
||||
.tooltip.bottom .tooltip-arrow {
|
||||
inset-inline-start:50%;
|
||||
margin-inline-start:-10px
|
||||
}
|
||||
|
||||
.tooltip.bottom-left .tooltip-arrow {
|
||||
inset-inline-end:10px;
|
||||
margin-top:-10px
|
||||
}
|
||||
|
||||
.tooltip.bottom-right .tooltip-arrow {
|
||||
inset-inline-start:10px;
|
||||
margin-top:-10px
|
||||
}
|
||||
|
||||
.tooltip-inner {
|
||||
max-width:350px;
|
||||
padding:5px 8px !important;
|
||||
background-color:#fff;
|
||||
color:#000 !important;
|
||||
text-align:center !important;
|
||||
font-weight:normal !important;
|
||||
border-radius:3px
|
||||
}
|
||||
|
||||
.tooltip-arrow {
|
||||
position:absolute;
|
||||
width:0;
|
||||
height:0;
|
||||
border-color:transparent;
|
||||
border-style:solid
|
||||
}
|
||||
|
|
@ -1,27 +0,0 @@
|
|||
/**
|
||||
* SPDX-FileCopyrightText: 2012 Eric Hynds
|
||||
* SPDX-License-Identifier: MIT
|
||||
*/
|
||||
.ui-multiselect { padding:2px 0 2px 4px; text-align:left; }
|
||||
.ui-multiselect span.ui-icon { float:right; }
|
||||
.ui-multiselect-single .ui-multiselect-checkboxes input { position:absolute !important; top: auto !important; left:-9999px; }
|
||||
.ui-multiselect-single .ui-multiselect-checkboxes label { padding:5px !important; }
|
||||
|
||||
.ui-multiselect-header { margin-bottom:3px; padding:3px 0 3px 4px; }
|
||||
.ui-multiselect-header ul { font-size:14px; }
|
||||
.ui-multiselect-header ul li { float:left; padding:0 10px 0 0; }
|
||||
.ui-multiselect-header a { text-decoration:none; }
|
||||
.ui-multiselect-header a:hover { text-decoration:underline; }
|
||||
.ui-multiselect-header span.ui-icon { float:left;}
|
||||
.ui-multiselect-header li.ui-multiselect-close { float:right; text-align:right; padding-right:0; }
|
||||
|
||||
.ui-multiselect-menu { display:none; padding:3px; position:absolute; z-index:10000; text-align: left; }
|
||||
.ui-multiselect-checkboxes { position:relative /* fixes bug in IE6/7 */; overflow-y:scroll; }
|
||||
.ui-multiselect-checkboxes label { cursor:default; display:block; border:1px solid transparent; padding:3px 1px; }
|
||||
.ui-multiselect-checkboxes label input { position:relative; top:1px; }
|
||||
.ui-multiselect-checkboxes li { clear:both; font-size:14px; padding-right:3px; }
|
||||
.ui-multiselect-checkboxes li.ui-multiselect-optgroup-label { text-align:center; font-weight:bold; border-bottom:1px solid; }
|
||||
.ui-multiselect-checkboxes li.ui-multiselect-optgroup-label a { display:block; padding:3px; margin:1px 0; text-decoration:none; }
|
||||
|
||||
/* remove label borders in IE6 because IE6 does not support transparency */
|
||||
* html .ui-multiselect-checkboxes label { border:none; }
|
||||
|
|
@ -1,35 +0,0 @@
|
|||
/**
|
||||
* SPDX-FileCopyrightText: 2017-2024 Nextcloud GmbH and Nextcloud contributors
|
||||
* SPDX-License-Identifier: AGPL-3.0-or-later
|
||||
*/
|
||||
|
||||
OCA = OCA || {}
|
||||
OCA.LDAP = _.extend(OC.LDAP || {}, {
|
||||
onRenewPassword: function() {
|
||||
$('#submit')
|
||||
.removeClass('icon-confirm-white')
|
||||
.addClass('icon-loading-small')
|
||||
.attr('value', t('core', 'Renewing …'))
|
||||
return true
|
||||
},
|
||||
})
|
||||
|
||||
window.addEventListener('DOMContentLoaded', function() {
|
||||
$('form[name=renewpassword]').submit(OCA.LDAP.onRenewPassword)
|
||||
|
||||
if ($('#newPassword').length) {
|
||||
$('#newPassword').showPassword().keyup()
|
||||
}
|
||||
$('#newPassword').strengthify({
|
||||
zxcvbn: OC.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,
|
||||
$addAfter: $('input[name="newPassword-clone"]'),
|
||||
})
|
||||
})
|
||||
|
|
@ -1,707 +0,0 @@
|
|||
/* jshint forin:true, noarg:true, noempty:true, eqeqeq:true, boss:true, undef:true, curly:true, browser:true, jquery:true */
|
||||
/*
|
||||
* jQuery MultiSelect UI Widget 1.13
|
||||
* Copyright (c) 2012 Eric Hynds
|
||||
*
|
||||
* http://www.erichynds.com/jquery/jquery-ui-multiselect-widget/
|
||||
*
|
||||
* Depends:
|
||||
* - jQuery 1.4.2+
|
||||
* - jQuery UI 1.8 widget factory
|
||||
*
|
||||
* Optional:
|
||||
* - jQuery UI effects
|
||||
* - jQuery UI position utility
|
||||
*
|
||||
* Dual licensed under the MIT and GPL licenses:
|
||||
* http://www.opensource.org/licenses/mit-license.php
|
||||
* http://www.gnu.org/licenses/gpl.html
|
||||
*
|
||||
* SPDX-FileCopyrightText: 2012 Eric Hynds
|
||||
* SPDX-License-Identifier: MIT
|
||||
*/
|
||||
(function($, undefined) {
|
||||
let multiselectID = 0
|
||||
|
||||
$.widget('ech.multiselect', {
|
||||
|
||||
// default options
|
||||
options: {
|
||||
header: true,
|
||||
height: 175,
|
||||
minWidth: 225,
|
||||
classes: '',
|
||||
checkAllText: 'Check all',
|
||||
uncheckAllText: 'Uncheck all',
|
||||
noneSelectedText: 'Select options',
|
||||
selectedText: '# selected',
|
||||
selectedList: 0,
|
||||
show: null,
|
||||
hide: null,
|
||||
autoOpen: false,
|
||||
multiple: true,
|
||||
position: {},
|
||||
},
|
||||
|
||||
_create: function() {
|
||||
const el = this.element.hide(),
|
||||
o = this.options
|
||||
|
||||
this.speed = $.fx.speeds._default // default speed for effects
|
||||
this._isOpen = false // assume no
|
||||
|
||||
const
|
||||
button = (this.button = $('<button type="button"><span class="ui-icon ui-icon-triangle-2-n-s"></span></button>'))
|
||||
.addClass('ui-multiselect ui-widget ui-state-default ui-corner-all')
|
||||
.addClass(o.classes)
|
||||
.attr({ title: el.attr('title'), 'aria-haspopup': true, tabIndex: el.attr('tabIndex') })
|
||||
.insertAfter(el),
|
||||
|
||||
buttonlabel = (this.buttonlabel = $('<span />'))
|
||||
.html(o.noneSelectedText)
|
||||
.appendTo(button),
|
||||
|
||||
menu = (this.menu = $('<div />'))
|
||||
.addClass('ui-multiselect-menu ui-widget ui-widget-content ui-corner-all')
|
||||
.addClass(o.classes)
|
||||
.appendTo(document.body),
|
||||
|
||||
header = (this.header = $('<div />'))
|
||||
.addClass('ui-widget-header ui-corner-all ui-multiselect-header ui-helper-clearfix')
|
||||
.appendTo(menu),
|
||||
|
||||
headerLinkContainer = (this.headerLinkContainer = $('<ul />'))
|
||||
.addClass('ui-helper-reset')
|
||||
.html(function() {
|
||||
if (o.header === true) {
|
||||
return '<li><a class="ui-multiselect-all" href="#"><span class="ui-icon ui-icon-check"></span><span>' + o.checkAllText + '</span></a></li><li><a class="ui-multiselect-none" href="#"><span class="ui-icon ui-icon-closethick"></span><span>' + o.uncheckAllText + '</span></a></li>'
|
||||
} else if (typeof o.header === 'string') {
|
||||
return '<li>' + o.header + '</li>'
|
||||
} else {
|
||||
return ''
|
||||
}
|
||||
})
|
||||
.append('<li class="ui-multiselect-close"><a href="#" class="ui-multiselect-close"><span class="ui-icon ui-icon-circle-close"></span></a></li>')
|
||||
.appendTo(header),
|
||||
|
||||
checkboxContainer = (this.checkboxContainer = $('<ul />'))
|
||||
.addClass('ui-multiselect-checkboxes ui-helper-reset')
|
||||
.appendTo(menu)
|
||||
|
||||
// perform event bindings
|
||||
this._bindEvents()
|
||||
|
||||
// build menu
|
||||
this.refresh(true)
|
||||
|
||||
// some addl. logic for single selects
|
||||
if (!o.multiple) {
|
||||
menu.addClass('ui-multiselect-single')
|
||||
}
|
||||
},
|
||||
|
||||
_init: function() {
|
||||
if (this.options.header === false) {
|
||||
this.header.hide()
|
||||
}
|
||||
if (!this.options.multiple) {
|
||||
this.headerLinkContainer.find('.ui-multiselect-all, .ui-multiselect-none').hide()
|
||||
}
|
||||
if (this.options.autoOpen) {
|
||||
this.open()
|
||||
}
|
||||
if (this.element.is(':disabled')) {
|
||||
this.disable()
|
||||
}
|
||||
},
|
||||
|
||||
refresh: function(init) {
|
||||
let el = this.element,
|
||||
o = this.options,
|
||||
menu = this.menu,
|
||||
checkboxContainer = this.checkboxContainer,
|
||||
optgroups = [],
|
||||
html = '',
|
||||
id = el.attr('id') || multiselectID++ // unique ID for the label & option tags
|
||||
|
||||
// build items
|
||||
el.find('option').each(function(i) {
|
||||
let $this = $(this),
|
||||
parent = this.parentNode,
|
||||
title = this.innerHTML,
|
||||
description = this.title,
|
||||
value = this.value,
|
||||
inputID = 'ui-multiselect-' + (this.id || id + '-option-' + i),
|
||||
isDisabled = this.disabled,
|
||||
isSelected = this.selected,
|
||||
labelClasses = ['ui-corner-all'],
|
||||
liClasses = (isDisabled ? 'ui-multiselect-disabled ' : ' ') + this.className,
|
||||
optLabel
|
||||
|
||||
// is this an optgroup?
|
||||
if (parent.tagName === 'OPTGROUP') {
|
||||
optLabel = parent.getAttribute('label')
|
||||
|
||||
// has this optgroup been added already?
|
||||
if ($.inArray(optLabel, optgroups) === -1) {
|
||||
html += '<li class="ui-multiselect-optgroup-label ' + parent.className + '"><a href="#">' + optLabel + '</a></li>'
|
||||
optgroups.push(optLabel)
|
||||
}
|
||||
}
|
||||
|
||||
if (isDisabled) {
|
||||
labelClasses.push('ui-state-disabled')
|
||||
}
|
||||
|
||||
// browsers automatically select the first option
|
||||
// by default with single selects
|
||||
if (isSelected && !o.multiple) {
|
||||
labelClasses.push('ui-state-active')
|
||||
}
|
||||
|
||||
html += '<li class="' + liClasses + '">'
|
||||
|
||||
// create the label
|
||||
html += '<label for="' + inputID + '" title="' + description + '" class="' + labelClasses.join(' ') + '">'
|
||||
html += '<input id="' + inputID + '" name="multiselect_' + id + '" type="' + (o.multiple ? 'checkbox' : 'radio') + '" value="' + value + '" title="' + title + '"'
|
||||
|
||||
// pre-selected?
|
||||
if (isSelected) {
|
||||
html += ' checked="checked"'
|
||||
html += ' aria-selected="true"'
|
||||
}
|
||||
|
||||
// disabled?
|
||||
if (isDisabled) {
|
||||
html += ' disabled="disabled"'
|
||||
html += ' aria-disabled="true"'
|
||||
}
|
||||
|
||||
// add the title and close everything off
|
||||
html += ' /><span>' + title + '</span></label></li>'
|
||||
})
|
||||
|
||||
// insert into the DOM
|
||||
checkboxContainer.html(html)
|
||||
|
||||
// cache some moar useful elements
|
||||
this.labels = menu.find('label')
|
||||
this.inputs = this.labels.children('input')
|
||||
|
||||
// set widths
|
||||
this._setButtonWidth()
|
||||
this._setMenuWidth()
|
||||
|
||||
// remember default value
|
||||
this.button[0].defaultValue = this.update()
|
||||
|
||||
// broadcast refresh event; useful for widgets
|
||||
if (!init) {
|
||||
this._trigger('refresh')
|
||||
}
|
||||
},
|
||||
|
||||
// updates the button text. call refresh() to rebuild
|
||||
update: function() {
|
||||
let o = this.options,
|
||||
$inputs = this.inputs,
|
||||
$checked = $inputs.filter(':checked'),
|
||||
numChecked = $checked.length,
|
||||
value
|
||||
|
||||
if (numChecked === 0) {
|
||||
value = o.noneSelectedText
|
||||
} else {
|
||||
if ($.isFunction(o.selectedText)) {
|
||||
value = o.selectedText.call(this, numChecked, $inputs.length, $checked.get())
|
||||
} else if (/\d/.test(o.selectedList) && o.selectedList > 0 && numChecked <= o.selectedList) {
|
||||
value = $checked.map(function() { return $(this).next().html() }).get().join(', ')
|
||||
} else {
|
||||
value = o.selectedText.replace('#', numChecked).replace('#', $inputs.length)
|
||||
}
|
||||
}
|
||||
|
||||
this.buttonlabel.html(value)
|
||||
return value
|
||||
},
|
||||
|
||||
// binds events
|
||||
_bindEvents: function() {
|
||||
const self = this, button = this.button
|
||||
|
||||
/**
|
||||
*
|
||||
*/
|
||||
function clickHandler() {
|
||||
self[self._isOpen ? 'close' : 'open']()
|
||||
return false
|
||||
}
|
||||
|
||||
// webkit doesn't like it when you click on the span :(
|
||||
button
|
||||
.find('span')
|
||||
.bind('click.multiselect', clickHandler)
|
||||
|
||||
// button events
|
||||
button.bind({
|
||||
click: clickHandler,
|
||||
keypress: function(e) {
|
||||
switch (e.which) {
|
||||
case 27: // esc
|
||||
case 38: // up
|
||||
case 37: // left
|
||||
self.close()
|
||||
break
|
||||
case 39: // right
|
||||
case 40: // down
|
||||
self.open()
|
||||
break
|
||||
}
|
||||
},
|
||||
mouseenter: function() {
|
||||
if (!button.hasClass('ui-state-disabled')) {
|
||||
$(this).addClass('ui-state-hover')
|
||||
}
|
||||
},
|
||||
mouseleave: function() {
|
||||
$(this).removeClass('ui-state-hover')
|
||||
},
|
||||
focus: function() {
|
||||
if (!button.hasClass('ui-state-disabled')) {
|
||||
$(this).addClass('ui-state-focus')
|
||||
}
|
||||
},
|
||||
blur: function() {
|
||||
$(this).removeClass('ui-state-focus')
|
||||
},
|
||||
})
|
||||
|
||||
// header links
|
||||
this.header
|
||||
.delegate('a', 'click.multiselect', function(e) {
|
||||
// close link
|
||||
if ($(this).hasClass('ui-multiselect-close')) {
|
||||
self.close()
|
||||
|
||||
// check all / uncheck all
|
||||
} else {
|
||||
self[$(this).hasClass('ui-multiselect-all') ? 'checkAll' : 'uncheckAll']()
|
||||
}
|
||||
|
||||
e.preventDefault()
|
||||
})
|
||||
|
||||
// optgroup label toggle support
|
||||
this.menu
|
||||
.delegate('li.ui-multiselect-optgroup-label a', 'click.multiselect', function(e) {
|
||||
e.preventDefault()
|
||||
|
||||
const $this = $(this),
|
||||
$inputs = $this.parent().nextUntil('li.ui-multiselect-optgroup-label').find('input:visible:not(:disabled)'),
|
||||
nodes = $inputs.get(),
|
||||
label = $this.parent().text()
|
||||
|
||||
// trigger event and bail if the return is false
|
||||
if (self._trigger('beforeoptgrouptoggle', e, { inputs: nodes, label }) === false) {
|
||||
return
|
||||
}
|
||||
|
||||
// toggle inputs
|
||||
self._toggleChecked(
|
||||
$inputs.filter(':checked').length !== $inputs.length,
|
||||
$inputs,
|
||||
)
|
||||
|
||||
self._trigger('optgrouptoggle', e, {
|
||||
inputs: nodes,
|
||||
label,
|
||||
checked: nodes[0].checked,
|
||||
})
|
||||
})
|
||||
.delegate('label', 'mouseenter.multiselect', function() {
|
||||
if (!$(this).hasClass('ui-state-disabled')) {
|
||||
self.labels.removeClass('ui-state-hover')
|
||||
$(this).addClass('ui-state-hover').find('input').focus()
|
||||
}
|
||||
})
|
||||
.delegate('label', 'keydown.multiselect', function(e) {
|
||||
e.preventDefault()
|
||||
|
||||
switch (e.which) {
|
||||
case 9: // tab
|
||||
case 27: // esc
|
||||
self.close()
|
||||
break
|
||||
case 38: // up
|
||||
case 40: // down
|
||||
case 37: // left
|
||||
case 39: // right
|
||||
self._traverse(e.which, this)
|
||||
break
|
||||
case 13: // enter
|
||||
$(this).find('input')[0].click()
|
||||
break
|
||||
}
|
||||
})
|
||||
.delegate('input[type="checkbox"], input[type="radio"]', 'click.multiselect', function(e) {
|
||||
const $this = $(this),
|
||||
val = this.value,
|
||||
checked = this.checked,
|
||||
tags = self.element.find('option')
|
||||
|
||||
// bail if this input is disabled or the event is cancelled
|
||||
if (this.disabled || self._trigger('click', e, { value: val, text: this.title, checked }) === false) {
|
||||
e.preventDefault()
|
||||
return
|
||||
}
|
||||
|
||||
// make sure the input has focus. otherwise, the esc key
|
||||
// won't close the menu after clicking an item.
|
||||
$this.focus()
|
||||
|
||||
// toggle aria state
|
||||
$this.attr('aria-selected', checked)
|
||||
|
||||
// change state on the original option tags
|
||||
tags.each(function() {
|
||||
if (this.value === val) {
|
||||
this.selected = checked
|
||||
} else if (!self.options.multiple) {
|
||||
this.selected = false
|
||||
}
|
||||
})
|
||||
|
||||
// some additional single select-specific logic
|
||||
if (!self.options.multiple) {
|
||||
self.labels.removeClass('ui-state-active')
|
||||
$this.closest('label').toggleClass('ui-state-active', checked)
|
||||
|
||||
// close menu
|
||||
self.close()
|
||||
}
|
||||
|
||||
// fire change on the select box
|
||||
self.element.trigger('change')
|
||||
|
||||
// setTimeout is to fix multiselect issue #14 and #47. caused by jQuery issue #3827
|
||||
// http://bugs.jquery.com/ticket/3827
|
||||
setTimeout($.proxy(self.update, self), 10)
|
||||
})
|
||||
|
||||
// close each widget when clicking on any other element/anywhere else on the page
|
||||
$(document).bind('mousedown.multiselect', function(e) {
|
||||
if (self._isOpen && !$.contains(self.menu[0], e.target) && !$.contains(self.button[0], e.target) && e.target !== self.button[0]) {
|
||||
self.close()
|
||||
}
|
||||
})
|
||||
|
||||
// deal with form resets. the problem here is that buttons aren't
|
||||
// restored to their defaultValue prop on form reset, and the reset
|
||||
// handler fires before the form is actually reset. delaying it a bit
|
||||
// gives the form inputs time to clear.
|
||||
$(this.element[0].form).bind('reset.multiselect', function() {
|
||||
setTimeout($.proxy(self.refresh, self), 10)
|
||||
})
|
||||
},
|
||||
|
||||
// set button width
|
||||
_setButtonWidth: function() {
|
||||
let width = this.element.outerWidth(),
|
||||
o = this.options
|
||||
|
||||
if (/\d/.test(o.minWidth) && width < o.minWidth) {
|
||||
width = o.minWidth
|
||||
}
|
||||
|
||||
// set widths
|
||||
this.button.width(width)
|
||||
},
|
||||
|
||||
// set menu width
|
||||
_setMenuWidth: function() {
|
||||
const m = this.menu,
|
||||
width = this.button.outerWidth()
|
||||
- parseInt(m.css('padding-left'), 10)
|
||||
- parseInt(m.css('padding-right'), 10)
|
||||
- parseInt(m.css('border-right-width'), 10)
|
||||
- parseInt(m.css('border-left-width'), 10)
|
||||
|
||||
m.width(width || this.button.outerWidth())
|
||||
},
|
||||
|
||||
// move up or down within the menu
|
||||
_traverse: function(which, start) {
|
||||
const $start = $(start),
|
||||
moveToLast = which === 38 || which === 37,
|
||||
|
||||
// select the first li that isn't an optgroup label / disabled
|
||||
$next = $start.parent()[moveToLast ? 'prevAll' : 'nextAll']('li:not(.ui-multiselect-disabled, .ui-multiselect-optgroup-label)')[moveToLast ? 'last' : 'first']()
|
||||
|
||||
// if at the first/last element
|
||||
if (!$next.length) {
|
||||
const $container = this.menu.find('ul').last()
|
||||
|
||||
// move to the first/last
|
||||
this.menu.find('label')[moveToLast ? 'last' : 'first']().trigger('mouseover')
|
||||
|
||||
// set scroll position
|
||||
$container.scrollTop(moveToLast ? $container.height() : 0)
|
||||
} else {
|
||||
$next.find('label').trigger('mouseover')
|
||||
}
|
||||
},
|
||||
|
||||
// This is an internal function to toggle the checked property and
|
||||
// other related attributes of a checkbox.
|
||||
//
|
||||
// The context of this function should be a checkbox; do not proxy it.
|
||||
_toggleState: function(prop, flag) {
|
||||
return function() {
|
||||
if (!this.disabled) {
|
||||
this[prop] = flag
|
||||
}
|
||||
|
||||
if (flag) {
|
||||
this.setAttribute('aria-selected', true)
|
||||
} else {
|
||||
this.removeAttribute('aria-selected')
|
||||
}
|
||||
}
|
||||
},
|
||||
|
||||
_toggleChecked: function(flag, group) {
|
||||
const $inputs = (group && group.length) ? group : this.inputs,
|
||||
self = this
|
||||
|
||||
// toggle state on inputs
|
||||
$inputs.each(this._toggleState('checked', flag))
|
||||
|
||||
// give the first input focus
|
||||
$inputs.eq(0).focus()
|
||||
|
||||
// update button text
|
||||
this.update()
|
||||
|
||||
// gather an array of the values that actually changed
|
||||
const values = $inputs.map(function() {
|
||||
return this.value
|
||||
}).get()
|
||||
|
||||
// toggle state on original option tags
|
||||
this.element
|
||||
.find('option')
|
||||
.each(function() {
|
||||
if (!this.disabled && $.inArray(this.value, values) > -1) {
|
||||
self._toggleState('selected', flag).call(this)
|
||||
}
|
||||
})
|
||||
|
||||
// trigger the change event on the select
|
||||
if ($inputs.length) {
|
||||
this.element.trigger('change')
|
||||
}
|
||||
},
|
||||
|
||||
_toggleDisabled: function(flag) {
|
||||
this.button
|
||||
.attr({ disabled: flag, 'aria-disabled': flag })[flag ? 'addClass' : 'removeClass']('ui-state-disabled')
|
||||
|
||||
let inputs = this.menu.find('input')
|
||||
const key = 'ech-multiselect-disabled'
|
||||
|
||||
if (flag) {
|
||||
// remember which elements this widget disabled (not pre-disabled)
|
||||
// elements, so that they can be restored if the widget is re-enabled.
|
||||
inputs = inputs.filter(':enabled')
|
||||
.data(key, true)
|
||||
} else {
|
||||
inputs = inputs.filter(function() {
|
||||
return $.data(this, key) === true
|
||||
}).removeData(key)
|
||||
}
|
||||
|
||||
inputs
|
||||
.attr({ disabled: flag, 'arial-disabled': flag })
|
||||
.parent()[flag ? 'addClass' : 'removeClass']('ui-state-disabled')
|
||||
|
||||
this.element
|
||||
.attr({ disabled: flag, 'aria-disabled': flag })
|
||||
},
|
||||
|
||||
// open the menu
|
||||
open: function(e) {
|
||||
let self = this,
|
||||
button = this.button,
|
||||
menu = this.menu,
|
||||
speed = this.speed,
|
||||
o = this.options,
|
||||
args = []
|
||||
|
||||
// bail if the multiselectopen event returns false, this widget is disabled, or is already open
|
||||
if (this._trigger('beforeopen') === false || button.hasClass('ui-state-disabled') || this._isOpen) {
|
||||
return
|
||||
}
|
||||
|
||||
let $container = menu.find('ul').last(),
|
||||
effect = o.show,
|
||||
pos = button.offset()
|
||||
|
||||
// figure out opening effects/speeds
|
||||
if ($.isArray(o.show)) {
|
||||
effect = o.show[0]
|
||||
speed = o.show[1] || self.speed
|
||||
}
|
||||
|
||||
// if there's an effect, assume jQuery UI is in use
|
||||
// build the arguments to pass to show()
|
||||
if (effect) {
|
||||
args = [effect, speed]
|
||||
}
|
||||
|
||||
// set the scroll of the checkbox container
|
||||
$container.scrollTop(0).height(o.height)
|
||||
|
||||
// position and show menu
|
||||
if ($.ui.position && !$.isEmptyObject(o.position)) {
|
||||
o.position.of = o.position.of || button
|
||||
|
||||
menu
|
||||
.show()
|
||||
.position(o.position)
|
||||
.hide()
|
||||
|
||||
// if position utility is not available...
|
||||
} else {
|
||||
menu.css({
|
||||
top: pos.top + button.outerHeight(),
|
||||
'inset-inline-start': pos.left,
|
||||
})
|
||||
}
|
||||
|
||||
// show the menu, maybe with a speed/effect combo
|
||||
$.fn.show.apply(menu, args)
|
||||
|
||||
// select the first option
|
||||
// triggering both mouseover and mouseover because 1.4.2+ has a bug where triggering mouseover
|
||||
// will actually trigger mouseenter. the mouseenter trigger is there for when it's eventually fixed
|
||||
this.labels.eq(0).trigger('mouseover').trigger('mouseenter').find('input').trigger('focus')
|
||||
|
||||
button.addClass('ui-state-active')
|
||||
this._isOpen = true
|
||||
this._trigger('open')
|
||||
},
|
||||
|
||||
// close the menu
|
||||
close: function() {
|
||||
if (this._trigger('beforeclose') === false) {
|
||||
return
|
||||
}
|
||||
|
||||
let o = this.options,
|
||||
effect = o.hide,
|
||||
speed = this.speed,
|
||||
args = []
|
||||
|
||||
// figure out opening effects/speeds
|
||||
if ($.isArray(o.hide)) {
|
||||
effect = o.hide[0]
|
||||
speed = o.hide[1] || this.speed
|
||||
}
|
||||
|
||||
if (effect) {
|
||||
args = [effect, speed]
|
||||
}
|
||||
|
||||
$.fn.hide.apply(this.menu, args)
|
||||
this.button.removeClass('ui-state-active').trigger('blur').trigger('mouseleave')
|
||||
this._isOpen = false
|
||||
this._trigger('close')
|
||||
},
|
||||
|
||||
enable: function() {
|
||||
this._toggleDisabled(false)
|
||||
},
|
||||
|
||||
disable: function() {
|
||||
this._toggleDisabled(true)
|
||||
},
|
||||
|
||||
checkAll: function(e) {
|
||||
this._toggleChecked(true)
|
||||
this._trigger('checkAll')
|
||||
},
|
||||
|
||||
uncheckAll: function() {
|
||||
this._toggleChecked(false)
|
||||
this._trigger('uncheckAll')
|
||||
},
|
||||
|
||||
getChecked: function() {
|
||||
return this.menu.find('input').filter(':checked')
|
||||
},
|
||||
|
||||
destroy: function() {
|
||||
// remove classes + data
|
||||
$.Widget.prototype.destroy.call(this)
|
||||
|
||||
this.button.remove()
|
||||
this.menu.remove()
|
||||
this.element.show()
|
||||
|
||||
return this
|
||||
},
|
||||
|
||||
isOpen: function() {
|
||||
return this._isOpen
|
||||
},
|
||||
|
||||
widget: function() {
|
||||
return this.menu
|
||||
},
|
||||
|
||||
getButton: function() {
|
||||
return this.button
|
||||
},
|
||||
|
||||
// react to option changes after initialization
|
||||
_setOption: function(key, value) {
|
||||
const menu = this.menu
|
||||
|
||||
switch (key) {
|
||||
case 'header':
|
||||
menu.find('div.ui-multiselect-header')[value ? 'show' : 'hide']()
|
||||
break
|
||||
case 'checkAllText':
|
||||
menu.find('a.ui-multiselect-all span').eq(-1).text(value)
|
||||
break
|
||||
case 'uncheckAllText':
|
||||
menu.find('a.ui-multiselect-none span').eq(-1).text(value)
|
||||
break
|
||||
case 'height':
|
||||
menu.find('ul').last().height(parseInt(value, 10))
|
||||
break
|
||||
case 'minWidth':
|
||||
this.options[key] = parseInt(value, 10)
|
||||
this._setButtonWidth()
|
||||
this._setMenuWidth()
|
||||
break
|
||||
case 'selectedText':
|
||||
case 'selectedList':
|
||||
case 'noneSelectedText':
|
||||
this.options[key] = value // these all needs to update immediately for the update() call
|
||||
this.update()
|
||||
break
|
||||
case 'classes':
|
||||
menu.add(this.button).removeClass(this.options.classes).addClass(value)
|
||||
break
|
||||
case 'multiple':
|
||||
menu.toggleClass('ui-multiselect-single', !value)
|
||||
this.options.multiple = value
|
||||
this.element[0].multiple = value
|
||||
this.refresh()
|
||||
}
|
||||
|
||||
$.Widget.prototype._setOption.apply(this, arguments)
|
||||
},
|
||||
})
|
||||
})(jQuery)
|
||||
|
|
@ -30,6 +30,7 @@ use OCP\AppFramework\Bootstrap\IBootstrap;
|
|||
use OCP\AppFramework\Bootstrap\IRegistrationContext;
|
||||
use OCP\AppFramework\IAppContainer;
|
||||
use OCP\AppFramework\Services\IAppConfig;
|
||||
use OCP\AppFramework\Services\IInitialState;
|
||||
use OCP\Config\IUserConfig;
|
||||
use OCP\EventDispatcher\IEventDispatcher;
|
||||
use OCP\IAvatarManager;
|
||||
|
|
@ -67,6 +68,7 @@ class Application extends App implements IBootstrap {
|
|||
$appContainer->get(IL10N::class),
|
||||
$appContainer->get('Session'),
|
||||
$appContainer->get(IURLGenerator::class),
|
||||
$appContainer->get(IInitialState::class),
|
||||
);
|
||||
});
|
||||
|
||||
|
|
|
|||
|
|
@ -6,6 +6,7 @@
|
|||
*/
|
||||
namespace OCA\User_LDAP\Controller;
|
||||
|
||||
use OCA\User_LDAP\AppInfo\Application;
|
||||
use OCP\AppFramework\Controller;
|
||||
use OCP\AppFramework\Http\Attribute\NoCSRFRequired;
|
||||
use OCP\AppFramework\Http\Attribute\OpenAPI;
|
||||
|
|
@ -13,6 +14,7 @@ use OCP\AppFramework\Http\Attribute\PublicPage;
|
|||
use OCP\AppFramework\Http\Attribute\UseSession;
|
||||
use OCP\AppFramework\Http\RedirectResponse;
|
||||
use OCP\AppFramework\Http\TemplateResponse;
|
||||
use OCP\AppFramework\Services\IInitialState;
|
||||
use OCP\Config\IUserConfig;
|
||||
use OCP\HintException;
|
||||
use OCP\IConfig;
|
||||
|
|
@ -20,8 +22,8 @@ use OCP\IL10N;
|
|||
use OCP\IRequest;
|
||||
use OCP\ISession;
|
||||
use OCP\IURLGenerator;
|
||||
use OCP\IUser;
|
||||
use OCP\IUserManager;
|
||||
use OCP\Util;
|
||||
|
||||
#[OpenAPI(scope: OpenAPI::SCOPE_IGNORE)]
|
||||
class RenewPasswordController extends Controller {
|
||||
|
|
@ -34,6 +36,7 @@ class RenewPasswordController extends Controller {
|
|||
protected IL10N $l10n,
|
||||
private ISession $session,
|
||||
private IURLGenerator $urlGenerator,
|
||||
private IInitialState $initialState,
|
||||
) {
|
||||
parent::__construct($appName, $request);
|
||||
}
|
||||
|
|
@ -51,7 +54,7 @@ class RenewPasswordController extends Controller {
|
|||
if (!$this->userConfig->getValueBool($user, 'user_ldap', 'needsPasswordReset')) {
|
||||
return new RedirectResponse($this->urlGenerator->linkToRouteAbsolute('core.login.showLoginForm'));
|
||||
}
|
||||
$parameters = [];
|
||||
|
||||
$renewPasswordMessages = $this->session->get('renewPasswordMessages');
|
||||
$errors = [];
|
||||
$messages = [];
|
||||
|
|
@ -59,25 +62,23 @@ class RenewPasswordController extends Controller {
|
|||
[$errors, $messages] = $renewPasswordMessages;
|
||||
}
|
||||
$this->session->remove('renewPasswordMessages');
|
||||
foreach ($errors as $value) {
|
||||
$parameters[$value] = true;
|
||||
}
|
||||
|
||||
$parameters['messages'] = $messages;
|
||||
$parameters['user'] = $user;
|
||||
|
||||
$parameters['canResetPassword'] = true;
|
||||
$parameters['resetPasswordLink'] = $this->config->getSystemValue('lost_password_link', '');
|
||||
if (!$parameters['resetPasswordLink']) {
|
||||
$userObj = $this->userManager->get($user);
|
||||
if ($userObj instanceof IUser) {
|
||||
$parameters['canResetPassword'] = $userObj->canChangePassword();
|
||||
}
|
||||
}
|
||||
$parameters['cancelLink'] = $this->urlGenerator->linkToRouteAbsolute('core.login.showLoginForm');
|
||||
$this->initialState->provideInitialState('renewPasswordParameters',
|
||||
[
|
||||
'user' => $user,
|
||||
'errors' => $errors,
|
||||
'messages' => $messages,
|
||||
'cancelRenewUrl' => $this->urlGenerator->linkToRouteAbsolute('core.login.showLoginForm'),
|
||||
'tryRenewPasswordUrl' => $this->urlGenerator->linkToRouteAbsolute('user_ldap.renewPassword.tryRenewPassword'),
|
||||
],
|
||||
);
|
||||
|
||||
Util::addStyle(Application::APP_ID, 'renewPassword');
|
||||
Util::addScript(Application::APP_ID, 'renewPassword');
|
||||
return new TemplateResponse(
|
||||
$this->appName, 'renewpassword', $parameters, 'guest'
|
||||
Application::APP_ID,
|
||||
'renewpassword',
|
||||
renderAs: 'guest',
|
||||
);
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -1,11 +0,0 @@
|
|||
<!--
|
||||
- SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors
|
||||
- SPDX-License-Identifier: AGPL-3.0-or-later
|
||||
-->
|
||||
<template>
|
||||
<Settings />
|
||||
</template>
|
||||
|
||||
<script lang="ts" setup>
|
||||
import Settings from './views/Settings.vue'
|
||||
</script>
|
||||
10
apps/user_ldap/src/renewPassword.ts
Normal file
10
apps/user_ldap/src/renewPassword.ts
Normal file
|
|
@ -0,0 +1,10 @@
|
|||
/**
|
||||
* SPDX-FileCopyrightText: 2026 Nextcloud GmbH and Nextcloud contributors
|
||||
* SPDX-License-Identifier: AGPL-3.0-or-later
|
||||
*/
|
||||
|
||||
import { createApp } from 'vue'
|
||||
import RenewPasswordView from './views/RenewPassword.vue'
|
||||
|
||||
const app = createApp(RenewPasswordView)
|
||||
app.mount('#user_ldap-renewPassword')
|
||||
|
|
@ -2,8 +2,9 @@
|
|||
* SPDX-FileCopyrightText: 2023 Nextcloud GmbH and Nextcloud contributors
|
||||
* SPDX-License-Identifier: AGPL-3.0-or-later
|
||||
*/
|
||||
|
||||
import { createApp } from 'vue'
|
||||
import LDAPSettingsApp from './LDAPSettingsApp.vue'
|
||||
import LDAPSettingsApp from './views/LDAPSettingsApp.vue'
|
||||
import { pinia } from './store/index.ts'
|
||||
|
||||
const app = createApp(LDAPSettingsApp)
|
||||
|
|
|
|||
|
|
@ -87,8 +87,6 @@
|
|||
</template>
|
||||
|
||||
<script lang="ts" setup>
|
||||
/* eslint vue/multi-word-component-names: "warn" */
|
||||
|
||||
import { loadState } from '@nextcloud/initial-state'
|
||||
import { t } from '@nextcloud/l10n'
|
||||
import { NcButton, NcCheckboxRadioSwitch, NcNoteCard, NcSelect } from '@nextcloud/vue'
|
||||
|
|
@ -132,8 +130,9 @@ const selectedConfigHasServerInfo = computed(() => {
|
|||
})
|
||||
|
||||
/**
|
||||
* Request to clear the mapping.
|
||||
*
|
||||
* @param subject
|
||||
* @param subject - The subject to clear
|
||||
*/
|
||||
async function requestClearMapping(subject: 'user' | 'group') {
|
||||
try {
|
||||
97
apps/user_ldap/src/views/RenewPassword.vue
Normal file
97
apps/user_ldap/src/views/RenewPassword.vue
Normal file
|
|
@ -0,0 +1,97 @@
|
|||
<!--
|
||||
- SPDX-FileCopyrightText: 2026 Nextcloud GmbH and Nextcloud contributors
|
||||
- SPDX-License-Identifier: AGPL-3.0-or-later
|
||||
-->
|
||||
|
||||
<script setup lang="ts">
|
||||
import { getRequestToken } from '@nextcloud/auth'
|
||||
import { loadState } from '@nextcloud/initial-state'
|
||||
import { t } from '@nextcloud/l10n'
|
||||
import { ref } from 'vue'
|
||||
import NcButton from '@nextcloud/vue/components/NcButton'
|
||||
import NcGuestContent from '@nextcloud/vue/components/NcGuestContent'
|
||||
import NcNoteCard from '@nextcloud/vue/components/NcNoteCard'
|
||||
import NcPasswordField from '@nextcloud/vue/components/NcPasswordField'
|
||||
|
||||
const renewPasswordParameters = loadState<{
|
||||
user: string
|
||||
errors: string[]
|
||||
messages: string[]
|
||||
cancelRenewUrl: string
|
||||
tryRenewPasswordUrl: string
|
||||
}>('user_ldap', 'renewPasswordParameters')
|
||||
|
||||
const hasInvalidPassword = renewPasswordParameters.errors.includes('invalidpassword')
|
||||
|
||||
const requestToken = getRequestToken()
|
||||
const isRenewing = ref(false)
|
||||
|
||||
/**
|
||||
* Handle the form submission.
|
||||
*/
|
||||
function onSubmit() {
|
||||
isRenewing.value = true
|
||||
}
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<NcGuestContent>
|
||||
<h2>{{ t('user_ldap', 'Please renew your password') }}</h2>
|
||||
<NcNoteCard v-if="renewPasswordParameters.messages.length" type="warning">
|
||||
<p v-for="(message, index) in renewPasswordParameters.messages" :key="index">
|
||||
{{ message }}
|
||||
</p>
|
||||
</NcNoteCard>
|
||||
<NcNoteCard
|
||||
v-if="renewPasswordParameters.errors.includes('internalexception')"
|
||||
:heading="t('user_ldap', 'An internal error occurred.')"
|
||||
:text="t('user_ldap', 'Please try again or contact your administrator.')"
|
||||
type="warning" />
|
||||
|
||||
<form
|
||||
method="post"
|
||||
name="renewpassword"
|
||||
:action="renewPasswordParameters.tryRenewPasswordUrl"
|
||||
@submit="onSubmit">
|
||||
<NcPasswordField
|
||||
autofocus
|
||||
autocomplete="off"
|
||||
autocapitalize="off"
|
||||
:error="hasInvalidPassword"
|
||||
:helper-text="hasInvalidPassword ? t('user_ldap', 'Wrong password.') : ''"
|
||||
:label="t('user_ldap', 'Current password')"
|
||||
required
|
||||
spellcheck="false"
|
||||
name="oldPassword" />
|
||||
<NcPasswordField
|
||||
autofocus
|
||||
autocomplete="off"
|
||||
autocapitalize="off"
|
||||
:label="t('user_ldap', 'New password')"
|
||||
required
|
||||
spellcheck="false"
|
||||
name="newPassword" />
|
||||
|
||||
<div :class="$style.renewPassword__actions">
|
||||
<NcButton :href="renewPasswordParameters.cancelRenewUrl" variant="error">
|
||||
{{ t('user_ldap', 'Cancel') }}
|
||||
</NcButton>
|
||||
<NcButton :disabled="isRenewing" type="submit" variant="primary">
|
||||
{{ isRenewing ? t('user_ldap', 'Renewing…') : t('user_ldap', 'Renew password') }}
|
||||
</NcButton>
|
||||
</div>
|
||||
|
||||
<input type="hidden" name="user" :value="renewPasswordParameters.user">
|
||||
<input type="hidden" name="requesttoken" :value="requestToken">
|
||||
</form>
|
||||
</NcGuestContent>
|
||||
</template>
|
||||
|
||||
<style module>
|
||||
.renewPassword__actions {
|
||||
display: flex;
|
||||
justify-content: end;
|
||||
gap: var(--default-grid-baseline);
|
||||
margin-top: 1rem;
|
||||
}
|
||||
</style>
|
||||
|
|
@ -1,66 +1,9 @@
|
|||
<?php
|
||||
|
||||
/**
|
||||
* SPDX-FileCopyrightText: 2017 Nextcloud GmbH and Nextcloud contributors
|
||||
* SPDX-FileCopyrightText: 2026 Nextcloud GmbH and Nextcloud contributors
|
||||
* SPDX-License-Identifier: AGPL-3.0-or-later
|
||||
*/
|
||||
/** @var \OCP\IL10N $l */
|
||||
|
||||
\OCP\Util::addScript('user_ldap', 'renewPassword', 'core');
|
||||
style('user_ldap', 'renewPassword');
|
||||
?>
|
||||
|
||||
<form method="post" name="renewpassword" id="renewpassword" action="<?php p(\OCP\Server::get(\OCP\IURLGenerator::class)->linkToRoute('user_ldap.renewPassword.tryRenewPassword')); ?>">
|
||||
<fieldset>
|
||||
<div class="warning title">
|
||||
<?php p($l->t('Please renew your password.')); ?><br>
|
||||
</div>
|
||||
<?php foreach ($_['messages'] as $message): ?>
|
||||
<div class="warning">
|
||||
<?php p($message); ?><br>
|
||||
</div>
|
||||
<?php endforeach; ?>
|
||||
<?php if (isset($_['internalexception']) && $_['internalexception']): ?>
|
||||
<div class="warning">
|
||||
<?php p($l->t('An internal error occurred.')); ?><br>
|
||||
<small><?php p($l->t('Please try again or contact your administrator.')); ?></small>
|
||||
</div>
|
||||
<?php endif; ?>
|
||||
<div id="message" class="hidden">
|
||||
<img class="float-spinner" alt=""
|
||||
src="<?php p(image_path('core', 'loading-dark.gif'));?>">
|
||||
<span id="messageText"></span>
|
||||
<!-- the following div ensures that the spinner is always inside the #message div -->
|
||||
<div style="clear: both;"></div>
|
||||
</div>
|
||||
<p class="grouptop">
|
||||
<input type="password" id="oldPassword" name="oldPassword"
|
||||
placeholder="<?php echo $l->t('Current password');?>"
|
||||
autofocus autocomplete="off" autocapitalize="off" spellcheck="false" required/>
|
||||
<label for="oldPassword" class="infield"><?php p($l->t('Current password')); ?></label>
|
||||
</p>
|
||||
|
||||
<p class="groupbottom">
|
||||
<input type="checkbox" id="personal-show" name="show" class="hidden-visually" /><label for="personal-show"></label>
|
||||
<label id="newPassword-label" for="newPassword" class="infield"><?php p($l->t('New password')); ?></label>
|
||||
<input type="password" id="newPassword" name="newPassword"
|
||||
placeholder="<?php echo $l->t('New password');?>"
|
||||
data-typetoggle="#personal-show" autofocus autocomplete="off" autocapitalize="off" spellcheck="false" required/>
|
||||
</p>
|
||||
|
||||
<input type="submit" id="submit" class="login primary icon-confirm-white" value="<?php p($l->t('Renew password')); ?>"/>
|
||||
|
||||
<?php if (!empty($_['invalidpassword'])) { ?>
|
||||
<p class="warning">
|
||||
<?php p($l->t('Wrong password.')); ?>
|
||||
</p>
|
||||
<?php } ?>
|
||||
<p id="cancel-container" class="info">
|
||||
<a id="cancel" href="<?php p($_['cancelLink']); ?>">
|
||||
<?php p($l->t('Cancel')); ?>
|
||||
</a>
|
||||
</p>
|
||||
<input type="hidden" name="user" id="user" value="<?php p($_['user']) ?>">
|
||||
<input type="hidden" name="requesttoken" value="<?php p($_['requesttoken']) ?>">
|
||||
</fieldset>
|
||||
</form>
|
||||
<div id="user_ldap-renewPassword"></div>
|
||||
|
|
|
|||
|
|
@ -46,6 +46,7 @@ const modules = {
|
|||
'settings-personal': resolve(import.meta.dirname, 'apps/twofactor_backupcodes/src', 'settings-personal.ts'),
|
||||
},
|
||||
user_ldap: {
|
||||
renewPassword: resolve(import.meta.dirname, 'apps/user_ldap/src', 'renewPassword.ts'),
|
||||
'settings-admin': resolve(import.meta.dirname, 'apps/user_ldap/src', 'settings-admin.ts'),
|
||||
},
|
||||
user_status: {
|
||||
|
|
|
|||
|
|
@ -1,2 +1,2 @@
|
|||
import{r as u,a as p,t as h,_ as C}from"./_plugin-vue_export-helper-CDPKodk-.chunk.mjs";import{j as _,E as i,o as e,H as o,F as s,x as y,e as H,f as n,y as d,b,z as f}from"./mdi-B9XVyi7B.chunk.mjs";const k={name:"HelpCircleIcon",emits:["click"],props:{title:{type:String},fillColor:{type:String,default:"currentColor"},size:{type:Number,default:24}}},A=["aria-hidden","aria-label"],v=["fill","width","height"],z={d:"M15.07,11.25L14.17,12.17C13.45,12.89 13,13.5 13,15H11V14.5C11,13.39 11.45,12.39 12.17,11.67L13.41,10.41C13.78,10.05 14,9.55 14,9C14,7.89 13.1,7 12,7A2,2 0 0,0 10,9H8A4,4 0 0,1 12,5A4,4 0 0,1 16,9C16,9.88 15.64,10.67 15.07,11.25M13,19H11V17H13M12,2A10,10 0 0,0 2,12A10,10 0 0,0 12,22A10,10 0 0,0 22,12C22,6.47 17.5,2 12,2Z"},V={key:0};function w(a,l,t,c,g,m){return e(),i("span",f(a.$attrs,{"aria-hidden":t.title?null:"true","aria-label":t.title,class:"material-design-icon help-circle-icon",role:"img",onClick:l[0]||(l[0]=r=>a.$emit("click",r))}),[(e(),i("svg",{fill:t.fillColor,class:"material-design-icon__svg",width:t.size,height:t.size,viewBox:"0 0 24 24"},[o("path",z,[t.title?(e(),i("title",V,n(t.title),1)):s("",!0)])],8,v))],16,A)}const x=p(k,[["render",w]]);u();const M={class:"settings-section"},S={class:"settings-section__name"},$=["aria-label","href","title"],I={key:0,class:"settings-section__desc"},N=_({__name:"NcSettingsSection",props:{name:{},description:{default:""},docUrl:{default:""}},setup(a){const l=h("External documentation");return(t,c)=>(e(),i("div",M,[o("h2",S,[H(n(t.name)+" ",1),t.docUrl?(e(),i("a",{key:0,"aria-label":d(l),class:"settings-section__info",href:t.docUrl,rel:"noreferrer nofollow",target:"_blank",title:d(l)},[b(x,{size:20})],8,$)):s("",!0)]),t.description?(e(),i("p",I,n(t.description),1)):s("",!0),y(t.$slots,"default",{},void 0,!0)]))}}),P=p(N,[["__scopeId","data-v-9cedb949"]]),U={name:"ContentCopyIcon",emits:["click"],props:{title:{type:String},fillColor:{type:String,default:"currentColor"},size:{type:Number,default:24}}},B=["aria-hidden","aria-label"],E=["fill","width","height"],L={d:"M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"},Z={key:0};function j(a,l,t,c,g,m){return e(),i("span",f(a.$attrs,{"aria-hidden":t.title?null:"true","aria-label":t.title,class:"material-design-icon content-copy-icon",role:"img",onClick:l[0]||(l[0]=r=>a.$emit("click",r))}),[(e(),i("svg",{fill:t.fillColor,class:"material-design-icon__svg",width:t.size,height:t.size,viewBox:"0 0 24 24"},[o("path",L,[t.title?(e(),i("title",Z,n(t.title),1)):s("",!0)])],8,E))],16,B)}const T=C(U,[["render",j]]);export{T as I,P as N};
|
||||
//# sourceMappingURL=ContentCopy-CFmC6HSf.chunk.mjs.map
|
||||
import{r as u,a as p,t as h,_ as C}from"./_plugin-vue_export-helper-B5bm_3R2.chunk.mjs";import{j as _,E as i,o as e,J as o,F as s,x as y,e as H,f as n,y as d,b,z as f}from"./mdi-BjfN1ic1.chunk.mjs";const k={name:"HelpCircleIcon",emits:["click"],props:{title:{type:String},fillColor:{type:String,default:"currentColor"},size:{type:Number,default:24}}},A=["aria-hidden","aria-label"],v=["fill","width","height"],z={d:"M15.07,11.25L14.17,12.17C13.45,12.89 13,13.5 13,15H11V14.5C11,13.39 11.45,12.39 12.17,11.67L13.41,10.41C13.78,10.05 14,9.55 14,9C14,7.89 13.1,7 12,7A2,2 0 0,0 10,9H8A4,4 0 0,1 12,5A4,4 0 0,1 16,9C16,9.88 15.64,10.67 15.07,11.25M13,19H11V17H13M12,2A10,10 0 0,0 2,12A10,10 0 0,0 12,22A10,10 0 0,0 22,12C22,6.47 17.5,2 12,2Z"},V={key:0};function w(a,l,t,c,g,m){return e(),i("span",f(a.$attrs,{"aria-hidden":t.title?null:"true","aria-label":t.title,class:"material-design-icon help-circle-icon",role:"img",onClick:l[0]||(l[0]=r=>a.$emit("click",r))}),[(e(),i("svg",{fill:t.fillColor,class:"material-design-icon__svg",width:t.size,height:t.size,viewBox:"0 0 24 24"},[o("path",z,[t.title?(e(),i("title",V,n(t.title),1)):s("",!0)])],8,v))],16,A)}const x=p(k,[["render",w]]);u();const M={class:"settings-section"},S={class:"settings-section__name"},$=["aria-label","href","title"],I={key:0,class:"settings-section__desc"},N=_({__name:"NcSettingsSection",props:{name:{},description:{default:""},docUrl:{default:""}},setup(a){const l=h("External documentation");return(t,c)=>(e(),i("div",M,[o("h2",S,[H(n(t.name)+" ",1),t.docUrl?(e(),i("a",{key:0,"aria-label":d(l),class:"settings-section__info",href:t.docUrl,rel:"noreferrer nofollow",target:"_blank",title:d(l)},[b(x,{size:20})],8,$)):s("",!0)]),t.description?(e(),i("p",I,n(t.description),1)):s("",!0),y(t.$slots,"default",{},void 0,!0)]))}}),D=p(N,[["__scopeId","data-v-9cedb949"]]),U={name:"ContentCopyIcon",emits:["click"],props:{title:{type:String},fillColor:{type:String,default:"currentColor"},size:{type:Number,default:24}}},B=["aria-hidden","aria-label"],E=["fill","width","height"],L={d:"M19,21H8V7H19M19,5H8A2,2 0 0,0 6,7V21A2,2 0 0,0 8,23H19A2,2 0 0,0 21,21V7A2,2 0 0,0 19,5M16,1H4A2,2 0 0,0 2,3V17H4V3H16V1Z"},Z={key:0};function j(a,l,t,c,g,m){return e(),i("span",f(a.$attrs,{"aria-hidden":t.title?null:"true","aria-label":t.title,class:"material-design-icon content-copy-icon",role:"img",onClick:l[0]||(l[0]=r=>a.$emit("click",r))}),[(e(),i("svg",{fill:t.fillColor,class:"material-design-icon__svg",width:t.size,height:t.size,viewBox:"0 0 24 24"},[o("path",L,[t.title?(e(),i("title",Z,n(t.title),1)):s("",!0)])],8,E))],16,B)}const P=C(U,[["render",j]]);export{P as I,D as N};
|
||||
//# sourceMappingURL=ContentCopy-r6LH1e3H.chunk.mjs.map
|
||||
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
5
dist/NcAvatar-DmUGApWA-B1NGB-kt.chunk.mjs
vendored
Normal file
5
dist/NcAvatar-DmUGApWA-B1NGB-kt.chunk.mjs
vendored
Normal file
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
5
dist/NcAvatar-DmUGApWA-CajOq8xc.chunk.mjs
vendored
5
dist/NcAvatar-DmUGApWA-CajOq8xc.chunk.mjs
vendored
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
6
dist/NcEmojiPicker-pM4Pg2yq-DH71bTmR.chunk.mjs
vendored
Normal file
6
dist/NcEmojiPicker-pM4Pg2yq-DH71bTmR.chunk.mjs
vendored
Normal file
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
1
dist/NcGuestContent-j8ai4O1K-D0718NyY.chunk.css
vendored
Normal file
1
dist/NcGuestContent-j8ai4O1K-D0718NyY.chunk.css
vendored
Normal file
|
|
@ -0,0 +1 @@
|
|||
.material-design-icon[data-v-26ad2498]{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}#guest-content-vue[data-v-26ad2498]{color:var(--color-main-text);background-color:var(--color-main-background);min-width:0;border-radius:var(--border-radius-element);box-shadow:0 0 10px var(--color-box-shadow);height:fit-content;padding:15px;margin:20px auto}.material-design-icon{display:flex;align-self:center;justify-self:center;align-items:center;justify-content:center}#content.nc-guest-content{overflow:auto;margin-bottom:0;height:calc(var(--body-height) + var(--body-container-margin))}
|
||||
7
dist/NcGuestContent-j8ai4O1K-DOYqnAt_.chunk.mjs.license
vendored
Normal file
7
dist/NcGuestContent-j8ai4O1K-DOYqnAt_.chunk.mjs.license
vendored
Normal file
|
|
@ -0,0 +1,7 @@
|
|||
SPDX-License-Identifier: MIT
|
||||
SPDX-FileCopyrightText: Rich Harris
|
||||
|
||||
This file is generated from multiple sources. Included packages:
|
||||
- rollup
|
||||
- version: 4.52.5
|
||||
- license: MIT
|
||||
7
dist/NcGuestContent-j8ai4O1K-DOYqnAt_.chunk.mjs.map.license
vendored
Normal file
7
dist/NcGuestContent-j8ai4O1K-DOYqnAt_.chunk.mjs.map.license
vendored
Normal file
|
|
@ -0,0 +1,7 @@
|
|||
SPDX-License-Identifier: MIT
|
||||
SPDX-FileCopyrightText: Rich Harris
|
||||
|
||||
This file is generated from multiple sources. Included packages:
|
||||
- rollup
|
||||
- version: 4.52.5
|
||||
- license: MIT
|
||||
2
dist/NcInputField-Bwsh2aHY-D1wb04Qy.chunk.mjs
vendored
Normal file
2
dist/NcInputField-Bwsh2aHY-D1wb04Qy.chunk.mjs
vendored
Normal file
|
|
@ -0,0 +1,2 @@
|
|||
import{j as V,m as h,u as j,N as L,p as S,s as n,E as u,o as i,J as p,F as d,O as q,c as t,z,f as v,P as A,x as y,w as E,y as s,e as G,G as J}from"./mdi-BjfN1ic1.chunk.mjs";import{i as g,c as M,d as m,N as o,e as x}from"./NcNoteCard-CVhtNL04-CL6uGjhw.chunk.mjs";import{a as D,e as H}from"./_plugin-vue_export-helper-B5bm_3R2.chunk.mjs";const K={class:"input-field__main-wrapper"},P=["id","aria-describedby","disabled","placeholder","type","value"],Q=["for"],R={class:"input-field__icon input-field__icon--leading"},U={key:2,class:"input-field__icon input-field__icon--trailing"},W=["id"],X=V({inheritAttrs:!1,__name:"NcInputField",props:h({class:{default:""},inputClass:{default:""},id:{default:()=>H()},label:{default:void 0},labelOutside:{type:Boolean},type:{default:"text"},placeholder:{default:void 0},showTrailingButton:{type:Boolean},trailingButtonLabel:{default:void 0},success:{type:Boolean},error:{type:Boolean},helperText:{default:""},disabled:{type:Boolean},pill:{type:Boolean}},{modelValue:{required:!0},modelModifiers:{}}),emits:h(["trailingButtonClick"],["update:modelValue"]),setup(c,{expose:B,emit:k}){const r=j(c,"modelValue"),l=c,$=k;B({focus:N,select:O});const f=L(),b=S("input"),T=n(()=>l.showTrailingButton||l.success),w=n(()=>{if(l.placeholder)return l.placeholder;if(l.label)return g?l.label:""}),_=n(()=>l.label||l.labelOutside),C=n(()=>{const e=[];return l.helperText&&e.push(`${l.id}-helper-text`),f["aria-describedby"]&&e.push(String(f["aria-describedby"])),e.join(" ")||void 0});function N(e){b.value.focus(e)}function O(){b.value.select()}function F(e){const a=e.target;r.value=l.type==="number"&&typeof r.value=="number"?parseFloat(a.value):a.value}return(e,a)=>(i(),u("div",{class:J(["input-field",[{"input-field--disabled":e.disabled,"input-field--error":e.error,"input-field--label-outside":e.labelOutside||!_.value,"input-field--leading-icon":!!e.$slots.icon,"input-field--trailing-icon":T.value,"input-field--pill":e.pill,"input-field--success":e.success,"input-field--legacy":s(g)},e.$props.class]])},[p("div",K,[p("input",z(e.$attrs,{id:e.id,ref:"input","aria-describedby":C.value,"aria-live":"polite",class:["input-field__input",e.inputClass],disabled:e.disabled,placeholder:w.value,type:e.type,value:r.value.toString(),onInput:F}),null,16,P),!e.labelOutside&&_.value?(i(),u("label",{key:0,class:"input-field__label",for:e.id},v(e.label),9,Q)):d("",!0),q(p("div",R,[y(e.$slots,"icon",{},void 0,!0)],512),[[A,!!e.$slots.icon]]),e.showTrailingButton?(i(),t(M,{key:1,class:"input-field__trailing-button","aria-label":e.trailingButtonLabel,disabled:e.disabled,variant:"tertiary-no-background",onClick:a[0]||(a[0]=I=>$("trailingButtonClick",I))},{icon:E(()=>[y(e.$slots,"trailing-button-icon",{},void 0,!0)]),_:3},8,["aria-label","disabled"])):e.success||e.error?(i(),u("div",U,[e.success?(i(),t(o,{key:0,path:s(m)},null,8,["path"])):(i(),t(o,{key:1,path:s(x)},null,8,["path"]))])):d("",!0)]),e.helperText?(i(),u("p",{key:0,id:`${e.id}-helper-text`,class:"input-field__helper-text-message"},[e.success?(i(),t(o,{key:0,class:"input-field__helper-text-message__icon",path:s(m),inline:""},null,8,["path"])):e.error?(i(),t(o,{key:1,class:"input-field__helper-text-message__icon",path:s(x),inline:""},null,8,["path"])):d("",!0),G(" "+v(e.helperText),1)],8,W)):d("",!0)],2))}}),le=D(X,[["__scopeId","data-v-a0e80f48"]]);export{le as N};
|
||||
//# sourceMappingURL=NcInputField-Bwsh2aHY-D1wb04Qy.chunk.mjs.map
|
||||
File diff suppressed because one or more lines are too long
|
|
@ -1,2 +0,0 @@
|
|||
import{j as N,m as h,u as V,J as j,p as q,s as n,E as u,o as i,H as p,F as d,K as z,c as t,z as A,f as v,L as E,x as y,w as G,y as s,e as H,G as J}from"./mdi-B9XVyi7B.chunk.mjs";import{i as g,b as K,c as m,N as o,d as x}from"./NcNoteCard-CVhtNL04-BSciYEDO.chunk.mjs";import{a as M,e as S}from"./_plugin-vue_export-helper-CDPKodk-.chunk.mjs";const D={class:"input-field__main-wrapper"},P=["id","aria-describedby","disabled","placeholder","type","value"],Q=["for"],R={class:"input-field__icon input-field__icon--leading"},U={key:2,class:"input-field__icon input-field__icon--trailing"},W=["id"],X=N({inheritAttrs:!1,__name:"NcInputField",props:h({class:{default:""},inputClass:{default:""},id:{default:()=>S()},label:{default:void 0},labelOutside:{type:Boolean},type:{default:"text"},placeholder:{default:void 0},showTrailingButton:{type:Boolean},trailingButtonLabel:{default:void 0},success:{type:Boolean},error:{type:Boolean},helperText:{default:""},disabled:{type:Boolean},pill:{type:Boolean}},{modelValue:{required:!0},modelModifiers:{}}),emits:h(["trailingButtonClick"],["update:modelValue"]),setup(c,{expose:B,emit:k}){const r=V(c,"modelValue"),l=c,$=k;B({focus:O,select:F});const f=j(),b=q("input"),T=n(()=>l.showTrailingButton||l.success),w=n(()=>{if(l.placeholder)return l.placeholder;if(l.label)return g?l.label:""}),_=n(()=>l.label||l.labelOutside),C=n(()=>{const e=[];return l.helperText&&e.push(`${l.id}-helper-text`),f["aria-describedby"]&&e.push(String(f["aria-describedby"])),e.join(" ")||void 0});function O(e){b.value.focus(e)}function F(){b.value.select()}function I(e){const a=e.target;r.value=l.type==="number"&&typeof r.value=="number"?parseFloat(a.value):a.value}return(e,a)=>(i(),u("div",{class:J(["input-field",[{"input-field--disabled":e.disabled,"input-field--error":e.error,"input-field--label-outside":e.labelOutside||!_.value,"input-field--leading-icon":!!e.$slots.icon,"input-field--trailing-icon":T.value,"input-field--pill":e.pill,"input-field--success":e.success,"input-field--legacy":s(g)},e.$props.class]])},[p("div",D,[p("input",A(e.$attrs,{id:e.id,ref:"input","aria-describedby":C.value,"aria-live":"polite",class:["input-field__input",e.inputClass],disabled:e.disabled,placeholder:w.value,type:e.type,value:r.value.toString(),onInput:I}),null,16,P),!e.labelOutside&&_.value?(i(),u("label",{key:0,class:"input-field__label",for:e.id},v(e.label),9,Q)):d("",!0),z(p("div",R,[y(e.$slots,"icon",{},void 0,!0)],512),[[E,!!e.$slots.icon]]),e.showTrailingButton?(i(),t(K,{key:1,class:"input-field__trailing-button","aria-label":e.trailingButtonLabel,disabled:e.disabled,variant:"tertiary-no-background",onClick:a[0]||(a[0]=L=>$("trailingButtonClick",L))},{icon:G(()=>[y(e.$slots,"trailing-button-icon",{},void 0,!0)]),_:3},8,["aria-label","disabled"])):e.success||e.error?(i(),u("div",U,[e.success?(i(),t(o,{key:0,path:s(m)},null,8,["path"])):(i(),t(o,{key:1,path:s(x)},null,8,["path"]))])):d("",!0)]),e.helperText?(i(),u("p",{key:0,id:`${e.id}-helper-text`,class:"input-field__helper-text-message"},[e.success?(i(),t(o,{key:0,class:"input-field__helper-text-message__icon",path:s(m),inline:""},null,8,["path"])):e.error?(i(),t(o,{key:1,class:"input-field__helper-text-message__icon",path:s(x),inline:""},null,8,["path"])):d("",!0),H(" "+v(e.helperText),1)],8,W)):d("",!0)],2))}}),le=M(X,[["__scopeId","data-v-a0e80f48"]]);export{le as N};
|
||||
//# sourceMappingURL=NcInputField-Bwsh2aHY-kbXSi5f0.chunk.mjs.map
|
||||
2
dist/NcNoteCard-CVhtNL04-BSciYEDO.chunk.mjs
vendored
2
dist/NcNoteCard-CVhtNL04-BSciYEDO.chunk.mjs
vendored
File diff suppressed because one or more lines are too long
2
dist/NcNoteCard-CVhtNL04-CL6uGjhw.chunk.mjs
vendored
Normal file
2
dist/NcNoteCard-CVhtNL04-CL6uGjhw.chunk.mjs
vendored
Normal file
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
|
|
@ -1,2 +1,2 @@
|
|||
import{l as V,N as S,m as C,a as N}from"./NcNoteCard-CVhtNL04-BSciYEDO.chunk.mjs";import{c as F}from"./index-BOuI_nzB.chunk.mjs";import{j as M,m as c,u as v,k as $,n as j,p as q,q as m,s as h,c as z,o as H,v as I,w as f,x as L,b as O,y as l,z as U}from"./mdi-B9XVyi7B.chunk.mjs";import{r as A,a as D,g as E,t as n}from"./_plugin-vue_export-helper-CDPKodk-.chunk.mjs";import{d as G}from"./string_decoder-mL5xNZ9K.chunk.mjs";import{N as J}from"./NcInputField-Bwsh2aHY-kbXSi5f0.chunk.mjs";A();const K=M({__name:"NcPasswordField",props:c({class:{},inputClass:{default:""},id:{},label:{},labelOutside:{type:Boolean},placeholder:{},showTrailingButton:{type:Boolean,default:!0},success:{type:Boolean},error:{type:Boolean},helperText:{},disabled:{type:Boolean},pill:{type:Boolean},checkPasswordStrength:{type:Boolean},minlength:{default:void 0},asText:{type:Boolean}},{modelValue:{default:""},modelModifiers:{},visible:{type:Boolean,default:!1},visibleModifiers:{}}),emits:c(["valid","invalid"],["update:modelValue","update:visible"]),setup(o,{expose:y,emit:w}){const s=v(o,"modelValue"),a=v(o,"visible"),t=o,d=w;$(s,G(B,500)),y({focus:_,select:k});const{password_policy:g}=j(),u=q("inputField"),i=m(""),r=m(),b=h(()=>{const e={...t};return delete e.checkPasswordStrength,delete e.minlength,delete e.asText,delete e.error,delete e.helperText,delete e.inputClass,delete e.success,e}),x=h(()=>t.minlength??(t.checkPasswordStrength?g?.minLength:void 0)??void 0);async function B(){if(t.checkPasswordStrength)try{const{data:e}=await F.post(E("apps/password_policy/api/v1/validate"),{password:s.value});if(r.value=e.ocs.data.passed,e.ocs.data.passed){i.value=n("Password is secure"),d("valid");return}i.value=e.ocs.data.reason,d("invalid")}catch(e){V.error("Password policy returned an error",{error:e})}}function T(){a.value=!a.value}function _(e){u.value.focus(e)}function k(){u.value.select()}return(e,p)=>(H(),z(J,U(b.value,{ref:"inputField",modelValue:s.value,"onUpdate:modelValue":p[0]||(p[0]=P=>s.value=P),error:e.error||r.value===!1,"helper-text":e.helperText||i.value,"input-class":[e.inputClass,{"password-field__input--secure-text":!a.value&&e.asText}],minlength:x.value,success:e.success||r.value===!0,"trailing-button-label":a.value?l(n)("Hide password"):l(n)("Show password"),type:a.value||e.asText?"text":"password",onTrailingButtonClick:T}),I({"trailing-button-icon":f(()=>[O(S,{path:a.value?l(C):l(N)},null,8,["path"])]),_:2},[e.$slots.icon?{name:"icon",fn:f(()=>[L(e.$slots,"icon",{},void 0,!0)]),key:"0"}:void 0]),1040,["modelValue","error","helper-text","input-class","minlength","success","trailing-button-label","type"]))}}),ee=D(K,[["__scopeId","data-v-b2684de6"]]);export{ee as N};
|
||||
//# sourceMappingURL=NcPasswordField-djttkA5Q-BxuGevvX.chunk.mjs.map
|
||||
import{l as V,N as S,m as C,a as N}from"./NcNoteCard-CVhtNL04-CL6uGjhw.chunk.mjs";import{c as F}from"./index-E0dOMeMP.chunk.mjs";import{j as M,m as c,u as v,k as $,n as j,p as q,q as m,s as h,c as z,o as H,v as I,w as f,x as L,b as O,y as l,z as U}from"./mdi-BjfN1ic1.chunk.mjs";import{r as A,a as D,g as E,t as n}from"./_plugin-vue_export-helper-B5bm_3R2.chunk.mjs";import{d as G}from"./string_decoder-mL5xNZ9K.chunk.mjs";import{N as J}from"./NcInputField-Bwsh2aHY-D1wb04Qy.chunk.mjs";A();const K=M({__name:"NcPasswordField",props:c({class:{},inputClass:{default:""},id:{},label:{},labelOutside:{type:Boolean},placeholder:{},showTrailingButton:{type:Boolean,default:!0},success:{type:Boolean},error:{type:Boolean},helperText:{},disabled:{type:Boolean},pill:{type:Boolean},checkPasswordStrength:{type:Boolean},minlength:{default:void 0},asText:{type:Boolean}},{modelValue:{default:""},modelModifiers:{},visible:{type:Boolean,default:!1},visibleModifiers:{}}),emits:c(["valid","invalid"],["update:modelValue","update:visible"]),setup(o,{expose:y,emit:w}){const s=v(o,"modelValue"),a=v(o,"visible"),t=o,d=w;$(s,G(B,500)),y({focus:_,select:k});const{password_policy:g}=j(),u=q("inputField"),i=m(""),r=m(),b=h(()=>{const e={...t};return delete e.checkPasswordStrength,delete e.minlength,delete e.asText,delete e.error,delete e.helperText,delete e.inputClass,delete e.success,e}),x=h(()=>t.minlength??(t.checkPasswordStrength?g?.minLength:void 0)??void 0);async function B(){if(t.checkPasswordStrength)try{const{data:e}=await F.post(E("apps/password_policy/api/v1/validate"),{password:s.value});if(r.value=e.ocs.data.passed,e.ocs.data.passed){i.value=n("Password is secure"),d("valid");return}i.value=e.ocs.data.reason,d("invalid")}catch(e){V.error("Password policy returned an error",{error:e})}}function T(){a.value=!a.value}function _(e){u.value.focus(e)}function k(){u.value.select()}return(e,p)=>(H(),z(J,U(b.value,{ref:"inputField",modelValue:s.value,"onUpdate:modelValue":p[0]||(p[0]=P=>s.value=P),error:e.error||r.value===!1,"helper-text":e.helperText||i.value,"input-class":[e.inputClass,{"password-field__input--secure-text":!a.value&&e.asText}],minlength:x.value,success:e.success||r.value===!0,"trailing-button-label":a.value?l(n)("Hide password"):l(n)("Show password"),type:a.value||e.asText?"text":"password",onTrailingButtonClick:T}),I({"trailing-button-icon":f(()=>[O(S,{path:a.value?l(C):l(N)},null,8,["path"])]),_:2},[e.$slots.icon?{name:"icon",fn:f(()=>[L(e.$slots,"icon",{},void 0,!0)]),key:"0"}:void 0]),1040,["modelValue","error","helper-text","input-class","minlength","success","trailing-button-label","type"]))}}),ee=D(K,[["__scopeId","data-v-b2684de6"]]);export{ee as N};
|
||||
//# sourceMappingURL=NcPasswordField-djttkA5Q-BcZFsl0T.chunk.mjs.map
|
||||
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
|
|
@ -1,4 +1,4 @@
|
|||
import{c as T}from"./index-BOuI_nzB.chunk.mjs";import{j as p,m as q,u as g,s as o,k as h,n as w,E as f,F as x,o as m,G as y}from"./mdi-B9XVyi7B.chunk.mjs";import{r as l,c as b,a as D,t as s,g as B}from"./_plugin-vue_export-helper-CDPKodk-.chunk.mjs";import{l as I}from"./NcNoteCard-CVhtNL04-BSciYEDO.chunk.mjs";const S=`<!--
|
||||
import{c as T}from"./index-E0dOMeMP.chunk.mjs";import{j as p,m as q,u as g,s as o,k as h,n as w,E as f,F as x,o as m,G as y}from"./mdi-BjfN1ic1.chunk.mjs";import{r as l,c as b,a as D,t as s,g as B}from"./_plugin-vue_export-helper-B5bm_3R2.chunk.mjs";import{l as I}from"./NcNoteCard-CVhtNL04-CL6uGjhw.chunk.mjs";const S=`<!--
|
||||
- SPDX-FileCopyrightText: 2020 Google Inc.
|
||||
- SPDX-License-Identifier: Apache-2.0
|
||||
-->
|
||||
|
|
@ -44,4 +44,4 @@ import{c as T}from"./index-BOuI_nzB.chunk.mjs";import{j as p,m as q,u as g,s as
|
|||
d="m424-296 282-282-56-56-226 226-114-114-56 56 170 170Zm56 216q-83 0-156-31.5T197-197q-54-54-85.5-127T80-480q0-83 31.5-156T197-763q54-54 127-85.5T480-880q83 0 156 31.5T763-763q54 54 85.5 127T880-480q0 83-31.5 156T763-197q-54 54-127 85.5T480-80Z"/>
|
||||
</svg>
|
||||
`;l(),l(b);function M(a){switch(a){case"away":return s("away");case"busy":return s("busy");case"dnd":return s("do not disturb");case"online":return s("online");case"invisible":return s("invisible");case"offline":return s("offline");default:return a}}const L=["aria-hidden","aria-label","innerHTML"],C=p({__name:"NcUserStatusIcon",props:q({user:{default:void 0},ariaHidden:{type:[Boolean,String],default:!1}},{status:{},statusModifiers:{}}),emits:["update:status"],setup(a){const e=g(a,"status"),i=a,c=o(()=>e.value&&["invisible","offline"].includes(e.value)),n=o(()=>e.value&&(!i.ariaHidden||i.ariaHidden==="false")?s("User status: {status}",{status:M(e.value)}):void 0);h(()=>i.user,async r=>{if(!e.value&&r&&w()?.user_status?.enabled)try{const{data:t}=await T.get(B("/apps/user_status/api/v1/statuses/{user}",{user:r}));e.value=t.ocs?.data?.status}catch(t){I.debug("Error while fetching user status",{error:t})}},{immediate:!0});const v={online:Z,away:S,busy:P,dnd:X,invisible:u,offline:u},d=o(()=>e.value&&v[e.value]);return(r,t)=>e.value?(m(),f("span",{key:0,class:y(["user-status-icon",{"user-status-icon--invisible":c.value}]),"aria-hidden":!n.value||void 0,"aria-label":n.value,role:"img",innerHTML:d.value},null,10,L)):x("",!0)}}),A=D(C,[["__scopeId","data-v-881a79fb"]]);export{A as N,M as g};
|
||||
//# sourceMappingURL=NcUserStatusIcon-CGEf7fej-CrSZFJV_.chunk.mjs.map
|
||||
//# sourceMappingURL=NcUserStatusIcon-CGEf7fej-knVeRP-B.chunk.mjs.map
|
||||
File diff suppressed because one or more lines are too long
|
|
@ -1,2 +1,2 @@
|
|||
import{a as p,_ as u}from"./_plugin-vue_export-helper-CDPKodk-.chunk.mjs";import{j as g,s as h,E as e,o as l,H as r,F as s,f as o,z as f}from"./mdi-B9XVyi7B.chunk.mjs";const m=["aria-label"],v=["width","height"],L=["fill"],C=["fill"],k={key:0},z=g({__name:"NcLoadingIcon",props:{appearance:{default:"auto"},name:{default:""},size:{default:20}},setup(n){const t=n,a=h(()=>{const i=["#777","#CCC"];return t.appearance==="light"?i:t.appearance==="dark"?i.reverse():["var(--color-loading-light)","var(--color-loading-dark)"]});return(i,c)=>(l(),e("span",{"aria-label":i.name,role:"img",class:"material-design-icon loading-icon"},[(l(),e("svg",{width:i.size,height:i.size,viewBox:"0 0 24 24"},[r("path",{fill:a.value[0],d:"M12,4V2A10,10 0 1,0 22,12H20A8,8 0 1,1 12,4Z"},null,8,L),r("path",{fill:a.value[1],d:"M12,4V2A10,10 0 0,1 22,12H20A8,8 0 0,0 12,4Z"},[i.name?(l(),e("title",k,o(i.name),1)):s("",!0)],8,C)],8,v))],8,m))}}),N=p(z,[["__scopeId","data-v-cf399190"]]),_={name:"PencilOutlineIcon",emits:["click"],props:{title:{type:String},fillColor:{type:String,default:"currentColor"},size:{type:Number,default:24}}},w=["aria-hidden","aria-label"],b=["fill","width","height"],y={d:"M14.06,9L15,9.94L5.92,19H5V18.08L14.06,9M17.66,3C17.41,3 17.15,3.1 16.96,3.29L15.13,5.12L18.88,8.87L20.71,7.04C21.1,6.65 21.1,6 20.71,5.63L18.37,3.29C18.17,3.09 17.92,3 17.66,3M14.06,6.19L3,17.25V21H6.75L17.81,9.94L14.06,6.19Z"},H={key:0};function M(n,t,a,i,c,A){return l(),e("span",f(n.$attrs,{"aria-hidden":a.title?null:"true","aria-label":a.title,class:"material-design-icon pencil-outline-icon",role:"img",onClick:t[0]||(t[0]=d=>n.$emit("click",d))}),[(l(),e("svg",{fill:a.fillColor,class:"material-design-icon__svg",width:a.size,height:a.size,viewBox:"0 0 24 24"},[r("path",y,[a.title?(l(),e("title",H,o(a.title),1)):s("",!0)])],8,b))],16,w)}const B=u(_,[["render",M]]);export{N,B as P};
|
||||
//# sourceMappingURL=PencilOutline-BWbwYeLs.chunk.mjs.map
|
||||
import{a as p,_ as u}from"./_plugin-vue_export-helper-B5bm_3R2.chunk.mjs";import{j as g,s as h,E as e,o as l,J as r,F as s,f as o,z as f}from"./mdi-BjfN1ic1.chunk.mjs";const m=["aria-label"],v=["width","height"],L=["fill"],C=["fill"],k={key:0},z=g({__name:"NcLoadingIcon",props:{appearance:{default:"auto"},name:{default:""},size:{default:20}},setup(n){const t=n,a=h(()=>{const i=["#777","#CCC"];return t.appearance==="light"?i:t.appearance==="dark"?i.reverse():["var(--color-loading-light)","var(--color-loading-dark)"]});return(i,c)=>(l(),e("span",{"aria-label":i.name,role:"img",class:"material-design-icon loading-icon"},[(l(),e("svg",{width:i.size,height:i.size,viewBox:"0 0 24 24"},[r("path",{fill:a.value[0],d:"M12,4V2A10,10 0 1,0 22,12H20A8,8 0 1,1 12,4Z"},null,8,L),r("path",{fill:a.value[1],d:"M12,4V2A10,10 0 0,1 22,12H20A8,8 0 0,0 12,4Z"},[i.name?(l(),e("title",k,o(i.name),1)):s("",!0)],8,C)],8,v))],8,m))}}),N=p(z,[["__scopeId","data-v-cf399190"]]),_={name:"PencilOutlineIcon",emits:["click"],props:{title:{type:String},fillColor:{type:String,default:"currentColor"},size:{type:Number,default:24}}},w=["aria-hidden","aria-label"],b=["fill","width","height"],y={d:"M14.06,9L15,9.94L5.92,19H5V18.08L14.06,9M17.66,3C17.41,3 17.15,3.1 16.96,3.29L15.13,5.12L18.88,8.87L20.71,7.04C21.1,6.65 21.1,6 20.71,5.63L18.37,3.29C18.17,3.09 17.92,3 17.66,3M14.06,6.19L3,17.25V21H6.75L17.81,9.94L14.06,6.19Z"},M={key:0};function A(n,t,a,i,c,H){return l(),e("span",f(n.$attrs,{"aria-hidden":a.title?null:"true","aria-label":a.title,class:"material-design-icon pencil-outline-icon",role:"img",onClick:t[0]||(t[0]=d=>n.$emit("click",d))}),[(l(),e("svg",{fill:a.fillColor,class:"material-design-icon__svg",width:a.size,height:a.size,viewBox:"0 0 24 24"},[r("path",y,[a.title?(l(),e("title",M,o(a.title),1)):s("",!0)])],8,b))],16,w)}const B=u(_,[["render",A]]);export{N,B as P};
|
||||
//# sourceMappingURL=PencilOutline-DvuO9fyo.chunk.mjs.map
|
||||
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
|
|
@ -1,2 +1,2 @@
|
|||
import{N as f,k as b,n as k,o as w}from"./NcNoteCard-CVhtNL04-BSciYEDO.chunk.mjs";import{r as x,t as c,_ as C}from"./_plugin-vue_export-helper-CDPKodk-.chunk.mjs";import{N as h}from"./NcInputField-Bwsh2aHY-kbXSi5f0.chunk.mjs";import{j as _,m as I,u as M,p as O,s as j,c as d,o as l,v as z,w as g,x as E,y as a,z as y,E as p,H as F,F as N,f as S}from"./mdi-B9XVyi7B.chunk.mjs";x();const q=_({__name:"NcTextField",props:I({class:{},inputClass:{},id:{},label:{},labelOutside:{type:Boolean},type:{},placeholder:{},showTrailingButton:{type:Boolean},trailingButtonLabel:{default:void 0},success:{type:Boolean},error:{type:Boolean},helperText:{},disabled:{type:Boolean},pill:{type:Boolean},trailingButtonIcon:{default:"close"}},{modelValue:{default:""},modelModifiers:{}}),emits:["update:modelValue"],setup(o,{expose:i}){const e=M(o,"modelValue"),s=o;i({focus:B,select:v});const r=O("inputField"),m={arrowEnd:c("Save changes"),close:c("Clear text"),undo:c("Undo changes")},u=new Set(Object.keys(h.props)),V=j(()=>{const t=Object.fromEntries(Object.entries(s).filter(([n])=>u.has(n)));return t.trailingButtonLabel??=m[s.trailingButtonIcon],t});function B(t){r.value.focus(t)}function v(){r.value.select()}return(t,n)=>(l(),d(a(h),y(V.value,{ref:"inputField",modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=H=>e.value=H)}),z({_:2},[t.$slots.icon?{name:"icon",fn:g(()=>[E(t.$slots,"icon")]),key:"0"}:void 0,t.type!=="search"?{name:"trailing-button-icon",fn:g(()=>[t.trailingButtonIcon==="arrowEnd"?(l(),d(a(f),{key:0,directional:"",path:a(b)},null,8,["path"])):(l(),d(a(f),{key:1,path:t.trailingButtonIcon==="undo"?a(k):a(w)},null,8,["path"]))]),key:"1"}:void 0]),1040,["modelValue"]))}}),T={name:"TrashCanOutlineIcon",emits:["click"],props:{title:{type:String},fillColor:{type:String,default:"currentColor"},size:{type:Number,default:24}}},$=["aria-hidden","aria-label"],A=["fill","width","height"],L={d:"M9,3V4H4V6H5V19A2,2 0 0,0 7,21H17A2,2 0 0,0 19,19V6H20V4H15V3H9M7,6H17V19H7V6M9,8V17H11V8H9M13,8V17H15V8H13Z"},U={key:0};function D(o,i,e,s,r,m){return l(),p("span",y(o.$attrs,{"aria-hidden":e.title?null:"true","aria-label":e.title,class:"material-design-icon trash-can-outline-icon",role:"img",onClick:i[0]||(i[0]=u=>o.$emit("click",u))}),[(l(),p("svg",{fill:e.fillColor,class:"material-design-icon__svg",width:e.size,height:e.size,viewBox:"0 0 24 24"},[F("path",L,[e.title?(l(),p("title",U,S(e.title),1)):N("",!0)])],8,A))],16,$)}const G=C(T,[["render",D]]);export{G as D,q as _};
|
||||
//# sourceMappingURL=TrashCanOutline-u_08oBcy.chunk.mjs.map
|
||||
import{N as f,k as H,n as k,o as w}from"./NcNoteCard-CVhtNL04-CL6uGjhw.chunk.mjs";import{r as x,t as c,_ as C}from"./_plugin-vue_export-helper-B5bm_3R2.chunk.mjs";import{N as h}from"./NcInputField-Bwsh2aHY-D1wb04Qy.chunk.mjs";import{j as _,m as I,u as M,p as O,s as j,c as d,o as l,v as z,w as g,x as E,y as a,z as y,E as p,J as F,F as N,f as S}from"./mdi-BjfN1ic1.chunk.mjs";x();const Z=_({__name:"NcTextField",props:I({class:{},inputClass:{},id:{},label:{},labelOutside:{type:Boolean},type:{},placeholder:{},showTrailingButton:{type:Boolean},trailingButtonLabel:{default:void 0},success:{type:Boolean},error:{type:Boolean},helperText:{},disabled:{type:Boolean},pill:{type:Boolean},trailingButtonIcon:{default:"close"}},{modelValue:{default:""},modelModifiers:{}}),emits:["update:modelValue"],setup(o,{expose:i}){const e=M(o,"modelValue"),s=o;i({focus:B,select:v});const r=O("inputField"),m={arrowEnd:c("Save changes"),close:c("Clear text"),undo:c("Undo changes")},u=new Set(Object.keys(h.props)),V=j(()=>{const t=Object.fromEntries(Object.entries(s).filter(([n])=>u.has(n)));return t.trailingButtonLabel??=m[s.trailingButtonIcon],t});function B(t){r.value.focus(t)}function v(){r.value.select()}return(t,n)=>(l(),d(a(h),y(V.value,{ref:"inputField",modelValue:e.value,"onUpdate:modelValue":n[0]||(n[0]=b=>e.value=b)}),z({_:2},[t.$slots.icon?{name:"icon",fn:g(()=>[E(t.$slots,"icon")]),key:"0"}:void 0,t.type!=="search"?{name:"trailing-button-icon",fn:g(()=>[t.trailingButtonIcon==="arrowEnd"?(l(),d(a(f),{key:0,directional:"",path:a(H)},null,8,["path"])):(l(),d(a(f),{key:1,path:t.trailingButtonIcon==="undo"?a(k):a(w)},null,8,["path"]))]),key:"1"}:void 0]),1040,["modelValue"]))}}),T={name:"TrashCanOutlineIcon",emits:["click"],props:{title:{type:String},fillColor:{type:String,default:"currentColor"},size:{type:Number,default:24}}},$=["aria-hidden","aria-label"],A=["fill","width","height"],L={d:"M9,3V4H4V6H5V19A2,2 0 0,0 7,21H17A2,2 0 0,0 19,19V6H20V4H15V3H9M7,6H17V19H7V6M9,8V17H11V8H9M13,8V17H15V8H13Z"},U={key:0};function D(o,i,e,s,r,m){return l(),p("span",y(o.$attrs,{"aria-hidden":e.title?null:"true","aria-label":e.title,class:"material-design-icon trash-can-outline-icon",role:"img",onClick:i[0]||(i[0]=u=>o.$emit("click",u))}),[(l(),p("svg",{fill:e.fillColor,class:"material-design-icon__svg",width:e.size,height:e.size,viewBox:"0 0 24 24"},[F("path",L,[e.title?(l(),p("title",U,S(e.title),1)):N("",!0)])],8,A))],16,$)}const q=C(T,[["render",D]]);export{q as D,Z as _};
|
||||
//# sourceMappingURL=TrashCanOutline-BhnCuc8B.chunk.mjs.map
|
||||
File diff suppressed because one or more lines are too long
|
|
@ -1,2 +1,2 @@
|
|||
import{_ as s}from"./_plugin-vue_export-helper-CDPKodk-.chunk.mjs";import{E as t,o as l,H as o,F as n,f as c,z as d}from"./mdi-B9XVyi7B.chunk.mjs";const k='<svg xmlns="http://www.w3.org/2000/svg" id="mdi-check" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z" /></svg>',g={name:"TrayArrowDownIcon",emits:["click"],props:{title:{type:String},fillColor:{type:String,default:"currentColor"},size:{type:Number,default:24}}},m=["aria-hidden","aria-label"],h=["fill","width","height"],p={d:"M2 12H4V17H20V12H22V17C22 18.11 21.11 19 20 19H4C2.9 19 2 18.11 2 17V12M12 15L17.55 9.54L16.13 8.13L13 11.25V2H11V11.25L7.88 8.13L6.46 9.55L12 15Z"},w={key:0};function L(r,a,i,f,u,v){return l(),t("span",d(r.$attrs,{"aria-hidden":i.title?null:"true","aria-label":i.title,class:"material-design-icon tray-arrow-down-icon",role:"img",onClick:a[0]||(a[0]=e=>r.$emit("click",e))}),[(l(),t("svg",{fill:i.fillColor,class:"material-design-icon__svg",width:i.size,height:i.size,viewBox:"0 0 24 24"},[o("path",p,[i.title?(l(),t("title",w,c(i.title),1)):n("",!0)])],8,h))],16,m)}const y=s(g,[["render",L]]);export{y as D,k as s};
|
||||
//# sourceMappingURL=TrayArrowDown-BCxZJuTJ.chunk.mjs.map
|
||||
import{_ as s}from"./_plugin-vue_export-helper-B5bm_3R2.chunk.mjs";import{E as t,o as l,J as o,F as n,f as c,z as d}from"./mdi-BjfN1ic1.chunk.mjs";const k='<svg xmlns="http://www.w3.org/2000/svg" id="mdi-check" viewBox="0 0 24 24"><path d="M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z" /></svg>',g={name:"TrayArrowDownIcon",emits:["click"],props:{title:{type:String},fillColor:{type:String,default:"currentColor"},size:{type:Number,default:24}}},m=["aria-hidden","aria-label"],h=["fill","width","height"],p={d:"M2 12H4V17H20V12H22V17C22 18.11 21.11 19 20 19H4C2.9 19 2 18.11 2 17V12M12 15L17.55 9.54L16.13 8.13L13 11.25V2H11V11.25L7.88 8.13L6.46 9.55L12 15Z"},w={key:0};function L(r,a,i,f,u,v){return l(),t("span",d(r.$attrs,{"aria-hidden":i.title?null:"true","aria-label":i.title,class:"material-design-icon tray-arrow-down-icon",role:"img",onClick:a[0]||(a[0]=e=>r.$emit("click",e))}),[(l(),t("svg",{fill:i.fillColor,class:"material-design-icon__svg",width:i.size,height:i.size,viewBox:"0 0 24 24"},[o("path",p,[i.title?(l(),t("title",w,c(i.title),1)):n("",!0)])],8,h))],16,m)}const y=s(g,[["render",L]]);export{y as D,k as s};
|
||||
//# sourceMappingURL=TrayArrowDown-DgBWywGd.chunk.mjs.map
|
||||
|
|
@ -1 +1 @@
|
|||
{"version":3,"file":"TrayArrowDown-BCxZJuTJ.chunk.mjs","sources":["../node_modules/@mdi/svg/svg/check.svg?raw","../node_modules/vue-material-design-icons/TrayArrowDown.vue"],"sourcesContent":["export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" id=\\\"mdi-check\\\" viewBox=\\\"0 0 24 24\\\"><path d=\\\"M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z\\\" /></svg>\"","<template>\n <span v-bind=\"$attrs\"\n :aria-hidden=\"title ? null : 'true'\"\n :aria-label=\"title\"\n class=\"material-design-icon tray-arrow-down-icon\"\n role=\"img\"\n @click=\"$emit('click', $event)\">\n <svg :fill=\"fillColor\"\n class=\"material-design-icon__svg\"\n :width=\"size\"\n :height=\"size\"\n viewBox=\"0 0 24 24\">\n <path d=\"M2 12H4V17H20V12H22V17C22 18.11 21.11 19 20 19H4C2.9 19 2 18.11 2 17V12M12 15L17.55 9.54L16.13 8.13L13 11.25V2H11V11.25L7.88 8.13L6.46 9.55L12 15Z\">\n <title v-if=\"title\">{{ title }}</title>\n </path>\n </svg>\n </span>\n</template>\n\n<script>\nexport default {\n name: \"TrayArrowDownIcon\",\n emits: ['click'],\n props: {\n title: {\n type: String,\n },\n fillColor: {\n type: String,\n default: \"currentColor\"\n },\n size: {\n type: Number,\n default: 24\n }\n }\n}\n</script>"],"names":["svgCheck","_sfc_main","_hoisted_3","_createElementBlock","_mergeProps","_ctx","$props","_cache","$event","_createElementVNode","_openBlock"],"mappings":"mJAAA,MAAAA,EAAe,wJCoBVC,EAAU,CACb,KAAM,oBACN,MAAO,CAAC,OAAO,EACf,MAAO,CACL,MAAO,CACL,KAAM,QAER,UAAW,CACT,KAAM,OACN,QAAS,gBAEX,KAAM,CACJ,KAAM,OACN,QAAS,EACX,CACF,CACF,6DAxBYC,EAAA,CAAA,EAAE,oJAAoJ,+CAXhKC,EAeO,OAfPC,EAAcC,EAAA,OAAM,CACb,cAAaC,EAAA,MAAK,KAAA,OAClB,aAAYA,EAAA,MACb,MAAM,4CACN,KAAK,MACJ,QAAKC,EAAA,CAAA,IAAAA,EAAA,CAAA,EAAAC,GAAEH,EAAA,MAAK,QAAUG,CAAM,WACjCL,EAQM,MAAA,CARA,KAAMG,EAAA,UACP,MAAM,4BACL,MAAOA,EAAA,KACP,OAAQA,EAAA,KACT,QAAQ,cACXG,EAEO,OAFPP,EAEO,CADQI,EAAA,OAAbI,EAAA,EAAAP,EAAuC,YAAhBG,EAAA,KAAK,EAAA,CAAA","x_google_ignoreList":[0,1]}
|
||||
{"version":3,"file":"TrayArrowDown-DgBWywGd.chunk.mjs","sources":["../node_modules/@mdi/svg/svg/check.svg?raw","../node_modules/vue-material-design-icons/TrayArrowDown.vue"],"sourcesContent":["export default \"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\" id=\\\"mdi-check\\\" viewBox=\\\"0 0 24 24\\\"><path d=\\\"M21,7L9,19L3.5,13.5L4.91,12.09L9,16.17L19.59,5.59L21,7Z\\\" /></svg>\"","<template>\n <span v-bind=\"$attrs\"\n :aria-hidden=\"title ? null : 'true'\"\n :aria-label=\"title\"\n class=\"material-design-icon tray-arrow-down-icon\"\n role=\"img\"\n @click=\"$emit('click', $event)\">\n <svg :fill=\"fillColor\"\n class=\"material-design-icon__svg\"\n :width=\"size\"\n :height=\"size\"\n viewBox=\"0 0 24 24\">\n <path d=\"M2 12H4V17H20V12H22V17C22 18.11 21.11 19 20 19H4C2.9 19 2 18.11 2 17V12M12 15L17.55 9.54L16.13 8.13L13 11.25V2H11V11.25L7.88 8.13L6.46 9.55L12 15Z\">\n <title v-if=\"title\">{{ title }}</title>\n </path>\n </svg>\n </span>\n</template>\n\n<script>\nexport default {\n name: \"TrayArrowDownIcon\",\n emits: ['click'],\n props: {\n title: {\n type: String,\n },\n fillColor: {\n type: String,\n default: \"currentColor\"\n },\n size: {\n type: Number,\n default: 24\n }\n }\n}\n</script>"],"names":["svgCheck","_sfc_main","_hoisted_3","_createElementBlock","_mergeProps","_ctx","$props","_cache","$event","_createElementVNode","_openBlock"],"mappings":"mJAAA,MAAAA,EAAe,wJCoBVC,EAAU,CACb,KAAM,oBACN,MAAO,CAAC,OAAO,EACf,MAAO,CACL,MAAO,CACL,KAAM,QAER,UAAW,CACT,KAAM,OACN,QAAS,gBAEX,KAAM,CACJ,KAAM,OACN,QAAS,EACX,CACF,CACF,6DAxBYC,EAAA,CAAA,EAAE,oJAAoJ,+CAXhKC,EAeO,OAfPC,EAAcC,EAAA,OAAM,CACb,cAAaC,EAAA,MAAK,KAAA,OAClB,aAAYA,EAAA,MACb,MAAM,4CACN,KAAK,MACJ,QAAKC,EAAA,CAAA,IAAAA,EAAA,CAAA,EAAAC,GAAEH,EAAA,MAAK,QAAUG,CAAM,WACjCL,EAQM,MAAA,CARA,KAAMG,EAAA,UACP,MAAM,4BACL,MAAOA,EAAA,KACP,OAAQA,EAAA,KACT,QAAQ,cACXG,EAEO,OAFPP,EAEO,CADQI,EAAA,OAAbI,EAAA,EAAAP,EAAuC,YAAhBG,EAAA,KAAK,EAAA,CAAA","x_google_ignoreList":[0,1]}
|
||||
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
Some files were not shown because too many files have changed in this diff Show more
Loading…
Reference in a new issue