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

refactor(user_ldap): migrate jQuery UI of password renewal to Vue
This commit is contained in:
Ferdinand Thiessen 2026-01-12 22:56:09 +01:00 committed by GitHub
commit ac3d09d817
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
209 changed files with 393 additions and 1218 deletions

View file

@ -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
}

View file

@ -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; }

View file

@ -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"]'),
})
})

View file

@ -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)

View file

@ -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),
);
});

View file

@ -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',
);
}

View file

@ -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>

View 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')

View file

@ -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)

View file

@ -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 {

View 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>

View file

@ -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>

View file

@ -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: {

View file

@ -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

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

View 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))}

View 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

View 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

View 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

View file

@ -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

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

View file

@ -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

View file

@ -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

View file

@ -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

View file

@ -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

View file

@ -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

View file

@ -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]}

Some files were not shown because too many files have changed in this diff Show more