@digital-blueprint/formalize-app
Version:
[GitHub Repository](https://github.com/digital-blueprint/formalize-app) | [npmjs package](https://www.npmjs.com/package/@digital-blueprint/formalize-app) | [Unpkg CDN](https://unpkg.com/browse/@digital-blueprint/formalize-app/) | [Formalize Bundle](https:
318 lines (292 loc) • 54 kB
JavaScript
let e,t,s,r,i,a,o,n,l,c,A,d,m,u,h,p,b,g=e=>e;function f(e,t){var s=Object.keys(e);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(e);t&&(r=r.filter((function(t){return Object.getOwnPropertyDescriptor(e,t).enumerable}))),s.push.apply(s,r)}return s}function E(e){for(var t=1;t<arguments.length;t++){var s=null!=arguments[t]?arguments[t]:{};t%2?f(Object(s),!0).forEach((function(t){B(e,t,s[t])})):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(s)):f(Object(s)).forEach((function(t){Object.defineProperty(e,t,Object.getOwnPropertyDescriptor(s,t))}))}return e}function B(e,t,s){return(t=function(e){var t=function(e,t){if("object"!=typeof e||!e)return e;var s=e[Symbol.toPrimitive];if(void 0!==s){var r=s.call(e,t||"default");if("object"!=typeof r)return r;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===t?String:Number)(e)}
/*!
* License: LGPL-2.1-or-later
* Dependencies:
*
* @webcomponents/scoped-custom-element-registry: BSD-3-Clause
* @dbp-toolkit/app-shell: LGPL-2.1-or-later
* @dbp-toolkit/language-select: LGPL-2.1-or-later
* @dbp-toolkit/auth: LGPL-2.1-or-later
* @dbp-toolkit/theme-switcher: LGPL-2.1-or-later
* universal-router: MIT
* @dbp-toolkit/matomo: LGPL-2.1-or-later
* @dbp-toolkit/tabulator-table: LGPL-2.1-or-later
* xlsx: Apache-2.0
* jspdf-autotable: MIT
* xss: MIT
* cssfilter: MIT
* @dbp-toolkit/common: LGPL-2.1-or-later
* lit-html: BSD-3-Clause
*/(e,"string");return"symbol"==typeof t?t:t+""}(t))in e?Object.defineProperty(e,t,{value:s,enumerable:!0,configurable:!0,writable:!0}):e[t]=s,e}import{B as C,a as w,e as y,n as D}from"./shared/ref.Ds46LGIc.es.js";import{S as k,x as Q,i as I,j as x,A as L,w as U,I as S,g as q,d as K,e as v,y as N,z as j,l as J}from"./shared/notification.DekX2Yn_.es.js";import{e as R,D as F,f as W,c as O,d as V}from"./shared/enum.1OT3_9bb.es.js";import{P as H,s as M,$ as G,a as T,b as Y,f as Z,c as z}from"./shared/person-select.DccVd1jv.es.js";import{c as P}from"./shared/utils.CegV9Vgv.es.js";import{c as X}from"./shared/i18n.sFs-myza.es.js";import{e as $}from"./shared/error.CxyP7_gO.es.js";import"./shared/_commonjsHelpers.NVLIRKl0.es.js";class _ extends(k(R)){constructor(){super()}static get properties(){return E({},super.properties)}static get scopedElements(){return{"dbp-person-select":H}}handleInputValue(e){let t=e.target.getAttribute("data-object"),s=t?JSON.parse(t):null;if(null!=s){let e=`${s.givenName} ${s.familyName}`,t=`${s.localData.email}`;this.value=e+" "+t}else this.value="";this.dispatchEvent(new CustomEvent("change",{detail:{value:s},bubbles:!0}))}renderInput(){return Q(e||(e=g`
<div class="control">
<dbp-person-select
id="${0}-picker"
name="${0}Picker"
subscribe="lang, auth, entry-point-url"
@change="${0}"></dbp-person-select>
</div>
`),this.name,this.name,this.handleInputValue)}static get styles(){return[...super.styles,I(t||(t=g`
/* For some reasons the selector chevron was very large */
select:not(.select) {
background-size: 1em;
}
`))]}}x("dbp-person-select-element",_);class ee extends(k(L)){constructor(){super(),Object.assign(ee.prototype,$),this.auth={},this._i18n=X(),this.lang=this._i18n.language,this.entryPointUrl=null,this.$select=null,this.active=!1,this.selectId="course-select-"+U(24),this.value="",this.object=null,this.ignoreValueUpdate=!1,this.isSearching=!1,this.lastResult={},this.showReloadButton=!1,this.reloadButtonTitle="",this.disabled=!1,this._onDocumentClicked=this._onDocumentClicked.bind(this),M(window,G)}static get scopedElements(){return{"dbp-icon":S}}$(e){return G(this.shadowRoot.querySelector(e))}static get properties(){return E(E({},super.properties),{},{lang:{type:String},active:{type:Boolean,attribute:!1},entryPointUrl:{type:String,attribute:"entry-point-url"},value:{type:String},object:{type:Object,attribute:!1},showReloadButton:{type:Boolean,attribute:"show-reload-button"},reloadButtonTitle:{type:String,attribute:"reload-button-title"},auth:{type:Object},disabled:{type:Boolean,reflect:!0},name:{type:String},id:{type:String},required:{type:Boolean}})}clear(){this.object=null,G(this).attr("data-object",""),G(this).data("object",null),this.value="",G(this).attr("value",""),this.$select.val(null).trigger("change").trigger("select2:unselect")}connectedCallback(){super.connectedCallback(),document.addEventListener("click",this._onDocumentClicked),this.updateComplete.then((()=>{this.$select=this.$("#"+this.selectId),this.select2IsInitialized()||this.initSelect2()}))}disconnectedCallback(){document.removeEventListener("click",this._onDocumentClicked),super.disconnectedCallback()}_onDocumentClicked(e){if(!e.composedPath().includes(this)){const e=this.$("#"+this.selectId);e.length&&this.select2IsInitialized()&&e.select2("close")}}initSelect2(e=!1){const t=this._i18n,s=G(this);if(null===this.$select||null===this.entryPointUrl)return!1;const r=P(this.entryPointUrl,"/base/courses");return this.$select&&this.$select.hasClass("select2-hidden-accessible")&&(this.$select.select2("destroy"),this.$select.off("select2:select"),this.$select.off("select2:closing")),this.$select.select2({width:"100%",language:"de"===this.lang?T():Y(),minimumInputLength:2,placeholder:this.authenticated()?t.t("render-form.course-select.placeholder"):t.t("render-form.course-select.login-required"),dropdownParent:this.$("#course-select-dropdown"),ajax:{delay:500,url:r,contentType:"application/ld+json",beforeSend:e=>{e.setRequestHeader("Authorization","Bearer "+this.auth.token),e.setRequestHeader("Accept-Language",this.lang),this.isSearching=!0},data:e=>this.buildUrlData(this,e),processResults:e=>{this.$("#course-select-dropdown").addClass("select2-bug"),this.lastResult=e;let t=e["hydra:member"];const s=[];return t.forEach((e=>{s.push({id:e["@id"],text:this.formatCourse(this,e)})})),{results:s}},error:(e,t,s)=>{this.handleXhrError(e,t,s)},complete:(e,t)=>{this.isSearching=!1}}}).on("select2:select",(e=>{this.$("#course-select-dropdown").removeClass("select2-bug");const t=e.params.data.id;this.object=Z(t,this.lastResult),s.attr("data-object",JSON.stringify(this.object)),s.data("object",this.object),s.attr("value")!==t&&(this.ignoreValueUpdate=!0,s.attr("value",t),this.dispatchEvent(new CustomEvent("change",{detail:{value:t},bubbles:!0})))})).on("select2:closing",(e=>{this.isSearching&&e.preventDefault()})),!0}buildUrlData(e,t){return{search:t.term.replaceAll(".","").trim(),includeLocal:"teachingTerm,type"}}formatCourse(e,t){let s=`${t.code}: ${t.name} (${t.localData.type}, ${t.localData.teachingTerm})`;return null!=s?s:""}update(e){e.forEach(((e,t)=>{switch(t){case"lang":this._i18n.changeLanguage(this.lang),this.select2IsInitialized()&&this.initSelect2(!0);break;case"value":!this.ignoreValueUpdate&&this.select2IsInitialized()&&this.initSelect2(),this.ignoreValueUpdate=!1;break;case"entryPointUrl":this.initSelect2(!0);break;case"auth":this.active=this.authenticated(),!this.active||e&&e.token||this.initSelect2()}})),super.update(e)}select2IsInitialized(){return null!==this.$select&&this.$select.hasClass("select2-hidden-accessible")}reloadClick(){null!==this.object&&this.dispatchEvent(new CustomEvent("change",{detail:{value:this.value},bubbles:!0}))}authenticated(){return""!==(this.auth.token||"")}static get styles(){return[q(),K(),v(),N(),j(),I(s||(s=g`
#course-select-dropdown {
position: relative;
}
.select2-control.control {
width: 100%;
}
.field .button.control {
display: flex;
align-items: center;
justify-content: center;
border: var(--dbp-border);
border-color: var(--dbp-muted);
-moz-border-radius-topright: var(--dbp-border-radius);
-moz-border-radius-bottomright: var(--dbp-border-radius);
line-height: 100%;
}
.field .button.control dbp-icon {
top: 0;
}
/* https://github.com/select2/select2/issues/5457 */
.select2-bug .loading-results {
display: none !important;
}
.select2-results__option.loading-results,
{
background-image: url("")
background-repeat: no-repeat;
padding-left: 35px;
background-position: 10px 50%;
}
`))]}render(){const e=this._i18n,t=J(z);return Q(r||(r=g`
<link rel="stylesheet" href="${0}" />
<style>
#${0} {
width: 100%;
}
</style>
<div class="select">
<div class="field has-addons">
<div class="select2-control control">
<!-- https://select2.org-->
<select
id="${0}"
name="course"
class="select"
?disabled=${0}>
${0}
</select>
</div>
<a
class="control button"
id="reload-button"
?disabled=${0}
@click="${0}"
style="display: ${0}"
title="${0}">
<dbp-icon name="reload"></dbp-icon>
</a>
</div>
<div id="course-select-dropdown"></div>
</div>
`),t,this.selectId,this.selectId,!this.active||this.disabled,this.authenticated()?"":Q(i||(i=g`
<option value="" disabled selected>
${0}
</option>
`),e.t("render-form.course-select.login-required")),null===this.object,this.reloadClick,this.showReloadButton?"flex":"none",this.reloadButtonTitle)}}class te extends(k(L)){constructor(){super(),Object.assign(te.prototype,$),this.auth={},this._i18n=X(),this.lang=this._i18n.language,this.entryPointUrl=null,this.$select=null,this.active=!1,this.selectId="room-select-"+U(24),this.value="",this.object=null,this.ignoreValueUpdate=!1,this.isSearching=!1,this.lastResult={},this.showReloadButton=!1,this.reloadButtonTitle="",this.disabled=!1,this._onDocumentClicked=this._onDocumentClicked.bind(this),M(window,G)}static get scopedElements(){return{"dbp-icon":S}}$(e){return G(this.shadowRoot.querySelector(e))}static get properties(){return E(E({},super.properties),{},{lang:{type:String},active:{type:Boolean,attribute:!1},entryPointUrl:{type:String,attribute:"entry-point-url"},value:{type:String},object:{type:Object,attribute:!1},showReloadButton:{type:Boolean,attribute:"show-reload-button"},reloadButtonTitle:{type:String,attribute:"reload-button-title"},auth:{type:Object},disabled:{type:Boolean,reflect:!0},name:{type:String},id:{type:String},required:{type:Boolean}})}clear(){this.object=null,G(this).attr("data-object",""),G(this).data("object",null),this.value="",G(this).attr("value",""),this.$select.val(null).trigger("change").trigger("select2:unselect")}connectedCallback(){super.connectedCallback(),document.addEventListener("click",this._onDocumentClicked),this.updateComplete.then((()=>{this.$select=this.$("#"+this.selectId),this.select2IsInitialized()||this.initSelect2()}))}disconnectedCallback(){document.removeEventListener("click",this._onDocumentClicked),super.disconnectedCallback()}_onDocumentClicked(e){if(!e.composedPath().includes(this)){const e=this.$("#"+this.selectId);e.length&&this.select2IsInitialized()&&e.select2("close")}}initSelect2(e=!1){const t=this._i18n,s=this,r=G(this);if(null===this.$select||null===this.entryPointUrl)return!1;const i=P(this.entryPointUrl,"/base/rooms");return this.$select&&this.$select.hasClass("select2-hidden-accessible")&&(this.$select.select2("destroy"),this.$select.off("select2:select"),this.$select.off("select2:closing")),this.$select.select2({width:"100%",language:"de"===this.lang?T():Y(),minimumInputLength:2,placeholder:this.authenticated()?t.t("render-form.room-select.placeholder"):t.t("render-form.room-select.login-required"),dropdownParent:this.$("#room-select-dropdown"),ajax:{delay:500,url:i,contentType:"application/ld+json",beforeSend:function(e){e.setRequestHeader("Authorization","Bearer "+s.auth.token),s.isSearching=!0},data:e=>this.buildUrlData(this,e),processResults:function(e){s.$("#room-select-dropdown").addClass("select2-bug"),s.lastResult=e;let t=e["hydra:member"];const r=[];return t.forEach((e=>{r.push({id:e["@id"],text:s.formatRoom(s,e)})})),{results:r}},error:(e,t,s)=>{this.handleXhrError(e,t,s)},complete:(e,t)=>{s.isSearching=!1}}}).on("select2:select",(function(e){s.$("#room-select-dropdown").removeClass("select2-bug");const t=e.params.data.id;s.object=Z(t,s.lastResult),r.attr("data-object",JSON.stringify(s.object)),r.data("object",s.object),r.attr("value")!==t&&(s.ignoreValueUpdate=!0,r.attr("value",t),s.dispatchEvent(new CustomEvent("change",{detail:{value:t},bubbles:!0})))})).on("select2:closing",(e=>{s.isSearching&&e.preventDefault()})),!0}buildUrlData(e,t){return{search:t.term.trim()}}formatRoom(e,t){var s;return null!==(s=t.code)&&void 0!==s?s:""}update(e){e.forEach(((e,t)=>{switch(t){case"lang":this._i18n.changeLanguage(this.lang),this.select2IsInitialized()&&this.initSelect2(!0);break;case"value":!this.ignoreValueUpdate&&this.select2IsInitialized()&&this.initSelect2(),this.ignoreValueUpdate=!1;break;case"entryPointUrl":this.initSelect2(!0);break;case"auth":this.active=this.authenticated(),!this.active||e&&e.token||this.initSelect2()}})),super.update(e)}select2IsInitialized(){return null!==this.$select&&this.$select.hasClass("select2-hidden-accessible")}reloadClick(){null!==this.object&&this.dispatchEvent(new CustomEvent("change",{detail:{value:this.value},bubbles:!0}))}authenticated(){return""!==(this.auth.token||"")}static get styles(){return[q(),K(),v(),N(),j(),I(a||(a=g`
#room-select-dropdown {
position: relative;
}
.select2-control.control {
width: 100%;
}
.field .button.control {
display: flex;
align-items: center;
justify-content: center;
border: var(--dbp-border);
border-color: var(--dbp-muted);
-moz-border-radius-topright: var(--dbp-border-radius);
-moz-border-radius-bottomright: var(--dbp-border-radius);
line-height: 100%;
}
.field .button.control dbp-icon {
top: 0;
}
/* https://github.com/select2/select2/issues/5457 */
.select2-bug .loading-results {
display: none !important;
}
.select2-results__option.loading-results,
{
background-image: url("")
background-repeat: no-repeat;
padding-left: 35px;
background-position: 10px 50%;
}
`))]}render(){const e=this._i18n,t=J(z);return Q(o||(o=g`
<link rel="stylesheet" href="${0}" />
<style>
#${0} {
width: 100%;
}
</style>
<div class="select">
<div class="field has-addons">
<div class="select2-control control">
<!-- https://select2.org-->
<select
id="${0}"
name="room"
class="select"
?disabled=${0}>
${0}
</select>
</div>
<a
class="control button"
id="reload-button"
?disabled=${0}
@click="${0}"
style="display: ${0}"
title="${0}">
<dbp-icon name="reload"></dbp-icon>
</a>
</div>
<div id="room-select-dropdown"></div>
</div>
`),t,this.selectId,this.selectId,!this.active||this.disabled,this.authenticated()?"":Q(n||(n=g`
<option value="" disabled selected>
${0}
</option>
`),e.t("render-form.room-select.login-required")),null===this.object,this.reloadClick,this.showReloadButton?"flex":"none",this.reloadButtonTitle)}}class se extends(k(R)){constructor(){super(),this.entryPointUrl=null}static get properties(){return E(E({},super.properties),{},{entryPointUrl:{type:String,attribute:"entry-point-url"}})}static get scopedElements(){return{"dbp-course-select":ee}}async fetchGermanCourseData(e){const t=await fetch(this.entryPointUrl+e,{headers:{"Content-Type":"application/ld+json","Accept-Language":"de",Authorization:"Bearer "+this.auth.token}});if(!t.ok)return null;try{return await t.json()}catch(e){return null}}async handleInputValue(e){let t=JSON.parse(e.target.getAttribute("data-object"));if(null!=t){let e=t.localData.type,s=t.localData.teachingTerm;if("de"!==this.lang){const e=await this.fetchGermanCourseData(t["@id"]);null!=e&&(t=e)}let r=t.code,i=t.name;this.value=`${r}: ${i} (${e}, ${s})`}}renderInput(){return Q(l||(l=g`
<div class="control">
<dbp-course-select
id="${0}-picker"
name="${0}Picker"
subscribe="lang,auth,entry-point-url"
@change="${0}"></dbp-course-select>
</div>
`),this.name,this.name,this.handleInputValue)}static get styles(){return[...super.styles,I(c||(c=g`
/* For some reasons the selector chevron was very large */
select:not(.select) {
background-size: 1em;
}
`))]}}x("dbp-course-select-element",se);class re extends(k(R)){constructor(){super()}static get properties(){return E({},super.properties)}static get scopedElements(){return{"dbp-room-select":te}}handleInputValue(e){let t=JSON.parse(e.target.getAttribute("data-object"));null!=t&&(this.value=t.code)}renderInput(){return Q(A||(A=g`
<div class="control">
<dbp-room-select
id="${0}-picker"
name="${0}Picker"
subscribe="lang, auth, entry-point-url"
@change="${0}"></dbp-room-select>
</div>
`),this.name,this.name,this.handleInputValue)}static get styles(){return[...super.styles,I(d||(d=g`
/* For some reasons the selector chevron was very large */
select:not(.select) {
background-size: 1em;
}
`))]}}x("dbp-room-select-element",re);class ie extends C{getUrlSlug(){return"accessible-exams"}getFormComponent(){return ae}getFormIdentifier(){return"0193cfbd-9b68-703a-81f9-c10d0e2375b7"}}class ae extends w{constructor(){super(),this.submitted=!1,this.submissionError=!1,this.beginTimeRef=y(),this.examinerTextRef=y(),this.examinerTextDisabled=!1}static get properties(){return E(E({},super.properties),{},{submitted:{type:Boolean},submissionError:{type:Boolean},examinerTextDisabled:{type:Boolean}})}connectedCallback(){var e=this;super.connectedCallback(),this.updateComplete.then((()=>{this._("#examiner-picker-element")._("#examiner-picker").buildUrlData=function(e,t){return{search:t.term.trim(),includeLocal:"email",preparedFilter:"staffAccountsOnly"}},this._("#additional-examiner-picker-element")._("#additionalExaminer-picker").buildUrlData=function(e,t){return{search:t.term.trim(),includeLocal:"email",preparedFilter:"staffAccountsOnly"}},this.addEventListener("DbpFormalizeFormSubmission",(async function(t){const s=t.detail.formData;if(s.identifier=e.formData.identifier,e.createUUID(),s.uuid=e.formData.uuid,e.createExamID(),s.examid=e.formData.examid,s.examinerText)s.examiner=s.examinerText,s.email_examiner="",delete s.examinerText;else{var r,i;let t=e.getExaminerMail(s.examiner);s.examiner=null!==(r=t[0])&&void 0!==r?r:"",s.email_examiner=null!==(i=t[1])&&void 0!==i?i:""}let a=e.getExaminerMail(s.additionalExaminer);s.additionalExaminer=a[0],s.email_additionalExaminer=a[1],console.log("Form submission data:",s);try{if(e.isPostingSubmission=!0,e.wasSubmissionSuccessful)return;let t={form:"/formalize/forms/0193cfbd-9b68-703a-81f9-c10d0e2375b7",dataFeedElement:JSON.stringify(s)};const r=await fetch(e.entryPointUrl+"/formalize/submissions",{method:"POST",headers:{"Content-Type":"application/ld+json",Authorization:"Bearer "+e.auth.token},body:JSON.stringify(t)});if(!r.ok)throw e.submissionError=!0,e.saveButtonEnabled=!0,new Error(`Response status: ${r.status}`);return e.wasSubmissionSuccessful=!0,e.submissionError=!1,e._("#title").style.display="none",e._("#description").style.display="none",e._("#accessible-exams-form").style.display="none",e.submitted=e.wasSubmissionSuccessful,console.log(e.wasSubmissionSuccessful,r),r}catch(e){console.error(e.message)}finally{e.isPostingSubmission=!1}}))}))}static get scopedElements(){return{"dbp-form-string-element":V,"dbp-form-date-element":O,"dbp-form-time-element":W,"dbp-form-boolean-element":F,"dbp-course-select-element":se,"dbp-room-select-element":re,"dbp-course-select":ee,"dbp-room-select":te,"dbp-person-select-element":_,"dbp-person-select":H}}async fetchUserData(){console.log("Fetching user data ...");try{let e=await fetch(this.entryPointUrl+"/base/people/"+this.auth["user-id"]+"?includeLocal=email,matriculationNumber",{headers:{"Content-Type":"application/ld+json",Authorization:"Bearer "+this.auth.token}});if(!e.ok)throw new Error(e);this.formData=await e.json(),this.formData.identifier=`${this.formData.identifier}`,this.formData.givenName=`${this.formData.givenName}`,this.formData.familyName=`${this.formData.familyName}`,this.formData.matriculationNumber=`${this.formData.localData.matriculationNumber}`,this.formData.email_student=`${this.formData.localData.email}`}catch(e){console.error(e.message)}}createUUID(){let e=self.crypto.randomUUID();console.log("Created UUID: "+e),this.formData.uuid=e}createExamID(){let e=Math.floor(9e4*Math.random())+1e4;console.log("Created ExamID: "+e),this.formData.examid=e}getExaminerMail(e){const t=e.split(" ");return[t.slice(0,-1).join(" "),t[t.length-1]]}render(){const e=this._i18n;console.log("-- Render FormalizeFormElement --"),this.formData.givenName||this.formData.familyName||this.fetchUserData(),console.log("this.formData",this.formData);const t=this.formData||{};return Q(m||(m=g`
<h2 id="title">${0}</h2>
<p id="description">
${0}
<br />
${0}
</p>
<form id="accessible-exams-form">
<fieldset>
<legend>${0}</legend>
<dbp-course-select-element
subscribe="lang,auth,entry-point-url"
name="courseName"
label="${0}"
value=${0}
required></dbp-course-select-element>
<dbp-form-string-element
subscribe="lang"
name="differentTerm"
label=${0}
value=${0}
hidden></dbp-form-string-element>
<dbp-form-date-element
subscribe="lang"
name="date"
label=${0}
.min=${0}
.customValidator=${0}
value=${0}
required></dbp-form-date-element>
<dbp-form-time-element
${0}
subscribe="lang"
name="beginTime"
label=${0}
value=${0}
required></dbp-form-time-element>
<dbp-form-time-element
subscribe="lang"
name="endTime"
label=${0}
.customValidator=${0}
value=${0}
required></dbp-form-time-element>
<dbp-person-select-element
id="examiner-picker-element"
subscribe="lang"
name="examiner"
label=${0}
value=${0}
@change="${0}"
.customValidator=${0}></dbp-person-select-element>
<dbp-form-string-element
subscribe="lang"
${0}
name="examinerText"
label=${0}
value=${0}
?disabled=${0}
.customValidator=${0}></dbp-form-string-element>
<dbp-person-select-element
id="additional-examiner-picker-element"
subscribe="lang"
name="additionalExaminer"
label=${0}
value=${0}></dbp-person-select-element>
<dbp-room-select-element
subscribe="lang"
name="room"
label="${0}"
value=${0}
hidden></dbp-room-select-element>
<dbp-form-string-element
subscribe="lang"
name="comment"
label=${0}
value=${0}></dbp-form-string-element>
<dbp-form-boolean-element
subscribe="lang"
name="group"
label=${0}
hidden
.state=${0}></dbp-form-boolean-element>
<dbp-form-boolean-element
subscribe="lang"
name="online"
label=${0}
.state=${0}></dbp-form-boolean-element>
</fieldset>
<fieldset>
<legend>
${0}
</legend>
<dbp-form-string-element
subscribe="lang"
name="matriculationNumber"
label=${0}
value=${0}
disabled></dbp-form-string-element>
<dbp-form-string-element
subscribe="lang"
name="givenName"