profile-pane 3.1.2-8a70896f → 3.1.2-e3347eef
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/lib/profile-pane.min.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
!function(n,e){"object"==typeof exports&&"object"==typeof module?module.exports=e(require("UI"),require("SolidLogic"),require("rdflib")):"function"==typeof define&&define.amd?define(["UI","SolidLogic","rdflib"],e):"object"==typeof exports?exports.ProfilePane=e(require("UI"),require("SolidLogic"),require("rdflib")):n.ProfilePane=e(n.UI,n.SolidLogic,n.rdflib)}(this,(n,e,t)=>(()=>{var o={3955(n,e,t){var o;globalThis,o=(n,e,t)=>(()=>{"use strict";var o={903(n,e,t){t.d(e,{A:()=>s});var o=t(354),r=t.n(o),a=t(314),i=t.n(a)()(r());i.push([n.id,'/* Visually hidden utility for accessibility */\n.visually-hidden {\n position: absolute !important;\n height: 1px; width: 1px;\n overflow: hidden;\n clip: rect(1px, 1px, 1px, 1px);\n white-space: nowrap;\n border: 0;\n padding: 0;\n margin: -1px;\n}\n\n/* Focus indicator for keyboard navigation */\n.personRow:focus, .dataCell:focus, tr[tabindex="0"]:focus {\n outline: 2px solid #1976d2;\n outline-offset: 2px;\n background: #e3f2fd;\n}\n/* contactsPane styles — extracted from inline styles in contactsPane.js */\n/* Uses CSS custom properties from the global stylesheet (dev-global.css / mashlib) */\n\n/* ── Layout: Three-column browser ────────────────────────────── */\n\n.contactPane .bookTable {\n border-collapse: collapse;\n margin-right: 0;\n max-height: 9in;\n}\n\n.contactPane .groupsHeader {\n min-width: 10em;\n padding-bottom: 0.2em;\n}\n\n.contactPane .peopleHeader {\n min-width: 18em;\n}\n\n.contactPane .peopleMain {\n overflow: scroll;\n}\n\n.contactPane .cardMain {\n margin: 0;\n}\n\n.contactPane .groupsMain,\n.contactPane .groupsFooter {\n padding: 0.1em;\n}\n\n/* ── Search ──────────────────────────────────────────────────── */\n\n.contactPane .searchInput {\n border: 0.1em solid var(--color-text-muted);\n border-radius: var(--border-radius-base);\n width: 100%;\n font-size: var(--font-size-base);\n padding: 0.1em 0.6em;\n margin: 0.2em;\n}\n\n/* ── Data cells ──────────────────────────────────────────────── */\n\n.contactPane .dataCell {\n padding: 0.1em;\n}\n\n/* ── Rendered sub-pane ───────────────────────────────────────── */\n\n.contactPane .renderPane {\n border: 0.1em solid var(--color-text-muted);\n border-radius: var(--border-radius-base);\n}\n\n/* ── Delete button ───────────────────────────────────────────── */\n\n.contactPane .deleteButton {\n height: 2em;\n}\n\n/* ── Sharing button & icon ───────────────────────────────────── */\n\n.contactPane .sharingButton {\n padding: var(--spacing-md);\n margin: var(--spacing-md);\n}\n\n.contactPane .sharingButtonIcon {\n width: var(--spacing-lg);\n height: var(--spacing-lg);\n}\n\n/* ── "All" groups button ─────────────────────────────────────── */\n\n.contactPane .allGroupsButton {\n margin-left: var(--spacing-md);\n font-size: var(--font-size-base);\n}\n\n.contactPane .allGroupsButton--loading {\n background-color: #ff8;\n}\n\n.contactPane .allGroupsButton--active {\n background-color: var(--color-text);\n color: var(--color-background);\n}\n\n.contactPane .allGroupsButton--loaded {\n background-color: #cfc;\n}\n\n/* ── Selection & visibility states ───────────────────────────── */\n\n.contactPane .selected {\n background-color: #cce;\n}\n\n.contactPane .group-loading {\n background-color: #ffe;\n}\n\n.contactPane .hidden {\n display: none;\n}\n\n/* ── Mint new address book ───────────────────────────────────── */\n\n.contactPane .claimSuccess {\n font-size: 140%;\n}\n\n.contactPane .addressBook-grid {\n max-width: max-content;\n\n}\n\n.contactPane .addressBookSection {\n width: 100%;\n max-width: 100%;\n box-sizing: border-box;\n margin-bottom: var(--spacing-md);\n box-sizing: border-box;\n margin-bottom: var(--spacing-md);\n}\n\n@media (min-width: 900px) {\n .contactPane .addressBookSection {\n margin-bottom: 0;\n }\n}\n\n/* Section Title - primary colored heading */\n.contactPane .section-title {\n font-size: 1.25em;\n font-weight: 600;\n color: var(--color-primary);\n margin: 0;\n}\n\n/* Card Section Background */\n.contactPane .section-bg {\n background: var(--color-section-bg);\n border-radius: var(--border-radius-full);\n box-shadow: var(--box-shadow);\n padding: var(--spacing-md);\n}\n\n.contactPane td {\n border: 1px dotted #999;\n}\n\n/* Primary Button */\n.btn-primary {\n min-height: var(--min-touch-target);\n padding: var(--spacing-sm) var(--spacing-md);\n border: 1px solid var(--color-primary);\n border-radius: var(--border-radius-base);\n background: var(--color-primary);\n color: white;\n font-weight: 600;\n cursor: pointer;\n transition: all var(--animation-duration) ease;\n}\n\n.btn-primary:hover {\n background: color-mix(in srgb, var(--color-primary) 90%, black);\n box-shadow: 0 2px 4px rgba(124, 77, 255, 0.2);\n}\n\n.btn-primary:active {\n box-shadow: 0 1px 2px rgba(124, 77, 255, 0.2);\n}\n\n.btn-primary:disabled {\n opacity: 0.6;\n cursor: not-allowed;\n transform: none;\n}\n\n/* Secondary button */\n.btn-secondary {\n min-height: var(--min-touch-target);\n padding: var(--spacing-sm) var(--spacing-md);\n border: var(--border-width-thin) solid var(--color-secondary);\n border-radius: var(--border-radius-base);\n background: var(--color-secondary);\n color: var(--color-background);\n font-weight: var(--font-weight-bold);\n cursor: pointer;\n transition: all var(--animation-duration) ease;\n text-decoration: none;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n}\n\n.btn-secondary:hover {\n background: color-mix(in srgb, var(--color-secondary) 85%, black);\n}\n\n.btn-secondary:disabled {\n opacity: var(--opacity-disabled);\n cursor: not-allowed;\n}\n\n/* Action Button Focus - used by ChatWithMe, ProfileCard */\n.action-button-focus:focus,\n.action-button-focus:focus-visible {\n outline: 3px solid var(--color-primary) !important;\n outline-offset: 2px !important;\n box-shadow: 0 0 0 2px var(--color-background), 0 0 0 5px rgba(124, 77, 255, 0.25) !important;\n z-index: 1;\n}',"",{version:3,sources:["webpack://./src/styles/contactsPane.css"],names:[],mappings:"AAAA,8CAA8C;AAC9C;EACE,6BAA6B;EAC7B,WAAW,EAAE,UAAU;EACvB,gBAAgB;EAChB,8BAA8B;EAC9B,mBAAmB;EACnB,SAAS;EACT,UAAU;EACV,YAAY;AACd;;AAEA,4CAA4C;AAC5C;EACE,0BAA0B;EAC1B,mBAAmB;EACnB,mBAAmB;AACrB;AACA,0EAA0E;AAC1E,qFAAqF;;AAErF,mEAAmE;;AAEnE;EACE,yBAAyB;EACzB,eAAe;EACf,eAAe;AACjB;;AAEA;EACE,eAAe;EACf,qBAAqB;AACvB;;AAEA;EACE,eAAe;AACjB;;AAEA;EACE,gBAAgB;AAClB;;AAEA;EACE,SAAS;AACX;;AAEA;;EAEE,cAAc;AAChB;;AAEA,mEAAmE;;AAEnE;EACE,2CAA2C;EAC3C,wCAAwC;EACxC,WAAW;EACX,gCAAgC;EAChC,oBAAoB;EACpB,aAAa;AACf;;AAEA,mEAAmE;;AAEnE;EACE,cAAc;AAChB;;AAEA,mEAAmE;;AAEnE;EACE,2CAA2C;EAC3C,wCAAwC;AAC1C;;AAEA,mEAAmE;;AAEnE;EACE,WAAW;AACb;;AAEA,mEAAmE;;AAEnE;EACE,0BAA0B;EAC1B,yBAAyB;AAC3B;;AAEA;EACE,wBAAwB;EACxB,yBAAyB;AAC3B;;AAEA,mEAAmE;;AAEnE;EACE,8BAA8B;EAC9B,gCAAgC;AAClC;;AAEA;EACE,sBAAsB;AACxB;;AAEA;EACE,mCAAmC;EACnC,8BAA8B;AAChC;;AAEA;EACE,sBAAsB;AACxB;;AAEA,mEAAmE;;AAEnE;EACE,sBAAsB;AACxB;;AAEA;EACE,sBAAsB;AACxB;;AAEA;EACE,aAAa;AACf;;AAEA,mEAAmE;;AAEnE;EACE,eAAe;AACjB;;AAEA;EACE,sBAAsB;;AAExB;;AAEA;EACE,WAAW;EACX,eAAe;EACf,sBAAsB;EACtB,gCAAgC;EAChC,sBAAsB;EACtB,gCAAgC;AAClC;;AAEA;EACE;IACE,gBAAgB;EAClB;AACF;;AAEA,4CAA4C;AAC5C;EACE,iBAAiB;EACjB,gBAAgB;EAChB,2BAA2B;EAC3B,SAAS;AACX;;AAEA,4BAA4B;AAC5B;EACE,mCAAmC;EACnC,wCAAwC;EACxC,6BAA6B;EAC7B,0BAA0B;AAC5B;;AAEA;EACE,uBAAuB;AACzB;;AAEA,mBAAmB;AACnB;EACE,mCAAmC;EACnC,4CAA4C;EAC5C,sCAAsC;EACtC,wCAAwC;EACxC,gCAAgC;EAChC,YAAY;EACZ,gBAAgB;EAChB,eAAe;EACf,8CAA8C;AAChD;;AAEA;EACE,+DAA+D;EAC/D,6CAA6C;AAC/C;;AAEA;EACE,6CAA6C;AAC/C;;AAEA;EACE,YAAY;EACZ,mBAAmB;EACnB,eAAe;AACjB;;AAEA,qBAAqB;AACrB;EACE,mCAAmC;EACnC,4CAA4C;EAC5C,6DAA6D;EAC7D,wCAAwC;EACxC,kCAAkC;EAClC,8BAA8B;EAC9B,oCAAoC;EACpC,eAAe;EACf,8CAA8C;EAC9C,qBAAqB;EACrB,oBAAoB;EACpB,mBAAmB;EACnB,uBAAuB;AACzB;;AAEA;EACE,iEAAiE;AACnE;;AAEA;EACE,gCAAgC;EAChC,mBAAmB;AACrB;;AAEA,0DAA0D;AAC1D;;EAEE,kDAAkD;EAClD,8BAA8B;EAC9B,4FAA4F;EAC5F,UAAU;AACZ",sourcesContent:['/* Visually hidden utility for accessibility */\n.visually-hidden {\n position: absolute !important;\n height: 1px; width: 1px;\n overflow: hidden;\n clip: rect(1px, 1px, 1px, 1px);\n white-space: nowrap;\n border: 0;\n padding: 0;\n margin: -1px;\n}\n\n/* Focus indicator for keyboard navigation */\n.personRow:focus, .dataCell:focus, tr[tabindex="0"]:focus {\n outline: 2px solid #1976d2;\n outline-offset: 2px;\n background: #e3f2fd;\n}\n/* contactsPane styles — extracted from inline styles in contactsPane.js */\n/* Uses CSS custom properties from the global stylesheet (dev-global.css / mashlib) */\n\n/* ── Layout: Three-column browser ────────────────────────────── */\n\n.contactPane .bookTable {\n border-collapse: collapse;\n margin-right: 0;\n max-height: 9in;\n}\n\n.contactPane .groupsHeader {\n min-width: 10em;\n padding-bottom: 0.2em;\n}\n\n.contactPane .peopleHeader {\n min-width: 18em;\n}\n\n.contactPane .peopleMain {\n overflow: scroll;\n}\n\n.contactPane .cardMain {\n margin: 0;\n}\n\n.contactPane .groupsMain,\n.contactPane .groupsFooter {\n padding: 0.1em;\n}\n\n/* ── Search ──────────────────────────────────────────────────── */\n\n.contactPane .searchInput {\n border: 0.1em solid var(--color-text-muted);\n border-radius: var(--border-radius-base);\n width: 100%;\n font-size: var(--font-size-base);\n padding: 0.1em 0.6em;\n margin: 0.2em;\n}\n\n/* ── Data cells ──────────────────────────────────────────────── */\n\n.contactPane .dataCell {\n padding: 0.1em;\n}\n\n/* ── Rendered sub-pane ───────────────────────────────────────── */\n\n.contactPane .renderPane {\n border: 0.1em solid var(--color-text-muted);\n border-radius: var(--border-radius-base);\n}\n\n/* ── Delete button ───────────────────────────────────────────── */\n\n.contactPane .deleteButton {\n height: 2em;\n}\n\n/* ── Sharing button & icon ───────────────────────────────────── */\n\n.contactPane .sharingButton {\n padding: var(--spacing-md);\n margin: var(--spacing-md);\n}\n\n.contactPane .sharingButtonIcon {\n width: var(--spacing-lg);\n height: var(--spacing-lg);\n}\n\n/* ── "All" groups button ─────────────────────────────────────── */\n\n.contactPane .allGroupsButton {\n margin-left: var(--spacing-md);\n font-size: var(--font-size-base);\n}\n\n.contactPane .allGroupsButton--loading {\n background-color: #ff8;\n}\n\n.contactPane .allGroupsButton--active {\n background-color: var(--color-text);\n color: var(--color-background);\n}\n\n.contactPane .allGroupsButton--loaded {\n background-color: #cfc;\n}\n\n/* ── Selection & visibility states ───────────────────────────── */\n\n.contactPane .selected {\n background-color: #cce;\n}\n\n.contactPane .group-loading {\n background-color: #ffe;\n}\n\n.contactPane .hidden {\n display: none;\n}\n\n/* ── Mint new address book ───────────────────────────────────── */\n\n.contactPane .claimSuccess {\n font-size: 140%;\n}\n\n.contactPane .addressBook-grid {\n max-width: max-content;\n\n}\n\n.contactPane .addressBookSection {\n width: 100%;\n max-width: 100%;\n box-sizing: border-box;\n margin-bottom: var(--spacing-md);\n box-sizing: border-box;\n margin-bottom: var(--spacing-md);\n}\n\n@media (min-width: 900px) {\n .contactPane .addressBookSection {\n margin-bottom: 0;\n }\n}\n\n/* Section Title - primary colored heading */\n.contactPane .section-title {\n font-size: 1.25em;\n font-weight: 600;\n color: var(--color-primary);\n margin: 0;\n}\n\n/* Card Section Background */\n.contactPane .section-bg {\n background: var(--color-section-bg);\n border-radius: var(--border-radius-full);\n box-shadow: var(--box-shadow);\n padding: var(--spacing-md);\n}\n\n.contactPane td {\n border: 1px dotted #999;\n}\n\n/* Primary Button */\n.btn-primary {\n min-height: var(--min-touch-target);\n padding: var(--spacing-sm) var(--spacing-md);\n border: 1px solid var(--color-primary);\n border-radius: var(--border-radius-base);\n background: var(--color-primary);\n color: white;\n font-weight: 600;\n cursor: pointer;\n transition: all var(--animation-duration) ease;\n}\n\n.btn-primary:hover {\n background: color-mix(in srgb, var(--color-primary) 90%, black);\n box-shadow: 0 2px 4px rgba(124, 77, 255, 0.2);\n}\n\n.btn-primary:active {\n box-shadow: 0 1px 2px rgba(124, 77, 255, 0.2);\n}\n\n.btn-primary:disabled {\n opacity: 0.6;\n cursor: not-allowed;\n transform: none;\n}\n\n/* Secondary button */\n.btn-secondary {\n min-height: var(--min-touch-target);\n padding: var(--spacing-sm) var(--spacing-md);\n border: var(--border-width-thin) solid var(--color-secondary);\n border-radius: var(--border-radius-base);\n background: var(--color-secondary);\n color: var(--color-background);\n font-weight: var(--font-weight-bold);\n cursor: pointer;\n transition: all var(--animation-duration) ease;\n text-decoration: none;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n}\n\n.btn-secondary:hover {\n background: color-mix(in srgb, var(--color-secondary) 85%, black);\n}\n\n.btn-secondary:disabled {\n opacity: var(--opacity-disabled);\n cursor: not-allowed;\n}\n\n/* Action Button Focus - used by ChatWithMe, ProfileCard */\n.action-button-focus:focus,\n.action-button-focus:focus-visible {\n outline: 3px solid var(--color-primary) !important;\n outline-offset: 2px !important;\n box-shadow: 0 0 0 2px var(--color-background), 0 0 0 5px rgba(124, 77, 255, 0.25) !important;\n z-index: 1;\n}'],sourceRoot:""}]);const s=i},479(n,e,t){t.d(e,{A:()=>s});var o=t(354),r=t.n(o),a=t(314),i=t.n(a)()(r());i.push([n.id,"/* individual.js styles — extracted from inline styles */\n\n/* ── Individual pane container ───────────────────────────────── */\n\n.contactPane .individualPane {\n padding: var(--spacing-xs) var(--spacing-lg) var(--spacing-md) var(--spacing-lg);\n}","",{version:3,sources:["webpack://./src/styles/individual.css"],names:[],mappings:"AAAA,wDAAwD;;AAExD,mEAAmE;;AAEnE;EACE,gFAAgF;AAClF",sourcesContent:["/* individual.js styles — extracted from inline styles */\n\n/* ── Individual pane container ───────────────────────────────── */\n\n.contactPane .individualPane {\n padding: var(--spacing-xs) var(--spacing-lg) var(--spacing-md) var(--spacing-lg);\n}"],sourceRoot:""}]);const s=i},715(n,e,t){t.d(e,{A:()=>s});var o=t(354),r=t.n(o),a=t(314),i=t.n(a)()(r());i.push([n.id,"/* mugshotGallery.js styles — extracted from inline styles */\n/* Uses CSS custom properties from the global stylesheet (dev-global.css / mashlib) */\n\n/* ── Mugshot image ───────────────────────────────────────────── */\n\n.contactPane .mugshotImage {\n max-height: 10em;\n border-radius: var(--border-radius-full);\n margin: 0.7em;\n}\n","",{version:3,sources:["webpack://./src/styles/mugshotGallery.css"],names:[],mappings:"AAAA,4DAA4D;AAC5D,qFAAqF;;AAErF,mEAAmE;;AAEnE;EACE,gBAAgB;EAChB,wCAAwC;EACxC,aAAa;AACf",sourcesContent:["/* mugshotGallery.js styles — extracted from inline styles */\n/* Uses CSS custom properties from the global stylesheet (dev-global.css / mashlib) */\n\n/* ── Mugshot image ───────────────────────────────────────────── */\n\n.contactPane .mugshotImage {\n max-height: 10em;\n border-radius: var(--border-radius-full);\n margin: 0.7em;\n}\n"],sourceRoot:""}]);const s=i},434(n,e,t){t.d(e,{A:()=>s});var o=t(354),r=t.n(o),a=t(314),i=t.n(a)()(r());i.push([n.id,'/* Solid-UI form */\n.individualPane .hoverControl:not(:has(> img:first-child)) {\n border: 0.1em solid rgb(136, 136, 136) !important;\n}\n\n.individualPane .hoverControl:has(> img:first-child) {\n background-color: transparent !important;\n border: none !important;\n margin: 0 !important;\n border-radius: 0 !important;\n padding: 0.7em !important;\n min-height: var(--min-touch-target);\n min-width: var(--min-touch-target);\n cursor: pointer;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n}\n\n.individualPane .hoverControlHide {\n width: 1.5em !important;\n height: 1.5em !important;\n display: block;\n margin-top: 0 !important;\n margin-left: 0 !important;\n margin-right: 0 !important;\n margin-bottom: 0.3em !important;\n}\n\n.individualPane .hoverControl:has(> img:first-child) > span {\n display: inline-flex;\n align-items: center;\n margin-left: 0.3em;\n}\n\n.individualPane div[style*="padding: 0.5em"]:has(> img) {\n display: inline-flex;\n align-items: center;\n}\n\n.individualPane div[style*="padding: 0.5em"]:has(> img) > span {\n margin-left: 0.3em;\n}\n\n.individualPane .hoverControl:has(> img:first-child):hover {\n background-color: transparent !important;\n}\n\n.individualPane button:has(> img[src$=".svg"]) {\n background-color: transparent !important;\n border: none !important;\n margin: 0 !important;\n border-radius: 0 !important;\n}\n\n.individualPane button {\n min-height: var(--min-touch-target);\n min-width: var(--min-touch-target);\n}\n\n.individualPane input:not([type="color"]),\n.individualPane textarea,\n.individualPane select {\n max-width: 100%;\n min-width: 0;\n box-sizing: border-box ;\n font: inherit;\n color: var(--color-text);\n background-color: var(--color-card-bg) !important;\n border: 1px solid var(--color-border-pale);\n}\n\n.individualPane textarea {\n border-color: var(--color-border-pale) !important;\n margin: 0 !important;\n padding: 0 !important;\n}\n\n.individualPane input[type="date"],\n.individualPane input[type="month"],\n.individualPane input[type="week"],\n.individualPane input[type="time"],\n.individualPane input[type="datetime-local"] {\n min-height: var(--min-touch-target);\n}\n\n.individualPane .hoverControl:has(> img:first-child):focus-visible,\n.individualPane button:focus-visible,\n.individualPane input:not([type="color"]):focus-visible,\n.individualPane textarea:focus-visible,\n.individualPane select:focus-visible {\n outline: var(--focus-ring-width) solid var(--color-primary) !important;\n outline-offset: 2px;\n box-shadow: 0 0 0 1px var(--color-background);\n}\n\n.individualPane input[type="url"] {\n width: 100%;\n}\n\n.individualPane .formFieldValue {\n min-width: 0;\n margin-bottom: var(--spacing-sm);\n}\n\n.individualPane .formFieldValue table {\n margin: 0 !important;\n padding: 0 !important;\n}\n\n.individualPane .formFieldValue td {\n padding: 0 !important;\n}\n\n.individualPane .formFieldValue input:not([type="color"]),\n.individualPane .formFieldValue textarea,\n.individualPane .formFieldValue select {\n width: 100%;\n max-width: 100%;\n}\n\n.individualPane select#formSelect {\n width: 100%;\n max-width: 97%;\n box-sizing: border-box;\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n.individualPane span select {\n max-width: 96% !important;\n box-sizing: border-box;\n margin: 0 !important;\n}\n\n.individualPane .formFieldValue span select {\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n/* Remove border/padding from the first wrapper div (and its first child wrapper). */\n.individualPane > div:first-of-type,\n.individualPane > div:first-of-type > div:first-of-type {\n border: none !important;\n padding: 0 !important;\n}\n\n/* Align schema.org, solid terms, FOAF, vCard, and org field labels with their input values. */\n.individualPane :not(.choiceBox):has(> .formFieldName):has(> .formFieldValue) {\n display: flex;\n align-items: baseline;\n margin-bottom: var(--spacing-sm);\n}\n\n.individualPane :not(.choiceBox):has(> .formFieldName):has(> .formFieldValue) > .formFieldValue {\n margin-bottom: 0;\n}\n\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://schema.org/"]),\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/solid/terms#"]),\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://xmlns.com/foaf/0.1/"]),\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/2006/vcard/ns"]),\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/org#"]) {\n display: inline-flex;\n align-items: center;\n vertical-align: middle;\n}\n\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://schema.org/"]) + .formFieldValue,\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/solid/terms#"]) + .formFieldValue,\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://xmlns.com/foaf/0.1/"]) + .formFieldValue,\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/2006/vcard/ns"]) + .formFieldValue,\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/org#"]) + .formFieldValue {\n display: inline-flex;\n align-items: center;\n vertical-align: middle;\n flex: 1;\n min-width: 0;\n}\n\n.individualPane textarea,\n.individualPane .formFieldValue textarea {\n appearance: none;\n -webkit-appearance: none;\n border: .05em solid #88c !important;\n border-style: solid !important;\n border-width: .05em !important;\n border-color: #88c !important;\n border-radius: 0.2em !important;\n width: 100%;\n box-sizing: border-box;\n margin-top: var(--spacing-xs);\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n/* Center textarea label vertically in flex rows. */\n.individualPane div[style*="display: flex"][style*="flex-direction: row"]:has(textarea) {\n align-items: flex-start;\n}\n\n.individualPane div[style*="display: flex"][style*="flex-direction: row"]:has(textarea) > div:has(> a) {\n padding-left: var(--spacing-xs);\n}\n\n/* Keep autocomplete/table-based fields (e.g. Occupation) aligned to label text baseline. */\n.individualPane :not(.choiceBox):has(> .formFieldValue input[data-testid="autocomplete-input"]) {\n align-items: flex-start;\n}\n\n.individualPane :not(.choiceBox):has(> .formFieldValue input[data-testid="autocomplete-input"]) > .formFieldName {\n padding-top: 0.55em !important;\n}\n\n.individualPane .formFieldValue:has(input[data-testid="autocomplete-input"]) {\n align-self: flex-start;\n}\n\n.individualPane .formFieldValue table[data-testid="autocomplete-table"],\n.individualPane .formFieldValue input[data-testid="autocomplete-input"] {\n margin: 0 !important;\n}\n\n.individualPane .formFieldValue table[data-testid="autocomplete-table"] {\n vertical-align: baseline;\n}\n\n.individualPane input:not([type="color"]) {\n width: 100%;\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n.individualPane input:disabled,\n.individualPane textarea:disabled,\n.individualPane select:disabled,\n.individualPane input[readonly],\n.individualPane textarea[readonly],\n.individualPane input:read-only,\n.individualPane textarea:read-only {\n background-color: var(--color-background) !important;\n cursor: not-allowed;\n opacity: 0.75;\n border: 0.05em solid white !important;\n}\n\n.individualPane textarea,\n.individualPane .formFieldValue textarea {\n padding: 0.5em !important;\n}\n\n.webidControl table td div.contactPane.namedPane {\n border: none !important;\n}',"",{version:3,sources:["webpack://./src/styles/rdfFormsEnforced.css"],names:[],mappings:"AAAA,kBAAkB;AAClB;EACE,iDAAiD;AACnD;;AAEA;EACE,wCAAwC;EACxC,uBAAuB;EACvB,oBAAoB;EACpB,2BAA2B;EAC3B,yBAAyB;EACzB,mCAAmC;EACnC,kCAAkC;EAClC,eAAe;EACf,oBAAoB;EACpB,mBAAmB;EACnB,uBAAuB;AACzB;;AAEA;EACE,uBAAuB;EACvB,wBAAwB;EACxB,cAAc;EACd,wBAAwB;EACxB,yBAAyB;EACzB,0BAA0B;EAC1B,+BAA+B;AACjC;;AAEA;EACE,oBAAoB;EACpB,mBAAmB;EACnB,kBAAkB;AACpB;;AAEA;EACE,oBAAoB;EACpB,mBAAmB;AACrB;;AAEA;EACE,kBAAkB;AACpB;;AAEA;EACE,wCAAwC;AAC1C;;AAEA;EACE,wCAAwC;EACxC,uBAAuB;EACvB,oBAAoB;EACpB,2BAA2B;AAC7B;;AAEA;EACE,mCAAmC;EACnC,kCAAkC;AACpC;;AAEA;;;EAGE,eAAe;EACf,YAAY;EACZ,uBAAuB;EACvB,aAAa;EACb,wBAAwB;EACxB,iDAAiD;EACjD,0CAA0C;AAC5C;;AAEA;EACE,iDAAiD;EACjD,oBAAoB;EACpB,qBAAqB;AACvB;;AAEA;;;;;EAKE,mCAAmC;AACrC;;AAEA;;;;;EAKE,sEAAsE;EACtE,mBAAmB;EACnB,6CAA6C;AAC/C;;AAEA;EACE,WAAW;AACb;;AAEA;EACE,YAAY;EACZ,gCAAgC;AAClC;;AAEA;EACE,oBAAoB;EACpB,qBAAqB;AACvB;;AAEA;EACE,qBAAqB;AACvB;;AAEA;;;EAGE,WAAW;EACX,eAAe;AACjB;;AAEA;EACE,WAAW;EACX,cAAc;EACd,sBAAsB;EACtB,yBAAyB;EACzB,0BAA0B;AAC5B;;AAEA;EACE,yBAAyB;EACzB,sBAAsB;EACtB,oBAAoB;AACtB;;AAEA;EACE,yBAAyB;EACzB,0BAA0B;AAC5B;;AAEA,oFAAoF;AACpF;;EAEE,uBAAuB;EACvB,qBAAqB;AACvB;;AAEA,8FAA8F;AAC9F;EACE,aAAa;EACb,qBAAqB;EACrB,gCAAgC;AAClC;;AAEA;EACE,gBAAgB;AAClB;;AAEA;;;;;EAKE,oBAAoB;EACpB,mBAAmB;EACnB,sBAAsB;AACxB;;AAEA;;;;;EAKE,oBAAoB;EACpB,mBAAmB;EACnB,sBAAsB;EACtB,OAAO;EACP,YAAY;AACd;;AAEA;;EAEE,gBAAgB;EAChB,wBAAwB;EACxB,mCAAmC;EACnC,8BAA8B;EAC9B,8BAA8B;EAC9B,6BAA6B;EAC7B,+BAA+B;EAC/B,WAAW;EACX,sBAAsB;EACtB,6BAA6B;EAC7B,yBAAyB;EACzB,0BAA0B;AAC5B;;AAEA,mDAAmD;AACnD;EACE,uBAAuB;AACzB;;AAEA;EACE,+BAA+B;AACjC;;AAEA,2FAA2F;AAC3F;EACE,uBAAuB;AACzB;;AAEA;EACE,8BAA8B;AAChC;;AAEA;EACE,sBAAsB;AACxB;;AAEA;;EAEE,oBAAoB;AACtB;;AAEA;EACE,wBAAwB;AAC1B;;AAEA;EACE,WAAW;EACX,yBAAyB;EACzB,0BAA0B;AAC5B;;AAEA;;;;;;;EAOE,oDAAoD;EACpD,mBAAmB;EACnB,aAAa;EACb,qCAAqC;AACvC;;AAEA;;EAEE,yBAAyB;AAC3B;;AAEA;EACE,uBAAuB;AACzB",sourcesContent:['/* Solid-UI form */\n.individualPane .hoverControl:not(:has(> img:first-child)) {\n border: 0.1em solid rgb(136, 136, 136) !important;\n}\n\n.individualPane .hoverControl:has(> img:first-child) {\n background-color: transparent !important;\n border: none !important;\n margin: 0 !important;\n border-radius: 0 !important;\n padding: 0.7em !important;\n min-height: var(--min-touch-target);\n min-width: var(--min-touch-target);\n cursor: pointer;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n}\n\n.individualPane .hoverControlHide {\n width: 1.5em !important;\n height: 1.5em !important;\n display: block;\n margin-top: 0 !important;\n margin-left: 0 !important;\n margin-right: 0 !important;\n margin-bottom: 0.3em !important;\n}\n\n.individualPane .hoverControl:has(> img:first-child) > span {\n display: inline-flex;\n align-items: center;\n margin-left: 0.3em;\n}\n\n.individualPane div[style*="padding: 0.5em"]:has(> img) {\n display: inline-flex;\n align-items: center;\n}\n\n.individualPane div[style*="padding: 0.5em"]:has(> img) > span {\n margin-left: 0.3em;\n}\n\n.individualPane .hoverControl:has(> img:first-child):hover {\n background-color: transparent !important;\n}\n\n.individualPane button:has(> img[src$=".svg"]) {\n background-color: transparent !important;\n border: none !important;\n margin: 0 !important;\n border-radius: 0 !important;\n}\n\n.individualPane button {\n min-height: var(--min-touch-target);\n min-width: var(--min-touch-target);\n}\n\n.individualPane input:not([type="color"]),\n.individualPane textarea,\n.individualPane select {\n max-width: 100%;\n min-width: 0;\n box-sizing: border-box ;\n font: inherit;\n color: var(--color-text);\n background-color: var(--color-card-bg) !important;\n border: 1px solid var(--color-border-pale);\n}\n\n.individualPane textarea {\n border-color: var(--color-border-pale) !important;\n margin: 0 !important;\n padding: 0 !important;\n}\n\n.individualPane input[type="date"],\n.individualPane input[type="month"],\n.individualPane input[type="week"],\n.individualPane input[type="time"],\n.individualPane input[type="datetime-local"] {\n min-height: var(--min-touch-target);\n}\n\n.individualPane .hoverControl:has(> img:first-child):focus-visible,\n.individualPane button:focus-visible,\n.individualPane input:not([type="color"]):focus-visible,\n.individualPane textarea:focus-visible,\n.individualPane select:focus-visible {\n outline: var(--focus-ring-width) solid var(--color-primary) !important;\n outline-offset: 2px;\n box-shadow: 0 0 0 1px var(--color-background);\n}\n\n.individualPane input[type="url"] {\n width: 100%;\n}\n\n.individualPane .formFieldValue {\n min-width: 0;\n margin-bottom: var(--spacing-sm);\n}\n\n.individualPane .formFieldValue table {\n margin: 0 !important;\n padding: 0 !important;\n}\n\n.individualPane .formFieldValue td {\n padding: 0 !important;\n}\n\n.individualPane .formFieldValue input:not([type="color"]),\n.individualPane .formFieldValue textarea,\n.individualPane .formFieldValue select {\n width: 100%;\n max-width: 100%;\n}\n\n.individualPane select#formSelect {\n width: 100%;\n max-width: 97%;\n box-sizing: border-box;\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n.individualPane span select {\n max-width: 96% !important;\n box-sizing: border-box;\n margin: 0 !important;\n}\n\n.individualPane .formFieldValue span select {\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n/* Remove border/padding from the first wrapper div (and its first child wrapper). */\n.individualPane > div:first-of-type,\n.individualPane > div:first-of-type > div:first-of-type {\n border: none !important;\n padding: 0 !important;\n}\n\n/* Align schema.org, solid terms, FOAF, vCard, and org field labels with their input values. */\n.individualPane :not(.choiceBox):has(> .formFieldName):has(> .formFieldValue) {\n display: flex;\n align-items: baseline;\n margin-bottom: var(--spacing-sm);\n}\n\n.individualPane :not(.choiceBox):has(> .formFieldName):has(> .formFieldValue) > .formFieldValue {\n margin-bottom: 0;\n}\n\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://schema.org/"]),\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/solid/terms#"]),\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://xmlns.com/foaf/0.1/"]),\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/2006/vcard/ns"]),\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/org#"]) {\n display: inline-flex;\n align-items: center;\n vertical-align: middle;\n}\n\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://schema.org/"]) + .formFieldValue,\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/solid/terms#"]) + .formFieldValue,\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://xmlns.com/foaf/0.1/"]) + .formFieldValue,\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/2006/vcard/ns"]) + .formFieldValue,\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/org#"]) + .formFieldValue {\n display: inline-flex;\n align-items: center;\n vertical-align: middle;\n flex: 1;\n min-width: 0;\n}\n\n.individualPane textarea,\n.individualPane .formFieldValue textarea {\n appearance: none;\n -webkit-appearance: none;\n border: .05em solid #88c !important;\n border-style: solid !important;\n border-width: .05em !important;\n border-color: #88c !important;\n border-radius: 0.2em !important;\n width: 100%;\n box-sizing: border-box;\n margin-top: var(--spacing-xs);\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n/* Center textarea label vertically in flex rows. */\n.individualPane div[style*="display: flex"][style*="flex-direction: row"]:has(textarea) {\n align-items: flex-start;\n}\n\n.individualPane div[style*="display: flex"][style*="flex-direction: row"]:has(textarea) > div:has(> a) {\n padding-left: var(--spacing-xs);\n}\n\n/* Keep autocomplete/table-based fields (e.g. Occupation) aligned to label text baseline. */\n.individualPane :not(.choiceBox):has(> .formFieldValue input[data-testid="autocomplete-input"]) {\n align-items: flex-start;\n}\n\n.individualPane :not(.choiceBox):has(> .formFieldValue input[data-testid="autocomplete-input"]) > .formFieldName {\n padding-top: 0.55em !important;\n}\n\n.individualPane .formFieldValue:has(input[data-testid="autocomplete-input"]) {\n align-self: flex-start;\n}\n\n.individualPane .formFieldValue table[data-testid="autocomplete-table"],\n.individualPane .formFieldValue input[data-testid="autocomplete-input"] {\n margin: 0 !important;\n}\n\n.individualPane .formFieldValue table[data-testid="autocomplete-table"] {\n vertical-align: baseline;\n}\n\n.individualPane input:not([type="color"]) {\n width: 100%;\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n.individualPane input:disabled,\n.individualPane textarea:disabled,\n.individualPane select:disabled,\n.individualPane input[readonly],\n.individualPane textarea[readonly],\n.individualPane input:read-only,\n.individualPane textarea:read-only {\n background-color: var(--color-background) !important;\n cursor: not-allowed;\n opacity: 0.75;\n border: 0.05em solid white !important;\n}\n\n.individualPane textarea,\n.individualPane .formFieldValue textarea {\n padding: 0.5em !important;\n}\n\n.webidControl table td div.contactPane.namedPane {\n border: none !important;\n}'],sourceRoot:""}]);const s=i},295(n,e,t){t.d(e,{A:()=>s});var o=t(354),r=t.n(o),a=t(314),i=t.n(a)()(r());i.push([n.id,"/* toolsPane.js styles — extracted from inline styles */\n/* Uses CSS custom properties from the global stylesheet (dev-global.css / mashlib) */\n\n/* ── Tools pane table ────────────────────────────────────────── */\n\n.contactPane .toolsTable {\n font-size: 120%;\n margin: var(--spacing-md);\n border: 0.1em solid var(--color-border-pale);\n}\n\n/* ── Tools header row ────────────────────────────────────────── */\n\n.contactPane .toolsHeader {\n min-width: 20em;\n padding: var(--spacing-md);\n font-size: 150%;\n border-bottom: 0.1em solid var(--color-error);\n margin-bottom: var(--spacing-xl);\n}\n\n/* ── Status block ────────────────────────────────────────────── */\n\n.contactPane .toolsStatusBlock {\n padding: var(--spacing-xl);\n}\n\n/* ── Tools buttons ───────────────────────────────────────────── */\n\n.contactPane .toolsButton {\n font-size: var(--font-size-base);\n margin: 0.8em;\n padding: var(--spacing-xs);\n}\n\n/* ── Load index button states ────────────────────────────────── */\n\n.contactPane .toolsButton--loading {\n background-color: #ffc;\n}\n\n.contactPane .toolsButton--error {\n background-color: #fcc;\n}\n\n.contactPane .toolsButton--success {\n background-color: #cfc;\n}\n","",{version:3,sources:["webpack://./src/styles/toolsPane.css"],names:[],mappings:"AAAA,uDAAuD;AACvD,qFAAqF;;AAErF,mEAAmE;;AAEnE;EACE,eAAe;EACf,yBAAyB;EACzB,4CAA4C;AAC9C;;AAEA,mEAAmE;;AAEnE;EACE,eAAe;EACf,0BAA0B;EAC1B,eAAe;EACf,6CAA6C;EAC7C,gCAAgC;AAClC;;AAEA,mEAAmE;;AAEnE;EACE,0BAA0B;AAC5B;;AAEA,mEAAmE;;AAEnE;EACE,gCAAgC;EAChC,aAAa;EACb,0BAA0B;AAC5B;;AAEA,mEAAmE;;AAEnE;EACE,sBAAsB;AACxB;;AAEA;EACE,sBAAsB;AACxB;;AAEA;EACE,sBAAsB;AACxB",sourcesContent:["/* toolsPane.js styles — extracted from inline styles */\n/* Uses CSS custom properties from the global stylesheet (dev-global.css / mashlib) */\n\n/* ── Tools pane table ────────────────────────────────────────── */\n\n.contactPane .toolsTable {\n font-size: 120%;\n margin: var(--spacing-md);\n border: 0.1em solid var(--color-border-pale);\n}\n\n/* ── Tools header row ────────────────────────────────────────── */\n\n.contactPane .toolsHeader {\n min-width: 20em;\n padding: var(--spacing-md);\n font-size: 150%;\n border-bottom: 0.1em solid var(--color-error);\n margin-bottom: var(--spacing-xl);\n}\n\n/* ── Status block ────────────────────────────────────────────── */\n\n.contactPane .toolsStatusBlock {\n padding: var(--spacing-xl);\n}\n\n/* ── Tools buttons ───────────────────────────────────────────── */\n\n.contactPane .toolsButton {\n font-size: var(--font-size-base);\n margin: 0.8em;\n padding: var(--spacing-xs);\n}\n\n/* ── Load index button states ────────────────────────────────── */\n\n.contactPane .toolsButton--loading {\n background-color: #ffc;\n}\n\n.contactPane .toolsButton--error {\n background-color: #fcc;\n}\n\n.contactPane .toolsButton--success {\n background-color: #cfc;\n}\n"],sourceRoot:""}]);const s=i},886(n,e,t){t.d(e,{A:()=>s});var o=t(354),r=t.n(o),a=t(314),i=t.n(a)()(r());i.push([n.id,"/* webidControl.js styles — extracted from inline styles */\n/* Uses CSS custom properties from the global stylesheet (dev-global.css / mashlib) */\n\n/* ── Named pane (rendered sub-pane) ──────────────────────────── */\n\n.contactPane .namedPane {\n border: 0.1em solid var(--color-text-muted);\n border-radius: var(--border-radius-base);\n}\n\n/* ── WebID / Public ID outer container ───────────────────────── */\n\n.contactPane .webidControl {\n border-radius: 0.3em;\n border: 0.1em solid #888;\n}\n\n/* ── Persona row ─────────────────────────────────────────────── */\n\n.contactPane .personaRow {\n padding: 0.2em;\n}\n\n.contactPane .personaRow--webid {\n background-color: #ffe6ff;\n}\n\n/* ── Full-width elements ─────────────────────────────────────── */\n\n.contactPane .fullWidth {\n width: 100%;\n}\n\n/* ── Open/close profile button ───────────────────────────────── */\n\n.contactPane .personaOpenButton {\n float: right;\n background-color: transparent;\n border: none;\n}\n\n/* ── Section heading ─────────────────────────────────────────── */\n\n.contactPane .webidHeading {\n font-size: 110%;\n font-weight: bold;\n color: var(--color-primary);\n padding: 0.2em;\n margin: 0.7em 0;\n}\n\n/* ── Prompt text ─────────────────────────────────────────────── */\n\n.contactPane .webidPrompt {\n padding: 0.7em;\n border: none;\n font-size: var(--font-size-base);\n white-space: pre-wrap;\n}\n","",{version:3,sources:["webpack://./src/styles/webidControl.css"],names:[],mappings:"AAAA,0DAA0D;AAC1D,qFAAqF;;AAErF,mEAAmE;;AAEnE;EACE,2CAA2C;EAC3C,wCAAwC;AAC1C;;AAEA,mEAAmE;;AAEnE;EACE,oBAAoB;EACpB,wBAAwB;AAC1B;;AAEA,mEAAmE;;AAEnE;EACE,cAAc;AAChB;;AAEA;EACE,yBAAyB;AAC3B;;AAEA,mEAAmE;;AAEnE;EACE,WAAW;AACb;;AAEA,mEAAmE;;AAEnE;EACE,YAAY;EACZ,6BAA6B;EAC7B,YAAY;AACd;;AAEA,mEAAmE;;AAEnE;EACE,eAAe;EACf,iBAAiB;EACjB,2BAA2B;EAC3B,cAAc;EACd,eAAe;AACjB;;AAEA,mEAAmE;;AAEnE;EACE,cAAc;EACd,YAAY;EACZ,gCAAgC;EAChC,qBAAqB;AACvB",sourcesContent:["/* webidControl.js styles — extracted from inline styles */\n/* Uses CSS custom properties from the global stylesheet (dev-global.css / mashlib) */\n\n/* ── Named pane (rendered sub-pane) ──────────────────────────── */\n\n.contactPane .namedPane {\n border: 0.1em solid var(--color-text-muted);\n border-radius: var(--border-radius-base);\n}\n\n/* ── WebID / Public ID outer container ───────────────────────── */\n\n.contactPane .webidControl {\n border-radius: 0.3em;\n border: 0.1em solid #888;\n}\n\n/* ── Persona row ─────────────────────────────────────────────── */\n\n.contactPane .personaRow {\n padding: 0.2em;\n}\n\n.contactPane .personaRow--webid {\n background-color: #ffe6ff;\n}\n\n/* ── Full-width elements ─────────────────────────────────────── */\n\n.contactPane .fullWidth {\n width: 100%;\n}\n\n/* ── Open/close profile button ───────────────────────────────── */\n\n.contactPane .personaOpenButton {\n float: right;\n background-color: transparent;\n border: none;\n}\n\n/* ── Section heading ─────────────────────────────────────────── */\n\n.contactPane .webidHeading {\n font-size: 110%;\n font-weight: bold;\n color: var(--color-primary);\n padding: 0.2em;\n margin: 0.7em 0;\n}\n\n/* ── Prompt text ─────────────────────────────────────────────── */\n\n.contactPane .webidPrompt {\n padding: 0.7em;\n border: none;\n font-size: var(--font-size-base);\n white-space: pre-wrap;\n}\n"],sourceRoot:""}]);const s=i},314(n){n.exports=function(n){var e=[];return e.toString=function(){return this.map(function(e){var t="",o=void 0!==e[5];return e[4]&&(t+="@supports (".concat(e[4],") {")),e[2]&&(t+="@media ".concat(e[2]," {")),o&&(t+="@layer".concat(e[5].length>0?" ".concat(e[5]):""," {")),t+=n(e),o&&(t+="}"),e[2]&&(t+="}"),e[4]&&(t+="}"),t}).join("")},e.i=function(n,t,o,r,a){"string"==typeof n&&(n=[[null,n,void 0]]);var i={};if(o)for(var s=0;s<this.length;s++){var d=this[s][0];null!=d&&(i[d]=!0)}for(var l=0;l<n.length;l++){var c=[].concat(n[l]);o&&i[c[0]]||(void 0!==a&&(void 0===c[5]||(c[1]="@layer".concat(c[5].length>0?" ".concat(c[5]):""," {").concat(c[1],"}")),c[5]=a),t&&(c[2]?(c[1]="@media ".concat(c[2]," {").concat(c[1],"}"),c[2]=t):c[2]=t),r&&(c[4]?(c[1]="@supports (".concat(c[4],") {").concat(c[1],"}"),c[4]=r):c[4]="".concat(r)),e.push(c))}},e}},354(n){n.exports=function(n){var e=n[1],t=n[3];if(!t)return e;if("function"==typeof btoa){var o=btoa(unescape(encodeURIComponent(JSON.stringify(t)))),r="sourceMappingURL=data:application/json;charset=utf-8;base64,".concat(o),a="/*# ".concat(r," */");return[e].concat([a]).join("\n")}return[e].join("\n")}},72(n){var e=[];function t(n){for(var t=-1,o=0;o<e.length;o++)if(e[o].identifier===n){t=o;break}return t}function o(n,o){for(var a={},i=[],s=0;s<n.length;s++){var d=n[s],l=o.base?d[0]+o.base:d[0],c=a[l]||0,u="".concat(l," ").concat(c);a[l]=c+1;var p=t(u),A={css:d[1],media:d[2],sourceMap:d[3],supports:d[4],layer:d[5]};if(-1!==p)e[p].references++,e[p].updater(A);else{var m=r(A,o);o.byIndex=s,e.splice(s,0,{identifier:u,updater:m,references:1})}i.push(u)}return i}function r(n,e){var t=e.domAPI(e);return t.update(n),function(e){if(e){if(e.css===n.css&&e.media===n.media&&e.sourceMap===n.sourceMap&&e.supports===n.supports&&e.layer===n.layer)return;t.update(n=e)}else t.remove()}}n.exports=function(n,r){var a=o(n=n||[],r=r||{});return function(n){n=n||[];for(var i=0;i<a.length;i++){var s=t(a[i]);e[s].references--}for(var d=o(n,r),l=0;l<a.length;l++){var c=t(a[l]);0===e[c].references&&(e[c].updater(),e.splice(c,1))}a=d}}},659(n){var e={};n.exports=function(n,t){var o=function(n){if(void 0===e[n]){var t=document.querySelector(n);if(window.HTMLIFrameElement&&t instanceof window.HTMLIFrameElement)try{t=t.contentDocument.head}catch(n){t=null}e[n]=t}return e[n]}(n);if(!o)throw new Error("Couldn't find a style target. This probably means that the value for the 'insert' parameter is invalid.");o.appendChild(t)}},540(n){n.exports=function(n){var e=document.createElement("style");return n.setAttributes(e,n.attributes),n.insert(e,n.options),e}},56(n,e,t){n.exports=function(n){var e=t.nc;e&&n.setAttribute("nonce",e)}},825(n){n.exports=function(n){if("undefined"==typeof document)return{update:function(){},remove:function(){}};var e=n.insertStyleElement(n);return{update:function(t){!function(n,e,t){var o="";t.supports&&(o+="@supports (".concat(t.supports,") {")),t.media&&(o+="@media ".concat(t.media," {"));var r=void 0!==t.layer;r&&(o+="@layer".concat(t.layer.length>0?" ".concat(t.layer):""," {")),o+=t.css,r&&(o+="}"),t.media&&(o+="}"),t.supports&&(o+="}");var a=t.sourceMap;a&&"undefined"!=typeof btoa&&(o+="\n/*# sourceMappingURL=data:application/json;base64,".concat(btoa(unescape(encodeURIComponent(JSON.stringify(a))))," */")),e.styleTagTransform(o,n,e.options)}(e,n,t)},remove:function(){!function(n){if(null===n.parentNode)return!1;n.parentNode.removeChild(n)}(e)}}}},113(n){n.exports=function(n,e){if(e.styleSheet)e.styleSheet.cssText=n;else{for(;e.firstChild;)e.removeChild(e.firstChild);e.appendChild(document.createTextNode(n))}}},53(n){n.exports=t},941(e){e.exports=n},104(n){n.exports=e}},r={};function a(n){var e=r[n];if(void 0!==e)return e.exports;var t=r[n]={id:n,exports:{}};return o[n](t,t.exports,a),t.exports}a.n=n=>{var e=n&&n.__esModule?()=>n.default:()=>n;return a.d(e,{a:e}),e},a.d=(n,e)=>{for(var t in e)a.o(e,t)&&!a.o(n,t)&&Object.defineProperty(n,t,{enumerable:!0,get:e[t]})},a.o=(n,e)=>Object.prototype.hasOwnProperty.call(n,e),a.nc=void 0;var i={};a.d(i,{default:()=>Tn});var s=a(941),d=a(104),l=a(53),c=a(72),u=a.n(c),p=a(825),A=a.n(p),m=a(659),h=a.n(m),f=a(56),g=a.n(f),b=a(540),C=a.n(b),w=a(113),y=a.n(w),v=a(886),E={};E.styleTagTransform=y(),E.setAttributes=g(),E.insert=h().bind(null,"head"),E.domAPI=A(),E.insertStyleElement=C(),u()(v.A,E),v.A&&v.A.locals&&v.A.locals;const B=d.ns,x=d.widgets,k=d.utils,P=s.store,T=x.publicData.wikidataClasses,D=x.publicData.wikidataParameters,S="Solid ID",F="In public data",L=d.icons.iconBase+"noun_1369241.svg",I=d.icons.iconBase+"noun_1369237.svg";function N(n,e){const t=function(n,e,t){return n.each(e,B.vcard("url"),null,e.doc()).filter(o=>n.holds(o,B.rdf("type"),t,e.doc())).map(t=>n.any(t,B.vcard("value"),null,e.doc())).filter(n=>!!n)}(n,e).concat(function(n,e,t){const o=new Set,r=new Set([e.uri]);for(;r.size;){const e=Array.from(r)[0];if(r.delete(e),o.has(e))continue;o.add(e);const a=n.sym(e);n.each(a,B.owl("sameAs"),null,t).concat(n.each(null,B.owl("sameAs"),a,t)).forEach(n=>{console.log(" OWL sameAs found "+n),r.add(n.uri)}),n.each(a,B.schema("sameAs"),null,t).concat(n.each(null,B.schema("sameAs"),a,t)).forEach(n=>{console.log(" Schema sameAs found "+n),r.add(n.uri)})}return o.delete(e.uri),Array.from(o).map(e=>n.sym(e))}(n,e,e.doc())),o=[...new Set(t.map(n=>n.value))].map(e=>n.sym(e));return o.sort(),o.filter(n=>!n.sameTerm(e)),o}function _(n){const e=n.doc();return P.holds(n,B.rdf("type"),B.vcard("Organization"),e)||P.holds(n,B.rdf("type"),B.schema("Organization"),e)}async function O(n,e,t){function o(o,a,i){const s=o.createElement("div");s.classList.add("fullWidth");const c=s.appendChild(o.createElement("table"));c.classList.add("fullWidth");const u=c.appendChild(function(e){const a=new l.Literal(e.uri),c=t.urlType.sameTerm(B.vcard("WebID")),u=t.editable?async function(){try{await async function(n,e,t,o){console.log(`Removing from ${n} their ${S}: ${e}.`);const r=o.each(n,B.vcard("url"),null,n.doc()).filter(e=>o.holds(e,B.rdf("type"),t,n.doc())).filter(t=>o.holds(t,B.vcard("value"),e,n.doc()));if(!r.length)throw new Error(`Person ${n} does not have ${S} ${e}.`);const a=r[0],i=[l.st(n,B.vcard("url"),a,n.doc()),l.st(a,B.rdf("type"),t,n.doc()),l.st(a,B.vcard("value"),e,n.doc())];await o.updater.update(i,[]);const s=o.each(null,B.vcard("hasMember"),o.sym(e));let d=[];const c=[];s.forEach(async t=>{d=d.concat(o.statementsMatching(o.sym(e),B.owl("sameAs"),n,t.doc())),c.push(l.st(t,B.vcard("hasMember"),n,t.doc())),o.statementsMatching(o.sym(e),B.owl("sameAs"),null,t.doc()).length<2&&(d=d.concat(o.statementsMatching(t,B.vcard("hasMember"),o.sym(e),t.doc())))}),await R(d,c)}(n,a,t.urlType,i)}catch(e){s.appendChild(x.errorMessageBlock(o,`Error removing Id ${a} from ${n}: ${e}`))}await r()}:null,p={deleteFunction:u,draggable:!0};c&&(p.title=e.uri.split("/")[2],p.image=x.faviconOrDefault(o,e.site()));const A=x.personTR(o,d.ns.foaf("knows"),e,p);return c&&(A.children[1].textConent=p.title,A.classList.add("personaRow--webid")),A.classList.add("personaRow"),A}(a));u.classList.add("fullWidth");const p=c.appendChild(o.createElement("tr")).appendChild(o.createElement("td"));let A;p.setAttribute("colspan",3);let m=!0;const h=u.children[2].appendChild(x.button(o,L,"View",function(n){m=!m,A.style.visibility=m?"visible":"collapse",h.children[0].src=m?I:L}));h.classList.add("personaOpenButton");const f=(_(n)||_(a),"profile");return x.publicData.loadPublicDataThing(i,n,a).then(n=>{try{A=function(n,e,t,o){const r=o.session.paneRegistry.byName(t).render(e,o);return r.classList.add("namedPane"),r}(0,a,f,e),console.log("main: ",A),A.classList.add("fullWidth"),console.log("renderIdControl: main element: ",A),p.appendChild(A)}catch(n){A=x.errorMessageBlock(o,`Problem displaying persona ${a}: ${n}`),p.appendChild(A)}},n=>{A=x.errorMessageBlock(o,`Error loading persona ${a}: ${n}`),p.appendChild(A)}),s}async function r(){const e=N(P,n);console.log("WebId personas: "+n+" -> "+e.map(n=>n.uri).join(",\n ")),c.style.display=e.length?"none":"",k.syncTableToArrayReOrdered(u,e,n=>o(a,n,P))}const{dom:a}=e;(t=t||{}).editable=P.updater.editable(n.doc().uri,P);const i=a.createElement("div");if(i.classList.add("webidControl"),0===N(P,n).length&&!t.editable)return i.style.display="none",i;const s=i.appendChild(a.createElement("h4"));s.textContent=t.idNoun,s.classList.add("webidHeading");const c=i.appendChild(a.createElement("p"));if(c.classList.add("webidPrompt"),c.textContent=t.longPrompt,i.appendChild(a.createElement("table")).classList.add("fullWidth"),t.editable){const e={editable:t.editable,manualURIEntry:!0,idNoun:t.idNoun,dbLookup:t.dbLookup},o={queryParams:t.queryParams||D,targetClass:t.class};try{i.appendChild(await x.renderAutocompleteControl(a,n,e,o,async function(n,e){try{await async function(n,e,t,o){try{new URL(e)}catch(n){throw new Error(`${S}: ${e} is not a valid url.`)}console.log(`Adding to ${n} a ${S}: ${e}.`);const r=o.bnode(),a=[l.st(n,B.vcard("url"),r,n.doc()),l.st(r,B.rdf("type"),t,n.doc()),l.st(r,B.vcard("value"),e,n.doc())],i=o.each(null,B.vcard("hasMember"),n);let s=[];i.forEach(t=>{s=s.concat(o.statementsMatching(t,B.vcard("hasMember"),n,t.doc())),a.push(l.st(t,B.vcard("hasMember"),o.sym(e),t.doc())),a.push(l.st(o.sym(e),B.owl("sameAs"),n,t.doc()))});try{await R(s,a)}catch(n){throw new Error(`Could not create webId ${S}: ${e}.`)}}(n,e,t.urlType,P)}catch(t){i.appendChild(x.errorMessageBlock(a,`Error adding Id ${e} to ${n}: ${t}`))}await r()}))}catch(n){console.error("renderAutocompleteControl failed:",n),i.appendChild(x.errorMessageBlock(a,"Error rendering autocomplete: "+n))}}const u=i.appendChild(a.createElement("div"));return await r(),i}const U=d.ns,M=d.utils,z=s.store,$=z.updater;async function R(n,e=[]){const t=n.concat(e).map(n=>n.why),o=[];t.forEach(n=>{o.find(e=>e.equals(n))||o.push(n)});const r=o.map(t=>z.updater.update(n.filter(n=>n.why.sameTerm(t)),e.filter(n=>n.why.sameTerm(t))));return Promise.all(r)}async function j(n,e){await z.fetcher.load(n.doc());const t=z.any(n,U.vcard("groupIndex")),o=function(n){return n.replace(/\W/gu,"_").replace(/_+/g,"_")}(e),r=z.sym(n.dir().uri+"Group/"+o+".ttl#this"),a=r.doc();try{await z.fetcher.load(t)}catch(n){throw new Error("Error loading group index!"+t.uri+": "+n)}if(z.holds(n,U.vcard("includesGroup"),r,t))return r;const i=[l.st(n,U.vcard("includesGroup"),r,t),l.st(r,U.rdf("type"),U.vcard("Group"),t),l.st(r,U.vcard("fn"),e,t)];try{await $.update([],i)}catch(n){throw new Error("Could not update group index "+n)}const s=[l.st(n,U.vcard("includesGroup"),r,a),l.st(r,U.rdf("type"),U.vcard("Group"),a),l.st(r,U.vcard("fn"),e,a)];try{await $.update([],s)}catch(n){throw new Error("Could not update group file: "+n)}return r}async function q(n,e){const t=[n.doc(),e.doc()];try{await z.fetcher.load(t)}catch(n){throw new Error("addPersonToGroup: "+n)}const o=z.findTypeURIs(n);if(!(U.vcard("Individual").uri in o)&&!(U.vcard("Organization").uri in o))return alert(`Can't add ${n} to a group: it has to be an individual or another group.`);const r=z.any(n,U.vcard("fn")),a=z.any(e,U.vcard("fn"));if(!r)return alert("No vcard name known for "+n);if(z.holds(n,U.vcard("fn"),null,e.doc()))return alert("ALREADY added "+r+" to group "+a);if(!confirm("Add "+r+" to group "+a+"?"))return;const i=[l.st(n,U.vcard("fn"),r,e.doc())],s=N(z,n).map(n=>n.value);s.length?s.forEach(t=>{i.push(l.st(z.sym(t),U.owl("sameAs"),n,e.doc())),i.push(l.st(e,U.vcard("hasMember"),z.sym(t),e.doc()))}):i.push(l.st(e,U.vcard("hasMember"),n,e.doc()));try{await $.update([],i),z.fetcher.unload(e.doc()),await z.fetcher.load(e.doc())}catch(n){throw new Error(`Error adding ${r} to group ${a}:`+n)}return n}function G(n,e){const t=n.each(e,U.vcard("hasMember"),null,e.doc());let o=[];t.forEach(t=>{o=n.any(t,U.vcard("fn"),null,e.doc())?o.concat(t):o.concat(n.each(t,U.owl("sameAs"),null,e.doc()))});const r=new Set(o.map(n=>n.uri));return o=[...r].map(e=>n.sym(e)),o}function H(n,e){const t=n.dir().dir().dir();return e.uri&&e.uri.startsWith(t.uri)}async function W(n){const e=[],t=[];return n.forEach(n=>{z.each(n,U.vcard("hasMember"),null,n.doc()).forEach(o=>{const r=function(n,e,t){return n.each(e,U.owl("sameAs"),null,t).concat(n.each(null,U.owl("sameAs"),e,t))}(z,o,n.doc());if(r.length&&H(n,o))for(const a of r)if(!H(n,a)){e.push(l.st(n,U.vcard("hasMember"),o,n.doc())),t.push(l.st(n,U.vcard("hasMember"),a,n.doc()));break}})}),{del:e,ins:t}}const{setACLUserPublic:V}=s.solidLogicSingleton.acl;var Y=a(715),Z={};Z.styleTagTransform=y(),Z.setAttributes=g(),Z.insert=h().bind(null,"head"),Z.domAPI=A(),Z.insertStyleElement=C(),u()(Y.A,Z),Y.A&&Y.A.locals&&Y.A.locals;const Q={"image/png":"png","image/jpeg":"jpg","image/gif":"gif","image/svg+xml":"svg","image/webp":"webp","image/bmp":"bmp","image/tiff":"tiff","application/pdf":"pdf","text/plain":"txt","text/html":"html","application/json":"json","application/octet-stream":"bin"},K=Object.fromEntries(Object.entries(Q).map(([n,e])=>[e,n])),X=n=>Q[n]||!1,J=n=>{const e=n.split(".").pop().toLowerCase();return K[e]||!1},nn=d.ns,en=d.utils,tn=s.store;function on(n,e){function t(e){console.log(e),f.appendChild(d.widgets.errorMessageBlock(n,e,"pink"))}async function o(n,e,t){const o=[l.st(n,nn.vcard("hasPhoto"),e,n.doc())];try{t?await tn.updater.update(o,[]):await tn.updater.update([],o)}catch(n){const t=" Write back image link FAIL "+e+", Error: "+n;console.log(t),alert(t)}}function r(n){tn.fetcher.nowOrWhenFetched(n.doc(),function(t,o){if(t){const t=tn.findTypeURIs(n);for(const n in t)console.log(" drop object type includes: "+n);console.log("Default: assume web page "+n),tn.add(e,nn.wf("attachment"),n,e.doc())}else console.log("Error looking up dropped thing "+n+": "+o)})}function a(n,o,r){const a=X(o);let i,s;o!==J(n)&&(n+="_."+a,console.log("MIME TYPE MISMATCH -- adding extension: "+n));const d=o.startsWith("image");let l,c;for(d?(i="image_",s=nn.vcard("hasPhoto")):(i="attachment_",s=nn.wf("attachment")),l=0;c=tn.sym(e.dir().uri+n),tn.holds(e,nn.vcard("hasPhoto"),c);l++)n=i+l+"."+a;console.log("Putting "+r.byteLength+" bytes of "+o+" to "+c),tn.fetcher.webOperation("PUT",c.uri,{data:r,contentType:o}).then(function(n){n.ok?(console.log(" Upload: put OK: "+c),tn.add(e,s,c,e.doc()),tn.fetcher.putBack(e.doc(),{contentType:"text/turtle"}).then(function(n){d&&g.refresh()},function(n){console.log(" Write back image link FAIL "+c+", Error: "+n)})):t("Error uploading "+c+":"+n.status)})}async function i(n){for(const e of n){let n=l.sym(e);if(console.log("Dropped on mugshot thing "+n),e.startsWith("http")&&e.indexOf("#")<0){e.startsWith("http:")&&(n=l.sym("https:"+e.slice(5)));const o={withCredentials:!1,credentials:"omit"};let i;try{i=await tn.fetcher.webOperation("GET",n.uri,o)}catch(e){return t(`Gallery: fetch error trying to read picture ${n} data: ${e}`),void r(n)}const s=i.headers.get("Content-Type");let d=n.uri.split("/").slice(-1)[0];d=d.split("?")[0];const c=await i.arrayBuffer();return i.ok?void a(d,s,c):(alert("Cant download, so will link image. "+n+":"+i.status),void r(n))}alert("Not a web document URI, cannot copy as picture: "+n),r(n)}}function c(n){for(let e=0;e<n.length;e++){const t=n[e];console.log(" contacts: Filename: "+t.name+", type: "+(t.type||"n/a")+" size: "+t.size+" bytes, last modified: "+(t.lastModifiedDate?t.lastModifiedDate.toLocaleDateString():"n/a"));const o=new FileReader;o.onload=function(n){return function(e){const t=e.target.result;console.log(" File read byteLength : "+t.byteLength),a(encodeURIComponent(n.name),n.type,t)}}(t),o.readAsArrayBuffer(t)}}function u(e){const t=n.createElement("img");return t.classList.add("mugshotImage"),d.widgets.makeDropTarget(t,i,c),e&&(s.store.fetcher._fetch(e.uri).then(function(n){return n.blob()}).then(function(n){const e=URL.createObjectURL(n);t.setAttribute("src",e)}),d.widgets.makeDraggable(t,e)),t}function p(){let n=tn.each(e,nn.vcard("hasPhoto"));n.sort(),n=n.slice(0,5),0===n.length?(g.innerHTML="",h&&g.appendChild(b)):en.syncTableToArray(g,n,u)}function A(){return tn.sym(e.dir().uri+"Image_"+Date.now()+".png")}async function m(n){n&&(await o(e,n),p())}const h=tn.updater.editable(e.doc().uri,tn),f=n.createElement("div"),g=f.appendChild(n.createElement("div")),b=u();return d.widgets.setImage(b,e),p(),g.refresh=p,h&&f.appendChild(function(){const t=n.createElement("table"),r=t.appendChild(n.createElement("tr")),a=r.appendChild(n.createElement("td")),i=r.appendChild(n.createElement("td")),s=r.appendChild(n.createElement("td"));a.appendChild(d.media.cameraButton(n,tn,A,m));try{i.appendChild(d.widgets.fileUploadButtonDiv(n,c))}catch(n){console.log("ignore fileUploadButtonDiv error for now",n)}return s.appendChild(function(){const t=d.widgets.button(n,d.icons.iconBase+"noun_925021.svg","Drag here to delete");return d.widgets.makeDropTarget(t,async function(n){const t=tn.each(e,nn.vcard("hasPhoto")).map(n=>n.uri);for(const r of n){if(!t.includes(r))return void alert("Only drop images in this contact onto this trash can.");if(confirm(`Permanently DELETE image ${r} completely?`)){console.log("Unlinking image file "+r),await o(e,tn.sym(r),!0);try{console.log("Deleting image file "+r),await tn.fetcher.webOperation("DELETE",r)}catch(n){alert("Unable to delete picture! "+n)}}}p()},null),t}()),t}()),f}const rn=d.ns,an=d.utils,sn=s.store;function dn(n){let e=sn.statementsMatching(null,rn.owl("sameAs"),n).map(n=>n.why).concat(sn.each(null,rn.vcard("hasMember"),n));const t=new Set(e.map(n=>n.uri));return e=[...t].map(n=>sn.sym(n)),e}async function ln(n,e){function t(e){const t={deleteFunction:function(){!async function(e,t){const s=a.any(e,rn.vcard("fn")),l=a.any(t,rn.vcard("fn")),c=a.each(null,rn.owl("sameAs"),e,t.doc());let u=[];c.forEach(n=>{a.statementsMatching(n,rn.owl("sameAs"),e,t.doc())&&(u=u.concat(n))});let p=e;if(u.length>0&&(p=u[0]),a.each(null,rn.vcard("hasMember"),p).length<2)alert("Must be a member of at least one group. Add to another group first.");else if(confirm("Remove "+s+" from group "+l+"?")){let e=a.statementsMatching(n,void 0,void 0,t.doc()).concat(a.statementsMatching(void 0,void 0,n,t.doc()));u.forEach(n=>{a.statementsMatching(n,rn.owl("sameAs"),void 0,t.doc()).length<2&&(e=e.concat(a.statementsMatching(void 0,void 0,n,t.doc())))}),a.updater.update(e,[],function(n,e,o){if(!e){const n="Error removing member from group "+t+": "+o;i.parentNode.appendChild(d.widgets.errorMessageBlock(r,n,"pink"))}}),console.log("Removed "+s+" from group "+l),a.fetcher.unload(t.doc()),await a.fetcher.load(t.doc()),o()}}(n,e)},noun:"membership"};return d.widgets.personTR(r,null,e,t)}function o(){an.syncTableToArray(i,dn(n),t)}const{dom:r}=e,a=e.session.store,i=r.createElement("table");return await async function(n=null){if(!n&&!(n=a.any(void 0,rn.vcard("includesGroup"))))return;const e=a.any(n,rn.vcard("groupIndex")),t=n?a.each(n,rn.vcard("includesGroup"),null,e):[];await a.fetcher.load(t)}(),i.refresh=o,o(),i}const cn='# This turtle file defines the forms used in the contacts management\n#\n# Individuals and orgs are in one file as they both\n# share some forms (address etc) and also interactions (roles)\n\n# Forms documentation: https://solidos.github.io/solid-ui/docs/forms-intro.html\n\n@prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>.\n@prefix dct: <http://purl.org/dc/terms/>.\n@prefix foaf: <http://xmlns.com/foaf/0.1/>.\n@prefix owl: <http://www.w3.org/2002/07/owl#>.\n@prefix prov: <http://www.w3.org/ns/prov#>.\n@prefix ui: <http://www.w3.org/ns/ui#>.\n@prefix schema: <http://schema.org/>.\n@prefix solid: <http://www.w3.org/ns/solid/terms#>.\n@prefix vcard: <http://www.w3.org/2006/vcard/ns#>.\n@prefix : <#>.\n\n\n############# For individual:\n:individualForm a ui:Form ;\n dct:title "Contact details for a person" ;\n ui:parts (\n :fullNameField\n :roleField\n :orgNameField\n # :addressesComment\n :addresses\n # :emailComment\n :eMails\n # :telephoneComment\n :telephones\n :birthdayField\n # :noteComment\n :noteField \n ) .\n\n :fullNameField\n a ui:SingleLineTextField ;\n ui:label "Name";\n ui:maxLength "128" ;\n ui:property vcard:fn .\n\n :roleField\n a ui:SingleLineTextField ;\n ui:suppressEmptyUneditable true;\n ui:maxLength "128" ;\n ui:property vcard:role .\n\n :orgNameField\n a ui:SingleLineTextField ;\n ui:suppressEmptyUneditable true;\n ui:maxLength "128" ;\n ui:property vcard:organization-name .\n\n :addresses a ui:Multiple ;\n dct:title "Address details" ;\n ui:part :oneAddress ;\n ui:property vcard:hasAddress .\n\n :oneAddress a ui:Group ;\n ui:parts ( \n :id1409437207443 :id1409437292400 \n :id1409437421996 :id1409437467649 \n :id1409437569420 ). \n\n :id1409437207443\n a ui:SingleLineTextField ;\n ui:maxLength "128" ;\n ui:property vcard:street-address .\n\n :id1409437292400\n a ui:SingleLineTextField ;\n ui:maxLength "128" ;\n ui:property vcard:locality .\n\n :id1409437421996\n a ui:SingleLineTextField ;\n ui:maxLength "25" ;\n ui:property vcard:postal-code .\n\n :id1409437467649\n a ui:SingleLineTextField ;\n ui:maxLength "128" ;\n ui:property vcard:region .\n\n :id1409437569420\n a ui:SingleLineTextField ;\n ui:maxLength "128" ;\n ui:property vcard:country-name .\n\n\n :eMails a ui:Multiple ;\n ui:part :oneEMail ;\n ui:property vcard:hasEmail .\n\n :oneEMail a ui:Group ; # hint: side by side is good\n ui:part :emailValue, :emailType ;\n ui:parts ( :emailType :emailValue ).\n\n :emailValue\n a ui:EmailField ; ui:label "email";\n ui:property vcard:value .\n\n :emailType\n a ui:Classifier ;\n ui:canMintNew "0" ;\n ui:category vcard:Type ;\n ui:from vcard:Type ;\n ui:property rdf:type .\n\n :telephones a ui:Multiple ;\n ui:part :onetelephone ;\n ui:property vcard:hasTelephone .\n\n :onetelephone\n a ui:Group ;\n ui:part :telephoneValue, :telephoneType ;\n ui:parts ( :telephoneType :telephoneValue ).\n\n :telephoneValue\n a ui:PhoneField ;\n ui:property vcard:value .\n\n :telephoneType\n a ui:Classifier ;\n ui:canMintNew "0" ;\n ui:category vcard:TelephoneType ;\n ui:from vcard:Type ;\n ui:property rdf:type .\n\n :birthdayField a ui:DateField;\n ui:label "Born"@en;\n ui:suppressEmptyUneditable true;\n ui:property vcard:bday .\n\n :noteField\n a ui:MultiLineTextField ;\n ui:suppressEmptyUneditable true;\n ui:property vcard:note .\n\n# Ontology additions or interpretations needed for the form to work well\n\n# The ontology file doesn\'t make them disjoint. This makes the selector be a choice.\nvcard:TelephoneType owl:disjointUnionOf ( vcard:Cell vcard:Home vcard:Work) .\nvcard:Type owl:disjointUnionOf (vcard:Home vcard:Work) . # for email\n\n# Better field labels\nvcard:Cell ui:label "mobile"@en . # app will make initial caps if necessary\nvcard:hasAddress ui:label "address"@en .\nvcard:bday ui:label "born"@en.\nvcard:hasEmail ui:label "email"@en .\nvcard:hasTelephone ui:label "phone"@en .\nvcard:note ui:label "notes"@en .\n\n\n############ For organizations\n\n:organizationForm a ui:Form ; \n dct:title "Contact details for an organization";\n ui:parts (\n :OrgClassifier\n :fullNameField\n :homePageURIField\n :addresses\n :eMails\n :telephones\n :noteField ) .\n\n :OrgClassifier a ui:Classifier; \n ui:label "What sort of organization?"@en;\n ui:category solid:InterestingOrganization .\n\n :homePageURIField a ui:NamedNodeURIField;\n ui:label "Homepage"@en;\n ui:property schema:url .\n\n# Ontology data to drive the :OrgClassifier classifier\n solid:InterestingOrganization owl:disjointUnionOf (\n # Airline - a Corporation\n # Consortium - a Corporation or a NGO\n schema:Corporation\n schema:EducationalOrganization\n schema:ResearchOrganization # Proposed. https://github.com/schemaorg/schemaorg/issues/2877\n # FundingScheme - eh?\n schema:GovernmentOrganization\n # LibrarySystem\n # LocalBusiness - Corporation\n # MedicalOrganization - a Corporation or a NGO\n schema:NGO\n # NewsMediaOrganization - a Corporation or a NGO\n schema:PerformingGroup # a band\n schema:Project # like Solid\n schema:SportsOrganization) .\n';var un=a(479),pn={};pn.styleTagTransform=y(),pn.setAttributes=g(),pn.insert=h().bind(null,"head"),pn.domAPI=A(),pn.insertStyleElement=C(),u()(un.A,pn),un.A&&un.A.locals&&un.A.locals;var An=a(434),mn={};mn.styleTagTransform=y(),mn.setAttributes=g(),mn.insert=h().bind(null,"head"),mn.domAPI=A(),mn.insertStyleElement=C(),u()(An.A,mn),An.A&&An.A.locals&&An.A.locals;const hn="https://solidos.github.io/contacts-pane/src/ontology/";function fn(n,e,t,o){const r=o||hn+t,a=(0,l.sym)(r);n.holds(void 0,void 0,void 0,a)||(0,l.parse)(e,n,r,"text/turtle",()=>null)}const gn=d.ns,bn=s.store,Cn="individualAndOrganizationForm.ttl";async function wn(n,e,t,o){const r=bn.findTypeURIs(t),a=!(!r[gn.vcard("Organization").uri]&&!r[gn.schema("Organization").uri]),i=bn.updater.editable(t.doc().uri,bn);fn(bn,cn,Cn);const c=d.ns.vcard("Type").doc().uri;fn(bn,'@prefix : <http://www.w3.org/2006/vcard/ns#> .\n@prefix owl: <http://www.w3.org/2002/07/owl#> .\n@prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#> .\n@prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#> .\n@prefix xml: <http://www.w3.org/XML/1998/namespace> .\n@prefix xsd: <http://www.w3.org/2001/XMLSchema#> .\n\n:Acquaintance a owl:Class ;\n rdfs:label "Acquaintance"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Agent a owl:Class ;\n rdfs:label "Agent"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:BBS a owl:Class ;\n rdfs:label "BBS"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :TelephoneType ;\n owl:deprecated true .\n\n:Car a owl:Class ;\n rdfs:label "Car"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :TelephoneType ;\n owl:deprecated true .\n\n:Cell a owl:Class ;\n rdfs:label "Cell"@en ;\n rdfs:comment "Also called mobile telephone"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :TelephoneType .\n\n:Child a owl:Class ;\n rdfs:label "Child"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Colleague a owl:Class ;\n rdfs:label "Colleague"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Contact a owl:Class ;\n rdfs:label "Contact"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Coresident a owl:Class ;\n rdfs:label "Coresident"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Coworker a owl:Class ;\n rdfs:label "Coworker"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Crush a owl:Class ;\n rdfs:label "Crush"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Date a owl:Class ;\n rdfs:label "Date"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Dom a owl:Class ;\n rdfs:label "Dom"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Type ;\n owl:deprecated true .\n\n:Emergency a owl:Class ;\n rdfs:label "Emergency"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Fax a owl:Class ;\n rdfs:label "Fax"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :TelephoneType .\n\n:Female a owl:Class ;\n rdfs:label "Female"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Gender .\n\n:Friend a owl:Class ;\n rdfs:label "Friend"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Home a owl:Class ;\n rdfs:label "Home"@en ;\n rdfs:comment "This implies that the property is related to an individual\'s personal life"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Type .\n\n:ISDN a owl:Class ;\n rdfs:label "ISDN"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Type ;\n owl:deprecated true .\n\n:Internet a owl:Class ;\n rdfs:label "Internet"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Type ;\n owl:deprecated true .\n\n:Intl a owl:Class ;\n rdfs:label "Intl"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Type ;\n owl:deprecated true .\n\n:Kin a owl:Class ;\n rdfs:label "Kin"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Label a owl:Class ;\n rdfs:label "Label"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Type ;\n owl:deprecated true .\n\n:Male a owl:Class ;\n rdfs:label "Male"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Gender .\n\n:Me a owl:Class ;\n rdfs:label "Me"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Met a owl:Class ;\n rdfs:label "Met"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Modem a owl:Class ;\n rdfs:label "Modem"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :TelephoneType ;\n owl:deprecated true .\n\n:Msg a owl:Class ;\n rdfs:label "Msg"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :TelephoneType ;\n owl:deprecated true .\n\n:Muse a owl:Class ;\n rdfs:label "Muse"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Neighbor a owl:Class ;\n rdfs:label "Neighbor"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:None a owl:Class ;\n rdfs:label "None"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Gender .\n\n:Other a owl:Class ;\n rdfs:label "Other"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Gender .\n\n:PCS a owl:Class ;\n rdfs:label "PCS"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :TelephoneType ;\n owl:deprecated true .\n\n:Pager a owl:Class ;\n rdfs:label "Pager"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :TelephoneType .\n\n:Parcel a owl:Class ;\n rdfs:label "Parcel"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Type ;\n owl:deprecated true .\n\n:Parent a owl:Class ;\n rdfs:label "Parent"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Postal a owl:Class ;\n rdfs:label "Postal"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Type ;\n owl:deprecated true .\n\n:Pref a owl:Class ;\n rdfs:label "Pref"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Type ;\n owl:deprecated true .\n\n:Sibling a owl:Class ;\n rdfs:label "Sibling"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Spouse a owl:Class ;\n rdfs:label "Spouse"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Sweetheart a owl:Class ;\n rdfs:label "Sweetheart"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Tel a owl:Class ;\n rdfs:label "Tel"@en ;\n rdfs:comment "This class is deprecated. Use the hasTelephone object property."@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:deprecated true .\n\n:Text a owl:Class ;\n rdfs:label "Text"@en ;\n rdfs:comment "Also called sms telephone"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :TelephoneType .\n\n:TextPhone a owl:Class ;\n rdfs:label "Text phone"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :TelephoneType .\n\n:Unknown a owl:Class ;\n rdfs:label "Unknown"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Gender .\n\n:Video a owl:Class ;\n rdfs:label "Video"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :TelephoneType .\n\n:Voice a owl:Class ;\n rdfs:label "Voice"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :TelephoneType .\n\n:Work a owl:Class ;\n rdfs:label "Work"@en ;\n rdfs:comment "This implies that the property is related to an individual\'s work place"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Type .\n\n:X400 a owl:Class ;\n rdfs:label "X400"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Type ;\n owl:deprecated true .\n\n:adr a owl:ObjectProperty ;\n rdfs:label "address"@en ;\n rdfs:comment "This object property has been mapped"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :hasAddress .\n\n:agent a owl:ObjectProperty ;\n rdfs:label "agent"@en ;\n rdfs:comment "This object property has been deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:deprecated true .\n\n:anniversary a owl:DatatypeProperty ;\n rdfs:label "anniversary"@en ;\n rdfs:comment "The date of marriage, or equivalent, of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range [ a rdfs:Datatype ;\n owl:unionOf ( xsd:dateTime xsd:gYear ) ] .\n\n:bday a owl:DatatypeProperty ;\n rdfs:label "birth date"@en ;\n rdfs:comment "To specify the birth date of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range [ a rdfs:Datatype ;\n owl:unionOf ( xsd:dateTime xsd:dateTimeStamp xsd:gYear ) ] .\n\n:category a owl:DatatypeProperty ;\n rdfs:label "category"@en ;\n rdfs:comment "The category information about the object, also known as tags"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:class a owl:DatatypeProperty ;\n rdfs:label "class"@en ;\n rdfs:comment "This data property has been deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:deprecated true .\n\n:email a owl:ObjectProperty ;\n rdfs:label "email"@en ;\n rdfs:comment "This object property has been mapped"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :hasEmail .\n\n:extended-address a owl:DatatypeProperty ;\n rdfs:label "extended address"@en ;\n rdfs:comment "This data property has been deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:deprecated true .\n\n:geo a owl:ObjectProperty ;\n rdfs:label "geo"@en ;\n rdfs:comment "This object property has been mapped"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :hasGeo .\n\n:hasAdditionalName a owl:ObjectProperty ;\n rdfs:label "has additional name"@en ;\n rdfs:comment "Used to support property parameters for the additional name data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasCalendarBusy a owl:ObjectProperty ;\n rdfs:label "has calendar busy"@en ;\n rdfs:comment "To specify the busy time associated with the object. (Was called FBURL in RFC6350)"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasCalendarLink a owl:ObjectProperty ;\n rdfs:label "has calendar link"@en ;\n rdfs:comment "To specify the calendar associated with the object. (Was called CALURI in RFC6350)"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasCalendarRequest a owl:ObjectProperty ;\n rdfs:label "has calendar request"@en ;\n rdfs:comment "To specify the calendar user address to which a scheduling request be sent for the object. (Was called CALADRURI in RFC6350)"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasCategory a owl:ObjectProperty ;\n rdfs:label "has category"@en ;\n rdfs:comment "Used to support property parameters for the category data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasCountryName a owl:ObjectProperty ;\n rdfs:label "has country name"@en ;\n rdfs:comment "Used to support property parameters for the country name data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasFN a owl:ObjectProperty ;\n rdfs:label "has formatted name"@en ;\n rdfs:comment "Used to support property parameters for the formatted name data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasFamilyName a owl:ObjectProperty ;\n rdfs:label "has family name"@en ;\n rdfs:comment "Used to support property parameters for the family name data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasGender a owl:ObjectProperty ;\n rdfs:label "has gender"@en ;\n rdfs:comment "To specify the sex or gender identity of the object. URIs are recommended to enable interoperable sex and gender codes to be used."@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasGivenName a owl:ObjectProperty ;\n rdfs:label "has given name"@en ;\n rdfs:comment "Used to support property parameters for the given name data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasHonorificPrefix a owl:ObjectProperty ;\n rdfs:label "has honorific prefix"@en ;\n rdfs:comment "Used to support property parameters for the honorific prefix data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasHonorificSuffix a owl:ObjectProperty ;\n rdfs:label "has honorific suffix"@en ;\n rdfs:comment "Used to support property parameters for the honorific suffix data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasInstantMessage a owl:ObjectProperty ;\n rdfs:label "has messaging"@en ;\n rdfs:comment "To specify the instant messaging and presence protocol communications with the object. (Was called IMPP in RFC6350)"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasLanguage a owl:ObjectProperty ;\n rdfs:label "has language"@en ;\n rdfs:comment "Used to support property parameters for the language data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasLocality a owl:ObjectProperty ;\n rdfs:label "has locality"@en ;\n rdfs:comment "Used to support property parameters for the locality data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasNickname a owl:ObjectProperty ;\n rdfs:label "has nickname"@en ;\n rdfs:comment "Used to support property parameters for the nickname data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:seeAlso :nickname .\n\n:hasNote a owl:ObjectProperty ;\n rdfs:label "has note"@en ;\n rdfs:comment "Used to support property parameters for the note data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasOrganizationName a owl:ObjectProperty ;\n rdfs:label "has organization name"@en ;\n rdfs:comment "Used to support property parameters for the organization name data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasOrganizationUnit a owl:ObjectProperty ;\n rdfs:label "has organization unit name"@en ;\n rdfs:comment "Used to support property parameters for the organization unit name data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasPostalCode a owl:ObjectProperty ;\n rdfs:label "has postal code"@en ;\n rdfs:comment "Used to support property parameters for the postal code data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasRegion a owl:ObjectProperty ;\n rdfs:label "has region"@en ;\n rdfs:comment "Used to support property parameters for the region data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasRelated a owl:ObjectProperty ;\n rdfs:label "has related"@en ;\n rdfs:comment "To specify a relationship between another entity and the entity represented by this object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasRole a owl:ObjectProperty ;\n rdfs:label "has role"@en ;\n rdfs:comment "Used to support property parameters for the role data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasSource a owl:ObjectProperty ;\n rdfs:label "has source"@en ;\n rdfs:comment "To identify the source of directory information of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasStreetAddress a owl:ObjectProperty ;\n rdfs:label "has street address"@en ;\n rdfs:comment "Used to support property parameters for the street address data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasTitle a owl:ObjectProperty ;\n rdfs:label "has title"@en ;\n rdfs:comment "Used to support property parameters for the title data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasUID a owl:ObjectProperty ;\n rdfs:label "has uid"@en ;\n rdfs:comment "To specify a value that represents a globally unique identifier corresponding to the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasValue a owl:ObjectProperty ;\n rdfs:label "has value"@en ;\n rdfs:comment "Used to indicate the resource value of an object property that requires property parameters"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:label a owl:DatatypeProperty ;\n rdfs:label "label"@en ;\n rdfs:comment "This data property has been deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:deprecated true .\n\n:language a owl:DatatypeProperty ;\n rdfs:label "language"@en ;\n rdfs:comment "To specify the language that may be used for contacting the object. May also be used as a property parameter."@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:latitude a owl:DatatypeProperty ;\n rdfs:label "latitude"@en ;\n rdfs:comment "This data property has been deprecated. See hasGeo"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:deprecated true .\n\n:longitude a owl:DatatypeProperty ;\n rdfs:label "longitude"@en ;\n rdfs:comment "This data property has been deprecated. See hasGeo"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:deprecated true .\n\n:mailer a owl:DatatypeProperty ;\n rdfs:label "mailer"@en ;\n rdfs:comment "This data property has been deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:deprecated true .\n\n:note a owl:DatatypeProperty ;\n rdfs:label "note"@en ;\n rdfs:comment "A note associated with the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:org a owl:ObjectProperty ;\n rdfs:label "organization"@en ;\n rdfs:comment "This object property has been mapped. Use the organization-name data property."@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :organization-name .\n\n:organization-unit a owl:DatatypeProperty ;\n rdfs:label "organizational unit name"@en ;\n rdfs:comment "To specify the organizational unit name associated with the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string ;\n rdfs:subPropertyOf :organization-name .\n\n:post-office-box a owl:DatatypeProperty ;\n rdfs:label "post office box"@en ;\n rdfs:comment "This data property has been deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:deprecated true .\n\n:prodid a owl:DatatypeProperty ;\n rdfs:label "product id"@en ;\n rdfs:comment "To specify the identifier for the product that created the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:rev a owl:DatatypeProperty ;\n rdfs:label "revision"@en ;\n rdfs:comment "To specify revision information about the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:dateTime .\n\n:role a owl:DatatypeProperty ;\n rdfs:label "role"@en ;\n rdfs:comment "To specify the function or part played in a particular situation by the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:sort-string a owl:DatatypeProperty ;\n rdfs:label "sort as"@en ;\n rdfs:comment "To specify the string to be used for national-language-specific sorting. Used as a property parameter only."@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:title a owl:DatatypeProperty ;\n rdfs:label "title"@en ;\n rdfs:comment "To specify the position or job of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:tz a owl:DatatypeProperty ;\n rdfs:label "time zone"@en ;\n rdfs:comment "To indicate time zone information that is specific to the object. May also be used as a property parameter."@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:value a owl:DatatypeProperty ;\n rdfs:label "value"@en ;\n rdfs:comment "Used to indicate the literal value of a data property that requires property parameters"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:Address a owl:Class ;\n rdfs:label "Address"@en ;\n rdfs:comment "To specify the components of the delivery address for the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentClass [ a owl:Class ;\n owl:unionOf ( [ a owl:Class ;\n owl:intersectionOf ( [ a owl:Restriction ;\n owl:onProperty :country-name ;\n owl:someValuesFrom xsd:string ] [ a owl:Restriction ;\n owl:maxCardinality "1"^^xsd:nonNegativeInteger ;\n owl:onProperty :country-name ] ) ] [ a owl:Class ;\n owl:intersectionOf ( [ a owl:Restriction ;\n owl:onProperty :locality ;\n owl:someValuesFrom xsd:string ] [ a owl:Restriction ;\n owl:maxCardinality "1"^^xsd:nonNegativeInteger ;\n owl:onProperty :locality ] ) ] [ a owl:Class ;\n owl:intersectionOf ( [ a owl:Restriction ;\n owl:onProperty :postal-code ;\n owl:someValuesFrom xsd:string ] [ a owl:Restriction ;\n owl:maxCardinality "1"^^xsd:nonNegativeInteger ;\n owl:onProperty :postal-code ] ) ] [ a owl:Class ;\n owl:intersectionOf ( [ a owl:Restriction ;\n owl:onProperty :region ;\n owl:someValuesFrom xsd:string ] [ a owl:Restriction ;\n owl:maxCardinality "1"^^xsd:nonNegativeInteger ;\n owl:onProperty :region ] ) ] [ a owl:Class ;\n owl:intersectionOf ( [ a owl:Restriction ;\n owl:onProperty :street-address ;\n owl:someValuesFrom xsd:string ] [ a owl:Restriction ;\n owl:maxCardinality "1"^^xsd:nonNegativeInteger ;\n owl:onProperty :street-address ] ) ] ) ] .\n\n:Email a owl:Class ;\n rdfs:label "Email"@en ;\n rdfs:comment "To specify the electronic mail address for communication with the object the vCard represents. Use the hasEmail object property."@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:deprecated true .\n\n:Group a owl:Class ;\n rdfs:label "Group"@en ;\n rdfs:comment "Object representing a group of persons or entities. A group object will usually contain hasMember properties to specify the members of the group."@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Kind ;\n owl:disjointWith :Individual,\n :Location,\n :Organization ;\n owl:equivalentClass [ a owl:Class ;\n owl:intersectionOf ( [ a owl:Restriction ;\n owl:onProperty :hasMember ;\n owl:someValuesFrom :Kind ] [ a owl:Restriction ;\n owl:minQualifiedCardinality "1"^^xsd:nonNegativeInteger ;\n owl:onClass :Kind ;\n owl:onProperty :hasMember ] ) ] .\n\n:Individual a owl:Class ;\n rdfs:label "Individual"@en ;\n rdfs:comment "An object representing a single person or entity"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Kind ;\n owl:disjointWith :Location,\n :Organization .\n\n:Name a owl:Class ;\n rdfs:label "Name"@en ;\n rdfs:comment "To specify the components of the name of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentClass [ a owl:Class ;\n owl:unionOf ( [ a owl:Class ;\n owl:intersectionOf ( [ a owl:Restriction ;\n owl:onProperty :additional-name ;\n owl:someValuesFrom xsd:string ] [ a owl:Restriction ;\n owl:minCardinality "0"^^xsd:nonNegativeInteger ;\n owl:onProperty :additional-name ] ) ] [ a owl:Class ;\n owl:intersectionOf ( [ a owl:Restriction ;\n owl:onProperty :family-name ;\n owl:someValuesFrom xsd:string ] [ a owl:Restriction ;\n owl:maxCardinality "1"^^xsd:nonNegativeInteger ;\n owl:onProperty :family-name ] ) ] [ a owl:Class ;\n owl:intersectionOf ( [ a owl:Restriction ;\n owl:onProperty :given-name ;\n owl:someValuesFrom xsd:string ] [ a owl:Restriction ;\n owl:maxCardinality "1"^^xsd:nonNegativeInteger ;\n owl:onProperty :given-name ] ) ] [ a owl:Class ;\n owl:intersectionOf ( [ a owl:Restriction ;\n owl:onProperty :honorific-prefix ;\n owl:someValuesFrom xsd:string ] [ a owl:Restriction ;\n owl:minCardinality "0"^^xsd:nonNegativeInteger ;\n owl:onProperty :honorific-prefix ] ) ] [ a owl:Class ;\n owl:intersectionOf ( [ a owl:Restriction ;\n owl:onProperty :honorific-suffix ;\n owl:someValuesFrom xsd:string ] [ a owl:Restriction ;\n owl:minCardinality "0"^^xsd:nonNegativeInteger ;\n owl:onProperty :honorific-suffix ] ) ] ) ] .\n\n:VCard a owl:Class ;\n rdfs:label "VCard"@en ;\n rdfs:comment "The vCard class is equivalent to the new Kind class, which is the parent for the four explicit types of vCards (Individual, Organization, Location, Group)"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentClass :Kind .\n\n:fn a owl:DatatypeProperty ;\n rdfs:label "formatted name"@en ;\n rdfs:comment "The formatted text corresponding to the name of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:hasAddress a owl:ObjectProperty ;\n rdfs:label "has address"@en ;\n rdfs:comment "To specify the components of the delivery address for the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range :Address .\n\n:hasEmail a owl:ObjectProperty ;\n rdfs:label "has email"@en ;\n rdfs:comment "To specify the electronic mail address for communication with the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range :Email .\n\n:hasGeo a owl:ObjectProperty ;\n rdfs:label "has geo"@en ;\n rdfs:comment "To specify information related to the global positioning of the object. May also be used as a property parameter."@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasKey a owl:ObjectProperty ;\n rdfs:label "has key"@en ;\n rdfs:comment "To specify a public key or authentication certificate associated with the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :key .\n\n:hasLogo a owl:ObjectProperty ;\n rdfs:label "has logo"@en ;\n rdfs:comment "To specify a graphic image of a logo associated with the object "@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :logo .\n\n:hasName a owl:ObjectProperty ;\n rdfs:label "has name"@en ;\n rdfs:comment "To specify the components of the name of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range :Name ;\n owl:equivalentProperty :n .\n\n:hasPhoto a owl:ObjectProperty ;\n rdfs:label "has photo"@en ;\n rdfs:comment "To specify an image or photograph information that annotates some aspect of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :photo .\n\n:hasSound a owl:ObjectProperty ;\n rdfs:label "has sound"@en ;\n rdfs:comment "To specify a digital sound content information that annotates some aspect of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :sound .\n\n:hasTelephone a owl:ObjectProperty ;\n rdfs:label "has telephone"@en ;\n rdfs:comment "To specify the telephone number for telephony communication with the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :tel .\n\n:hasURL a owl:ObjectProperty ;\n rdfs:label "has url"@en ;\n rdfs:comment "To specify a uniform resource locator associated with the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :url .\n\n:key a owl:ObjectProperty ;\n rdfs:label "key"@en ;\n rdfs:comment "This object property has been mapped"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :hasKey .\n\n:logo a owl:ObjectProperty ;\n rdfs:label "logo"@en ;\n rdfs:comment "This object property has been mapped"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :hasLogo .\n\n:n a owl:ObjectProperty ;\n rdfs:label "name"@en ;\n rdfs:comment "This object property has been mapped"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :hasName .\n\n:nickname a owl:DatatypeProperty ;\n rdfs:label "nickname"@en ;\n rdfs:comment "The nick name associated with the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:photo a owl:ObjectProperty ;\n rdfs:label "photo"@en ;\n rdfs:comment "This object property has been mapped"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :hasPhoto .\n\n:sound a owl:ObjectProperty ;\n rdfs:label "sound"@en ;\n rdfs:comment "This object property has been mapped"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :hasSound .\n\n:tel a owl:ObjectProperty ;\n rdfs:label "telephone"@en ;\n rdfs:comment "This object property has been mapped"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :hasTelephone .\n\n:url a owl:ObjectProperty ;\n rdfs:label "url"@en ;\n rdfs:comment "This object property has been mapped"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :hasURL .\n\n:Location a owl:Class ;\n rdfs:label "Location"@en ;\n rdfs:comment "An object representing a named geographical place"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Kind ;\n owl:disjointWith :Organization .\n\n:additional-name a owl:DatatypeProperty ;\n rdfs:label "additional name"@en ;\n rdfs:comment "The additional name associated with the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:country-name a owl:DatatypeProperty ;\n rdfs:label "country name"@en ;\n rdfs:comment "The country name associated with the address of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:family-name a owl:DatatypeProperty ;\n rdfs:label "family name"@en ;\n rdfs:comment "The family name associated with the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:given-name a owl:DatatypeProperty ;\n rdfs:label "given name"@en ;\n rdfs:comment "The given name associated with the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:hasMember a owl:ObjectProperty ;\n rdfs:label "has member"@en ;\n rdfs:comment "To include a member in the group this object represents. (This property can only be used by Group individuals)"@en ;\n rdfs:domain :Group ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range :Kind .\n\n:honorific-prefix a owl:DatatypeProperty ;\n rdfs:label "honorific prefix"@en ;\n rdfs:comment "The honorific prefix of the name associated with the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:honorific-suffix a owl:DatatypeProperty ;\n rdfs:label "honorific suffix"@en ;\n rdfs:comment "The honorific suffix of the name associated with the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:locality a owl:DatatypeProperty ;\n rdfs:label "locality"@en ;\n rdfs:comment "The locality (e.g. city or town) associated with the address of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:organization-name a owl:DatatypeProperty ;\n rdfs:label "organization name"@en ;\n rdfs:comment "To specify the organizational name associated with the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:postal-code a owl:DatatypeProperty ;\n rdfs:label "postal code"@en ;\n rdfs:comment "The postal code associated with the address of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:region a owl:DatatypeProperty ;\n rdfs:label "region"@en ;\n rdfs:comment "The region (e.g. state or province) associated with the address of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:street-address a owl:DatatypeProperty ;\n rdfs:label "street address"@en ;\n rdfs:comment "The street address associated with the address of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:Organization a owl:Class ;\n rdfs:label "Organization"@en ;\n rdfs:comment """An object representing an organization. An organization is a single entity, and might represent a business or government, a department or division within a business or government, a club, an association, or the like.\n"""@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Kind .\n\n:Gender a owl:Class ;\n rdfs:label "Gender"@en ;\n rdfs:comment "Used for gender codes. The URI of the gender code must be used as the value for Gender."@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:Kind a owl:Class ;\n rdfs:label "Kind"@en ;\n rdfs:comment "The parent class for all objects"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentClass [ a owl:Restriction ;\n owl:minQualifiedCardinality "1"^^xsd:nonNegativeInteger ;\n owl:onDataRange xsd:string ;\n owl:onProperty :fn ],\n :VCard .\n\n:Type a owl:Class ;\n rdfs:label "Type"@en ;\n rdfs:comment "Used for type codes. The URI of the type code must be used as the value for Type."@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:TelephoneType a owl:Class ;\n rdfs:label "Phone"@en ;\n rdfs:comment "Used for telephone type codes. The URI of the telephone type code must be used as the value for the Telephone Type."@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:RelatedType a owl:Class ;\n rdfs:label "Relation Type"@en ;\n rdfs:comment "Used for relation type codes. The URI of the relation type code must be used as the value for the Relation Type."@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n<http://www.w3.org/2006/vcard/ns> a owl:Ontology ;\n rdfs:label "Ontology for vCard"@en ;\n rdfs:comment "Ontology for vCard based on RFC6350"@en ;\n owl:versionInfo "Final"@en .\n\n\n',"vcard.ttl",c);try{await bn.fetcher.load(t.doc())}catch(t){u="Error: Failed to load profile card: "+t,console.log(u),e.appendChild(d.widgets.errorMessageBlock(n,u,"pink"))}var u;e.classList.add("individualPane"),s.authn.checkUser(),e.appendChild(on(n,t));const p=a?"organizationForm":"individualForm";!function(n,e,t,o,r,a,i,s){const c=hn+o,u=s||"this",p=(0,l.Namespace)(c+"#")(u);fn(r,t,o,c),d.widgets.appendForm(a,n,{},e,p,i,(n,e)=>{n||d.widgets.errorMessageBlock(a,e)})}(e,t,cn,Cn,s.store,n,t.doc(),p),e.appendChild(await ln(t,o)),d.widgets.attachmentList(n,t,e,{modify:i}),a?e.appendChild(await async function(n,e){let t=P.sym("http://www.wikidata.org/wiki/Q43229"),o="Organization";for(const e in T)P.holds(n,B.rdf("type"),B.schema(e),n.doc())&&(t=P.sym(T[e]),o=e,console.log(` renderPublicIdControl bingo: ${e} -> ${t}`));return O(n,e,{longPrompt:`If you know the ${F} of this ${o}, you can do more stuff with it.\n To record its ${F}, drag it onto the plus, or click the magnifyinng glass\n to search for it in WikiData.`,idNoun:F,urlType:B.vcard("PublicId"),dbLookup:!0,class:t,queryParams:D})}(t,o)):e.appendChild(await async function(n,e){return O(n,e,{longPrompt:`If you know someone's ${S}, you can do more stuff with them.\n To record their ${S}, drag it onto the plus, or click the plus\n to enter it by hand.`,idNoun:S,urlType:B.vcard("WebID")})}(t,o))}var yn=a(295),vn={};function En(n,e,t,o,r,a){const i=r.dom,c=s.store,u=d.ns,p=u.vcard,A=i.createElement("div"),m=A.appendChild(i.createElement("table"));m.classList.add("toolsTable");const h=m.appendChild(i.createElement("tr"));h.textContent=d.utils.label(o)+" - tools",h.classList.add("toolsHeader");const f=m.appendChild(i.createElement("tr")).appendChild(i.createElement("div"));f.classList.add("toolsStatusBlock");const g=m.appendChild(i.createElement("tr")),b=g.appendChild(i.createElement("table"));m.appendChild(i.createElement("tr"));const C={target:o,me:a,noun:"address book",div:A,dom:i,statusRegion:f};function w(n){console.log(n),f.appendChild(d.widgets.errorMessageBlock(i,n,"pink"))}return async function(){b.appendChild(d.aclControl.ACLControlBox5(o.dir(),r,"book",c,function(n,e){n||(b.innerHTML="ACL control box Failed: "+e)}));try{await d.login.registrationControl(C,o,u.vcard("AddressBook"))}catch(n){d.widgets.complain(C,"registrationControl: "+n)}console.log("Registration control finished.");const a=g.appendChild(i.createElement("pre"));function m(n){console.log(n),a.textContent+=n+"\n"}const h=A.appendChild(i.createElement("button"));h.textContent="Load main index",h.classList.add("toolsButton"),h.addEventListener("click",async function(n){h.classList.add("toolsButton--loading"),h.classList.remove("toolsButton--error","toolsButton--success");const e=c.any(o,u.vcard("nameEmailIndex"));try{await c.fetcher.load(e)}catch(n){h.classList.remove("toolsButton--loading"),h.classList.add("toolsButton--error"),m("Error: People index has NOT been loaded"+n+"\n")}h.classList.remove("toolsButton--loading"),h.classList.add("toolsButton--success"),m(" People index has been loaded\n")});const f=A.appendChild(i.createElement("button"));f.textContent="Statistics",f.classList.add("toolsButton"),f.addEventListener("click",function(){m(c.each(void 0,p("inAddressBook"),o).length+" cards loaded. ");let n=c.each(o,p("includesGroup"));const t=new Set(n.map(n=>n.uri));n=[...t].map(n=>c.sym(n)),m(n.length+" total groups. ");const r=[];for(const n in e)r.push(n);m(r.length+" selected groups. ")});const y=A.appendChild(i.createElement("button"));y.textContent="Check individual card access of selected groups",y.classList.add("toolsButton"),y.addEventListener("click",async function(n){function t(n){d.acl.fixIndividualCardACL(n,m,function(e,t){m(e?"Success for "+d.utils.label(n):"Failure for "+d.utils.label(n)+": "+t)})}const o=[];for(const n in e)o.push(n);for(let n=0;n<o.length;n++){const e=c.sym(o[n]),r=G(c,e);m(d.utils.label(e)+": "+r.length+" members");for(let n=0;n<r.length;n++){const e=r[n];m(d.utils.label(e)),t(e)}}});const v=A.appendChild(i.createElement("button"));async function E(n){const e=c.any(n,u.vcard("groupIndex")),t=c.any(n,u.vcard("nameEmailIndex"));try{await c.fetcher.load([t,e]);const o=c.each(n,u.vcard("includesGroup"));await c.fetcher.load(o)}catch(n){w("Error loading stuff:"+n)}const o={},r=[];let a=c.each(n,p("includesGroup"));const i=new Set(a.map(n=>n.uri));a=[...i].map(n=>c.sym(n)),m(a.length+" total groups. ");for(let n=0;n<a.length;n++){const e=a[n],t=G(c,e);m(d.utils.label(e)+": "+t.length+" members");for(let n=0;n<t.length;n++)c.allAliases(t[n]).forEach(function(n){o[n.uri]=e})}const s=c.each(void 0,p("inAddressBook"),n);m(s.length+" total cards");for(let n=0;n<s.length;n++)o[s[n].uri]||(r.push(s[n]),m(" groupless "+d.utils.label(s[n])));return m(r.length+" groupless cards."),r}v.textContent="Find duplicate cards",v.classList.add("toolsButton"),v.addEventListener("click",function(n){const e={};e.book=o,e.nameEmailIndex=c.any(o,u.vcard("nameEmailIndex")),m("Loading name index..."),s.store.fetcher.nowOrWhenFetched(e.nameEmailIndex,void 0,function(n,t){function r(n){let t;return Promise.resolve().then(()=>{const o=n.uri.replace("/Group/","/NewGroup/");t=c.sym(o);let r=[];for(let t=0;t<e.uniques.length;t++)r=r.concat(c.connectedStatements(e.uniques[t],n.doc()));const a=new l.Serializer(c).setBase(n.uri);m(" Regenerating group of uniques..."+t);const i=a.statementsToN3(r);return c.fetcher.webOperation("PUT",t,{data:i,contentType:"text/turtle"})}).then(()=>(m(" Done uniques group "+t),!0)).catch(n=>{m("Error saving : "+n)})}m("Loaded name index."),e.cards=[],e.duplicates=[],e.definitive=[],e.nameless=[],e.exactDuplicates=[],e.nameOnlyDuplicates=[],e.uniquesSet=[],e.groupProblems=[],e.nameDupLog=c.sym(o.dir().uri+"dedup-nameDupLog.ttl"),e.exactDupLog=c.sym(o.dir().uri+"dedup-exactDupLog.ttl"),e.nameOnlyErrors=[],e.nameLessZeroData=[],e.nameLessIndex=[],e.namelessUniques=[],e.nameOnlyDuplicatesGroupDiff=[];const a=function(){let n=[];return e.book&&([e.book].forEach(function(e){const t=(e?c.each(e,u.vcard("includesGroup")):[]).map(function(n){return[e,c.any(n,u.vcard("fn")),n]});n=n.concat(t)}),n.sort()),n}();e.groupObjects=a.map(n=>n[2]),m("Loading "+e.groupObjects.length+" groups... "),c.fetcher.load(e.groupObjects).then(function(){return new Promise(function(n){let t,o,r;for(e.cards=c.each(void 0,p("inAddressBook"),e.book),m(e.cards.length+" total cards"),t=0;t<e.cards.length;t++)o=e.cards[t],r=c.anyValue(o,u.vcard("fn")),r?e.definitive[r]===o||(e.definitive[r]?(e.duplicates.length,e.duplicates.push(o)):e.definitive[r]=o):e.nameless.push(o);e.duplicateSet=[];for(let n=0;n<e.duplicates.length;n++)e.duplicateSet[e.duplicates[n].uri]=e.duplicates[n];e.namelessSet=[];for(let n=0;n<e.nameless.length;n++)e.namelessSet[e.nameless[n].uri]=e.nameless[n];e.uniques=[],e.uniqueSet=[];for(let n=0;n<e.cards.length;n++){const t=e.cards[n].uri;e.duplicateSet[t]||e.namelessSet[t]||(e.uniques.push(e.cards[n]),e.uniqueSet[t]=e.cards[n])}m("Uniques: "+e.uniques.length),m(e.nameless.length+" nameless cards."),m(e.duplicates.length+" name-duplicate cards, leaving "+(e.cards.length-e.duplicates.length)),n(!0)})}).then(function(){return new Promise(function(n){m("Groups loaded");for(let n=0;n<e.uniques.length;n++)e.uniquesSet[e.uniques[n].uri]=!0;e.groupMembers=[],c.each(null,u.vcard("hasMember")).forEach(n=>{e.groupMembers=e.groupMembers.concat(G(c,n))}),m(" Naive group members "+e.groupMembers.length),e.groupMemberSet=[];for(let n=0;n<e.groupMembers.length;n++)e.groupMemberSet[e.groupMembers[n].uri]=e.groupMembers[n];e.groupMembers2=[];for(const n in e.groupMemberSet)e.groupMembers2.push(e.groupMemberSet[n]);if(m(" Compact group members "+e.groupMembers2.length),l.keepThisCodeForLaterButDisableFerossConstantConditionPolice){for(let n=0;n<e.groupMembers.length;n++){const t=e.groupMembers[n];e.uniquesSet[t.uri]||(m(" Not in uniques: "+t),e.groupProblems.push(t),e.duplicateSet[t.uri]?m(" ** IN duplicates alas:"+t):m(" **** WTF?"))}m("Problem cards: "+e.groupProblems.length)}n(!0)})}).then(function n(){return e.namelessToCheck=e.namelessToCheck||e.nameless.slice(),m("Nameless check left: "+e.namelessToCheck.length),new Promise(function(t){const o=e.namelessToCheck.shift();if(!o){if(m("namelessUniques: "+e.namelessUniques.length),m("namelessUniques: "+e.namelessUniques),e.namelessUniques.length>0&&confirm("Add all "+e.namelessUniques.length+" nameless cards to the rescued set?")){e.uniques=e.uniques.concat(e.namelessUniques);for(let n=0;n<e.namelessUniques.length;n++)e.uniqueSet[e.namelessUniques[n].uri]=!0}return t(!0)}var r;(r=o,new Promise(function(n){c.fetcher.load(r).then(function(t){m(" Nameless check "+r);const o={};o[u.vcard("hasUID").uri]=!0,o[u.dc("created").uri]=!0,o[u.dc("modified").uri]=!0;const a=(i=r,c.statementsMatching(null,null,null,i.doc()).filter(function(n){return!o[n.predicate.uri]}));var i;if(!a.length)return m(" Zero length "+r),e.nameLessZeroData.push(r),n(!1);const s=new l.Serializer(c).setBase(r.doc().uri).statementsToN3(a),d=e.nameLessIndex[s];if(d){m(" Matches with "+d);const t=c.each(null,u.vcard("hasMember"),r),o=c.each(null,u.vcard("hasMember"),d);for(let a=0;a<t.length;a++){let i=!1;for(let n=0;n<o.length;n++)o[n].sameTerm(t[a])&&(i=!0);if(!i)return m("This one groups: "+t),m("Other one groups: "+o),m("Cant skip this one because it has a group, "+t[a]+", which the other does not."),e.nameOnlyDuplicatesGroupDiff.push(r),n(!1)}console.log("Group check done -- exact duplicate: "+r)}else m("First nameless like: "+r.doc()),m("___________________________________________"),m(s),m("___________________________________________"),e.nameLessIndex[s]=r,e.namelessUniques.push(r);n(!0)}).catch(function(t){m("Cant load a nameless card!: "+t),e.nameOnlyErrors.push(r),n(!1)})})).then(function(e){m(" Nameless check returns "+e),n()})})}).then(()=>new Promise(function(n,e){confirm("Write new clean versions?")?n(!0):e(new Error("User cancelled writing clean versions"))})).then(function(){let n;return Promise.resolve().then(()=>{n=c.sym(e.book.dir().uri+"clean-people.ttl");let t=[];for(let n=0;n<e.uniques.length;n++)t=t.concat(c.connectedStatements(e.uniques[n],e.nameEmailIndex));const o=new l.Serializer(c).setBase(e.nameEmailIndex.uri);m("Serializing index of uniques...");const r=o.statementsToN3(t);return c.fetcher.webOperation("PUT",n,{data:r,contentType:"text/turtle"})}).then(function(){return m("Done uniques log "+n),!0}).catch(function(n){m("Error saving uniques: "+n)})}).then(function(){return m("Saving ALL GROUPS"),Promise.all(e.groupObjects.map(r))}).then(function(){m("Done!")})})});const B=A.appendChild(i.createElement("button"));B.classList.add("toolsButton"),B.textContent="Find individuals with no group",B.addEventListener("click",function(r){m("Loading groups..."),n(e,t,async function(n,e){if(!n)return void m("Load all groups: failed: "+e);const t=c.any(o,u.vcard("nameEmailIndex"));try{await c.fetcher.load(t)}catch(n){w(n)}m("Loaded groups and name index."),E(o),m("Groupless list finished..")})});const x=A.appendChild(i.createElement("button"));x.classList.add("toolsButton"),x.textContent="Put all individuals with no group in a new group",x.addEventListener("click",n=>async function(n){const e=await E(n);if(0===e.length)return void m("No groupless cards found.");const t=await j(n,"ZSortThese");if(confirm(`Add the ${e.length} cards without groups to a ZSortThese group?`))for(const n of e)m(" adding "+n),await q(n,t);m("People moved to group.")}(o));const k=A.appendChild(i.createElement("button"));k.classList.add("toolsButton"),k.textContent="Revert groups to old data model",k.addEventListener("click",n=>async function(n){let e=c.each(n,p("includesGroup"));const t=new Set(e.map(n=>n.uri));e=[...t].map(n=>c.sym(n)),async function(n){let e=[],t=[];n.forEach(n=>{let o=c.statementsMatching(null,u.owl("sameAs"),null,n.doc()).map(n=>n.subject);const r=new Set(o.map(n=>n.uri));o=[...r].map(n=>c.sym(n)),o.forEach(o=>{c.each(o,u.vcard("fn"),null,n.doc()).length||(e=e.concat(c.statementsMatching(o,u.owl("sameAs"),null,n.doc()).concat(c.statementsMatching(void 0,void 0,o,n.doc()))),c.each(o,u.owl("sameAs"),null,n.doc()).forEach(e=>{t=t.concat(l.st(e,u.owl("sameAs"),o,n.doc())).concat(l.st(n,u.vcard("hasMember"),e,n.doc()))}))})}),e.length&&confirm("Groups can be updated to old data model ?")?(await c.updater.updateMany(e,t),alert("Update done")):e.length||alert("Nothing to update.\nAll Groups already use the old data model.")}(e)}(o))}(),A}vn.styleTagTransform=y(),vn.setAttributes=g(),vn.insert=h().bind(null,"head"),vn.domAPI=A(),vn.insertStyleElement=C(),u()(yn.A,vn),yn.A&&yn.A.locals&&yn.A.locals;var Bn=a(903),xn={};xn.styleTagTransform=y(),xn.setAttributes=g(),xn.insert=h().bind(null,"head"),xn.domAPI=A(),xn.insertStyleElement=C(),u()(Bn.A,xn),Bn.A&&Bn.A.locals&&Bn.A.locals;const kn=d.ns,Pn=d.utils,Tn={icon:d.icons.iconBase+"noun_99101.svg",name:"contact",label:function(n,e){const t=e.session.store.findTypeURIs(n);return t[kn.vcard("Individual").uri]||t[kn.vcard("Organization").uri]?"Contact":t[kn.foaf("Person").uri]||t[kn.schema("Person").uri]?"Person":t[kn.vcard("Group").uri]?"Group":t[kn.vcard("AddressBook").uri]?"Address book":null},mintClass:d.ns.vcard("AddressBook"),mintNew:function(n,e){return new Promise(function(t,o){d.login.ensureLoadedProfile(e).then(e=>{console.log("Logged in as "+e.me);const r=e.me,a=e.dom,i=e.div,s=n.session.store,c=d.ns,u=e.newBase||e.newInstance.dir().uri;if((e.instanceClass||c.vcard("AddressBook")).sameTerm(c.vcard("Group"))){const n=e.newInstance||s.sym(e.newBase+"index.ttl#this"),r=n.doc();return s.add(n,c.rdf("type"),c.vcard("Group"),r),s.add(n,c.vcard("fn"),e.instanceName||"untitled group",r),void s.fetcher.putBack(r,{contentType:"text/turtle"}).then(function(n){t(e)}).catch(function(n){o(new Error("Error creating document for new group "+n))})}function p(n){i.appendChild(d.widgets.errorMessageBlock(a,n,"pink"))}let A='@prefix vcard: <http://www.w3.org/2006/vcard/ns#>.\n @prefix ab: <http://www.w3.org/ns/pim/ab#>.\n @prefix dc: <http://purl.org/dc/elements/1.1/>.\n @prefix xsd: <http://www.w3.org/2001/XMLSchema#>.\n\n <#this> a vcard:AddressBook;\n dc:title "New address Book";\n vcard:nameEmailIndex <people.ttl>;\n vcard:groupIndex <groups.ttl>.\n';A+="<#this> <http://www.w3.org/ns/auth/acl#owner> <"+r.uri+">.\n\n";const m=s.sym(u+"index.ttl#this"),h=[{to:"index.ttl",content:A,contentType:"text/turtle"},{to:"groups.ttl",content:"",contentType:"text/turtle"},{to:"people.ttl",content:"",contentType:"text/turtle"},{to:"",existing:!0,aclOptions:{defaultForNew:!0}}];!function n(){function d(e,t){if(!t)return p("Error writing new file "+c.to),o(new Error("Error writing new file "+c.to));V(A,r,f).then(()=>n()).catch(n=>{const e="Error setting access permissions for "+c.to+" : "+n.message;return p(e),o(new Error(e))})}if(0===h.length)!function(n,o){console.log(`New ${o} created at ${n}`);const r=i.appendChild(a.createElement("p"));r.classList.add("claimSuccess"),r.innerHTML="Your <a href='"+n.uri+"'><b>new "+o+"</b></a> is ready. <br/><br/><a href='"+n.uri+"'>Go to new "+o+"</a>";const s=Object.assign({newInstance:n},e);t(s)}(m,"address book");else{var c=h.shift();console.log("Creating new file "+c.to+" in new instance ");var A=l.uri.join(c.to,u),f=c.aclOptions||{};"content"in c?s.fetcher.webOperation("PUT",A,{data:c.content,saveMetadata:!0,contentType:c.contentType}).then(()=>d(0,!0)):"existing"in c?d(0,!0):o(new Error("copy not expected buiding new app!!"))}}()},n=>{e.div.appendChild(d.widgets.errorMessageBlock(n))})})},render:function(n,e,t={}){const o=this;function r(n){p.appendChild(d.widgets.errorMessageBlock(c,n,"pink"))}function a(n,e){n||r("Error: "+e)}function i(n){return d.login.newAppInstance(c,{noun:"address book",appPathSegment:"contactorator.timbl.com"},function(e,t){o.mintNew(n,t,{me:A,div:p,dom:c})})}const c=e.dom,u=e.session.store,p=c.createElement("div"),A=s.authn.currentUser();return d.aclControl.preventBrowserDropEvents(c),p.setAttribute("class","contactPane"),async function(){d.aclControl.preventBrowserDropEvents(c);const o=u.findTypeURIs(n);let A=s.authn.currentUser();const m={target:n,me:A,noun:"address book",div:p,dom:c};function h(n,o,m){u.fetcher.load(n).then(function(o){!function(n,o,m){const h=Pn.label(kn.vcard("AddressBook"));let f=n[0];const g=u.any(f,kn.vcard("groupIndex"));let b={},C={};const w=m.foreignGroup||f;let y=u.any(w,kn.dc("title"))||u.any(w,kn.vcard("fn"));function v(n){if(n)return n;let e;for(const n in b){e=u.sym(n);const t=u.any(void 0,kn.vcard("includesGroup"),e);if(t)return t}throw new Error("findBookFromGroups: Cant find address book which this group is part of")}function E(n){const e=u.any(n,kn.vcard("fn"))||u.any(n,kn.foaf("name"))||u.any(n,kn.vcard("organization-name"));return e?e.value:"???"}function B(n){const e=vn.value.trim().toLowerCase();if(0===e.length)return!0;const t=e.split(" ");for(let e=0;e<t.length;e++){const o=t[e];if(n.toLowerCase().indexOf(o)<0)return!1}return!0}function x(n){gn.innerHTML="loading...",C={},C[n.uri]=!0,k();const e=f?N(n):n;u.fetcher.nowOrWhenFetched(e.doc(),void 0,function(t,o){if(gn.innerHTML="",!t)return a(t,"Can't load card: "+e+": "+o);gn.appendChild(S(c,e,"contact")),gn.appendChild(c.createElement("br")),gn.appendChild(d.widgets.linkIcon(c,e));const r=d.widgets.deleteButtonWithCheck(c,gn,"contact",async function(){const e=n.dir(),t=u.any(n,kn.vcard("fn"));if(confirm("Delete contact "+t+" completely?? "+e)){console.log("Deleting a contact "+t),await T();const o=u.any(f,kn.vcard("nameEmailIndex"));await u.fetcher.load(o);const r=dn(n);let a=[];r.forEach(e=>{Dn(u,n,e.doc()).forEach(n=>{1===Dn(u,n,e.doc()).length&&(a=a.concat(u.statementsMatching(e,kn.vcard("hasMember"),n,e.doc())))})}),await u.updater.updateMany(a),await L(n),await I(u,e),_(),gn.innerHTML="Contact Data Deleted."}});r.classList.add("deleteButton")})}function k(n){let e=0,t=null;for(let n=0;n<fn.children.length;n++){const o=fn.children[n],r=B(E(o.subject));r&&(e++,t=o),o.classList.toggle("selected",r&&!!C[o.subject.uri]),o.classList.toggle("hidden",!r)}1===e&&n&&x(t.subject)}function P(n,e,t){function o(e,o){o.classList.add("group-loading"),u.fetcher.nowOrWhenFetched(e.doc(),void 0,function(s,d){if(!s){const n="Can't load group file: "+e+": "+d;return i.push(n),a(s,n)}o.classList.remove("group-loading"),o.classList.add("selected"),n[e.uri]=!0,R(),_(),r-=1,r||t&&t(0===i.length,i)})}let r=e.children.length;var i=[];for(let n=0;n<e.children.length;n++){const t=e.children[n];o(t.subject,t)}}async function T(){await u.fetcher.load(g);const n=f?u.each(f,kn.vcard("includesGroup"),null,g):[];return await u.fetcher.load(n),n}function D(){let e=[];return m.foreignGroup&&e.push(["",u.any(m.foreignGroup,kn.vcard("fn")),m.foreignGroup]),f&&(n.forEach(function(n){const t=(n?u.each(n,kn.vcard("includesGroup"),null,g):[]).map(function(e){return[n,u.any(e,kn.vcard("fn")),e]});e=e.concat(t)}),e.sort()),e.map(n=>n[2])}function S(n,t,o){const r=e.session.paneRegistry.byName(o).render(t,e);return r.classList.add("renderPane"),r}function F(n,e){let t=E(n),o=E(e);if(t&&o){if(t=t.toLowerCase(),o=o.toLowerCase(),t>o)return 1;if(t<o)return-1}return n.uri>e.uri?1:n.uri<e.uri?-1:0}async function L(n){console.log("deleteThingAndDoc: "+n);const e=u.statementsMatching(n).concat(u.statementsMatching(void 0,void 0,n));try{await u.updater.updateMany(e),console.log("Deleting resoure "+n.doc()),await u.fetcher.delete(n.doc()),console.log("Delete thing "+n+": complete.")}catch(e){r("Error deleting thing "+n+": "+e)}}function I(n,e){return new Promise(function(t){n.fetcher.load(e).then(function(){const o=n.each(e,kn.ldp("contains")).map(e=>{if(n.holds(e,kn.rdf("type"),kn.ldp("BasicContainer")))return I(n,e);if(console.log("deleteRecirsive file: "+e),!confirm(" Really DELETE File "+e))throw new Error("User aborted delete file");return n.fetcher.webOperation("DELETE",e.uri)});if(console.log("deleteRecirsive folder: "+e),!confirm(" Really DELETE folder "+e))throw new Error("User aborted delete file");o.push(n.fetcher.webOperation("DELETE",e.uri)),Promise.all(o).then(n=>{t()})})})}function N(n,e){const t=u.allAliases(n),o=f.dir().uri;for(let n=0;n<t.length;n++)if(t[n].uri.slice(0,o.length)===o)return t[n];throw new Error("No local URI for "+n)}function _(){function n(n,e){n.addEventListener("click",function(n){n.preventDefault(),x(e)})}let e=[];Object.keys(b).map(n=>u.sym(n)).forEach(n=>{b[n.value]&&(e=e.concat(G(u,n)))}),e.sort(F);for(let n=0;n<e.length-1;)e[n].uri===e[n+1].uri?e.splice(n,1):n++;function t(e){const t=c.createElement("tr");t.setAttribute("role","listitem"),t.setAttribute("tabindex","0"),t.setAttribute("aria-label",E(e)),t.classList.add("personRow"),t.subject=e;const o=t.appendChild(c.createElement("td"));o.classList.add("dataCell");const r=c.createElement("span");return r.classList.add("visually-hidden"),r.textContent="Contact: ",o.appendChild(r),o.appendChild(c.createTextNode(E(e))),d.widgets.makeDraggable(t,e),t.addEventListener("keydown",function(n){"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),x(e))}),n(t,e),t}un.textContent="Contact name",Pn.syncTableToArrayReOrdered(fn,e,t),k()}function O(n,e){for(let t=0;t<n.children.length;t++){const o=n.children[t];o.subject&&o.classList.toggle("selected",!!e[o.subject.uri])}}function R(){return O(mn,b)}function H(){function n(n){async function t(e){e.forEach(function(e){console.log("Dropped on group: "+e);const t=u.sym(e);try{q(t,n)}catch(n){r(n)}_()})}function o(t){t.preventDefault();const o=u.sym(n.uri.split("#")[0]);t.metaKey||(b={}),b[n.uri]=!b[n.uri],R(),fn.innerHTML="",u.fetcher.nowOrWhenFetched(o.uri,void 0,function(r,i){if(!r)return a(r,"Can't load group file: "+o+": "+i);if(_(),!t.metaKey){gn.innerHTML="";let t=!1;const o=d.aclControl.ACLControlBox5(n,e,"group",u,function(n,e,t){n||(t&&t.status&&403===t.status?gn.innerHTML="No control access.":gn.innerHTML="Failed to load access control: "+e)}),r=gn.appendChild(c.createElement("button"));r.classList.add("sharingButton"),r.setAttribute("aria-label","Toggle group sharing settings");const a=r.appendChild(c.createElement("img"));a.classList.add("sharingButtonIcon"),a.setAttribute("src",d.icons.iconBase+"noun_123691.svg"),a.setAttribute("alt","Sharing icon"),r.addEventListener("click",function(){t=!t,t?gn.appendChild(o):gn.removeChild(o)})}})}const i=u.any(n,kn.vcard("fn")),s=c.createElement("tr");s.setAttribute("role","listitem"),s.setAttribute("tabindex","0"),s.setAttribute("aria-label",i?i.value:"Group"),s.subject=n,d.widgets.makeDraggable(s,n),s.classList.add("dataCell");const l=c.createElement("span");return l.classList.add("visually-hidden"),l.textContent="Group: ",s.appendChild(l),s.appendChild(c.createTextNode(i)),s.addEventListener("keydown",function(n){"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),o(n))}),d.widgets.makeDropTarget(s,t),d.widgets.deleteButtonWithCheck(c,s,"group "+i,async function(){await L(n),H()}),s.addEventListener("click",o,!0),s}const t=D();Pn.syncTableToArrayReOrdered(mn,t,n),R()}async function V(){const n=await T(),{del:e,ins:t}=await W(n);e.length&&confirm(`Groups data model need to be updated? (${e.length})`)&&(await u.updater.updateMany(e,t),alert("Update done"))}async function Y(n){gn.innerHTML="";const t=u.any(f,kn.vcard("groupIndex"));try{await u.fetcher.load(t)}catch(n){console.log("Error: Group index NOT loaded:"+n+"\n")}console.log(" Group index has been loaded\n");const o=await d.widgets.askName(c,u,gn,d.ns.foaf("name"),kn.vcard("Group"),"group");if(!o)return;let r;try{r=await j(f,o)}catch(n){return console.log("Error: can't save new group:"+n),void(gn.innerHTML="Failed to save group"+n)}b={},b[r.uri]=!0,H(),gn.innerHTML="",gn.appendChild(d.aclControl.ACLControlBox5(r.doc(),e,"group",u,function(n,e){n||(gn.innerHTML="Group sharing setup failed: "+e)}))}async function Z(n){gn.innerHTML="";const e=v(f);try{await u.fetcher.load(e)}catch(n){throw new Error("Book won't load:"+e)}const t=u.any(e,kn.vcard("nameEmailIndex"));if(!t)throw new Error("Wot no nameEmailIndex?");await u.fetcher.load(t);const o=await d.widgets.askName(c,u,gn,d.ns.foaf("name"),n);if(!o)return;let r;gn.innerHTML="indexing...",f=v(f);try{r=await async function(n,e,t,o){await z.fetcher.load(n.doc());const r=z.any(n,U.vcard("nameEmailIndex")),a=M.genUuid(),i=z.sym(n.dir().uri+"Person/"+a+"/index.ttl#this"),s=i.doc(),d=[l.st(i,U.vcard("inAddressBook"),n,r),l.st(i,U.vcard("fn"),e,r),l.st(i,U.vcard("fn"),e,s),l.st(i,U.rdf("type"),o,s),l.st(s,U.dct("created"),new Date,s)];for(const n in t){const t=z.sym(n),o=t.doc();d.push(l.st(t,U.vcard("hasMember"),i,o),l.st(i,U.vcard("fn"),e,o))}try{await $.updateMany([],d)}catch(n){throw console.error("Error: can't update "+i+" as new contact:"+n),new Error("Updating new contact: "+n)}return i}(f,o,b,n)}catch(n){const e="Error: can't save new contact: "+n;console.log(e),alert(e)}C={},C[r.uri]=!0,_(),gn.innerHTML="",gn.appendChild(S(c,r,"contact"))}t.solo&&y&&"undefined"!=typeof document&&(document.title=y.value),y=y?y.value:h;const Q=c.createElement("main");Q.id="main-content",Q.classList.add("addressBook-grid"),Q.setAttribute("role","main"),Q.setAttribute("aria-label","Address Book"),Q.setAttribute("tabindex","-1"),p.appendChild(Q);const K=c.createElement("section");K.setAttribute("aria-labelledby","addressBook-section"),K.classList.add("addressBookSection","section-bg"),K.setAttribute("role","region"),K.setAttribute("tabindex","-1"),Q.appendChild(K);const X=c.createElement("header");X.classList.add("text-center","mb-md");const J=c.createElement("h2");J.id="addressBook-heading",J.setAttribute("tabindex","-1"),J.textContent=y,X.appendChild(J),K.appendChild(X);const nn=c.createElement("table");nn.classList.add("bookTable"),nn.setAttribute("role","table"),nn.setAttribute("aria-label","Contacts browser"),K.appendChild(nn);const en=c.createElement("caption");en.textContent="Contacts three-column browser",en.classList.add("visually-hidden"),nn.appendChild(en);const tn=c.createElement("thead"),on=c.createElement("tr");tn.appendChild(on),nn.appendChild(tn);const rn=c.createElement("tbody"),an=c.createElement("tr");rn.appendChild(an),nn.appendChild(rn);const sn=c.createElement("tfoot"),ln=c.createElement("tr");sn.appendChild(ln),nn.appendChild(sn);const cn=c.createElement("th");cn.setAttribute("scope","col"),cn.setAttribute("id","groupsHeader"),cn.textContent="Groups",cn.classList.add("groupsHeader"),on.appendChild(cn);const un=c.createElement("th");un.setAttribute("scope","col"),un.setAttribute("id","peopleHeader"),un.textContent="Name",un.classList.add("peopleHeader"),on.appendChild(un);const pn=c.createElement("th");pn.setAttribute("scope","col"),pn.setAttribute("id","cardHeader"),pn.textContent="Search for name",pn.classList.add("cardHeader"),on.appendChild(pn);const An=c.createElement("td");An.classList.add("groupsMain"),An.setAttribute("role","region"),An.setAttribute("aria-labelledby","groupsHeader");const mn=c.createElement("table");mn.setAttribute("role","list"),mn.setAttribute("aria-label","Groups list"),An.appendChild(mn),an.appendChild(An);const hn=c.createElement("td");hn.classList.add("peopleMain"),hn.setAttribute("role","region"),hn.setAttribute("aria-labelledby","peopleHeader");const fn=c.createElement("table");fn.setAttribute("role","list"),fn.setAttribute("aria-label","People list"),hn.appendChild(fn),an.appendChild(hn);const gn=c.createElement("td");gn.classList.add("cardMain"),gn.setAttribute("role","region"),gn.setAttribute("aria-labelledby","cardHeader"),an.appendChild(gn);const bn=c.createElement("td");bn.classList.add("groupsFooter"),ln.appendChild(bn);const Cn=c.createElement("td");ln.appendChild(Cn);const wn=c.createElement("td");ln.appendChild(wn);const yn=c.createElement("div");yn.classList.add("searchDiv"),pn.appendChild(yn);const vn=c.createElement("input");function Bn(n){cn.classList.toggle("hidden",!n),An.classList.toggle("hidden",!n),bn.classList.toggle("hidden",!n)}if(vn.setAttribute("type","text"),vn.setAttribute("aria-label","Search contacts"),vn.classList.add("searchInput"),yn.appendChild(vn),vn.addEventListener("input",function(n){k(!0)}),fn.addEventListener("keydown",function(n){const e=Array.from(fn.children),t=document.activeElement,o=e.indexOf(t);"ArrowDown"===n.key&&o<e.length-1?(e[o+1].focus(),n.preventDefault()):"ArrowUp"===n.key&&o>0&&(e[o-1].focus(),n.preventDefault())}),Bn(!0),m.foreignGroup&&(b[m.foreignGroup.uri]=!0),f){const n=cn.appendChild(c.createElement("button"));n.textContent="All",n.classList.add("allGroupsButton","actionButton","btn-secondary","action-button-focus"),n.addEventListener("click",function(e){n.state=n.state?0:1,fn.innerHTML="",n.state?(n.classList.add("allGroupsButton--loading"),P(b,mn,function(e,t){if(!e)return r(t);n.classList.remove("allGroupsButton--loading"),n.classList.add("allGroupsButton--active"),R()})):(n.classList.remove("allGroupsButton--loading","allGroupsButton--active"),n.classList.add("allGroupsButton--loaded"),b={},R())}),u.fetcher.nowOrWhenFetched(g.uri,f,function(n,e){if(!n)return console.log("Cannot load group index: "+e);H(),_()})}else H(),_(),console.log("No book, only one group -> hide list of groups"),Bn(!1);un.textContent="Contact name",un.classList.add("peopleHeader"),hn.classList.add("peopleMain");const xn=c.createElement("button"),Tn=c.createElement("div");xn.setAttribute("type","button"),A||xn.setAttribute("disabled","true"),s.authn.checkUser().then(n=>{n&&(A=n,xn.removeAttribute("disabled"))}),Tn.appendChild(xn),xn.innerHTML="New contact",xn.classList.add("actionButton","btn-secondary","action-button-focus"),Cn.appendChild(Tn),xn.addEventListener("click",async n=>Z(kn.vcard("Individual")),!1);const Sn=c.createElement("button"),Fn=c.createElement("div");if(Sn.setAttribute("type","button"),A||Sn.setAttribute("disabled","true"),s.authn.checkUser().then(n=>{n&&(A=n,Sn.removeAttribute("disabled"))}),Fn.appendChild(Sn),Sn.innerHTML="New organization",Sn.classList.add("actionButton","btn-secondary","action-button-focus"),Cn.appendChild(Fn),Sn.addEventListener("click",async n=>Z(kn.vcard("Organization")),!1),f){const n=bn.appendChild(c.createElement("button"));n.setAttribute("type","button"),n.innerHTML="New group",n.classList.add("actionButton","btn-secondary","action-button-focus"),n.addEventListener("click",Y,!1);const t=wn.appendChild(c.createElement("button"));t.setAttribute("type","button"),t.innerHTML="Tools",t.classList.add("actionButton","btn-secondary","action-button-focus"),t.addEventListener("click",function(n){gn.innerHTML="",gn.appendChild(En(P,b,mn,f,e,A))})}const Ln=i(f);Ln&&Ln.classList&&Ln.classList.add("actionButton","btn-secondary","action-button-focus"),wn.appendChild(Ln),p.appendChild(c.createElement("hr")),V().then(()=>{console.log("async checkDataModel done.")})}(n,0,m)}).catch(function(n){r(n)})}return o[kn.vcard("Individual").uri]||o[kn.foaf("Person").uri]||o[kn.schema("Person").uri]||o[kn.vcard("Organization").uri]||o[kn.schema("Organization").uri]?wn(c,p,n,e).then(()=>console.log("(individual rendered)")):o[kn.vcard("Group").uri]?d.login.findAppInstances(m,kn.vcard("AddressBook")).then(function(e){const t=e.instances,o={foreignGroup:n};t.length>0?h(t,0,o):h([],0,o)}).catch(function(n){d.widgets.complain(m,n)}):o[kn.vcard("AddressBook").uri]?h([n],0,{}):console.log("Error: Contact pane: No evidence that "+n+" is anything to do with contacts."),"undefined"!=typeof document&&document.location&&"http://localhost"===(""+document.location).slice(0,16)&&(A=u.any(n,d.ns.acl("owner")),console.log("Assuming user is "+A)),p}().then(()=>console.log("contactsPane Rendered "+n),n=>r(""+n)),p}};function Dn(n,e,t){return n.each(e,kn.owl("sameAs"),null,t).concat(n.each(null,kn.owl("sameAs"),e,t))}return i=i.default})(),n.exports=o(t(5663),t(9426),t(5491))},1267(n,e,t){"use strict";t.d(e,{A:()=>s});var o=t(1354),r=t.n(o),a=t(6314),i=t.n(a)()(r());i.push([n.id,"/* CVCard.css */\n/* Note: Uses utilities: .section-title for cvOrg styling */\n\n.cvSection {\n margin-bottom: 1.25em;\n}\n\n.cvRole {\n margin: var(--spacing-xs) 0;\n font-size: var(--font-size-base);\n line-height: var(--line-height-base);\n display: flex;\n flex-direction: column;\n gap: 0.2em;\n}\n\n.cvOrg {\n font-weight: 600;\n color: var(--color-primary);\n}\n\n.cvSkill, .cvLanguage {\n text-align: left;\n margin: var(--spacing-xs) 0;\n font-size: var(--font-size-base);\n line-height: var(--line-height-base);\n}\n\n.cvSection h3 {\n color: var(--color-text);\n font-size: var(--font-size-lg);\n font-weight: 600;\n line-height: var(--line-height-tight);\n margin-bottom: var(--spacing-xs);\n border-bottom: 1px solid var(--color-border-pale);\n padding-bottom: var(--spacing-xs);\n}\n","",{version:3,sources:["webpack://./src/styles/CVCard.css"],names:[],mappings:"AAAA,eAAe;AACf,2DAA2D;;AAE3D;EACE,qBAAqB;AACvB;;AAEA;EACE,2BAA2B;EAC3B,gCAAgC;EAChC,oCAAoC;EACpC,aAAa;EACb,sBAAsB;EACtB,UAAU;AACZ;;AAEA;EACE,gBAAgB;EAChB,2BAA2B;AAC7B;;AAEA;EACE,gBAAgB;EAChB,2BAA2B;EAC3B,gCAAgC;EAChC,oCAAoC;AACtC;;AAEA;EACE,wBAAwB;EACxB,8BAA8B;EAC9B,gBAAgB;EAChB,qCAAqC;EACrC,gCAAgC;EAChC,iDAAiD;EACjD,iCAAiC;AACnC",sourcesContent:["/* CVCard.css */\n/* Note: Uses utilities: .section-title for cvOrg styling */\n\n.cvSection {\n margin-bottom: 1.25em;\n}\n\n.cvRole {\n margin: var(--spacing-xs) 0;\n font-size: var(--font-size-base);\n line-height: var(--line-height-base);\n display: flex;\n flex-direction: column;\n gap: 0.2em;\n}\n\n.cvOrg {\n font-weight: 600;\n color: var(--color-primary);\n}\n\n.cvSkill, .cvLanguage {\n text-align: left;\n margin: var(--spacing-xs) 0;\n font-size: var(--font-size-base);\n line-height: var(--line-height-base);\n}\n\n.cvSection h3 {\n color: var(--color-text);\n font-size: var(--font-size-lg);\n font-weight: 600;\n line-height: var(--line-height-tight);\n margin-bottom: var(--spacing-xs);\n border-bottom: 1px solid var(--color-border-pale);\n padding-bottom: var(--spacing-xs);\n}\n"],sourceRoot:""}]);const s=i},3750(n,e,t){"use strict";t.d(e,{A:()=>s});var o=t(1354),r=t.n(o),a=t(6314),i=t.n(a)()(r());i.push([n.id,"/* ChatWithMe.css */\n/* Uses utilities: .section-centered, .loading-text, .btn-primary, .btn-transparent */\n\n.chatSection {\n overflow-x: auto;\n}\n","",{version:3,sources:["webpack://./src/styles/ChatWithMe.css"],names:[],mappings:"AAAA,mBAAmB;AACnB,qFAAqF;;AAErF;EACE,gBAAgB;AAClB",sourcesContent:["/* ChatWithMe.css */\n/* Uses utilities: .section-centered, .loading-text, .btn-primary, .btn-transparent */\n\n.chatSection {\n overflow-x: auto;\n}\n"],sourceRoot:""}]);const s=i},1699(n,e,t){"use strict";t.d(e,{A:()=>s});var o=t(1354),r=t.n(o),a=t(6314),i=t.n(a)()(r());i.push([n.id,'#add-to-contacts-button-container {\n position: relative;\n overflow: visible;\n}\n\n.contactsAddressBookSelector {\n width: fit-content;\n max-width: min(94vw, 48rem);\n min-width: 0;\n max-height: 80vh;\n overflow-y: auto;\n overflow-x: hidden;\n border-radius: var(--border-radius-base);\n box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;\n background: #F0F0F0;\n color: var(--color-primary);\n padding-top: 4em;\n align-items: stretch;\n box-sizing: border-box;\n gap: 7px;\n display: flex;\n flex-direction: column;\n font-weight: 600;\n position: absolute;\n top: 54%;\n bottom: auto;\n left: 50%;\n transform: translate(-50%, -50%);\n margin-top: 0;\n margin: 0;\n z-index: 200;\n opacity: 1;\n}\n\n@media (max-width: 900px) {\n .contactsAddressBookSelector {\n top: 54%;\n bottom: auto;\n left: 50%;\n transform: translate(-50%, -50%);\n }\n\n .contactsAddressBookDetails {\n flex-direction: column !important; /* Stacks items vertically on small screens */\n align-items: center !important;\n width: 100% !important;\n max-height: 60vh;\n overflow-y: auto;\n overflow-x: hidden; \n }\n\n .contactsAddressBookCreationDiv .contactsNewContactCreationButton {\n width: fit-content !important;\n min-width: 10em;\n margin-left: auto !important;\n margin-right: auto !important;\n align-self: center !important;\n display: inline-flex !important;\n justify-content: center !important;\n align-items: center !important;\n text-align: center;\n }\n}\n\n@media (max-width: 333px) {\n .contactsAddressBookSelector {\n width: 96vw;\n max-width: 96vw;\n min-width: 0;\n top: 50%;\n bottom: auto;\n left: 50%;\n transform: translate(-50%, -50%);\n padding-top: 3rem;\n position: fixed;\n overflow-x: hidden;\n }\n\n .contactsAddressBookDetails {\n width: 100% !important;\n min-width: 0;\n padding: 0.5rem;\n }\n .contactsAddressBookList,\n .contactsGroupList {\n min-width: 0;\n max-width: 100% !important;\n width: 100%;\n }\n}\n\n.contactsAddressBookCreationDiv {\n width: 100%;\n border-radius: var(--border-radius-base);\n background: #F0F0F0;\n box-sizing: border-box;\n padding: 5px;\n gap: 5px;\n display: flex;\n flex-direction: column;\n box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px;\n}\n\n.contactsHelpersButtonDiv {\n display: flex;\n flex-direction: row;\n gap: var(--spacing-md);\n justify-content: center;\n box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px;\n padding: var(--spacing-md);\n border-radius: var(--border-radius-base);\n}\n\n.contactsAddressBookCreationButton {\n flex-shrink: 0;\n background: color-mix(in srgb, var(--color-primary), white 85%) !important; \n color: var(--color-primary) !important;\n border-radius: 8px;\n text-align: left;\n cursor: pointer;\n white-space: nowrap;\n}\n\n.contactsAddressBookUriEntryButton {\n flex-shrink: 0;\n background: color-mix(in srgb, var(--color-primary), white 85%) !important; \n color: var(--color-primary) !important;\n border-radius: 8px;\n text-align: left;\n cursor: pointer;\n white-space: nowrap;\n}\n\n.contactsActionButton {\n background: var(--color-primary);\n color: white;\n border-radius: var(--border-radius-base);\n transition: all 0.3s ease-in-out;\n cursor: pointer;\n}\n\n.contactsActionButton:hover {\n transform: translateY(-2px);\n box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);\n}\n\n.contactsActionButton:active {\n box-shadow: 0 1px 2px white;\n}\n\n.contactsActionButton:focus,\n.contactsActionButton:focus-visible {\n outline: 3px solid var(--color-primary) !important;\n outline-offset: 2px !important;\n box-shadow: 0 0 0 2px white, 0 0 0 5px rgba(124, 77, 255, 0.25) !important;\n z-index: 1; \n}\n\n.contactsAddressBookDetails {\n width: 100%;\n min-width: 0;\n min-height: 0;\n border-radius: var(--border-radius-base);\n justify-content: flex-start;\n box-sizing: border-box;\n gap: 15px;\n display: flex;\n flex-direction: row;\n padding: var(--spacing-md);\n overflow-x: auto;\n overflow-y: auto;\n}\n\n.contactsAddressBookUriEntry {\n width: calc(100% - 1rem) !important;\n max-width: calc(100% - 1rem) !important;\n min-width: 0;\n box-sizing: border-box;\n padding-top: 3em !important;\n gap: 5px;\n display: flex;\n align-self: stretch;\n flex-direction: column;\n\n}\n\n.contactsAddressBookUriEntryForm {\n width: 100%;\n max-width: 100%;\n min-width: 0;\n background: #F0F0F0;\n box-sizing: border-box;\n gap: 5px;\n display: flex;\n flex-wrap: wrap;\n flex-direction: column;\n align-items: stretch;\n}\n\n.contactsAddressBookUriInput {\n width: clamp(14rem, 60vw, 22rem);\n max-width: 100%;\n min-width: 0;\n flex: 0 0 auto;\n align-self: flex-start;\n padding: 5px;\n gap: 15px;\n border-radius: var(--border-radius-base);\n border: 1px solid #ccc;\n}\n\n.contactsAddressBookUriEntryAddButton {\n width: 10%;\n min-width: 0;\n max-width: 4em;\n align-self: flex-end !important;\n margin-left: auto;\n display: inline-flex;\n justify-content: center;\n align-items: center;\n line-height: 1;\n\n /* width: 100% !important;\n max-width: 100% !important;\n margin-left: 0;\n align-self: stretch !important; */\n}\n\n.contactsNewGroupForm {\n box-sizing: border-box;\n padding-top: 2.5rem !important;\n gap: 5px;\n display: flex;\n flex-direction: column;\n}\n\n.contactsCreateNewAddressBook {\n border-radius: var(--border-radius);\n color: white;\n padding: var(--spacing-md);\n justify-content: center;\n box-sizing: border-box;\n display: flex;\n flex-direction: column;\n box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px;\n}\n\n.contactsAddressBookList {\n width: 100%;\n max-width: fit-content !important;\n box-shadow: 2px 0 5px rgba(0, 0, 0, 0.1);\n min-width: 200px;\n box-sizing: border-box;\n gap: 4px;\n display: flex;\n flex-direction: column;\n}\n\n.contactsGroupList {\n width: auto;\n max-width: fit-content !important;\n min-width: 200px;\n box-shadow: 2px 0 5px rgba(0, 0, 0, 0.1);\n box-sizing: border-box;\n gap: 4px;\n display: flex;\n flex-direction: column;\n}\n\n.contactsErrorDisplay {\n width: 90%;\n align-self: flex-end;\n padding: 5px;\n position: absolute;\n background: pink;\n display: none;\n color: #787878;\n border-radius: var(--border-radius-base);\n box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px; \n z-index: 3;\n}\n\n.contactsShowErrors {\n display: flex !important;\n flex-direction: row;\n justify-content: center;\n}\n.contactsCloseErrorDisplayButton {\n position: absolute;\n top: 0.2rem;\n right: 0.2rem;\n background: transparent;\n color: #787878;\n font-size: var(--font-size-xs);\n border: none;\n font-size: var(--font-size-sm);\n cursor: pointer;\n z-index: 4;\n}\n\n.contactsCloseButton {\n box-shadow: var(--box-shadow);\n border-radius: var(--border-radius-base);\n color: #787878 !important;\n padding: 1em;\n font-size: var(--font-size-sm);\n position: absolute;\n top: 0; \n right: 0;\n display: inline-block;\n width: auto !important;\n height: auto !important;\n cursor: pointer;\n font-size: var(--font-size-xs);\n line-height: 1;\n}\n\n.contactsCloseButton:hover {\n box-shadow: 0 2px 4px var(--color-primary) !important;\n}\n\n.contactsCloseButton:focus,\n.contactsCloseButton:focus-visible {\n outline: 3px solid var(--color-primary) !important;\n outline-offset: 2px !important;\n box-shadow: 0 0 0 2px white, 0 0 0 5px rgba(124, 77, 255, 0.25) !important;\n z-index: 1;\n}\n\n.contactsNewAddressForm {\n padding-top: 3em !important;\n gap: 5px;\n display: flex;\n flex-direction: column;\n}\n\n.contactsButton {\n flex-shrink: 0;\n background: #F0F0F0;\n color: #787878;\n border-radius: 8px;\n text-align: left;\n padding: var(--spacing-md);\n cursor: pointer;\n white-space: nowrap;\n}\n\n.contactsButton:hover {\n color: var(--color-primary);\n background: color-mix(in srgb, var(--color-primary), white 85%) !important; \n} \n\n.contactsSelectedButton {\n background: color-mix(in srgb, var(--color-primary), white 60%) !important; \n color: var(--color-primary);\n}\n\n.contactsContactExistsAlert {\n background: #F0F0F0 !important;\n color: #787878;\n padding: 10px;\n border-radius: var(--border-radius-base);\n box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;\n z-index: 10;\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n width: 300px;\n display: flex;\n flex-direction: column;\n align-items: center;\n gap: 15px; \n text-wrap: pretty;\n}\n\n.contactsContactExistsActions {\n display: flex;\n flex-direction: row;\n flex-wrap: nowrap;\n justify-content: center;\n align-items: center;\n gap: 10px;\n width: auto;\n}\n\n.contactsContactExistsActions .contactsConfirmButton,\n.contactsContactExistsActions .contactsCancelButton {\n display: inline-flex !important;\n width: auto !important;\n min-width: fit-content;\n flex: 0 0 auto;\n margin: 0;\n white-space: nowrap;\n}\n\n[role="alert"] {\n border: none !important; /* Hides the element from all users and AT */\n}\n\n.contactsPopupOverlay {\n position: absolute;\n inset: 0;\n background: rgba(0, 0, 0, 0.2);\n z-index: 8;\n}\n\n.contactsAddressBookSelector.contactsOverlayActive > *:not(.contactsPopupOverlay):not(.contactsPopupDialog):not(.contactsContactExistsAlert) {\n pointer-events: none;\n user-select: none;\n}\n\n.contactsAddressBookSelector.contactsOverlayActive .contactsPopupDialog,\n.contactsAddressBookSelector.contactsOverlayActive .contactsContactExistsAlert,\n.contactsAddressBookSelector.contactsOverlayActive .contactsPopupDialog *,\n.contactsAddressBookSelector.contactsOverlayActive .contactsContactExistsAlert * {\n pointer-events: auto;\n}\n\n.contactsPopupDialog {\n background: #F5F5F5 !important;\n color: var(--color-primary);\n padding: 2em;\n border-radius: var(--border-radius-base);\n box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;\n z-index: 50;\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n width: auto;\n max-width: min(92vw, 34rem);\n max-height: calc(100vh - 6rem);\n overflow: auto;\n box-sizing: border-box;\n}\n\n@media (max-width: 600px) {\n .contactsAddressBookUriEntry {\n padding-top: 3rem !important;\n }\n\n .contactsPopupDialog {\n max-width: 92vw;\n max-height: 78vh;\n padding: 1.25rem;\n }\n}\n\n.contactsConfirmButton {\n background: var(--color-primary);\n color: white;\n border-radius: var(--border-radius-base);\n padding: var(--spacing-md);\n transition: all 0.3s ease-in-out;\n cursor: pointer;\n}\n\n.contactsConfirmButton:hover {\n transform: translateY(-2px);\n box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);\n}\n\n.contactsCancelButton {\n background: transparent;\n color: #787878;\n border-radius: var(--border-radius-base);\n padding: var(--spacing-md);\n border: 1px solid #ccc;\n transition: all 0.3s ease-in-out;\n cursor: pointer;\n}\n.contactsCancelButton:hover {\n background: color-mix(in srgb, var(--color-primary), white 85%) !important; \n color: var(--color-primary);\n} \n\n.contactsNewContactCreationButton {\n width: 10em !important;\n align-self: flex-end;\n line-height: 1;\n}\n\n.contactsCreateGroupCreationButton {\n flex-shrink: 0;\n background: color-mix(in srgb, var(--color-primary), white 85%) !important; \n color: var(--color-primary) !important;\n border-radius: 8px;\n text-align: left;\n cursor: pointer;\n white-space: nowrap;\n}\n\n.contactsCloseButton {\n position: absolute !important;\n top: 0 !important;\n right: 0 !important;\n left: auto;\n margin: 0;\n align-self: auto !important;\n background: transparent;\n color: #787878;\n font-size: var(--font-size-xs);\n border: none;\n font-size: var(--font-size-sm);\n cursor: pointer;\n z-index: 100 !important;\n padding: 0.35rem 0.5rem;\n line-height: 1;\n}\n\n',"",{version:3,sources:["webpack://./src/styles/ContactsCard.css"],names:[],mappings:"AAAA;EACE,kBAAkB;EAClB,iBAAiB;AACnB;;AAEA;EACE,kBAAkB;EAClB,2BAA2B;EAC3B,YAAY;EACZ,gBAAgB;EAChB,gBAAgB;EAChB,kBAAkB;EAClB,wCAAwC;EACxC,4CAA4C;EAC5C,mBAAmB;EACnB,2BAA2B;EAC3B,gBAAgB;EAChB,oBAAoB;EACpB,sBAAsB;EACtB,QAAQ;EACR,aAAa;EACb,sBAAsB;EACtB,gBAAgB;EAChB,kBAAkB;EAClB,QAAQ;EACR,YAAY;EACZ,SAAS;EACT,gCAAgC;EAChC,aAAa;EACb,SAAS;EACT,YAAY;EACZ,UAAU;AACZ;;AAEA;EACE;IACE,QAAQ;IACR,YAAY;IACZ,SAAS;IACT,gCAAgC;EAClC;;EAEA;IACE,iCAAiC,EAAE,6CAA6C;IAChF,8BAA8B;IAC9B,sBAAsB;IACtB,gBAAgB;IAChB,gBAAgB;IAChB,kBAAkB;EACpB;;EAEA;IACE,6BAA6B;IAC7B,eAAe;IACf,4BAA4B;IAC5B,6BAA6B;IAC7B,6BAA6B;IAC7B,+BAA+B;IAC/B,kCAAkC;IAClC,8BAA8B;IAC9B,kBAAkB;EACpB;AACF;;AAEA;EACE;IACE,WAAW;IACX,eAAe;IACf,YAAY;IACZ,QAAQ;IACR,YAAY;IACZ,SAAS;IACT,gCAAgC;IAChC,iBAAiB;IACjB,eAAe;IACf,kBAAkB;EACpB;;EAEA;IACE,sBAAsB;IACtB,YAAY;IACZ,eAAe;EACjB;EACA;;IAEE,YAAY;IACZ,0BAA0B;IAC1B,WAAW;EACb;AACF;;AAEA;EACE,WAAW;EACX,wCAAwC;EACxC,mBAAmB;EACnB,sBAAsB;EACtB,YAAY;EACZ,QAAQ;EACR,aAAa;EACb,sBAAsB;EACtB,2CAA2C;AAC7C;;AAEA;EACE,aAAa;EACb,mBAAmB;EACnB,sBAAsB;EACtB,uBAAuB;EACvB,2CAA2C;EAC3C,0BAA0B;EAC1B,wCAAwC;AAC1C;;AAEA;EACE,cAAc;EACd,0EAA0E;EAC1E,sCAAsC;EACtC,kBAAkB;EAClB,gBAAgB;EAChB,eAAe;EACf,mBAAmB;AACrB;;AAEA;EACE,cAAc;EACd,0EAA0E;EAC1E,sCAAsC;EACtC,kBAAkB;EAClB,gBAAgB;EAChB,eAAe;EACf,mBAAmB;AACrB;;AAEA;EACE,gCAAgC;EAChC,YAAY;EACZ,wCAAwC;EACxC,gCAAgC;EAChC,eAAe;AACjB;;AAEA;EACE,2BAA2B;EAC3B,wCAAwC;AAC1C;;AAEA;EACE,2BAA2B;AAC7B;;AAEA;;EAEE,kDAAkD;EAClD,8BAA8B;EAC9B,0EAA0E;EAC1E,UAAU;AACZ;;AAEA;EACE,WAAW;EACX,YAAY;EACZ,aAAa;EACb,wCAAwC;EACxC,2BAA2B;EAC3B,sBAAsB;EACtB,SAAS;EACT,aAAa;EACb,mBAAmB;EACnB,0BAA0B;EAC1B,gBAAgB;EAChB,gBAAgB;AAClB;;AAEA;EACE,mCAAmC;EACnC,uCAAuC;EACvC,YAAY;EACZ,sBAAsB;EACtB,2BAA2B;EAC3B,QAAQ;EACR,aAAa;EACb,mBAAmB;EACnB,sBAAsB;;AAExB;;AAEA;EACE,WAAW;EACX,eAAe;EACf,YAAY;EACZ,mBAAmB;EACnB,sBAAsB;EACtB,QAAQ;EACR,aAAa;EACb,eAAe;EACf,sBAAsB;EACtB,oBAAoB;AACtB;;AAEA;EACE,gCAAgC;EAChC,eAAe;EACf,YAAY;EACZ,cAAc;EACd,sBAAsB;EACtB,YAAY;EACZ,SAAS;EACT,wCAAwC;EACxC,sBAAsB;AACxB;;AAEA;EACE,UAAU;EACV,YAAY;EACZ,cAAc;EACd,+BAA+B;EAC/B,iBAAiB;EACjB,oBAAoB;EACpB,uBAAuB;EACvB,mBAAmB;EACnB,cAAc;;KAEX;;;qCAGgC;AACrC;;AAEA;EACE,sBAAsB;EACtB,8BAA8B;EAC9B,QAAQ;EACR,aAAa;EACb,sBAAsB;AACxB;;AAEA;EACE,mCAAmC;EACnC,YAAY;EACZ,0BAA0B;EAC1B,uBAAuB;EACvB,sBAAsB;EACtB,aAAa;EACb,sBAAsB;EACtB,2CAA2C;AAC7C;;AAEA;EACE,WAAW;EACX,iCAAiC;EACjC,wCAAwC;EACxC,gBAAgB;EAChB,sBAAsB;EACtB,QAAQ;EACR,aAAa;EACb,sBAAsB;AACxB;;AAEA;EACE,WAAW;EACX,iCAAiC;EACjC,gBAAgB;EAChB,wCAAwC;EACxC,sBAAsB;EACtB,QAAQ;EACR,aAAa;EACb,sBAAsB;AACxB;;AAEA;EACE,UAAU;EACV,oBAAoB;EACpB,YAAY;EACZ,kBAAkB;EAClB,gBAAgB;EAChB,aAAa;EACb,cAAc;EACd,wCAAwC;EACxC,2CAA2C;EAC3C,UAAU;AACZ;;AAEA;EACE,wBAAwB;EACxB,mBAAmB;EACnB,uBAAuB;AACzB;AACA;EACE,kBAAkB;EAClB,WAAW;EACX,aAAa;EACb,uBAAuB;EACvB,cAAc;EACd,8BAA8B;EAC9B,YAAY;EACZ,8BAA8B;EAC9B,eAAe;EACf,UAAU;AACZ;;AAEA;EACE,6BAA6B;EAC7B,wCAAwC;EACxC,yBAAyB;EACzB,YAAY;EACZ,8BAA8B;EAC9B,kBAAkB;EAClB,MAAM;EACN,QAAQ;EACR,qBAAqB;EACrB,sBAAsB;EACtB,uBAAuB;EACvB,eAAe;EACf,8BAA8B;EAC9B,cAAc;AAChB;;AAEA;EACE,qDAAqD;AACvD;;AAEA;;EAEE,kDAAkD;EAClD,8BAA8B;EAC9B,0EAA0E;EAC1E,UAAU;AACZ;;AAEA;EACE,2BAA2B;EAC3B,QAAQ;EACR,aAAa;EACb,sBAAsB;AACxB;;AAEA;EACE,cAAc;EACd,mBAAmB;EACnB,cAAc;EACd,kBAAkB;EAClB,gBAAgB;EAChB,0BAA0B;EAC1B,eAAe;EACf,mBAAmB;AACrB;;AAEA;EACE,2BAA2B;EAC3B,0EAA0E;AAC5E;;AAEA;CACC,0EAA0E;CAC1E,2BAA2B;AAC5B;;AAEA;EACE,8BAA8B;EAC9B,cAAc;EACd,aAAa;EACb,wCAAwC;EACxC,4CAA4C;EAC5C,WAAW;EACX,kBAAkB;EAClB,QAAQ;EACR,SAAS;EACT,gCAAgC;EAChC,YAAY;EACZ,aAAa;EACb,sBAAsB;EACtB,mBAAmB;EACnB,SAAS;EACT,iBAAiB;AACnB;;AAEA;EACE,aAAa;EACb,mBAAmB;EACnB,iBAAiB;EACjB,uBAAuB;EACvB,mBAAmB;EACnB,SAAS;EACT,WAAW;AACb;;AAEA;;EAEE,+BAA+B;EAC/B,sBAAsB;EACtB,sBAAsB;EACtB,cAAc;EACd,SAAS;EACT,mBAAmB;AACrB;;AAEA;EACE,uBAAuB,EAAE,4CAA4C;AACvE;;AAEA;EACE,kBAAkB;EAClB,QAAQ;EACR,8BAA8B;EAC9B,UAAU;AACZ;;AAEA;EACE,oBAAoB;EACpB,iBAAiB;AACnB;;AAEA;;;;EAIE,oBAAoB;AACtB;;AAEA;EACE,8BAA8B;EAC9B,2BAA2B;EAC3B,YAAY;EACZ,wCAAwC;EACxC,4CAA4C;EAC5C,WAAW;EACX,kBAAkB;EAClB,QAAQ;EACR,SAAS;EACT,gCAAgC;EAChC,WAAW;EACX,2BAA2B;EAC3B,8BAA8B;EAC9B,cAAc;EACd,sBAAsB;AACxB;;AAEA;EACE;IACE,4BAA4B;EAC9B;;EAEA;IACE,eAAe;IACf,gBAAgB;IAChB,gBAAgB;EAClB;AACF;;AAEA;EACE,gCAAgC;EAChC,YAAY;EACZ,wCAAwC;EACxC,0BAA0B;EAC1B,gCAAgC;EAChC,eAAe;AACjB;;AAEA;EACE,2BAA2B;EAC3B,wCAAwC;AAC1C;;AAEA;EACE,uBAAuB;EACvB,cAAc;EACd,wCAAwC;EACxC,0BAA0B;EAC1B,sBAAsB;EACtB,gCAAgC;EAChC,eAAe;AACjB;AACA;EACE,0EAA0E;EAC1E,2BAA2B;AAC7B;;AAEA;EACE,sBAAsB;EACtB,oBAAoB;EACpB,cAAc;AAChB;;AAEA;EACE,cAAc;EACd,0EAA0E;EAC1E,sCAAsC;EACtC,kBAAkB;EAClB,gBAAgB;EAChB,eAAe;EACf,mBAAmB;AACrB;;AAEA;EACE,6BAA6B;EAC7B,iBAAiB;EACjB,mBAAmB;EACnB,UAAU;EACV,SAAS;EACT,2BAA2B;EAC3B,uBAAuB;EACvB,cAAc;EACd,8BAA8B;EAC9B,YAAY;EACZ,8BAA8B;EAC9B,eAAe;EACf,uBAAuB;EACvB,uBAAuB;EACvB,cAAc;AAChB",sourcesContent:['#add-to-contacts-button-container {\n position: relative;\n overflow: visible;\n}\n\n.contactsAddressBookSelector {\n width: fit-content;\n max-width: min(94vw, 48rem);\n min-width: 0;\n max-height: 80vh;\n overflow-y: auto;\n overflow-x: hidden;\n border-radius: var(--border-radius-base);\n box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;\n background: #F0F0F0;\n color: var(--color-primary);\n padding-top: 4em;\n align-items: stretch;\n box-sizing: border-box;\n gap: 7px;\n display: flex;\n flex-direction: column;\n font-weight: 600;\n position: absolute;\n top: 54%;\n bottom: auto;\n left: 50%;\n transform: translate(-50%, -50%);\n margin-top: 0;\n margin: 0;\n z-index: 200;\n opacity: 1;\n}\n\n@media (max-width: 900px) {\n .contactsAddressBookSelector {\n top: 54%;\n bottom: auto;\n left: 50%;\n transform: translate(-50%, -50%);\n }\n\n .contactsAddressBookDetails {\n flex-direction: column !important; /* Stacks items vertically on small screens */\n align-items: center !important;\n width: 100% !important;\n max-height: 60vh;\n overflow-y: auto;\n overflow-x: hidden; \n }\n\n .contactsAddressBookCreationDiv .contactsNewContactCreationButton {\n width: fit-content !important;\n min-width: 10em;\n margin-left: auto !important;\n margin-right: auto !important;\n align-self: center !important;\n display: inline-flex !important;\n justify-content: center !important;\n align-items: center !important;\n text-align: center;\n }\n}\n\n@media (max-width: 333px) {\n .contactsAddressBookSelector {\n width: 96vw;\n max-width: 96vw;\n min-width: 0;\n top: 50%;\n bottom: auto;\n left: 50%;\n transform: translate(-50%, -50%);\n padding-top: 3rem;\n position: fixed;\n overflow-x: hidden;\n }\n\n .contactsAddressBookDetails {\n width: 100% !important;\n min-width: 0;\n padding: 0.5rem;\n }\n .contactsAddressBookList,\n .contactsGroupList {\n min-width: 0;\n max-width: 100% !important;\n width: 100%;\n }\n}\n\n.contactsAddressBookCreationDiv {\n width: 100%;\n border-radius: var(--border-radius-base);\n background: #F0F0F0;\n box-sizing: border-box;\n padding: 5px;\n gap: 5px;\n display: flex;\n flex-direction: column;\n box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px;\n}\n\n.contactsHelpersButtonDiv {\n display: flex;\n flex-direction: row;\n gap: var(--spacing-md);\n justify-content: center;\n box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px;\n padding: var(--spacing-md);\n border-radius: var(--border-radius-base);\n}\n\n.contactsAddressBookCreationButton {\n flex-shrink: 0;\n background: color-mix(in srgb, var(--color-primary), white 85%) !important; \n color: var(--color-primary) !important;\n border-radius: 8px;\n text-align: left;\n cursor: pointer;\n white-space: nowrap;\n}\n\n.contactsAddressBookUriEntryButton {\n flex-shrink: 0;\n background: color-mix(in srgb, var(--color-primary), white 85%) !important; \n color: var(--color-primary) !important;\n border-radius: 8px;\n text-align: left;\n cursor: pointer;\n white-space: nowrap;\n}\n\n.contactsActionButton {\n background: var(--color-primary);\n color: white;\n border-radius: var(--border-radius-base);\n transition: all 0.3s ease-in-out;\n cursor: pointer;\n}\n\n.contactsActionButton:hover {\n transform: translateY(-2px);\n box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);\n}\n\n.contactsActionButton:active {\n box-shadow: 0 1px 2px white;\n}\n\n.contactsActionButton:focus,\n.contactsActionButton:focus-visible {\n outline: 3px solid var(--color-primary) !important;\n outline-offset: 2px !important;\n box-shadow: 0 0 0 2px white, 0 0 0 5px rgba(124, 77, 255, 0.25) !important;\n z-index: 1; \n}\n\n.contactsAddressBookDetails {\n width: 100%;\n min-width: 0;\n min-height: 0;\n border-radius: var(--border-radius-base);\n justify-content: flex-start;\n box-sizing: border-box;\n gap: 15px;\n display: flex;\n flex-direction: row;\n padding: var(--spacing-md);\n overflow-x: auto;\n overflow-y: auto;\n}\n\n.contactsAddressBookUriEntry {\n width: calc(100% - 1rem) !important;\n max-width: calc(100% - 1rem) !important;\n min-width: 0;\n box-sizing: border-box;\n padding-top: 3em !important;\n gap: 5px;\n display: flex;\n align-self: stretch;\n flex-direction: column;\n\n}\n\n.contactsAddressBookUriEntryForm {\n width: 100%;\n max-width: 100%;\n min-width: 0;\n background: #F0F0F0;\n box-sizing: border-box;\n gap: 5px;\n display: flex;\n flex-wrap: wrap;\n flex-direction: column;\n align-items: stretch;\n}\n\n.contactsAddressBookUriInput {\n width: clamp(14rem, 60vw, 22rem);\n max-width: 100%;\n min-width: 0;\n flex: 0 0 auto;\n align-self: flex-start;\n padding: 5px;\n gap: 15px;\n border-radius: var(--border-radius-base);\n border: 1px solid #ccc;\n}\n\n.contactsAddressBookUriEntryAddButton {\n width: 10%;\n min-width: 0;\n max-width: 4em;\n align-self: flex-end !important;\n margin-left: auto;\n display: inline-flex;\n justify-content: center;\n align-items: center;\n line-height: 1;\n\n /* width: 100% !important;\n max-width: 100% !important;\n margin-left: 0;\n align-self: stretch !important; */\n}\n\n.contactsNewGroupForm {\n box-sizing: border-box;\n padding-top: 2.5rem !important;\n gap: 5px;\n display: flex;\n flex-direction: column;\n}\n\n.contactsCreateNewAddressBook {\n border-radius: var(--border-radius);\n color: white;\n padding: var(--spacing-md);\n justify-content: center;\n box-sizing: border-box;\n display: flex;\n flex-direction: column;\n box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px;\n}\n\n.contactsAddressBookList {\n width: 100%;\n max-width: fit-content !important;\n box-shadow: 2px 0 5px rgba(0, 0, 0, 0.1);\n min-width: 200px;\n box-sizing: border-box;\n gap: 4px;\n display: flex;\n flex-direction: column;\n}\n\n.contactsGroupList {\n width: auto;\n max-width: fit-content !important;\n min-width: 200px;\n box-shadow: 2px 0 5px rgba(0, 0, 0, 0.1);\n box-sizing: border-box;\n gap: 4px;\n display: flex;\n flex-direction: column;\n}\n\n.contactsErrorDisplay {\n width: 90%;\n align-self: flex-end;\n padding: 5px;\n position: absolute;\n background: pink;\n display: none;\n color: #787878;\n border-radius: var(--border-radius-base);\n box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px; \n z-index: 3;\n}\n\n.contactsShowErrors {\n display: flex !important;\n flex-direction: row;\n justify-content: center;\n}\n.contactsCloseErrorDisplayButton {\n position: absolute;\n top: 0.2rem;\n right: 0.2rem;\n background: transparent;\n color: #787878;\n font-size: var(--font-size-xs);\n border: none;\n font-size: var(--font-size-sm);\n cursor: pointer;\n z-index: 4;\n}\n\n.contactsCloseButton {\n box-shadow: var(--box-shadow);\n border-radius: var(--border-radius-base);\n color: #787878 !important;\n padding: 1em;\n font-size: var(--font-size-sm);\n position: absolute;\n top: 0; \n right: 0;\n display: inline-block;\n width: auto !important;\n height: auto !important;\n cursor: pointer;\n font-size: var(--font-size-xs);\n line-height: 1;\n}\n\n.contactsCloseButton:hover {\n box-shadow: 0 2px 4px var(--color-primary) !important;\n}\n\n.contactsCloseButton:focus,\n.contactsCloseButton:focus-visible {\n outline: 3px solid var(--color-primary) !important;\n outline-offset: 2px !important;\n box-shadow: 0 0 0 2px white, 0 0 0 5px rgba(124, 77, 255, 0.25) !important;\n z-index: 1;\n}\n\n.contactsNewAddressForm {\n padding-top: 3em !important;\n gap: 5px;\n display: flex;\n flex-direction: column;\n}\n\n.contactsButton {\n flex-shrink: 0;\n background: #F0F0F0;\n color: #787878;\n border-radius: 8px;\n text-align: left;\n padding: var(--spacing-md);\n cursor: pointer;\n white-space: nowrap;\n}\n\n.contactsButton:hover {\n color: var(--color-primary);\n background: color-mix(in srgb, var(--color-primary), white 85%) !important; \n} \n\n.contactsSelectedButton {\n background: color-mix(in srgb, var(--color-primary), white 60%) !important; \n color: var(--color-primary);\n}\n\n.contactsContactExistsAlert {\n background: #F0F0F0 !important;\n color: #787878;\n padding: 10px;\n border-radius: var(--border-radius-base);\n box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;\n z-index: 10;\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n width: 300px;\n display: flex;\n flex-direction: column;\n align-items: center;\n gap: 15px; \n text-wrap: pretty;\n}\n\n.contactsContactExistsActions {\n display: flex;\n flex-direction: row;\n flex-wrap: nowrap;\n justify-content: center;\n align-items: center;\n gap: 10px;\n width: auto;\n}\n\n.contactsContactExistsActions .contactsConfirmButton,\n.contactsContactExistsActions .contactsCancelButton {\n display: inline-flex !important;\n width: auto !important;\n min-width: fit-content;\n flex: 0 0 auto;\n margin: 0;\n white-space: nowrap;\n}\n\n[role="alert"] {\n border: none !important; /* Hides the element from all users and AT */\n}\n\n.contactsPopupOverlay {\n position: absolute;\n inset: 0;\n background: rgba(0, 0, 0, 0.2);\n z-index: 8;\n}\n\n.contactsAddressBookSelector.contactsOverlayActive > *:not(.contactsPopupOverlay):not(.contactsPopupDialog):not(.contactsContactExistsAlert) {\n pointer-events: none;\n user-select: none;\n}\n\n.contactsAddressBookSelector.contactsOverlayActive .contactsPopupDialog,\n.contactsAddressBookSelector.contactsOverlayActive .contactsContactExistsAlert,\n.contactsAddressBookSelector.contactsOverlayActive .contactsPopupDialog *,\n.contactsAddressBookSelector.contactsOverlayActive .contactsContactExistsAlert * {\n pointer-events: auto;\n}\n\n.contactsPopupDialog {\n background: #F5F5F5 !important;\n color: var(--color-primary);\n padding: 2em;\n border-radius: var(--border-radius-base);\n box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;\n z-index: 50;\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n width: auto;\n max-width: min(92vw, 34rem);\n max-height: calc(100vh - 6rem);\n overflow: auto;\n box-sizing: border-box;\n}\n\n@media (max-width: 600px) {\n .contactsAddressBookUriEntry {\n padding-top: 3rem !important;\n }\n\n .contactsPopupDialog {\n max-width: 92vw;\n max-height: 78vh;\n padding: 1.25rem;\n }\n}\n\n.contactsConfirmButton {\n background: var(--color-primary);\n color: white;\n border-radius: var(--border-radius-base);\n padding: var(--spacing-md);\n transition: all 0.3s ease-in-out;\n cursor: pointer;\n}\n\n.contactsConfirmButton:hover {\n transform: translateY(-2px);\n box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);\n}\n\n.contactsCancelButton {\n background: transparent;\n color: #787878;\n border-radius: var(--border-radius-base);\n padding: var(--spacing-md);\n border: 1px solid #ccc;\n transition: all 0.3s ease-in-out;\n cursor: pointer;\n}\n.contactsCancelButton:hover {\n background: color-mix(in srgb, var(--color-primary), white 85%) !important; \n color: var(--color-primary);\n} \n\n.contactsNewContactCreationButton {\n width: 10em !important;\n align-self: flex-end;\n line-height: 1;\n}\n\n.contactsCreateGroupCreationButton {\n flex-shrink: 0;\n background: color-mix(in srgb, var(--color-primary), white 85%) !important; \n color: var(--color-primary) !important;\n border-radius: 8px;\n text-align: left;\n cursor: pointer;\n white-space: nowrap;\n}\n\n.contactsCloseButton {\n position: absolute !important;\n top: 0 !important;\n right: 0 !important;\n left: auto;\n margin: 0;\n align-self: auto !important;\n background: transparent;\n color: #787878;\n font-size: var(--font-size-xs);\n border: none;\n font-size: var(--font-size-sm);\n cursor: pointer;\n z-index: 100 !important;\n padding: 0.35rem 0.5rem;\n line-height: 1;\n}\n\n'],sourceRoot:""}]);const s=i},1666(n,e,t){"use strict";t.d(e,{A:()=>s});var o=t(1354),r=t.n(o),a=t(6314),i=t.n(a)()(r());i.push([n.id,"/* FriendList.css */\n/* Uses utilities: .list-reset, .section-title, .zebra-stripe, .flex, .gap-xs, .mb-md */\n\n.friendItem {\n padding: var(--spacing-xs) 0;\n font-size: 1em;\n color: var(--color-text-muted);\n}\n\n.friendItem:last-child {\n border-bottom: none;\n}\n","",{version:3,sources:["webpack://./src/styles/FriendList.css"],names:[],mappings:"AAAA,mBAAmB;AACnB,uFAAuF;;AAEvF;EACE,4BAA4B;EAC5B,cAAc;EACd,8BAA8B;AAChC;;AAEA;EACE,mBAAmB;AACrB",sourcesContent:["/* FriendList.css */\n/* Uses utilities: .list-reset, .section-title, .zebra-stripe, .flex, .gap-xs, .mb-md */\n\n.friendItem {\n padding: var(--spacing-xs) 0;\n font-size: 1em;\n color: var(--color-text-muted);\n}\n\n.friendItem:last-child {\n border-bottom: none;\n}\n"],sourceRoot:""}]);const s=i},1937(n,e,t){"use strict";t.d(e,{A:()=>s});var o=t(1354),r=t.n(o),a=t(6314),i=t.n(a)()(r());i.push([n.id,"/* ProfileCard.css */\n/* Uses utilities: .action-button-focus, .btn-primary, .flex-column-center, .text-truncate, .text-center, .text-wrap-anywhere, .section-centered, .btn-transparent */\n\n.profileCard {\n /* Component container */\n}\n\n.image {\n width: 160px;\n height: 160px;\n border-radius: 50%;\n object-fit: cover;\n margin-bottom: var(--spacing-sm);\n box-shadow: var(--box-shadow-sm);\n border: 3px solid var(--color-primary);\n background: var(--color-card-bg);\n box-sizing: border-box;\n}\n\n.image-alt {\n width: 160px;\n height: 160px;\n display: flex;\n align-items: center;\n justify-content: center;\n border-radius: 50%;\n margin-bottom: var(--spacing-sm);\n box-shadow: var(--box-shadow-sm);\n border: 3px solid var(--color-primary);\n background: var(--color-card-bg);\n box-sizing: border-box;\n color: var(--color-text-secondary);\n}\n\n.name {\n font-size: var(--font-size-xl);\n font-weight: 700;\n line-height: var(--line-height-tight);\n text-decoration: underline;\n text-underline-offset: 0.2em;\n margin: 0;\n letter-spacing: var(--letter-spacing-wide);\n}\n\n.intro {\n color: var(--color-text-secondary);\n font-size: var(--font-size-base);\n line-height: var(--line-height-base);\n margin-bottom: var(--spacing-xs);\n max-width: 40ch;\n margin-left: auto;\n margin-right: auto;\n}\n\n.buttonSection {\n color: var(--color-text-secondary);\n font-size: 1em;\n margin-bottom: var(--spacing-xs);\n}\n\n.buttonSubSection {\n width: 100%;\n min-width: 0;\n display: grid;\n}\n\n.buttonSubSection button {\n width: 100%;\n min-width: 0;\n}\n\n.qrCodeSection {\n color: var(--color-text-secondary);\n font-size: 1em;\n margin-bottom: var(--spacing-xs);\n}\n\n.details {\n color: var(--color-text-muted);\n font-size: var(--font-size-base);\n line-height: var(--line-height-base);\n max-width: 45ch;\n margin-left: auto;\n margin-right: auto;\n}\n\n/* ProfileCard styles as regular CSS */\n.profile-card {\n border: 1px solid #ccc;\n padding: 16px;\n background: white;\n}\n","",{version:3,sources:["webpack://./src/styles/ProfileCard.css"],names:[],mappings:"AAAA,oBAAoB;AACpB,oKAAoK;;AAEpK;EACE,wBAAwB;AAC1B;;AAEA;EACE,YAAY;EACZ,aAAa;EACb,kBAAkB;EAClB,iBAAiB;EACjB,gCAAgC;EAChC,gCAAgC;EAChC,sCAAsC;EACtC,gCAAgC;EAChC,sBAAsB;AACxB;;AAEA;EACE,YAAY;EACZ,aAAa;EACb,aAAa;EACb,mBAAmB;EACnB,uBAAuB;EACvB,kBAAkB;EAClB,gCAAgC;EAChC,gCAAgC;EAChC,sCAAsC;EACtC,gCAAgC;EAChC,sBAAsB;EACtB,kCAAkC;AACpC;;AAEA;EACE,8BAA8B;EAC9B,gBAAgB;EAChB,qCAAqC;EACrC,0BAA0B;EAC1B,4BAA4B;EAC5B,SAAS;EACT,0CAA0C;AAC5C;;AAEA;EACE,kCAAkC;EAClC,gCAAgC;EAChC,oCAAoC;EACpC,gCAAgC;EAChC,eAAe;EACf,iBAAiB;EACjB,kBAAkB;AACpB;;AAEA;EACE,kCAAkC;EAClC,cAAc;EACd,gCAAgC;AAClC;;AAEA;EACE,WAAW;EACX,YAAY;EACZ,aAAa;AACf;;AAEA;EACE,WAAW;EACX,YAAY;AACd;;AAEA;EACE,kCAAkC;EAClC,cAAc;EACd,gCAAgC;AAClC;;AAEA;EACE,8BAA8B;EAC9B,gCAAgC;EAChC,oCAAoC;EACpC,eAAe;EACf,iBAAiB;EACjB,kBAAkB;AACpB;;AAEA,sCAAsC;AACtC;EACE,sBAAsB;EACtB,aAAa;EACb,iBAAiB;AACnB",sourcesContent:["/* ProfileCard.css */\n/* Uses utilities: .action-button-focus, .btn-primary, .flex-column-center, .text-truncate, .text-center, .text-wrap-anywhere, .section-centered, .btn-transparent */\n\n.profileCard {\n /* Component container */\n}\n\n.image {\n width: 160px;\n height: 160px;\n border-radius: 50%;\n object-fit: cover;\n margin-bottom: var(--spacing-sm);\n box-shadow: var(--box-shadow-sm);\n border: 3px solid var(--color-primary);\n background: var(--color-card-bg);\n box-sizing: border-box;\n}\n\n.image-alt {\n width: 160px;\n height: 160px;\n display: flex;\n align-items: center;\n justify-content: center;\n border-radius: 50%;\n margin-bottom: var(--spacing-sm);\n box-shadow: var(--box-shadow-sm);\n border: 3px solid var(--color-primary);\n background: var(--color-card-bg);\n box-sizing: border-box;\n color: var(--color-text-secondary);\n}\n\n.name {\n font-size: var(--font-size-xl);\n font-weight: 700;\n line-height: var(--line-height-tight);\n text-decoration: underline;\n text-underline-offset: 0.2em;\n margin: 0;\n letter-spacing: var(--letter-spacing-wide);\n}\n\n.intro {\n color: var(--color-text-secondary);\n font-size: var(--font-size-base);\n line-height: var(--line-height-base);\n margin-bottom: var(--spacing-xs);\n max-width: 40ch;\n margin-left: auto;\n margin-right: auto;\n}\n\n.buttonSection {\n color: var(--color-text-secondary);\n font-size: 1em;\n margin-bottom: var(--spacing-xs);\n}\n\n.buttonSubSection {\n width: 100%;\n min-width: 0;\n display: grid;\n}\n\n.buttonSubSection button {\n width: 100%;\n min-width: 0;\n}\n\n.qrCodeSection {\n color: var(--color-text-secondary);\n font-size: 1em;\n margin-bottom: var(--spacing-xs);\n}\n\n.details {\n color: var(--color-text-muted);\n font-size: var(--font-size-base);\n line-height: var(--line-height-base);\n max-width: 45ch;\n margin-left: auto;\n margin-right: auto;\n}\n\n/* ProfileCard styles as regular CSS */\n.profile-card {\n border: 1px solid #ccc;\n padding: 16px;\n background: white;\n}\n"],sourceRoot:""}]);const s=i},436(n,e,t){"use strict";t.d(e,{A:()=>s});var o=t(1354),r=t.n(o),a=t(6314),i=t.n(a)()(r());i.push([n.id,"/* ProfileView.css */\n/* Uses utilities: .section-bg, .text-center */\n\n.profileSection {\n \n}\n\n/* Horizontal layout for cards */\n.profile-grid .profileSection {\n width: 100%;\n max-width: 100%;\n box-sizing: border-box;\n margin-bottom: var(--spacing-md);\n box-sizing: border-box;\n margin-bottom: var(--spacing-md);\n}\n\n@media (min-width: 900px) {\n .profileSection {\n margin-bottom: 0;\n }\n}\n","",{version:3,sources:["webpack://./src/styles/ProfileView.css"],names:[],mappings:"AAAA,oBAAoB;AACpB,8CAA8C;;AAE9C;;AAEA;;AAEA,gCAAgC;AAChC;EACE,WAAW;EACX,eAAe;EACf,sBAAsB;EACtB,gCAAgC;EAChC,sBAAsB;EACtB,gCAAgC;AAClC;;AAEA;EACE;IACE,gBAAgB;EAClB;AACF",sourcesContent:["/* ProfileView.css */\n/* Uses utilities: .section-bg, .text-center */\n\n.profileSection {\n \n}\n\n/* Horizontal layout for cards */\n.profile-grid .profileSection {\n width: 100%;\n max-width: 100%;\n box-sizing: border-box;\n margin-bottom: var(--spacing-md);\n box-sizing: border-box;\n margin-bottom: var(--spacing-md);\n}\n\n@media (min-width: 900px) {\n .profileSection {\n margin-bottom: 0;\n }\n}\n"],sourceRoot:""}]);const s=i},1134(n,e,t){"use strict";t.d(e,{A:()=>s});var o=t(1354),r=t.n(o),a=t(6314),i=t.n(a)()(r());i.push([n.id,'/* QRCodeCard.css */\n/* Note: Uses utilities: .text-center */\n\n/* Caption under the QR code */\n.qrCaption {\n text-align: center;\n margin-top: 0;\n font-size: 0.95em;\n color: var(--color-text-secondary);\n}\n\n.QRCode {\n width: 100%;\n max-width: 320px;\n min-width: 180px;\n margin: 0 auto;\n display: block;\n}\n\n.QRCode [role="img"]:focus {\n outline: 2px solid var(--color-primary, #7C4DFF);\n outline-offset: 2px;\n box-shadow: 0 0 0 2px rgba(124,77,255,0.2);\n}',"",{version:3,sources:["webpack://./src/styles/QRCodeCard.css"],names:[],mappings:"AAAA,mBAAmB;AACnB,uCAAuC;;AAEvC,8BAA8B;AAC9B;EACE,kBAAkB;EAClB,aAAa;EACb,iBAAiB;EACjB,kCAAkC;AACpC;;AAEA;EACE,WAAW;EACX,gBAAgB;EAChB,gBAAgB;EAChB,cAAc;EACd,cAAc;AAChB;;AAEA;EACE,gDAAgD;EAChD,mBAAmB;EACnB,0CAA0C;AAC5C",sourcesContent:['/* QRCodeCard.css */\n/* Note: Uses utilities: .text-center */\n\n/* Caption under the QR code */\n.qrCaption {\n text-align: center;\n margin-top: 0;\n font-size: 0.95em;\n color: var(--color-text-secondary);\n}\n\n.QRCode {\n width: 100%;\n max-width: 320px;\n min-width: 180px;\n margin: 0 auto;\n display: block;\n}\n\n.QRCode [role="img"]:focus {\n outline: 2px solid var(--color-primary, #7C4DFF);\n outline-offset: 2px;\n box-shadow: 0 0 0 2px rgba(124,77,255,0.2);\n}'],sourceRoot:""}]);const s=i},1649(n,e,t){"use strict";t.d(e,{A:()=>s});var o=t(1354),r=t.n(o),a=t(6314),i=t.n(a)()(r());i.push([n.id,'/* SocialCard.css */\n/* Uses utilities: .list-reset, .text-wrap-anywhere, .flex, .gap-sm, .gap-lg, .rounded-sm */\n\n.socialList {\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n gap: var(--spacing-lg);\n justify-content: center;\n}\n\n.socialItem {\n display: flex;\n align-items: center;\n gap: var(--spacing-sm);\n font-size: 1.1em;\n}\n\n.socialItem span {\n min-width: 0;\n display: block;\n}\n\n.socialItem a {\n color: var(--color-primary);\n text-decoration: none;\n display: flex;\n align-items: center;\n gap: var(--spacing-sm);\n min-height: var(--min-touch-target);\n padding: var(--spacing-xs);\n border-radius: var(--border-radius-base);\n transition: background-color var(--animation-duration) ease;\n position: relative;\n flex: 1;\n min-width: 0;\n}\n\n.socialItem a:hover,\n.socialItem a:focus {\n text-decoration: underline;\n background-color: rgba(124, 77, 255, 0.1);\n}\n\n/* Screen reader only external link indication */\n.socialItem a[href^="http"]:after {\n content: " (external link)";\n position: absolute;\n left: -10000px;\n width: 1px;\n height: 1px;\n overflow: hidden;\n}\n\n.socialIcon {\n width: 2.5em;\n height: 2.5em;\n border-radius: var(--border-radius-base);\n background: var(--color-card-bg);\n flex-shrink: 0;\n}\n',"",{version:3,sources:["webpack://./src/styles/SocialCard.css"],names:[],mappings:"AAAA,mBAAmB;AACnB,2FAA2F;;AAE3F;EACE,aAAa;EACb,mBAAmB;EACnB,eAAe;EACf,sBAAsB;EACtB,uBAAuB;AACzB;;AAEA;EACE,aAAa;EACb,mBAAmB;EACnB,sBAAsB;EACtB,gBAAgB;AAClB;;AAEA;EACE,YAAY;EACZ,cAAc;AAChB;;AAEA;EACE,2BAA2B;EAC3B,qBAAqB;EACrB,aAAa;EACb,mBAAmB;EACnB,sBAAsB;EACtB,mCAAmC;EACnC,0BAA0B;EAC1B,wCAAwC;EACxC,2DAA2D;EAC3D,kBAAkB;EAClB,OAAO;EACP,YAAY;AACd;;AAEA;;EAEE,0BAA0B;EAC1B,yCAAyC;AAC3C;;AAEA,gDAAgD;AAChD;EACE,2BAA2B;EAC3B,kBAAkB;EAClB,cAAc;EACd,UAAU;EACV,WAAW;EACX,gBAAgB;AAClB;;AAEA;EACE,YAAY;EACZ,aAAa;EACb,wCAAwC;EACxC,gCAAgC;EAChC,cAAc;AAChB",sourcesContent:['/* SocialCard.css */\n/* Uses utilities: .list-reset, .text-wrap-anywhere, .flex, .gap-sm, .gap-lg, .rounded-sm */\n\n.socialList {\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n gap: var(--spacing-lg);\n justify-content: center;\n}\n\n.socialItem {\n display: flex;\n align-items: center;\n gap: var(--spacing-sm);\n font-size: 1.1em;\n}\n\n.socialItem span {\n min-width: 0;\n display: block;\n}\n\n.socialItem a {\n color: var(--color-primary);\n text-decoration: none;\n display: flex;\n align-items: center;\n gap: var(--spacing-sm);\n min-height: var(--min-touch-target);\n padding: var(--spacing-xs);\n border-radius: var(--border-radius-base);\n transition: background-color var(--animation-duration) ease;\n position: relative;\n flex: 1;\n min-width: 0;\n}\n\n.socialItem a:hover,\n.socialItem a:focus {\n text-decoration: underline;\n background-color: rgba(124, 77, 255, 0.1);\n}\n\n/* Screen reader only external link indication */\n.socialItem a[href^="http"]:after {\n content: " (external link)";\n position: absolute;\n left: -10000px;\n width: 1px;\n height: 1px;\n overflow: hidden;\n}\n\n.socialIcon {\n width: 2.5em;\n height: 2.5em;\n border-radius: var(--border-radius-base);\n background: var(--color-card-bg);\n flex-shrink: 0;\n}\n'],sourceRoot:""}]);const s=i},6660(n,e,t){"use strict";t.d(e,{A:()=>s});var o=t(1354),r=t.n(o),a=t(6314),i=t.n(a)()(r());i.push([n.id,"/* StuffCard.css */\n/* Uses utilities: .zebra-stripe */\n\n.stuffTable {\n width: 100%;\n border-collapse: collapse;\n margin-bottom: var(--spacing-md);\n caption-side: top;\n}\n\n.stuffTable caption {\n font-weight: 600;\n padding: var(--spacing-sm);\n text-align: left;\n color: var(--color-text);\n}\n\n.stuffTable th,\n.stuffTable td {\n padding: var(--spacing-sm) var(--spacing-md);\n text-align: left;\n line-height: 1.4;\n}\n","",{version:3,sources:["webpack://./src/styles/StuffCard.css"],names:[],mappings:"AAAA,kBAAkB;AAClB,kCAAkC;;AAElC;EACE,WAAW;EACX,yBAAyB;EACzB,gCAAgC;EAChC,iBAAiB;AACnB;;AAEA;EACE,gBAAgB;EAChB,0BAA0B;EAC1B,gBAAgB;EAChB,wBAAwB;AAC1B;;AAEA;;EAEE,4CAA4C;EAC5C,gBAAgB;EAChB,gBAAgB;AAClB",sourcesContent:["/* StuffCard.css */\n/* Uses utilities: .zebra-stripe */\n\n.stuffTable {\n width: 100%;\n border-collapse: collapse;\n margin-bottom: var(--spacing-md);\n caption-side: top;\n}\n\n.stuffTable caption {\n font-weight: 600;\n padding: var(--spacing-sm);\n text-align: left;\n color: var(--color-text);\n}\n\n.stuffTable th,\n.stuffTable td {\n padding: var(--spacing-sm) var(--spacing-md);\n text-align: left;\n line-height: 1.4;\n}\n"],sourceRoot:""}]);const s=i},9053(n,e,t){"use strict";t.d(e,{A:()=>s});var o=t(1354),r=t.n(o),a=t(6314),i=t.n(a)()(r());i.push([n.id,'/* Solid-UI form sizing fixes scoped to Edit CV section */\n.profile-form .hoverControl:not(:has(> img:first-child)) {\n border: 0.1em solid rgb(136, 136, 136) !important;\n}\n\n.profile-form .hoverControl:has(> img:first-child) {\n background-color: transparent !important;\n border: none !important;\n margin: 0 !important;\n border-radius: 0 !important;\n padding: 0.7em !important;\n cursor: pointer;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n}\n\n.profile-form .hoverControlHide {\n width: 1.5em !important;\n height: 1.5em !important;\n display: block;\n margin-top: 0 !important;\n margin-left: 0 !important;\n margin-right: 0 !important;\n margin-bottom: 0.3em !important;\n}\n\n.profile-form .hoverControl:has(> img:first-child) > span {\n display: inline-flex;\n align-items: center;\n margin-left: 0.3em;\n}\n\n.profile-form div[style*="padding: 0.5em"]:has(> img) {\n display: inline-flex;\n align-items: center;\n}\n\n.profile-form div[style*="padding: 0.5em"]:has(> img) > span {\n margin-left: 0.3em;\n}\n\n.profile-form .hoverControl:has(> img:first-child):hover {\n background-color: transparent !important;\n}\n\n.profile-form button:has(> img[src$=".svg"]) {\n background-color: transparent !important;\n border: none !important;\n margin: 0 !important;\n border-radius: 0 !important;\n}\n\n.profile-form button {\n\n}\n\n.profile-form input:not([type="color"]),\n.profile-form textarea,\n.profile-form select {\n max-width: 100%;\n min-width: 0;\n box-sizing: border-box ;\n background-color: #eef !important;\n border: .05em solid #88c\n}\n\n.profile-form input[type="url"] {\n width: 100%;\n}\n\n.profile-form .formFieldValue {\n min-width: 0;\n margin-bottom: var(--spacing-sm);\n}\n\n.profile-form .formFieldValue table {\n margin: 0 !important;\n padding: 0 !important;\n}\n\n.profile-form .formFieldValue td {\n padding: 0 !important;\n}\n\n.profile-form .formFieldValue input:not([type="color"]),\n.profile-form .formFieldValue textarea,\n.profile-form .formFieldValue select {\n width: 100%;\n max-width: 100%;\n}\n\n.profile-form select#formSelect {\n width: 100%;\n max-width: 97%;\n box-sizing: border-box;\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n.profile-form span select {\n max-width: 96% !important;\n box-sizing: border-box;\n}\n\n/* Remove border/padding from the first wrapper div (and its first child wrapper). */\n.profile-form > div:first-of-type,\n.profile-form > div:first-of-type > div:first-of-type {\n border: none !important;\n padding: 0 !important;\n}\n\n/* Remove border/padding from the inner div of the first wrapper in the contact section. */\nsection[aria-labelledby="edit-profile-contact-heading"] .profile-form > div:first-of-type > div:first-of-type {\n border: none !important;\n padding: 0 !important;\n}\n\n/* In contactPane, remove border/padding from all direct child divs. */\n.contactPane > div {\n border: none !important;\n padding: 0 !important;\n}\n\n/* Align schema.org, solid terms, FOAF, vCard, and org field labels with their input values. */\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://schema.org/"]),\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/solid/terms#"]),\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://xmlns.com/foaf/0.1/"]),\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/2006/vcard/ns"]),\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/org#"]) {\n display: inline-flex;\n align-items: center;\n vertical-align: middle;\n}\n\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://schema.org/"]) + .formFieldValue,\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/solid/terms#"]) + .formFieldValue,\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://xmlns.com/foaf/0.1/"]) + .formFieldValue,\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/2006/vcard/ns"]) + .formFieldValue,\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/org#"]) + .formFieldValue {\n display: inline-flex;\n align-items: center;\n vertical-align: middle;\n}\n\n.profile-form textarea {\n width: 100%;\n box-sizing: border-box;\n margin-top: var(--spacing-xs);\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n/* Add horizontal gap between label and textarea for all label+textarea pairs. */\n.profile-form div:has(> a) + div:has(textarea) {\n margin-left: var(--spacing-sm);\n}\n\n/* Center textarea label vertically in flex rows. */\n.profile-form div[style*="display: flex"][style*="flex-direction: row"]:has(textarea) {\n align-items: flex-start;\n}\n\n.profile-form div[style*="display: flex"][style*="flex-direction: row"]:has(textarea) > div:has(> a) {\n padding-top: var(--spacing-xs);\n}\n\n.profile-form input:not([type="color"]) {\n width: 100%;\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n/* Remove padding from table cells within webidControl */\n.webidControl table td {\n padding: 0 !important;\n}\n\n/* Remove padding from contactPane divs inside webidControl table cells */\n.webidControl table td div.contactPane.namedPane.fullWidth.individualPane {\n padding: 0 !important;\n}\n\n.webidControl table td div.contactPane.namedPane {\n border: none !important;\n}\n',"",{version:3,sources:["webpack://./src/styles/rdfFormsEnforced.css"],names:[],mappings:"AAAA,yDAAyD;AACzD;EACE,iDAAiD;AACnD;;AAEA;EACE,wCAAwC;EACxC,uBAAuB;EACvB,oBAAoB;EACpB,2BAA2B;EAC3B,yBAAyB;EACzB,eAAe;EACf,oBAAoB;EACpB,mBAAmB;EACnB,uBAAuB;AACzB;;AAEA;EACE,uBAAuB;EACvB,wBAAwB;EACxB,cAAc;EACd,wBAAwB;EACxB,yBAAyB;EACzB,0BAA0B;EAC1B,+BAA+B;AACjC;;AAEA;EACE,oBAAoB;EACpB,mBAAmB;EACnB,kBAAkB;AACpB;;AAEA;EACE,oBAAoB;EACpB,mBAAmB;AACrB;;AAEA;EACE,kBAAkB;AACpB;;AAEA;EACE,wCAAwC;AAC1C;;AAEA;EACE,wCAAwC;EACxC,uBAAuB;EACvB,oBAAoB;EACpB,2BAA2B;AAC7B;;AAEA;;AAEA;;AAEA;;;EAGE,eAAe;EACf,YAAY;EACZ,uBAAuB;EACvB,iCAAiC;EACjC;AACF;;AAEA;EACE,WAAW;AACb;;AAEA;EACE,YAAY;EACZ,gCAAgC;AAClC;;AAEA;EACE,oBAAoB;EACpB,qBAAqB;AACvB;;AAEA;EACE,qBAAqB;AACvB;;AAEA;;;EAGE,WAAW;EACX,eAAe;AACjB;;AAEA;EACE,WAAW;EACX,cAAc;EACd,sBAAsB;EACtB,yBAAyB;EACzB,0BAA0B;AAC5B;;AAEA;EACE,yBAAyB;EACzB,sBAAsB;AACxB;;AAEA,oFAAoF;AACpF;;EAEE,uBAAuB;EACvB,qBAAqB;AACvB;;AAEA,0FAA0F;AAC1F;EACE,uBAAuB;EACvB,qBAAqB;AACvB;;AAEA,sEAAsE;AACtE;EACE,uBAAuB;EACvB,qBAAqB;AACvB;;AAEA,8FAA8F;AAC9F;;;;;EAKE,oBAAoB;EACpB,mBAAmB;EACnB,sBAAsB;AACxB;;AAEA;;;;;EAKE,oBAAoB;EACpB,mBAAmB;EACnB,sBAAsB;AACxB;;AAEA;EACE,WAAW;EACX,sBAAsB;EACtB,6BAA6B;EAC7B,yBAAyB;EACzB,0BAA0B;AAC5B;;AAEA,gFAAgF;AAChF;EACE,8BAA8B;AAChC;;AAEA,mDAAmD;AACnD;EACE,uBAAuB;AACzB;;AAEA;EACE,8BAA8B;AAChC;;AAEA;EACE,WAAW;EACX,yBAAyB;EACzB,0BAA0B;AAC5B;;AAEA,wDAAwD;AACxD;EACE,qBAAqB;AACvB;;AAEA,yEAAyE;AACzE;EACE,qBAAqB;AACvB;;AAEA;EACE,uBAAuB;AACzB",sourcesContent:['/* Solid-UI form sizing fixes scoped to Edit CV section */\n.profile-form .hoverControl:not(:has(> img:first-child)) {\n border: 0.1em solid rgb(136, 136, 136) !important;\n}\n\n.profile-form .hoverControl:has(> img:first-child) {\n background-color: transparent !important;\n border: none !important;\n margin: 0 !important;\n border-radius: 0 !important;\n padding: 0.7em !important;\n cursor: pointer;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n}\n\n.profile-form .hoverControlHide {\n width: 1.5em !important;\n height: 1.5em !important;\n display: block;\n margin-top: 0 !important;\n margin-left: 0 !important;\n margin-right: 0 !important;\n margin-bottom: 0.3em !important;\n}\n\n.profile-form .hoverControl:has(> img:first-child) > span {\n display: inline-flex;\n align-items: center;\n margin-left: 0.3em;\n}\n\n.profile-form div[style*="padding: 0.5em"]:has(> img) {\n display: inline-flex;\n align-items: center;\n}\n\n.profile-form div[style*="padding: 0.5em"]:has(> img) > span {\n margin-left: 0.3em;\n}\n\n.profile-form .hoverControl:has(> img:first-child):hover {\n background-color: transparent !important;\n}\n\n.profile-form button:has(> img[src$=".svg"]) {\n background-color: transparent !important;\n border: none !important;\n margin: 0 !important;\n border-radius: 0 !important;\n}\n\n.profile-form button {\n\n}\n\n.profile-form input:not([type="color"]),\n.profile-form textarea,\n.profile-form select {\n max-width: 100%;\n min-width: 0;\n box-sizing: border-box ;\n background-color: #eef !important;\n border: .05em solid #88c\n}\n\n.profile-form input[type="url"] {\n width: 100%;\n}\n\n.profile-form .formFieldValue {\n min-width: 0;\n margin-bottom: var(--spacing-sm);\n}\n\n.profile-form .formFieldValue table {\n margin: 0 !important;\n padding: 0 !important;\n}\n\n.profile-form .formFieldValue td {\n padding: 0 !important;\n}\n\n.profile-form .formFieldValue input:not([type="color"]),\n.profile-form .formFieldValue textarea,\n.profile-form .formFieldValue select {\n width: 100%;\n max-width: 100%;\n}\n\n.profile-form select#formSelect {\n width: 100%;\n max-width: 97%;\n box-sizing: border-box;\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n.profile-form span select {\n max-width: 96% !important;\n box-sizing: border-box;\n}\n\n/* Remove border/padding from the first wrapper div (and its first child wrapper). */\n.profile-form > div:first-of-type,\n.profile-form > div:first-of-type > div:first-of-type {\n border: none !important;\n padding: 0 !important;\n}\n\n/* Remove border/padding from the inner div of the first wrapper in the contact section. */\nsection[aria-labelledby="edit-profile-contact-heading"] .profile-form > div:first-of-type > div:first-of-type {\n border: none !important;\n padding: 0 !important;\n}\n\n/* In contactPane, remove border/padding from all direct child divs. */\n.contactPane > div {\n border: none !important;\n padding: 0 !important;\n}\n\n/* Align schema.org, solid terms, FOAF, vCard, and org field labels with their input values. */\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://schema.org/"]),\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/solid/terms#"]),\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://xmlns.com/foaf/0.1/"]),\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/2006/vcard/ns"]),\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/org#"]) {\n display: inline-flex;\n align-items: center;\n vertical-align: middle;\n}\n\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://schema.org/"]) + .formFieldValue,\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/solid/terms#"]) + .formFieldValue,\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://xmlns.com/foaf/0.1/"]) + .formFieldValue,\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/2006/vcard/ns"]) + .formFieldValue,\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/org#"]) + .formFieldValue {\n display: inline-flex;\n align-items: center;\n vertical-align: middle;\n}\n\n.profile-form textarea {\n width: 100%;\n box-sizing: border-box;\n margin-top: var(--spacing-xs);\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n/* Add horizontal gap between label and textarea for all label+textarea pairs. */\n.profile-form div:has(> a) + div:has(textarea) {\n margin-left: var(--spacing-sm);\n}\n\n/* Center textarea label vertically in flex rows. */\n.profile-form div[style*="display: flex"][style*="flex-direction: row"]:has(textarea) {\n align-items: flex-start;\n}\n\n.profile-form div[style*="display: flex"][style*="flex-direction: row"]:has(textarea) > div:has(> a) {\n padding-top: var(--spacing-xs);\n}\n\n.profile-form input:not([type="color"]) {\n width: 100%;\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n/* Remove padding from table cells within webidControl */\n.webidControl table td {\n padding: 0 !important;\n}\n\n/* Remove padding from contactPane divs inside webidControl table cells */\n.webidControl table td div.contactPane.namedPane.fullWidth.individualPane {\n padding: 0 !important;\n}\n\n.webidControl table td div.contactPane.namedPane {\n border: none !important;\n}\n'],sourceRoot:""}]);const s=i},5092(n,e,t){"use strict";t.d(e,{A:()=>s});var o=t(1354),r=t.n(o),a=t(6314),i=t.n(a)()(r());i.push([n.id,'/* Utility-first CSS classes for layout, spacing, and responsiveness */\n\n.actionButton {\n width: 100%;\n min-width: 180px;\n max-width: 320px;\n box-sizing: border-box;\n display: inline-block;\n}\n\n.selectedButton {\n background-color: var(--color-primary) !important;\n color: white !important;\n border: 1px solid white !important;\n}\n/* ===========================================\n PROFILE GRID LAYOUT\n =========================================== */\n\n.profile-grid {\n display: grid;\n grid-template-columns: repeat(auto-fit, minmax(30em, 1fr));\n gap: var(--spacing-lg);\n background: var(--color-background);\n}\n\n.profile-header,\n.profile-footer {\n grid-column: 1 / -1;\n}\n\n.center {\n justify-content: center;\n align-items: center;\n}\n\n.flex {\n display: flex;\n}\n.grid {\n display: grid;\n}\n\n/* Spacing utilities using CSS variables */\n.gap-xs { gap: var(--spacing-xs); }\n.gap-sm { gap: var(--spacing-sm); }\n.gap-md { gap: var(--spacing-md); }\n.gap-lg { gap: var(--spacing-lg); }\n.gap-xl { gap: var(--spacing-xl); }\n\n.mt-xs { margin-top: var(--spacing-xs); }\n.mt-sm { margin-top: var(--spacing-sm); }\n.mt-md { margin-top: var(--spacing-md); }\n.mt-lg { margin-top: var(--spacing-lg); }\n\n.mb-xs { margin-bottom: var(--spacing-xs); }\n.mb-sm { margin-bottom: var(--spacing-sm); }\n.mb-md { margin-bottom: var(--spacing-md); }\n.mb-lg { margin-bottom: var(--spacing-lg); }\n\n.p-xs { padding: var(--spacing-xs); }\n.p-sm { padding: var(--spacing-sm); }\n.p-md { padding: var(--spacing-md); }\n.p-lg { padding: var(--spacing-lg); }\n\n.rounded { border-radius: var(--border-radius-full); }\n.rounded-sm { border-radius: var(--border-radius-base); }\n\n.shadow { box-shadow: var(--box-shadow); }\n.shadow-sm { box-shadow: var(--box-shadow-sm); }\n\n.bg-primary {\n background: var(--color-primary);\n color: #fff;\n}\n.bg-card {\n background: var(--color-card-bg);\n}\n\n/* Accessibility utilities */\n.sr-only {\n position: absolute;\n width: 1px;\n height: 1px;\n padding: 0;\n margin: -1px;\n overflow: hidden;\n clip: rect(0, 0, 0, 0);\n white-space: nowrap;\n border: 0;\n}\n\n.min-touch-target {\n min-height: var(--min-touch-target);\n min-width: var(--min-touch-target);\n}\n\n/* Enhanced accessibility utilities */\n.visually-hidden {\n position: absolute !important;\n width: 1px !important;\n height: 1px !important;\n padding: 0 !important;\n margin: -1px !important;\n overflow: hidden !important;\n clip: rect(0, 0, 0, 0) !important;\n white-space: nowrap !important;\n border: 0 !important;\n}\n\n.visually-hidden.focusable:focus,\n.visually-hidden.focusable:active {\n position: static !important;\n width: auto !important;\n height: auto !important;\n padding: inherit !important;\n margin: inherit !important;\n overflow: visible !important;\n clip: auto !important;\n white-space: inherit !important;\n}\n\n/* Skip links utility */\n.skip-links {\n position: absolute;\n top: -100px;\n left: 0;\n z-index: 1000;\n}\n\n.skip-links a {\n position: absolute;\n left: 6px;\n top: 6px;\n padding: var(--spacing-sm);\n background: var(--color-primary);\n color: white;\n text-decoration: none;\n border-radius: var(--border-radius-base);\n}\n\n.skip-links a:focus {\n top: 6px;\n}\n\n.reduced-motion {\n animation: none !important;\n transition: none !important;\n}\n\n/* Focus management */\n.focus-ring {\n outline: 2px solid var(--color-primary);\n outline-offset: 2px;\n}\n\n.no-focus-ring {\n outline: none;\n}\n\n.no-focus-ring:focus-visible {\n outline: none;\n box-shadow: none;\n}\n\n/* ARIA live regions */\n.live-region {\n position: absolute;\n left: -10000px;\n width: 1px;\n height: 1px;\n overflow: hidden;\n}\n\n/* Note: Use aria-live="polite" or aria-live="assertive" HTML attributes with .live-region */\n\n/* Text scaling utilities */\n.text-scale-friendly {\n line-height: 1.5;\n max-width: 70ch; /* Optimal reading length */\n}\n\n/* Text accessibility utilities */\n.text-readable {\n line-height: var(--line-height-base);\n max-width: 65ch;\n}\n\n.text-lg {\n font-size: var(--font-size-lg);\n line-height: var(--line-height-base);\n}\n\n.text-small {\n font-size: max(var(--font-size-sm), var(--min-font-size));\n line-height: var(--min-line-height);\n}\n\n.text-contrast-high {\n color: var(--color-text);\n font-weight: 600;\n}\n\n:focus-visible {\n outline: var(--focus-ring-width) solid var(--color-primary);\n outline-offset: 2px;\n box-shadow: 0 0 0 1px var(--color-background);\n}\n\n:focus:not(:focus-visible) {\n outline: none;\n box-shadow: none;\n}\n\n/* Better focus for text elements */\n.focusable-text:focus {\n background-color: rgba(124, 77, 255, 0.1);\n outline: 2px solid var(--color-primary);\n outline-offset: 2px;\n border-radius: 2px;\n}\n\n/* High contrast text */\n.high-contrast {\n color: var(--color-text);\n background: var(--color-background);\n border: 1px solid var(--color-border-pale);\n}\n\n/* ===========================================\n CONSOLIDATED COMPONENT PATTERNS\n =========================================== */\n\n/* Primary Button - used by ChatWithMe, ProfileCard */\n.btn-primary {\n min-height: var(--min-touch-target);\n padding: var(--spacing-sm) var(--spacing-md);\n border: 1px solid var(--color-primary);\n border-radius: var(--border-radius-base);\n background: var(--color-primary);\n color: white;\n font-weight: 600;\n cursor: pointer;\n transition: all var(--animation-duration) ease;\n}\n\n.btn-primary:hover {\n background: color-mix(in srgb, var(--color-primary) 90%, black);\n box-shadow: 0 2px 4px rgba(124, 77, 255, 0.2);\n}\n\n.btn-primary:active {\n box-shadow: 0 1px 2px rgba(124, 77, 255, 0.2);\n}\n\n.btn-primary:disabled {\n opacity: 0.6;\n cursor: not-allowed;\n transform: none;\n}\n\n/* Action Button Focus - used by ChatWithMe, ProfileCard */\n.action-button-focus:focus,\n.action-button-focus:focus-visible {\n outline: 3px solid var(--color-primary) !important;\n outline-offset: 2px !important;\n box-shadow: 0 0 0 2px var(--color-background), 0 0 0 5px rgba(124, 77, 255, 0.25) !important;\n z-index: 1;\n}\n\n/* List Reset - used by FriendList, SocialCard, nav */\n.list-reset {\n list-style: none;\n padding: 0;\n margin: 0;\n}\n\n/* Zebra Striping - used by FriendList, StuffCard tables */\n.zebra-stripe tr:nth-child(even),\n.zebra-stripe > *:nth-child(even) {\n background-color: rgba(0, 0, 0, 0.02);\n}\n\n/* Section Title - primary colored heading */\n.section-title {\n font-size: 1.25em;\n font-weight: 600;\n color: var(--color-primary);\n margin: 0;\n}\n\n/* Text Overflow - used by ProfileCard, SocialCard */\n.text-truncate {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n}\n\n.text-wrap-anywhere {\n overflow-wrap: anywhere;\n word-break: break-word;\n}\n\n/* Loading Text - primary colored centered loading indicator */\n.loading-text {\n color: var(--color-primary);\n text-align: center;\n margin: var(--spacing-md) 0;\n}\n\n/* Centered Section - flex column with center alignment */\n.section-centered {\n display: flex;\n flex-direction: column;\n align-items: center;\n}\n\n/* Card Section Background */\n.section-bg {\n background: var(--color-section-bg);\n border-radius: var(--border-radius-full);\n box-shadow: var(--box-shadow);\n padding: var(--spacing-md);\n}\n\n\n/* Transparent button override (for solid-ui integration) */\n.btn-transparent {\n background-color: transparent;\n}\n\n.btn-transparent:hover {\n background-color: transparent;\n}\n\n/* input */\n.input {\n padding: 5px;\n min-height: var(--min-touch-target);\n height: 35px;\n box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px;\n border: none;\n border-radius: var(--border-radius-base);\n background: white;\n font-weight: 600;\n font-size: var(--font-size-sm);\n transition: box-shadow 0.3s ease;\n}\n\n.input:focus,\n.input:focus-visible {\n border-radius: var(--border-radius-base);\n box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px !important;\n z-index: 1;\n}\n\ninput[type="radio"] {\n accent-color: var(--color-secondary); /* Change to your desired color */\n}\n',"",{version:3,sources:["webpack://./src/styles/utilities.css"],names:[],mappings:"AAAA,sEAAsE;;AAEtE;EACE,WAAW;EACX,gBAAgB;EAChB,gBAAgB;EAChB,sBAAsB;EACtB,qBAAqB;AACvB;;AAEA;EACE,iDAAiD;EACjD,uBAAuB;EACvB,kCAAkC;AACpC;AACA;;gDAEgD;;AAEhD;EACE,aAAa;EACb,0DAA0D;EAC1D,sBAAsB;EACtB,mCAAmC;AACrC;;AAEA;;EAEE,mBAAmB;AACrB;;AAEA;EACE,uBAAuB;EACvB,mBAAmB;AACrB;;AAEA;EACE,aAAa;AACf;AACA;EACE,aAAa;AACf;;AAEA,0CAA0C;AAC1C,UAAU,sBAAsB,EAAE;AAClC,UAAU,sBAAsB,EAAE;AAClC,UAAU,sBAAsB,EAAE;AAClC,UAAU,sBAAsB,EAAE;AAClC,UAAU,sBAAsB,EAAE;;AAElC,SAAS,6BAA6B,EAAE;AACxC,SAAS,6BAA6B,EAAE;AACxC,SAAS,6BAA6B,EAAE;AACxC,SAAS,6BAA6B,EAAE;;AAExC,SAAS,gCAAgC,EAAE;AAC3C,SAAS,gCAAgC,EAAE;AAC3C,SAAS,gCAAgC,EAAE;AAC3C,SAAS,gCAAgC,EAAE;;AAE3C,QAAQ,0BAA0B,EAAE;AACpC,QAAQ,0BAA0B,EAAE;AACpC,QAAQ,0BAA0B,EAAE;AACpC,QAAQ,0BAA0B,EAAE;;AAEpC,WAAW,wCAAwC,EAAE;AACrD,cAAc,wCAAwC,EAAE;;AAExD,UAAU,6BAA6B,EAAE;AACzC,aAAa,gCAAgC,EAAE;;AAE/C;EACE,gCAAgC;EAChC,WAAW;AACb;AACA;EACE,gCAAgC;AAClC;;AAEA,4BAA4B;AAC5B;EACE,kBAAkB;EAClB,UAAU;EACV,WAAW;EACX,UAAU;EACV,YAAY;EACZ,gBAAgB;EAChB,sBAAsB;EACtB,mBAAmB;EACnB,SAAS;AACX;;AAEA;EACE,mCAAmC;EACnC,kCAAkC;AACpC;;AAEA,qCAAqC;AACrC;EACE,6BAA6B;EAC7B,qBAAqB;EACrB,sBAAsB;EACtB,qBAAqB;EACrB,uBAAuB;EACvB,2BAA2B;EAC3B,iCAAiC;EACjC,8BAA8B;EAC9B,oBAAoB;AACtB;;AAEA;;EAEE,2BAA2B;EAC3B,sBAAsB;EACtB,uBAAuB;EACvB,2BAA2B;EAC3B,0BAA0B;EAC1B,4BAA4B;EAC5B,qBAAqB;EACrB,+BAA+B;AACjC;;AAEA,uBAAuB;AACvB;EACE,kBAAkB;EAClB,WAAW;EACX,OAAO;EACP,aAAa;AACf;;AAEA;EACE,kBAAkB;EAClB,SAAS;EACT,QAAQ;EACR,0BAA0B;EAC1B,gCAAgC;EAChC,YAAY;EACZ,qBAAqB;EACrB,wCAAwC;AAC1C;;AAEA;EACE,QAAQ;AACV;;AAEA;EACE,0BAA0B;EAC1B,2BAA2B;AAC7B;;AAEA,qBAAqB;AACrB;EACE,uCAAuC;EACvC,mBAAmB;AACrB;;AAEA;EACE,aAAa;AACf;;AAEA;EACE,aAAa;EACb,gBAAgB;AAClB;;AAEA,sBAAsB;AACtB;EACE,kBAAkB;EAClB,cAAc;EACd,UAAU;EACV,WAAW;EACX,gBAAgB;AAClB;;AAEA,4FAA4F;;AAE5F,2BAA2B;AAC3B;EACE,gBAAgB;EAChB,eAAe,EAAE,2BAA2B;AAC9C;;AAEA,iCAAiC;AACjC;EACE,oCAAoC;EACpC,eAAe;AACjB;;AAEA;EACE,8BAA8B;EAC9B,oCAAoC;AACtC;;AAEA;EACE,yDAAyD;EACzD,mCAAmC;AACrC;;AAEA;EACE,wBAAwB;EACxB,gBAAgB;AAClB;;AAEA;EACE,2DAA2D;EAC3D,mBAAmB;EACnB,6CAA6C;AAC/C;;AAEA;EACE,aAAa;EACb,gBAAgB;AAClB;;AAEA,mCAAmC;AACnC;EACE,yCAAyC;EACzC,uCAAuC;EACvC,mBAAmB;EACnB,kBAAkB;AACpB;;AAEA,uBAAuB;AACvB;EACE,wBAAwB;EACxB,mCAAmC;EACnC,0CAA0C;AAC5C;;AAEA;;gDAEgD;;AAEhD,qDAAqD;AACrD;EACE,mCAAmC;EACnC,4CAA4C;EAC5C,sCAAsC;EACtC,wCAAwC;EACxC,gCAAgC;EAChC,YAAY;EACZ,gBAAgB;EAChB,eAAe;EACf,8CAA8C;AAChD;;AAEA;EACE,+DAA+D;EAC/D,6CAA6C;AAC/C;;AAEA;EACE,6CAA6C;AAC/C;;AAEA;EACE,YAAY;EACZ,mBAAmB;EACnB,eAAe;AACjB;;AAEA,0DAA0D;AAC1D;;EAEE,kDAAkD;EAClD,8BAA8B;EAC9B,4FAA4F;EAC5F,UAAU;AACZ;;AAEA,qDAAqD;AACrD;EACE,gBAAgB;EAChB,UAAU;EACV,SAAS;AACX;;AAEA,0DAA0D;AAC1D;;EAEE,qCAAqC;AACvC;;AAEA,4CAA4C;AAC5C;EACE,iBAAiB;EACjB,gBAAgB;EAChB,2BAA2B;EAC3B,SAAS;AACX;;AAEA,oDAAoD;AACpD;EACE,mBAAmB;EACnB,uBAAuB;EACvB,gBAAgB;AAClB;;AAEA;EACE,uBAAuB;EACvB,sBAAsB;AACxB;;AAEA,8DAA8D;AAC9D;EACE,2BAA2B;EAC3B,kBAAkB;EAClB,2BAA2B;AAC7B;;AAEA,yDAAyD;AACzD;EACE,aAAa;EACb,sBAAsB;EACtB,mBAAmB;AACrB;;AAEA,4BAA4B;AAC5B;EACE,mCAAmC;EACnC,wCAAwC;EACxC,6BAA6B;EAC7B,0BAA0B;AAC5B;;;AAGA,2DAA2D;AAC3D;EACE,6BAA6B;AAC/B;;AAEA;EACE,6BAA6B;AAC/B;;AAEA,UAAU;AACV;EACE,YAAY;EACZ,mCAAmC;EACnC,YAAY;EACZ,2CAA2C;EAC3C,YAAY;EACZ,wCAAwC;EACxC,iBAAiB;EACjB,gBAAgB;EAChB,8BAA8B;EAC9B,gCAAgC;AAClC;;AAEA;;EAEE,wCAAwC;EACxC,sDAAsD;EACtD,UAAU;AACZ;;AAEA;EACE,oCAAoC,EAAE,iCAAiC;AACzE",sourcesContent:['/* Utility-first CSS classes for layout, spacing, and responsiveness */\n\n.actionButton {\n width: 100%;\n min-width: 180px;\n max-width: 320px;\n box-sizing: border-box;\n display: inline-block;\n}\n\n.selectedButton {\n background-color: var(--color-primary) !important;\n color: white !important;\n border: 1px solid white !important;\n}\n/* ===========================================\n PROFILE GRID LAYOUT\n =========================================== */\n\n.profile-grid {\n display: grid;\n grid-template-columns: repeat(auto-fit, minmax(30em, 1fr));\n gap: var(--spacing-lg);\n background: var(--color-background);\n}\n\n.profile-header,\n.profile-footer {\n grid-column: 1 / -1;\n}\n\n.center {\n justify-content: center;\n align-items: center;\n}\n\n.flex {\n display: flex;\n}\n.grid {\n display: grid;\n}\n\n/* Spacing utilities using CSS variables */\n.gap-xs { gap: var(--spacing-xs); }\n.gap-sm { gap: var(--spacing-sm); }\n.gap-md { gap: var(--spacing-md); }\n.gap-lg { gap: var(--spacing-lg); }\n.gap-xl { gap: var(--spacing-xl); }\n\n.mt-xs { margin-top: var(--spacing-xs); }\n.mt-sm { margin-top: var(--spacing-sm); }\n.mt-md { margin-top: var(--spacing-md); }\n.mt-lg { margin-top: var(--spacing-lg); }\n\n.mb-xs { margin-bottom: var(--spacing-xs); }\n.mb-sm { margin-bottom: var(--spacing-sm); }\n.mb-md { margin-bottom: var(--spacing-md); }\n.mb-lg { margin-bottom: var(--spacing-lg); }\n\n.p-xs { padding: var(--spacing-xs); }\n.p-sm { padding: var(--spacing-sm); }\n.p-md { padding: var(--spacing-md); }\n.p-lg { padding: var(--spacing-lg); }\n\n.rounded { border-radius: var(--border-radius-full); }\n.rounded-sm { border-radius: var(--border-radius-base); }\n\n.shadow { box-shadow: var(--box-shadow); }\n.shadow-sm { box-shadow: var(--box-shadow-sm); }\n\n.bg-primary {\n background: var(--color-primary);\n color: #fff;\n}\n.bg-card {\n background: var(--color-card-bg);\n}\n\n/* Accessibility utilities */\n.sr-only {\n position: absolute;\n width: 1px;\n height: 1px;\n padding: 0;\n margin: -1px;\n overflow: hidden;\n clip: rect(0, 0, 0, 0);\n white-space: nowrap;\n border: 0;\n}\n\n.min-touch-target {\n min-height: var(--min-touch-target);\n min-width: var(--min-touch-target);\n}\n\n/* Enhanced accessibility utilities */\n.visually-hidden {\n position: absolute !important;\n width: 1px !important;\n height: 1px !important;\n padding: 0 !important;\n margin: -1px !important;\n overflow: hidden !important;\n clip: rect(0, 0, 0, 0) !important;\n white-space: nowrap !important;\n border: 0 !important;\n}\n\n.visually-hidden.focusable:focus,\n.visually-hidden.focusable:active {\n position: static !important;\n width: auto !important;\n height: auto !important;\n padding: inherit !important;\n margin: inherit !important;\n overflow: visible !important;\n clip: auto !important;\n white-space: inherit !important;\n}\n\n/* Skip links utility */\n.skip-links {\n position: absolute;\n top: -100px;\n left: 0;\n z-index: 1000;\n}\n\n.skip-links a {\n position: absolute;\n left: 6px;\n top: 6px;\n padding: var(--spacing-sm);\n background: var(--color-primary);\n color: white;\n text-decoration: none;\n border-radius: var(--border-radius-base);\n}\n\n.skip-links a:focus {\n top: 6px;\n}\n\n.reduced-motion {\n animation: none !important;\n transition: none !important;\n}\n\n/* Focus management */\n.focus-ring {\n outline: 2px solid var(--color-primary);\n outline-offset: 2px;\n}\n\n.no-focus-ring {\n outline: none;\n}\n\n.no-focus-ring:focus-visible {\n outline: none;\n box-shadow: none;\n}\n\n/* ARIA live regions */\n.live-region {\n position: absolute;\n left: -10000px;\n width: 1px;\n height: 1px;\n overflow: hidden;\n}\n\n/* Note: Use aria-live="polite" or aria-live="assertive" HTML attributes with .live-region */\n\n/* Text scaling utilities */\n.text-scale-friendly {\n line-height: 1.5;\n max-width: 70ch; /* Optimal reading length */\n}\n\n/* Text accessibility utilities */\n.text-readable {\n line-height: var(--line-height-base);\n max-width: 65ch;\n}\n\n.text-lg {\n font-size: var(--font-size-lg);\n line-height: var(--line-height-base);\n}\n\n.text-small {\n font-size: max(var(--font-size-sm), var(--min-font-size));\n line-height: var(--min-line-height);\n}\n\n.text-contrast-high {\n color: var(--color-text);\n font-weight: 600;\n}\n\n:focus-visible {\n outline: var(--focus-ring-width) solid var(--color-primary);\n outline-offset: 2px;\n box-shadow: 0 0 0 1px var(--color-background);\n}\n\n:focus:not(:focus-visible) {\n outline: none;\n box-shadow: none;\n}\n\n/* Better focus for text elements */\n.focusable-text:focus {\n background-color: rgba(124, 77, 255, 0.1);\n outline: 2px solid var(--color-primary);\n outline-offset: 2px;\n border-radius: 2px;\n}\n\n/* High contrast text */\n.high-contrast {\n color: var(--color-text);\n background: var(--color-background);\n border: 1px solid var(--color-border-pale);\n}\n\n/* ===========================================\n CONSOLIDATED COMPONENT PATTERNS\n =========================================== */\n\n/* Primary Button - used by ChatWithMe, ProfileCard */\n.btn-primary {\n min-height: var(--min-touch-target);\n padding: var(--spacing-sm) var(--spacing-md);\n border: 1px solid var(--color-primary);\n border-radius: var(--border-radius-base);\n background: var(--color-primary);\n color: white;\n font-weight: 600;\n cursor: pointer;\n transition: all var(--animation-duration) ease;\n}\n\n.btn-primary:hover {\n background: color-mix(in srgb, var(--color-primary) 90%, black);\n box-shadow: 0 2px 4px rgba(124, 77, 255, 0.2);\n}\n\n.btn-primary:active {\n box-shadow: 0 1px 2px rgba(124, 77, 255, 0.2);\n}\n\n.btn-primary:disabled {\n opacity: 0.6;\n cursor: not-allowed;\n transform: none;\n}\n\n/* Action Button Focus - used by ChatWithMe, ProfileCard */\n.action-button-focus:focus,\n.action-button-focus:focus-visible {\n outline: 3px solid var(--color-primary) !important;\n outline-offset: 2px !important;\n box-shadow: 0 0 0 2px var(--color-background), 0 0 0 5px rgba(124, 77, 255, 0.25) !important;\n z-index: 1;\n}\n\n/* List Reset - used by FriendList, SocialCard, nav */\n.list-reset {\n list-style: none;\n padding: 0;\n margin: 0;\n}\n\n/* Zebra Striping - used by FriendList, StuffCard tables */\n.zebra-stripe tr:nth-child(even),\n.zebra-stripe > *:nth-child(even) {\n background-color: rgba(0, 0, 0, 0.02);\n}\n\n/* Section Title - primary colored heading */\n.section-title {\n font-size: 1.25em;\n font-weight: 600;\n color: var(--color-primary);\n margin: 0;\n}\n\n/* Text Overflow - used by ProfileCard, SocialCard */\n.text-truncate {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n}\n\n.text-wrap-anywhere {\n overflow-wrap: anywhere;\n word-break: break-word;\n}\n\n/* Loading Text - primary colored centered loading indicator */\n.loading-text {\n color: var(--color-primary);\n text-align: center;\n margin: var(--spacing-md) 0;\n}\n\n/* Centered Section - flex column with center alignment */\n.section-centered {\n display: flex;\n flex-direction: column;\n align-items: center;\n}\n\n/* Card Section Background */\n.section-bg {\n background: var(--color-section-bg);\n border-radius: var(--border-radius-full);\n box-shadow: var(--box-shadow);\n padding: var(--spacing-md);\n}\n\n\n/* Transparent button override (for solid-ui integration) */\n.btn-transparent {\n background-color: transparent;\n}\n\n.btn-transparent:hover {\n background-color: transparent;\n}\n\n/* input */\n.input {\n padding: 5px;\n min-height: var(--min-touch-target);\n height: 35px;\n box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px;\n border: none;\n border-radius: var(--border-radius-base);\n background: white;\n font-weight: 600;\n font-size: var(--font-size-sm);\n transition: box-shadow 0.3s ease;\n}\n\n.input:focus,\n.input:focus-visible {\n border-radius: var(--border-radius-base);\n box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px !important;\n z-index: 1;\n}\n\ninput[type="radio"] {\n accent-color: var(--color-secondary); /* Change to your desired color */\n}\n'],sourceRoot:""}]);const s=i},6314(n){"use strict";n.exports=function(n){var e=[];return e.toString=function(){return this.map(function(e){var t="",o=void 0!==e[5];return e[4]&&(t+="@supports (".concat(e[4],") {")),e[2]&&(t+="@media ".concat(e[2]," {")),o&&(t+="@layer".concat(e[5].length>0?" ".concat(e[5]):""," {")),t+=n(e),o&&(t+="}"),e[2]&&(t+="}"),e[4]&&(t+="}"),t}).join("")},e.i=function(n,t,o,r,a){"string"==typeof n&&(n=[[null,n,void 0]]);var i={};if(o)for(var s=0;s<this.length;s++){var d=this[s][0];null!=d&&(i[d]=!0)}for(var l=0;l<n.length;l++){var c=[].concat(n[l]);o&&i[c[0]]||(void 0!==a&&(void 0===c[5]||(c[1]="@layer".concat(c[5].length>0?" ".concat(c[5]):""," {").concat(c[1],"}")),c[5]=a),t&&(c[2]?(c[1]="@media ".concat(c[2]," {").concat(c[1],"}"),c[2]=t):c[2]=t),r&&(c[4]?(c[1]="@supports (".concat(c[4],") {").concat(c[1],"}"),c[4]=r):c[4]="".concat(r)),e.push(c))}},e}},1354(n){"use strict";n.exports=function(n){var e=n[1],t=n[3];if(!t)return e;if("function"==typeof btoa){var o=btoa(unescape(encodeURIComponent(JSON.stringify(t)))),r="sourceMappingURL=data:application/json;charset=utf-8;base64,".concat(o),a="/*# ".concat(r," */");return[e].concat([a]).join("\n")}return[e].join("\n")}},6320(n){"use strict";var e={single_source_shortest_paths:function(n,t,o){var r={},a={};a[t]=0;var i,s,d,l,c,u,p,A=e.PriorityQueue.make();for(A.push(t,0);!A.empty();)for(d in s=(i=A.pop()).value,l=i.cost,c=n[s]||{})c.hasOwnProperty(d)&&(u=l+c[d],p=a[d],(void 0===a[d]||p>u)&&(a[d]=u,A.push(d,u),r[d]=s));if(void 0!==o&&void 0===a[o]){var m=["Could not find a path from ",t," to ",o,"."].join("");throw new Error(m)}return r},extract_shortest_path_from_predecessor_list:function(n,e){for(var t=[],o=e;o;)t.push(o),n[o],o=n[o];return t.reverse(),t},find_path:function(n,t,o){var r=e.single_source_shortest_paths(n,t,o);return e.extract_shortest_path_from_predecessor_list(r,o)},PriorityQueue:{make:function(n){var t,o=e.PriorityQueue,r={};for(t in n=n||{},o)o.hasOwnProperty(t)&&(r[t]=o[t]);return r.queue=[],r.sorter=n.sorter||o.default_sorter,r},default_sorter:function(n,e){return n.cost-e.cost},push:function(n,e){var t={value:n,cost:e};this.queue.push(t),this.queue.sort(this.sorter)},pop:function(){return this.queue.shift()},empty:function(){return 0===this.queue.length}}};n.exports=e},7583(n,e,t){const o=t(1333),r=t(157),a=t(7899),i=t(6756);function s(n,e,t,a,i){const s=[].slice.call(arguments,1),d=s.length,l="function"==typeof s[d-1];if(!l&&!o())throw new Error("Callback required as last argument");if(!l){if(d<1)throw new Error("Too few arguments provided");return 1===d?(t=e,e=a=void 0):2!==d||e.getContext||(a=t,t=e,e=void 0),new Promise(function(o,i){try{const i=r.create(t,a);o(n(i,e,a))}catch(n){i(n)}})}if(d<2)throw new Error("Too few arguments provided");2===d?(i=t,t=e,e=a=void 0):3===d&&(e.getContext&&void 0===i?(i=a,a=void 0):(i=a,a=t,t=e,e=void 0));try{const o=r.create(t,a);i(null,n(o,e,a))}catch(n){i(n)}}r.create,s.bind(null,a.render),s.bind(null,a.renderToDataURL),e.toString=s.bind(null,function(n,e,t){return i.render(n,t)})},1333(n){n.exports=function(){return"function"==typeof Promise&&Promise.prototype&&Promise.prototype.then}},6421(n,e,t){const o=t(6886).getSymbolSize;e.getRowColCoords=function(n){if(1===n)return[];const e=Math.floor(n/7)+2,t=o(n),r=145===t?26:2*Math.ceil((t-13)/(2*e-2)),a=[t-7];for(let n=1;n<e-1;n++)a[n]=a[n-1]-r;return a.push(6),a.reverse()},e.getPositions=function(n){const t=[],o=e.getRowColCoords(n),r=o.length;for(let n=0;n<r;n++)for(let e=0;e<r;e++)0===n&&0===e||0===n&&e===r-1||n===r-1&&0===e||t.push([o[n],o[e]]);return t}},1433(n,e,t){const o=t(208),r=["0","1","2","3","4","5","6","7","8","9","A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P","Q","R","S","T","U","V","W","X","Y","Z"," ","$","%","*","+","-",".","/",":"];function a(n){this.mode=o.ALPHANUMERIC,this.data=n}a.getBitsLength=function(n){return 11*Math.floor(n/2)+n%2*6},a.prototype.getLength=function(){return this.data.length},a.prototype.getBitsLength=function(){return a.getBitsLength(this.data.length)},a.prototype.write=function(n){let e;for(e=0;e+2<=this.data.length;e+=2){let t=45*r.indexOf(this.data[e]);t+=r.indexOf(this.data[e+1]),n.put(t,11)}this.data.length%2&&n.put(r.indexOf(this.data[e]),6)},n.exports=a},9899(n){function e(){this.buffer=[],this.length=0}e.prototype={get:function(n){const e=Math.floor(n/8);return 1==(this.buffer[e]>>>7-n%8&1)},put:function(n,e){for(let t=0;t<e;t++)this.putBit(1==(n>>>e-t-1&1))},getLengthInBits:function(){return this.length},putBit:function(n){const e=Math.floor(this.length/8);this.buffer.length<=e&&this.buffer.push(0),n&&(this.buffer[e]|=128>>>this.length%8),this.length++}},n.exports=e},8820(n){function e(n){if(!n||n<1)throw new Error("BitMatrix size must be defined and greater than 0");this.size=n,this.data=new Uint8Array(n*n),this.reservedBit=new Uint8Array(n*n)}e.prototype.set=function(n,e,t,o){const r=n*this.size+e;this.data[r]=t,o&&(this.reservedBit[r]=!0)},e.prototype.get=function(n,e){return this.data[n*this.size+e]},e.prototype.xor=function(n,e,t){this.data[n*this.size+e]^=t},e.prototype.isReserved=function(n,e){return this.reservedBit[n*this.size+e]},n.exports=e},5822(n,e,t){const o=t(208);function r(n){this.mode=o.BYTE,this.data="string"==typeof n?(new TextEncoder).encode(n):new Uint8Array(n)}r.getBitsLength=function(n){return 8*n},r.prototype.getLength=function(){return this.data.length},r.prototype.getBitsLength=function(){return r.getBitsLength(this.data.length)},r.prototype.write=function(n){for(let e=0,t=this.data.length;e<t;e++)n.put(this.data[e],8)},n.exports=r},7518(n,e,t){const o=t(9953),r=[1,1,1,1,1,1,1,1,1,1,2,2,1,2,2,4,1,2,4,4,2,4,4,4,2,4,6,5,2,4,6,6,2,5,8,8,4,5,8,8,4,5,8,11,4,8,10,11,4,9,12,16,4,9,16,16,6,10,12,18,6,10,17,16,6,11,16,19,6,13,18,21,7,14,21,25,8,16,20,25,8,17,23,25,9,17,23,34,9,18,25,30,10,20,27,32,12,21,29,35,12,23,34,37,12,25,34,40,13,26,35,42,14,28,38,45,15,29,40,48,16,31,43,51,17,33,45,54,18,35,48,57,19,37,51,60,19,38,53,63,20,40,56,66,21,43,59,70,22,45,62,74,24,47,65,77,25,49,68,81],a=[7,10,13,17,10,16,22,28,15,26,36,44,20,36,52,64,26,48,72,88,36,64,96,112,40,72,108,130,48,88,132,156,60,110,160,192,72,130,192,224,80,150,224,264,96,176,260,308,104,198,288,352,120,216,320,384,132,240,360,432,144,280,408,480,168,308,448,532,180,338,504,588,196,364,546,650,224,416,600,700,224,442,644,750,252,476,690,816,270,504,750,900,300,560,810,960,312,588,870,1050,336,644,952,1110,360,700,1020,1200,390,728,1050,1260,420,784,1140,1350,450,812,1200,1440,480,868,1290,1530,510,924,1350,1620,540,980,1440,1710,570,1036,1530,1800,570,1064,1590,1890,600,1120,1680,1980,630,1204,1770,2100,660,1260,1860,2220,720,1316,1950,2310,750,1372,2040,2430];e.getBlocksCount=function(n,e){switch(e){case o.L:return r[4*(n-1)+0];case o.M:return r[4*(n-1)+1];case o.Q:return r[4*(n-1)+2];case o.H:return r[4*(n-1)+3];default:return}},e.getTotalCodewordsCount=function(n,e){switch(e){case o.L:return a[4*(n-1)+0];case o.M:return a[4*(n-1)+1];case o.Q:return a[4*(n-1)+2];case o.H:return a[4*(n-1)+3];default:return}}},9953(n,e){e.L={bit:1},e.M={bit:0},e.Q={bit:3},e.H={bit:2},e.isValid=function(n){return n&&void 0!==n.bit&&n.bit>=0&&n.bit<4},e.from=function(n,t){if(e.isValid(n))return n;try{return function(n){if("string"!=typeof n)throw new Error("Param is not a string");switch(n.toLowerCase()){case"l":case"low":return e.L;case"m":case"medium":return e.M;case"q":case"quartile":return e.Q;case"h":case"high":return e.H;default:throw new Error("Unknown EC Level: "+n)}}(n)}catch(n){return t}}},7756(n,e,t){const o=t(6886).getSymbolSize;e.getPositions=function(n){const e=o(n);return[[0,0],[e-7,0],[0,e-7]]}},4565(n,e,t){const o=t(6886),r=o.getBCHDigit(1335);e.getEncodedBits=function(n,e){const t=n.bit<<3|e;let a=t<<10;for(;o.getBCHDigit(a)-r>=0;)a^=1335<<o.getBCHDigit(a)-r;return 21522^(t<<10|a)}},2731(n,e){const t=new Uint8Array(512),o=new Uint8Array(256);!function(){let n=1;for(let e=0;e<255;e++)t[e]=n,o[n]=e,n<<=1,256&n&&(n^=285);for(let n=255;n<512;n++)t[n]=t[n-255]}(),e.log=function(n){if(n<1)throw new Error("log("+n+")");return o[n]},e.exp=function(n){return t[n]},e.mul=function(n,e){return 0===n||0===e?0:t[o[n]+o[e]]}},4861(n,e,t){const o=t(208),r=t(6886);function a(n){this.mode=o.KANJI,this.data=n}a.getBitsLength=function(n){return 13*n},a.prototype.getLength=function(){return this.data.length},a.prototype.getBitsLength=function(){return a.getBitsLength(this.data.length)},a.prototype.write=function(n){let e;for(e=0;e<this.data.length;e++){let t=r.toSJIS(this.data[e]);if(t>=33088&&t<=40956)t-=33088;else{if(!(t>=57408&&t<=60351))throw new Error("Invalid SJIS character: "+this.data[e]+"\nMake sure your charset is UTF-8");t-=49472}t=192*(t>>>8&255)+(255&t),n.put(t,13)}},n.exports=a},1332(n,e){e.Patterns={PATTERN000:0,PATTERN001:1,PATTERN010:2,PATTERN011:3,PATTERN100:4,PATTERN101:5,PATTERN110:6,PATTERN111:7};const t=3,o=3,r=40,a=10;function i(n,t,o){switch(n){case e.Patterns.PATTERN000:return(t+o)%2==0;case e.Patterns.PATTERN001:return t%2==0;case e.Patterns.PATTERN010:return o%3==0;case e.Patterns.PATTERN011:return(t+o)%3==0;case e.Patterns.PATTERN100:return(Math.floor(t/2)+Math.floor(o/3))%2==0;case e.Patterns.PATTERN101:return t*o%2+t*o%3==0;case e.Patterns.PATTERN110:return(t*o%2+t*o%3)%2==0;case e.Patterns.PATTERN111:return(t*o%3+(t+o)%2)%2==0;default:throw new Error("bad maskPattern:"+n)}}e.isValid=function(n){return null!=n&&""!==n&&!isNaN(n)&&n>=0&&n<=7},e.from=function(n){return e.isValid(n)?parseInt(n,10):void 0},e.getPenaltyN1=function(n){const e=n.size;let o=0,r=0,a=0,i=null,s=null;for(let d=0;d<e;d++){r=a=0,i=s=null;for(let l=0;l<e;l++){let e=n.get(d,l);e===i?r++:(r>=5&&(o+=t+(r-5)),i=e,r=1),e=n.get(l,d),e===s?a++:(a>=5&&(o+=t+(a-5)),s=e,a=1)}r>=5&&(o+=t+(r-5)),a>=5&&(o+=t+(a-5))}return o},e.getPenaltyN2=function(n){const e=n.size;let t=0;for(let o=0;o<e-1;o++)for(let r=0;r<e-1;r++){const e=n.get(o,r)+n.get(o,r+1)+n.get(o+1,r)+n.get(o+1,r+1);4!==e&&0!==e||t++}return t*o},e.getPenaltyN3=function(n){const e=n.size;let t=0,o=0,a=0;for(let r=0;r<e;r++){o=a=0;for(let i=0;i<e;i++)o=o<<1&2047|n.get(r,i),i>=10&&(1488===o||93===o)&&t++,a=a<<1&2047|n.get(i,r),i>=10&&(1488===a||93===a)&&t++}return t*r},e.getPenaltyN4=function(n){let e=0;const t=n.data.length;for(let o=0;o<t;o++)e+=n.data[o];return Math.abs(Math.ceil(100*e/t/5)-10)*a},e.applyMask=function(n,e){const t=e.size;for(let o=0;o<t;o++)for(let r=0;r<t;r++)e.isReserved(r,o)||e.xor(r,o,i(n,r,o))},e.getBestMask=function(n,t){const o=Object.keys(e.Patterns).length;let r=0,a=1/0;for(let i=0;i<o;i++){t(i),e.applyMask(i,n);const o=e.getPenaltyN1(n)+e.getPenaltyN2(n)+e.getPenaltyN3(n)+e.getPenaltyN4(n);e.applyMask(i,n),o<a&&(a=o,r=i)}return r}},208(n,e,t){const o=t(1878),r=t(7044);e.NUMERIC={id:"Numeric",bit:1,ccBits:[10,12,14]},e.ALPHANUMERIC={id:"Alphanumeric",bit:2,ccBits:[9,11,13]},e.BYTE={id:"Byte",bit:4,ccBits:[8,16,16]},e.KANJI={id:"Kanji",bit:8,ccBits:[8,10,12]},e.MIXED={bit:-1},e.getCharCountIndicator=function(n,e){if(!n.ccBits)throw new Error("Invalid mode: "+n);if(!o.isValid(e))throw new Error("Invalid version: "+e);return e>=1&&e<10?n.ccBits[0]:e<27?n.ccBits[1]:n.ccBits[2]},e.getBestModeForData=function(n){return r.testNumeric(n)?e.NUMERIC:r.testAlphanumeric(n)?e.ALPHANUMERIC:r.testKanji(n)?e.KANJI:e.BYTE},e.toString=function(n){if(n&&n.id)return n.id;throw new Error("Invalid mode")},e.isValid=function(n){return n&&n.bit&&n.ccBits},e.from=function(n,t){if(e.isValid(n))return n;try{return function(n){if("string"!=typeof n)throw new Error("Param is not a string");switch(n.toLowerCase()){case"numeric":return e.NUMERIC;case"alphanumeric":return e.ALPHANUMERIC;case"kanji":return e.KANJI;case"byte":return e.BYTE;default:throw new Error("Unknown mode: "+n)}}(n)}catch(n){return t}}},4357(n,e,t){const o=t(208);function r(n){this.mode=o.NUMERIC,this.data=n.toString()}r.getBitsLength=function(n){return 10*Math.floor(n/3)+(n%3?n%3*3+1:0)},r.prototype.getLength=function(){return this.data.length},r.prototype.getBitsLength=function(){return r.getBitsLength(this.data.length)},r.prototype.write=function(n){let e,t,o;for(e=0;e+3<=this.data.length;e+=3)t=this.data.substr(e,3),o=parseInt(t,10),n.put(o,10);const r=this.data.length-e;r>0&&(t=this.data.substr(e),o=parseInt(t,10),n.put(o,3*r+1))},n.exports=r},4713(n,e,t){const o=t(2731);e.mul=function(n,e){const t=new Uint8Array(n.length+e.length-1);for(let r=0;r<n.length;r++)for(let a=0;a<e.length;a++)t[r+a]^=o.mul(n[r],e[a]);return t},e.mod=function(n,e){let t=new Uint8Array(n);for(;t.length-e.length>=0;){const n=t[0];for(let r=0;r<e.length;r++)t[r]^=o.mul(e[r],n);let r=0;for(;r<t.length&&0===t[r];)r++;t=t.slice(r)}return t},e.generateECPolynomial=function(n){let t=new Uint8Array([1]);for(let r=0;r<n;r++)t=e.mul(t,new Uint8Array([1,o.exp(r)]));return t}},157(n,e,t){const o=t(6886),r=t(9953),a=t(9899),i=t(8820),s=t(6421),d=t(7756),l=t(1332),c=t(7518),u=t(4764),p=t(1427),A=t(4565),m=t(208),h=t(9801);function f(n,e,t){const o=n.size,r=A.getEncodedBits(e,t);let a,i;for(a=0;a<15;a++)i=1==(r>>a&1),a<6?n.set(a,8,i,!0):a<8?n.set(a+1,8,i,!0):n.set(o-15+a,8,i,!0),a<8?n.set(8,o-a-1,i,!0):a<9?n.set(8,15-a-1+1,i,!0):n.set(8,15-a-1,i,!0);n.set(o-8,8,1,!0)}function g(n,e,t){const r=new a;t.forEach(function(e){r.put(e.mode.bit,4),r.put(e.getLength(),m.getCharCountIndicator(e.mode,n)),e.write(r)});const i=8*(o.getSymbolTotalCodewords(n)-c.getTotalCodewordsCount(n,e));for(r.getLengthInBits()+4<=i&&r.put(0,4);r.getLengthInBits()%8!=0;)r.putBit(0);const s=(i-r.getLengthInBits())/8;for(let n=0;n<s;n++)r.put(n%2?17:236,8);return function(n,e,t){const r=o.getSymbolTotalCodewords(e),a=c.getTotalCodewordsCount(e,t),i=r-a,s=c.getBlocksCount(e,t),d=r%s,l=s-d,p=Math.floor(r/s),A=Math.floor(i/s),m=A+1,h=p-A,f=new u(h);let g=0;const b=new Array(s),C=new Array(s);let w=0;const y=new Uint8Array(n.buffer);for(let n=0;n<s;n++){const e=n<l?A:m;b[n]=y.slice(g,g+e),C[n]=f.encode(b[n]),g+=e,w=Math.max(w,e)}const v=new Uint8Array(r);let E,B,x=0;for(E=0;E<w;E++)for(B=0;B<s;B++)E<b[B].length&&(v[x++]=b[B][E]);for(E=0;E<h;E++)for(B=0;B<s;B++)v[x++]=C[B][E];return v}(r,n,e)}function b(n,e,t,r){let a;if(Array.isArray(n))a=h.fromArray(n);else{if("string"!=typeof n)throw new Error("Invalid data");{let o=e;if(!o){const e=h.rawSplit(n);o=p.getBestVersionForData(e,t)}a=h.fromString(n,o||40)}}const c=p.getBestVersionForData(a,t);if(!c)throw new Error("The amount of data is too big to be stored in a QR Code");if(e){if(e<c)throw new Error("\nThe chosen QR Code version cannot contain this amount of data.\nMinimum version required to store current data is: "+c+".\n")}else e=c;const u=g(e,t,a),A=o.getSymbolSize(e),m=new i(A);return function(n,e){const t=n.size,o=d.getPositions(e);for(let e=0;e<o.length;e++){const r=o[e][0],a=o[e][1];for(let e=-1;e<=7;e++)if(!(r+e<=-1||t<=r+e))for(let o=-1;o<=7;o++)a+o<=-1||t<=a+o||(e>=0&&e<=6&&(0===o||6===o)||o>=0&&o<=6&&(0===e||6===e)||e>=2&&e<=4&&o>=2&&o<=4?n.set(r+e,a+o,!0,!0):n.set(r+e,a+o,!1,!0))}}(m,e),function(n){const e=n.size;for(let t=8;t<e-8;t++){const e=t%2==0;n.set(t,6,e,!0),n.set(6,t,e,!0)}}(m),function(n,e){const t=s.getPositions(e);for(let e=0;e<t.length;e++){const o=t[e][0],r=t[e][1];for(let e=-2;e<=2;e++)for(let t=-2;t<=2;t++)-2===e||2===e||-2===t||2===t||0===e&&0===t?n.set(o+e,r+t,!0,!0):n.set(o+e,r+t,!1,!0)}}(m,e),f(m,t,0),e>=7&&function(n,e){const t=n.size,o=p.getEncodedBits(e);let r,a,i;for(let e=0;e<18;e++)r=Math.floor(e/3),a=e%3+t-8-3,i=1==(o>>e&1),n.set(r,a,i,!0),n.set(a,r,i,!0)}(m,e),function(n,e){const t=n.size;let o=-1,r=t-1,a=7,i=0;for(let s=t-1;s>0;s-=2)for(6===s&&s--;;){for(let t=0;t<2;t++)if(!n.isReserved(r,s-t)){let o=!1;i<e.length&&(o=1==(e[i]>>>a&1)),n.set(r,s-t,o),a--,-1===a&&(i++,a=7)}if(r+=o,r<0||t<=r){r-=o,o=-o;break}}}(m,u),isNaN(r)&&(r=l.getBestMask(m,f.bind(null,m,t))),l.applyMask(r,m),f(m,t,r),{modules:m,version:e,errorCorrectionLevel:t,maskPattern:r,segments:a}}e.create=function(n,e){if(void 0===n||""===n)throw new Error("No input text");let t,a,i=r.M;return void 0!==e&&(i=r.from(e.errorCorrectionLevel,r.M),t=p.from(e.version),a=l.from(e.maskPattern),e.toSJISFunc&&o.setToSJISFunction(e.toSJISFunc)),b(n,t,i,a)}},4764(n,e,t){const o=t(4713);function r(n){this.genPoly=void 0,this.degree=n,this.degree&&this.initialize(this.degree)}r.prototype.initialize=function(n){this.degree=n,this.genPoly=o.generateECPolynomial(this.degree)},r.prototype.encode=function(n){if(!this.genPoly)throw new Error("Encoder not initialized");const e=new Uint8Array(n.length+this.degree);e.set(n);const t=o.mod(e,this.genPoly),r=this.degree-t.length;if(r>0){const n=new Uint8Array(this.degree);return n.set(t,r),n}return t},n.exports=r},7044(n,e){const t="[0-9]+";let o="(?:[u3000-u303F]|[u3040-u309F]|[u30A0-u30FF]|[uFF00-uFFEF]|[u4E00-u9FAF]|[u2605-u2606]|[u2190-u2195]|u203B|[u2010u2015u2018u2019u2025u2026u201Cu201Du2225u2260]|[u0391-u0451]|[u00A7u00A8u00B1u00B4u00D7u00F7])+";o=o.replace(/u/g,"\\u");const r="(?:(?![A-Z0-9 $%*+\\-./:]|"+o+")(?:.|[\r\n]))+";e.KANJI=new RegExp(o,"g"),e.BYTE_KANJI=new RegExp("[^A-Z0-9 $%*+\\-./:]+","g"),e.BYTE=new RegExp(r,"g"),e.NUMERIC=new RegExp(t,"g"),e.ALPHANUMERIC=new RegExp("[A-Z $%*+\\-./:]+","g");const a=new RegExp("^"+o+"$"),i=new RegExp("^"+t+"$"),s=new RegExp("^[A-Z0-9 $%*+\\-./:]+$");e.testKanji=function(n){return a.test(n)},e.testNumeric=function(n){return i.test(n)},e.testAlphanumeric=function(n){return s.test(n)}},9801(n,e,t){const o=t(208),r=t(4357),a=t(1433),i=t(5822),s=t(4861),d=t(7044),l=t(6886),c=t(6320);function u(n){return unescape(encodeURIComponent(n)).length}function p(n,e,t){const o=[];let r;for(;null!==(r=n.exec(t));)o.push({data:r[0],index:r.index,mode:e,length:r[0].length});return o}function A(n){const e=p(d.NUMERIC,o.NUMERIC,n),t=p(d.ALPHANUMERIC,o.ALPHANUMERIC,n);let r,a;l.isKanjiModeEnabled()?(r=p(d.BYTE,o.BYTE,n),a=p(d.KANJI,o.KANJI,n)):(r=p(d.BYTE_KANJI,o.BYTE,n),a=[]);return e.concat(t,r,a).sort(function(n,e){return n.index-e.index}).map(function(n){return{data:n.data,mode:n.mode,length:n.length}})}function m(n,e){switch(e){case o.NUMERIC:return r.getBitsLength(n);case o.ALPHANUMERIC:return a.getBitsLength(n);case o.KANJI:return s.getBitsLength(n);case o.BYTE:return i.getBitsLength(n)}}function h(n,e){let t;const d=o.getBestModeForData(n);if(t=o.from(e,d),t!==o.BYTE&&t.bit<d.bit)throw new Error('"'+n+'" cannot be encoded with mode '+o.toString(t)+".\n Suggested mode is: "+o.toString(d));switch(t!==o.KANJI||l.isKanjiModeEnabled()||(t=o.BYTE),t){case o.NUMERIC:return new r(n);case o.ALPHANUMERIC:return new a(n);case o.KANJI:return new s(n);case o.BYTE:return new i(n)}}e.fromArray=function(n){return n.reduce(function(n,e){return"string"==typeof e?n.push(h(e,null)):e.data&&n.push(h(e.data,e.mode)),n},[])},e.fromString=function(n,t){const r=function(n){const e=[];for(let t=0;t<n.length;t++){const r=n[t];switch(r.mode){case o.NUMERIC:e.push([r,{data:r.data,mode:o.ALPHANUMERIC,length:r.length},{data:r.data,mode:o.BYTE,length:r.length}]);break;case o.ALPHANUMERIC:e.push([r,{data:r.data,mode:o.BYTE,length:r.length}]);break;case o.KANJI:e.push([r,{data:r.data,mode:o.BYTE,length:u(r.data)}]);break;case o.BYTE:e.push([{data:r.data,mode:o.BYTE,length:u(r.data)}])}}return e}(A(n,l.isKanjiModeEnabled())),a=function(n,e){const t={},r={start:{}};let a=["start"];for(let i=0;i<n.length;i++){const s=n[i],d=[];for(let n=0;n<s.length;n++){const l=s[n],c=""+i+n;d.push(c),t[c]={node:l,lastCount:0},r[c]={};for(let n=0;n<a.length;n++){const i=a[n];t[i]&&t[i].node.mode===l.mode?(r[i][c]=m(t[i].lastCount+l.length,l.mode)-m(t[i].lastCount,l.mode),t[i].lastCount+=l.length):(t[i]&&(t[i].lastCount=l.length),r[i][c]=m(l.length,l.mode)+4+o.getCharCountIndicator(l.mode,e))}}a=d}for(let n=0;n<a.length;n++)r[a[n]].end=0;return{map:r,table:t}}(r,t),i=c.find_path(a.map,"start","end"),s=[];for(let n=1;n<i.length-1;n++)s.push(a.table[i[n]].node);return e.fromArray(function(n){return n.reduce(function(n,e){const t=n.length-1>=0?n[n.length-1]:null;return t&&t.mode===e.mode?(n[n.length-1].data+=e.data,n):(n.push(e),n)},[])}(s))},e.rawSplit=function(n){return e.fromArray(A(n,l.isKanjiModeEnabled()))}},6886(n,e){let t;const o=[0,26,44,70,100,134,172,196,242,292,346,404,466,532,581,655,733,815,901,991,1085,1156,1258,1364,1474,1588,1706,1828,1921,2051,2185,2323,2465,2611,2761,2876,3034,3196,3362,3532,3706];e.getSymbolSize=function(n){if(!n)throw new Error('"version" cannot be null or undefined');if(n<1||n>40)throw new Error('"version" should be in range from 1 to 40');return 4*n+17},e.getSymbolTotalCodewords=function(n){return o[n]},e.getBCHDigit=function(n){let e=0;for(;0!==n;)e++,n>>>=1;return e},e.setToSJISFunction=function(n){if("function"!=typeof n)throw new Error('"toSJISFunc" is not a valid function.');t=n},e.isKanjiModeEnabled=function(){return void 0!==t},e.toSJIS=function(n){return t(n)}},1878(n,e){e.isValid=function(n){return!isNaN(n)&&n>=1&&n<=40}},1427(n,e,t){const o=t(6886),r=t(7518),a=t(9953),i=t(208),s=t(1878),d=o.getBCHDigit(7973);function l(n,e){return i.getCharCountIndicator(n,e)+4}function c(n,e){let t=0;return n.forEach(function(n){const o=l(n.mode,e);t+=o+n.getBitsLength()}),t}e.from=function(n,e){return s.isValid(n)?parseInt(n,10):e},e.getCapacity=function(n,e,t){if(!s.isValid(n))throw new Error("Invalid QR Code version");void 0===t&&(t=i.BYTE);const a=8*(o.getSymbolTotalCodewords(n)-r.getTotalCodewordsCount(n,e));if(t===i.MIXED)return a;const d=a-l(t,n);switch(t){case i.NUMERIC:return Math.floor(d/10*3);case i.ALPHANUMERIC:return Math.floor(d/11*2);case i.KANJI:return Math.floor(d/13);case i.BYTE:default:return Math.floor(d/8)}},e.getBestVersionForData=function(n,t){let o;const r=a.from(t,a.M);if(Array.isArray(n)){if(n.length>1)return function(n,t){for(let o=1;o<=40;o++)if(c(n,o)<=e.getCapacity(o,t,i.MIXED))return o}(n,r);if(0===n.length)return 1;o=n[0]}else o=n;return function(n,t,o){for(let r=1;r<=40;r++)if(t<=e.getCapacity(r,o,n))return r}(o.mode,o.getLength(),r)},e.getEncodedBits=function(n){if(!s.isValid(n)||n<7)throw new Error("Invalid QR Code version");let e=n<<12;for(;o.getBCHDigit(e)-d>=0;)e^=7973<<o.getBCHDigit(e)-d;return n<<12|e}},7899(n,e,t){const o=t(2726);e.render=function(n,e,t){let r=t,a=e;void 0!==r||e&&e.getContext||(r=e,e=void 0),e||(a=function(){try{return document.createElement("canvas")}catch(n){throw new Error("You need to specify a canvas element")}}()),r=o.getOptions(r);const i=o.getImageWidth(n.modules.size,r),s=a.getContext("2d"),d=s.createImageData(i,i);return o.qrToImageData(d.data,n,r),function(n,e,t){n.clearRect(0,0,e.width,e.height),e.style||(e.style={}),e.height=t,e.width=t,e.style.height=t+"px",e.style.width=t+"px"}(s,a,i),s.putImageData(d,0,0),a},e.renderToDataURL=function(n,t,o){let r=o;void 0!==r||t&&t.getContext||(r=t,t=void 0),r||(r={});const a=e.render(n,t,r),i=r.type||"image/png",s=r.rendererOpts||{};return a.toDataURL(i,s.quality)}},6756(n,e,t){const o=t(2726);function r(n,e){const t=n.a/255,o=e+'="'+n.hex+'"';return t<1?o+" "+e+'-opacity="'+t.toFixed(2).slice(1)+'"':o}function a(n,e,t){let o=n+e;return void 0!==t&&(o+=" "+t),o}e.render=function(n,e,t){const i=o.getOptions(e),s=n.modules.size,d=n.modules.data,l=s+2*i.margin,c=i.color.light.a?"<path "+r(i.color.light,"fill")+' d="M0 0h'+l+"v"+l+'H0z"/>':"",u="<path "+r(i.color.dark,"stroke")+' d="'+function(n,e,t){let o="",r=0,i=!1,s=0;for(let d=0;d<n.length;d++){const l=Math.floor(d%e),c=Math.floor(d/e);l||i||(i=!0),n[d]?(s++,d>0&&l>0&&n[d-1]||(o+=i?a("M",l+t,.5+c+t):a("m",r,0),r=0,i=!1),l+1<e&&n[d+1]||(o+=a("h",s),s=0)):r++}return o}(d,s,i.margin)+'"/>',p='viewBox="0 0 '+l+" "+l+'"',A='<svg xmlns="http://www.w3.org/2000/svg" '+(i.width?'width="'+i.width+'" height="'+i.width+'" ':"")+p+' shape-rendering="crispEdges">'+c+u+"</svg>\n";return"function"==typeof t&&t(null,A),A}},2726(n,e){function t(n){if("number"==typeof n&&(n=n.toString()),"string"!=typeof n)throw new Error("Color should be defined as hex string");let e=n.slice().replace("#","").split("");if(e.length<3||5===e.length||e.length>8)throw new Error("Invalid hex color: "+n);3!==e.length&&4!==e.length||(e=Array.prototype.concat.apply([],e.map(function(n){return[n,n]}))),6===e.length&&e.push("F","F");const t=parseInt(e.join(""),16);return{r:t>>24&255,g:t>>16&255,b:t>>8&255,a:255&t,hex:"#"+e.slice(0,6).join("")}}e.getOptions=function(n){n||(n={}),n.color||(n.color={});const e=void 0===n.margin||null===n.margin||n.margin<0?4:n.margin,o=n.width&&n.width>=21?n.width:void 0,r=n.scale||4;return{width:o,scale:o?4:r,margin:e,color:{dark:t(n.color.dark||"#000000ff"),light:t(n.color.light||"#ffffffff")},type:n.type,rendererOpts:n.rendererOpts||{}}},e.getScale=function(n,e){return e.width&&e.width>=n+2*e.margin?e.width/(n+2*e.margin):e.scale},e.getImageWidth=function(n,t){const o=e.getScale(n,t);return Math.floor((n+2*t.margin)*o)},e.qrToImageData=function(n,t,o){const r=t.modules.size,a=t.modules.data,i=e.getScale(r,o),s=Math.floor((r+2*o.margin)*i),d=o.margin*i,l=[o.color.light,o.color.dark];for(let e=0;e<s;e++)for(let t=0;t<s;t++){let c=4*(e*s+t),u=o.color.light;if(e>=d&&t>=d&&e<s-d&&t<s-d){u=l[a[Math.floor((e-d)/i)*r+Math.floor((t-d)/i)]?1:0]}n[c++]=u.r,n[c++]=u.g,n[c++]=u.b,n[c]=u.a}}},8068(n){"use strict";var e=(()=>{var n=Object.defineProperty,e=Object.getOwnPropertyDescriptor,t=Object.getOwnPropertyNames,o=Object.getOwnPropertySymbols,r=Object.prototype.hasOwnProperty,a=Object.prototype.propertyIsEnumerable,i=(e,t,o)=>t in e?n(e,t,{enumerable:!0,configurable:!0,writable:!0,value:o}):e[t]=o,s=(n,e)=>{for(var t in e||(e={}))r.call(e,t)&&i(n,t,e[t]);if(o)for(var t of o(e))a.call(e,t)&&i(n,t,e[t]);return n},d=(n,e,t)=>i(n,"symbol"!=typeof e?e+"":e,t),l={};((e,t)=>{for(var o in t)n(e,o,{get:t[o],enumerable:!0})})(l,{DEFAULT_OPTIONS:()=>u,DEFAULT_UUID_LENGTH:()=>c,default:()=>m});var c=6,u={dictionary:"alphanum",shuffle:!0,debug:!1,length:c,counter:0},p=class{constructor(n={}){d(this,"counter"),d(this,"debug"),d(this,"dict"),d(this,"version"),d(this,"dictIndex",0),d(this,"dictRange",[]),d(this,"lowerBound",0),d(this,"upperBound",0),d(this,"dictLength",0),d(this,"uuidLength"),d(this,"_digit_first_ascii",48),d(this,"_digit_last_ascii",58),d(this,"_alpha_lower_first_ascii",97),d(this,"_alpha_lower_last_ascii",123),d(this,"_hex_last_ascii",103),d(this,"_alpha_upper_first_ascii",65),d(this,"_alpha_upper_last_ascii",91),d(this,"_number_dict_ranges",{digits:[this._digit_first_ascii,this._digit_last_ascii]}),d(this,"_alpha_dict_ranges",{lowerCase:[this._alpha_lower_first_ascii,this._alpha_lower_last_ascii],upperCase:[this._alpha_upper_first_ascii,this._alpha_upper_last_ascii]}),d(this,"_alpha_lower_dict_ranges",{lowerCase:[this._alpha_lower_first_ascii,this._alpha_lower_last_ascii]}),d(this,"_alpha_upper_dict_ranges",{upperCase:[this._alpha_upper_first_ascii,this._alpha_upper_last_ascii]}),d(this,"_alphanum_dict_ranges",{digits:[this._digit_first_ascii,this._digit_last_ascii],lowerCase:[this._alpha_lower_first_ascii,this._alpha_lower_last_ascii],upperCase:[this._alpha_upper_first_ascii,this._alpha_upper_last_ascii]}),d(this,"_alphanum_lower_dict_ranges",{digits:[this._digit_first_ascii,this._digit_last_ascii],lowerCase:[this._alpha_lower_first_ascii,this._alpha_lower_last_ascii]}),d(this,"_alphanum_upper_dict_ranges",{digits:[this._digit_first_ascii,this._digit_last_ascii],upperCase:[this._alpha_upper_first_ascii,this._alpha_upper_last_ascii]}),d(this,"_hex_dict_ranges",{decDigits:[this._digit_first_ascii,this._digit_last_ascii],alphaDigits:[this._alpha_lower_first_ascii,this._hex_last_ascii]}),d(this,"_dict_ranges",{_number_dict_ranges:this._number_dict_ranges,_alpha_dict_ranges:this._alpha_dict_ranges,_alpha_lower_dict_ranges:this._alpha_lower_dict_ranges,_alpha_upper_dict_ranges:this._alpha_upper_dict_ranges,_alphanum_dict_ranges:this._alphanum_dict_ranges,_alphanum_lower_dict_ranges:this._alphanum_lower_dict_ranges,_alphanum_upper_dict_ranges:this._alphanum_upper_dict_ranges,_hex_dict_ranges:this._hex_dict_ranges}),d(this,"log",(...n)=>{const e=[...n];e[0]="[short-unique-id] ".concat(n[0]),!0!==this.debug||"undefined"==typeof console||null===console||console.log(...e)}),d(this,"_normalizeDictionary",(n,e)=>{let t;if(n&&Array.isArray(n)&&n.length>1)t=n;else{t=[],this.dictIndex=0;const e="_".concat(n,"_dict_ranges"),o=this._dict_ranges[e];let r=0;for(const[,n]of Object.entries(o)){const[e,t]=n;r+=Math.abs(t-e)}t=new Array(r);let a=0;for(const[,n]of Object.entries(o)){this.dictRange=n,this.lowerBound=this.dictRange[0],this.upperBound=this.dictRange[1];const e=this.lowerBound<=this.upperBound,o=this.lowerBound,r=this.upperBound;if(e)for(let n=o;n<r;n++)t[a++]=String.fromCharCode(n),this.dictIndex=n;else for(let n=o;n>r;n--)t[a++]=String.fromCharCode(n),this.dictIndex=n}t.length=a}if(e){for(let n=t.length-1;n>0;n--){const e=Math.floor(Math.random()*(n+1));[t[n],t[e]]=[t[e],t[n]]}}return t}),d(this,"setDictionary",(n,e)=>{this.dict=this._normalizeDictionary(n,e),this.dictLength=this.dict.length,this.setCounter(0)}),d(this,"seq",()=>this.sequentialUUID()),d(this,"sequentialUUID",()=>{const n=this.dictLength,e=this.dict;let t=this.counter;const o=[];do{const r=t%n;t=Math.trunc(t/n),o.push(e[r])}while(0!==t);const r=o.join("");return this.counter+=1,r}),d(this,"rnd",(n=this.uuidLength||c)=>this.randomUUID(n)),d(this,"randomUUID",(n=this.uuidLength||c)=>{if(null==n||n<1)throw new Error("Invalid UUID Length Provided");const e=new Array(n),t=this.dictLength,o=this.dict;for(let r=0;r<n;r++){const n=Math.floor(Math.random()*t);e[r]=o[n]}return e.join("")}),d(this,"fmt",(n,e)=>this.formattedUUID(n,e)),d(this,"formattedUUID",(n,e)=>{const t={$r:this.randomUUID,$s:this.sequentialUUID,$t:this.stamp};return n.replace(/\$[rs]\d{0,}|\$t0|\$t[1-9]\d{1,}/g,n=>{const o=n.slice(0,2),r=Number.parseInt(n.slice(2),10);return"$s"===o?t[o]().padStart(r,"0"):"$t"===o&&e?t[o](r,e):t[o](r)})}),d(this,"availableUUIDs",(n=this.uuidLength)=>Number.parseFloat(([...new Set(this.dict)].length**n).toFixed(0))),d(this,"_collisionCache",new Map),d(this,"approxMaxBeforeCollision",(n=this.availableUUIDs(this.uuidLength))=>{const e=n,t=this._collisionCache.get(e);if(void 0!==t)return t;const o=Number.parseFloat(Math.sqrt(Math.PI/2*n).toFixed(20));return this._collisionCache.set(e,o),o}),d(this,"collisionProbability",(n=this.availableUUIDs(this.uuidLength),e=this.uuidLength)=>Number.parseFloat((this.approxMaxBeforeCollision(n)/this.availableUUIDs(e)).toFixed(20))),d(this,"uniqueness",(n=this.availableUUIDs(this.uuidLength))=>{const e=Number.parseFloat((1-this.approxMaxBeforeCollision(n)/n).toFixed(20));return e>1?1:e<0?0:e}),d(this,"getVersion",()=>this.version),d(this,"stamp",(n,e)=>{const t=Math.floor(+(e||new Date)/1e3).toString(16);if("number"==typeof n&&0===n)return t;if("number"!=typeof n||n<10)throw new Error(["Param finalLength must be a number greater than or equal to 10,","or 0 if you want the raw hexadecimal timestamp"].join("\n"));const o=n-9,r=Math.round(Math.random()*(o>15?15:o)),a=this.randomUUID(o);return"".concat(a.substring(0,r)).concat(t).concat(a.substring(r)).concat(r.toString(16))}),d(this,"parseStamp",(n,e)=>{if(e&&!/t0|t[1-9]\d{1,}/.test(e))throw new Error("Cannot extract date from a formated UUID with no timestamp in the format");const t=e?e.replace(/\$[rs]\d{0,}|\$t0|\$t[1-9]\d{1,}/g,n=>{const e={$r:n=>[...Array(n)].map(()=>"r").join(""),$s:n=>[...Array(n)].map(()=>"s").join(""),$t:n=>[...Array(n)].map(()=>"t").join("")},t=n.slice(0,2),o=Number.parseInt(n.slice(2),10);return e[t](o)}).replace(/^(.*?)(t{8,})(.*)$/g,(e,t,o)=>n.substring(t.length,t.length+o.length)):n;if(8===t.length)return new Date(1e3*Number.parseInt(t,16));if(t.length<10)throw new Error("Stamp length invalid");const o=Number.parseInt(t.substring(t.length-1),16);return new Date(1e3*Number.parseInt(t.substring(o,o+8),16))}),d(this,"setCounter",n=>{this.counter=n}),d(this,"validate",(n,e)=>{const t=e?this._normalizeDictionary(e):this.dict;return n.split("").every(n=>t.includes(n))});const e=s(s({},u),n);this.counter=0,this.debug=!1,this.dict=[],this.version="5.3.2";const{dictionary:t,shuffle:o,length:r,counter:a}=e;this.uuidLength=r,this.setDictionary(t,o),this.setCounter(a),this.debug=e.debug,this.log(this.dict),this.log("Generator instantiated with Dictionary Size ".concat(this.dictLength," and counter set to ").concat(this.counter)),this.log=this.log.bind(this),this.setDictionary=this.setDictionary.bind(this),this.setCounter=this.setCounter.bind(this),this.seq=this.seq.bind(this),this.sequentialUUID=this.sequentialUUID.bind(this),this.rnd=this.rnd.bind(this),this.randomUUID=this.randomUUID.bind(this),this.fmt=this.fmt.bind(this),this.formattedUUID=this.formattedUUID.bind(this),this.availableUUIDs=this.availableUUIDs.bind(this),this.approxMaxBeforeCollision=this.approxMaxBeforeCollision.bind(this),this.collisionProbability=this.collisionProbability.bind(this),this.uniqueness=this.uniqueness.bind(this),this.getVersion=this.getVersion.bind(this),this.stamp=this.stamp.bind(this),this.parseStamp=this.parseStamp.bind(this)}};d(p,"default",p);var A,m=p;return A=l,((o,a,i,s)=>{if(a&&"object"==typeof a||"function"==typeof a)for(let d of t(a))r.call(o,d)||d===i||n(o,d,{get:()=>a[d],enumerable:!(s=e(a,d))||s.enumerable});return o})(n({},"__esModule",{value:!0}),A)})();n.exports=e.default,"undefined"!=typeof window&&(e=e.default)},5072(n){"use strict";var e=[];function t(n){for(var t=-1,o=0;o<e.length;o++)if(e[o].identifier===n){t=o;break}return t}function o(n,o){for(var a={},i=[],s=0;s<n.length;s++){var d=n[s],l=o.base?d[0]+o.base:d[0],c=a[l]||0,u="".concat(l," ").concat(c);a[l]=c+1;var p=t(u),A={css:d[1],media:d[2],sourceMap:d[3],supports:d[4],layer:d[5]};if(-1!==p)e[p].references++,e[p].updater(A);else{var m=r(A,o);o.byIndex=s,e.splice(s,0,{identifier:u,updater:m,references:1})}i.push(u)}return i}function r(n,e){var t=e.domAPI(e);t.update(n);return function(e){if(e){if(e.css===n.css&&e.media===n.media&&e.sourceMap===n.sourceMap&&e.supports===n.supports&&e.layer===n.layer)return;t.update(n=e)}else t.remove()}}n.exports=function(n,r){var a=o(n=n||[],r=r||{});return function(n){n=n||[];for(var i=0;i<a.length;i++){var s=t(a[i]);e[s].references--}for(var d=o(n,r),l=0;l<a.length;l++){var c=t(a[l]);0===e[c].references&&(e[c].updater(),e.splice(c,1))}a=d}}},7659(n){"use strict";var e={};n.exports=function(n,t){var o=function(n){if(void 0===e[n]){var t=document.querySelector(n);if(window.HTMLIFrameElement&&t instanceof window.HTMLIFrameElement)try{t=t.contentDocument.head}catch(n){t=null}e[n]=t}return e[n]}(n);if(!o)throw new Error("Couldn't find a style target. This probably means that the value for the 'insert' parameter is invalid.");o.appendChild(t)}},540(n){"use strict";n.exports=function(n){var e=document.createElement("style");return n.setAttributes(e,n.attributes),n.insert(e,n.options),e}},5056(n,e,t){"use strict";n.exports=function(n){var e=t.nc;e&&n.setAttribute("nonce",e)}},7825(n){"use strict";n.exports=function(n){if("undefined"==typeof document)return{update:function(){},remove:function(){}};var e=n.insertStyleElement(n);return{update:function(t){!function(n,e,t){var o="";t.supports&&(o+="@supports (".concat(t.supports,") {")),t.media&&(o+="@media ".concat(t.media," {"));var r=void 0!==t.layer;r&&(o+="@layer".concat(t.layer.length>0?" ".concat(t.layer):""," {")),o+=t.css,r&&(o+="}"),t.media&&(o+="}"),t.supports&&(o+="}");var a=t.sourceMap;a&&"undefined"!=typeof btoa&&(o+="\n/*# sourceMappingURL=data:application/json;base64,".concat(btoa(unescape(encodeURIComponent(JSON.stringify(a))))," */")),e.styleTagTransform(o,n,e.options)}(e,n,t)},remove:function(){!function(n){if(null===n.parentNode)return!1;n.parentNode.removeChild(n)}(e)}}}},1113(n){"use strict";n.exports=function(n,e){if(e.styleSheet)e.styleSheet.cssText=n;else{for(;e.firstChild;)e.removeChild(e.firstChild);e.appendChild(document.createTextNode(n))}}},6077(n){n.exports=function(n){var e={};function t(o){if(e[o])return e[o].exports;var r=e[o]={i:o,l:!1,exports:{}};return n[o].call(r.exports,r,r.exports,t),r.l=!0,r.exports}return t.m=n,t.c=e,t.d=function(n,e,o){t.o(n,e)||Object.defineProperty(n,e,{enumerable:!0,get:o})},t.r=function(n){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(n,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(n,"__esModule",{value:!0})},t.t=function(n,e){if(1&e&&(n=t(n)),8&e)return n;if(4&e&&"object"==typeof n&&n&&n.__esModule)return n;var o=Object.create(null);if(t.r(o),Object.defineProperty(o,"default",{enumerable:!0,value:n}),2&e&&"string"!=typeof n)for(var r in n)t.d(o,r,function(e){return n[e]}.bind(null,r));return o},t.n=function(n){var e=n&&n.__esModule?function(){return n.default}:function(){return n};return t.d(e,"a",e),e},t.o=function(n,e){return Object.prototype.hasOwnProperty.call(n,e)},t.p="",t(t.s=0)}([function(n,e,t){"use strict";t.r(e),t.d(e,"validateHTMLColorName",function(){return i}),t.d(e,"validateHTMLColorSpecialName",function(){return s}),t.d(e,"validateHTMLColorHex",function(){return d}),t.d(e,"validateHTMLColorRgb",function(){return h}),t.d(e,"validateHTMLColorHsl",function(){return f}),t.d(e,"validateHTMLColorHwb",function(){return g}),t.d(e,"validateHTMLColorLab",function(){return b}),t.d(e,"validateHTMLColorLch",function(){return C}),t.d(e,"validateHTMLColor",function(){return w});const o=n=>n&&"string"==typeof n,r=["AliceBlue","AntiqueWhite","Aqua","Aquamarine","Azure","Beige","Bisque","Black","BlanchedAlmond","Blue","BlueViolet","Brown","BurlyWood","CadetBlue","Chartreuse","Chocolate","Coral","CornflowerBlue","Cornsilk","Crimson","Cyan","DarkBlue","DarkCyan","DarkGoldenrod","DarkGray","DarkGrey","DarkGreen","DarkKhaki","DarkMagenta","DarkOliveGreen","DarkOrange","DarkOrchid","DarkRed","DarkSalmon","DarkSeaGreen","DarkSlateBlue","DarkSlateGray","DarkSlateGrey","DarkTurquoise","DarkViolet","DeepPink","DeepSkyBlue","DimGray","DimGrey","DodgerBlue","FireBrick","FloralWhite","ForestGreen","Fuchsia","Gainsboro","GhostWhite","Gold","Goldenrod","Gray","Grey","Green","GreenYellow","HoneyDew","HotPink","IndianRed","Indigo","Ivory","Khaki","Lavender","LavenderBlush","LawnGreen","LemonChiffon","LightBlue","LightCoral","LightCyan","LightGoldenrodYellow","LightGray","LightGrey","LightGreen","LightPink","LightSalmon","LightSalmon","LightSeaGreen","LightSkyBlue","LightSlateGray","LightSlateGrey","LightSteelBlue","LightYellow","Lime","LimeGreen","Linen","Magenta","Maroon","MediumAquamarine","MediumBlue","MediumOrchid","MediumPurple","MediumSeaGreen","MediumSlateBlue","MediumSlateBlue","MediumSpringGreen","MediumTurquoise","MediumVioletRed","MidnightBlue","MintCream","MistyRose","Moccasin","NavajoWhite","Navy","OldLace","Olive","OliveDrab","Orange","OrangeRed","Orchid","PaleGoldenrod","PaleGreen","PaleTurquoise","PaleVioletRed","PapayaWhip","PeachPuff","Peru","Pink","Plum","PowderBlue","Purple","RebeccaPurple","Red","RosyBrown","RoyalBlue","SaddleBrown","Salmon","SandyBrown","SeaGreen","SeaShell","Sienna","Silver","SkyBlue","SlateBlue","SlateGray","SlateGrey","Snow","SpringGreen","SteelBlue","Tan","Teal","Thistle","Tomato","Turquoise","Violet","Wheat","White","WhiteSmoke","Yellow","YellowGreen"],a=["currentColor","inherit","transparent"],i=n=>{let e=!1;return o(n)&&r.map(t=>(n.toLowerCase()===t.toLowerCase()&&(e=!0),null)),e},s=n=>{let e=!1;return o(n)&&a.map(t=>(n.toLowerCase()===t.toLowerCase()&&(e=!0),null)),e},d=n=>{if(o(n)){return n&&/^#([\da-f]{3}){1,2}$|^#([\da-f]{4}){1,2}$/i.test(n)}return!1},l="(([\\d]{0,5})((\\.([\\d]{1,5}))?))",c=`(${l}%)`,u="(([0-9]|[1-9][0-9]|100)%)",p=`(${u}|(0?((\\.([\\d]{1,5}))?))|1)`,A=`([\\s]{0,5})\\)?)(([\\s]{0,5})(\\/?)([\\s]{1,5})(((${u}))|(0?((\\.([\\d]{1,5}))?))|1))?([\\s]{0,5})\\)`,m="(-?(([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-9][0-9]|3[0-5][0-9])((\\.([\\d]{1,5}))?)|360)(deg)?)",h=n=>{if(o(n)){const e="([\\s]{0,5})([\\d]{1,5})%?([\\s]{0,5}),?",t="((([\\s]{0,5}),?([\\s]{0,5}))|(([\\s]{1,5})))",o=new RegExp(`^(rgb)a?\\(${e}${t}${e}${t}${e}${t}((\\/?([\\s]{0,5})(0?\\.?([\\d]{1,5})%?([\\s]{0,5}))?|1|0))?\\)$`);return n&&o.test(n)}return!1},f=n=>{if(o(n)){const e=new RegExp(`^(hsl)a?\\((([\\s]{0,5})(${m}|(([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-9][0-9]|3[0-9][0-9]|400)grad)|((([0-5])?\\.([\\d]{1,5})|6\\.([0-9]|1[0-9]|2[0-8])|[0-6])rad)|((0?((\\.([\\d]{1,5}))?)|1)turn))((([\\s]{0,5}),([\\s]{0,5}))|(([\\s]{1,5}))))(([\\s]{0,5})(0|${u})((([\\s]{0,5}),([\\s]{0,5}))|(([\\s]{1,5}))))(([\\s]{0,5})(0|${u})([\\s]{0,5})\\)?)(([\\s]{0,5})(\\/?|,?)([\\s]{0,5})(((${u}))|(0?((\\.([\\d]{1,5}))?))|1))?\\)$`);return n&&e.test(n)}return!1},g=n=>{if(o(n)){const e=new RegExp(`^(hwb\\(([\\s]{0,5})${m}([\\s]{1,5}))((0|${u})([\\s]{1,5}))((0|${u})${A}$`);return n&&e.test(n)}return!1},b=n=>{if(o(n)){const e="(-?(([0-9]|[1-9][0-9]|1[0-5][0-9])((\\.([\\d]{1,5}))?)?|160))",t=new RegExp(`^(lab\\(([\\s]{0,5})${c}([\\s]{1,5})${e}([\\s]{1,5})${e}${A}$`);return n&&t.test(n)}return!1},C=n=>{if(o(n)){const e=new RegExp(`^lch\\((([\\s]{0,5})${"((([0-9]|[1-9][0-9])?((\\.([\\d]{1,5}))?)|100)(%)?)"}([\\s]{1,5})${""+l}([\\s]{1,5})${`((${m})|(0|${p})|(([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-9][0-9]|3[0-5][0-9])((\\.([\\d]{1,5}))?)|360))`}([\\s]{0,5})(${`(\\/([\\s]{0,5})${p})`})?)\\)$`);return n&&e.test(n)}return!1},w=n=>!!(n&&d(n)||h(n)||f(n)||g(n)||b(n)||C(n));e.default=n=>!!(n&&d(n)||i(n)||s(n)||h(n)||f(n)||g(n)||b(n)||C(n))}])},5663(n){"use strict";n.exports=e},9426(e){"use strict";e.exports=n},5491(n){"use strict";n.exports=t}},r={};function a(n){var e=r[n];if(void 0!==e)return e.exports;var t=r[n]={id:n,exports:{}};return o[n](t,t.exports,a),t.exports}a.n=n=>{var e=n&&n.__esModule?()=>n.default:()=>n;return a.d(e,{a:e}),e},a.d=(n,e)=>{for(var t in e)a.o(e,t)&&!a.o(n,t)&&Object.defineProperty(n,t,{enumerable:!0,get:e[t]})},a.o=(n,e)=>Object.prototype.hasOwnProperty.call(n,e),a.nc=void 0;var i={};return(()=>{"use strict";a.d(i,{default:()=>co});var n=a(5072),e=a.n(n),t=a(7825),o=a.n(t),r=a(7659),s=a.n(r),d=a(5056),l=a.n(d),c=a(540),u=a.n(c),p=a(1113),A=a.n(p),m=a(1267),h={};h.styleTagTransform=A(),h.setAttributes=l(),h.insert=s().bind(null,"head"),h.domAPI=o(),h.insertStyleElement=u();e()(m.A,h);m.A&&m.A.locals&&m.A.locals;var f=a(3750),g={};g.styleTagTransform=A(),g.setAttributes=l(),g.insert=s().bind(null,"head"),g.domAPI=o(),g.insertStyleElement=u();e()(f.A,g);f.A&&f.A.locals&&f.A.locals;var b=a(1666),C={};C.styleTagTransform=A(),C.setAttributes=l(),C.insert=s().bind(null,"head"),C.domAPI=o(),C.insertStyleElement=u();e()(b.A,C);b.A&&b.A.locals&&b.A.locals;var w=a(1937),y={};y.styleTagTransform=A(),y.setAttributes=l(),y.insert=s().bind(null,"head"),y.domAPI=o(),y.insertStyleElement=u();e()(w.A,y);w.A&&w.A.locals&&w.A.locals;var v=a(436),E={};E.styleTagTransform=A(),E.setAttributes=l(),E.insert=s().bind(null,"head"),E.domAPI=o(),E.insertStyleElement=u();e()(v.A,E);v.A&&v.A.locals&&v.A.locals;var B=a(1134),x={};x.styleTagTransform=A(),x.setAttributes=l(),x.insert=s().bind(null,"head"),x.domAPI=o(),x.insertStyleElement=u();e()(B.A,x);B.A&&B.A.locals&&B.A.locals;var k=a(1649),P={};P.styleTagTransform=A(),P.setAttributes=l(),P.insert=s().bind(null,"head"),P.domAPI=o(),P.insertStyleElement=u();e()(k.A,P);k.A&&k.A.locals&&k.A.locals;var T=a(6660),D={};D.styleTagTransform=A(),D.setAttributes=l(),D.insert=s().bind(null,"head"),D.domAPI=o(),D.insertStyleElement=u();e()(T.A,D);T.A&&T.A.locals&&T.A.locals;var S=a(5092),F={};F.styleTagTransform=A(),F.setAttributes=l(),F.insert=s().bind(null,"head"),F.domAPI=o(),F.insertStyleElement=u();e()(S.A,F);S.A&&S.A.locals&&S.A.locals;const L=globalThis,I=n=>n,N=L.trustedTypes,_=N?N.createPolicy("lit-html",{createHTML:n=>n}):void 0,O="$lit$",U=`lit$${Math.random().toFixed(9).slice(2)}$`,M="?"+U,z=`<${M}>`,$=document,R=()=>$.createComment(""),j=n=>null===n||"object"!=typeof n&&"function"!=typeof n,q=Array.isArray,G=n=>q(n)||"function"==typeof n?.[Symbol.iterator],H="[ \t\n\f\r]",W=/<(?:(!--|\/[^a-zA-Z])|(\/?[a-zA-Z][^>\s]*)|(\/?$))/g,V=/-->/g,Y=/>/g,Z=RegExp(`>|${H}(?:([^\\s"'>=/]+)(${H}*=${H}*(?:[^ \t\n\f\r"'\`<>=]|("|')|))|$)`,"g"),Q=/'/g,K=/"/g,X=/^(?:script|style|textarea|title)$/i,J=n=>(e,...t)=>({_$litType$:n,strings:e,values:t}),nn=J(1),en=(J(2),J(3),Symbol.for("lit-noChange")),tn=Symbol.for("lit-nothing"),on=new WeakMap,rn=$.createTreeWalker($,129);function an(n,e){if(!q(n)||!n.hasOwnProperty("raw"))throw Error("invalid template strings array");return void 0!==_?_.createHTML(e):e}const sn=(n,e)=>{const t=n.length-1,o=[];let r,a=2===e?"<svg>":3===e?"<math>":"",i=W;for(let e=0;e<t;e++){const t=n[e];let s,d,l=-1,c=0;for(;c<t.length&&(i.lastIndex=c,d=i.exec(t),null!==d);)c=i.lastIndex,i===W?"!--"===d[1]?i=V:void 0!==d[1]?i=Y:void 0!==d[2]?(X.test(d[2])&&(r=RegExp("</"+d[2],"g")),i=Z):void 0!==d[3]&&(i=Z):i===Z?">"===d[0]?(i=r??W,l=-1):void 0===d[1]?l=-2:(l=i.lastIndex-d[2].length,s=d[1],i=void 0===d[3]?Z:'"'===d[3]?K:Q):i===K||i===Q?i=Z:i===V||i===Y?i=W:(i=Z,r=void 0);const u=i===Z&&n[e+1].startsWith("/>")?" ":"";a+=i===W?t+z:l>=0?(o.push(s),t.slice(0,l)+O+t.slice(l)+U+u):t+U+(-2===l?e:u)}return[an(n,a+(n[t]||"<?>")+(2===e?"</svg>":3===e?"</math>":"")),o]};class dn{constructor({strings:n,_$litType$:e},t){let o;this.parts=[];let r=0,a=0;const i=n.length-1,s=this.parts,[d,l]=sn(n,e);if(this.el=dn.createElement(d,t),rn.currentNode=this.el.content,2===e||3===e){const n=this.el.content.firstChild;n.replaceWith(...n.childNodes)}for(;null!==(o=rn.nextNode())&&s.length<i;){if(1===o.nodeType){if(o.hasAttributes())for(const n of o.getAttributeNames())if(n.endsWith(O)){const e=l[a++],t=o.getAttribute(n).split(U),i=/([.?@])?(.*)/.exec(e);s.push({type:1,index:r,name:i[2],strings:t,ctor:"."===i[1]?An:"?"===i[1]?mn:"@"===i[1]?hn:pn}),o.removeAttribute(n)}else n.startsWith(U)&&(s.push({type:6,index:r}),o.removeAttribute(n));if(X.test(o.tagName)){const n=o.textContent.split(U),e=n.length-1;if(e>0){o.textContent=N?N.emptyScript:"";for(let t=0;t<e;t++)o.append(n[t],R()),rn.nextNode(),s.push({type:2,index:++r});o.append(n[e],R())}}}else if(8===o.nodeType)if(o.data===M)s.push({type:2,index:r});else{let n=-1;for(;-1!==(n=o.data.indexOf(U,n+1));)s.push({type:7,index:r}),n+=U.length-1}r++}}static createElement(n,e){const t=$.createElement("template");return t.innerHTML=n,t}}function ln(n,e,t=n,o){if(e===en)return e;let r=void 0!==o?t._$Co?.[o]:t._$Cl;const a=j(e)?void 0:e._$litDirective$;return r?.constructor!==a&&(r?._$AO?.(!1),void 0===a?r=void 0:(r=new a(n),r._$AT(n,t,o)),void 0!==o?(t._$Co??=[])[o]=r:t._$Cl=r),void 0!==r&&(e=ln(n,r._$AS(n,e.values),r,o)),e}class cn{constructor(n,e){this._$AV=[],this._$AN=void 0,this._$AD=n,this._$AM=e}get parentNode(){return this._$AM.parentNode}get _$AU(){return this._$AM._$AU}u(n){const{el:{content:e},parts:t}=this._$AD,o=(n?.creationScope??$).importNode(e,!0);rn.currentNode=o;let r=rn.nextNode(),a=0,i=0,s=t[0];for(;void 0!==s;){if(a===s.index){let e;2===s.type?e=new un(r,r.nextSibling,this,n):1===s.type?e=new s.ctor(r,s.name,s.strings,this,n):6===s.type&&(e=new fn(r,this,n)),this._$AV.push(e),s=t[++i]}a!==s?.index&&(r=rn.nextNode(),a++)}return rn.currentNode=$,o}p(n){let e=0;for(const t of this._$AV)void 0!==t&&(void 0!==t.strings?(t._$AI(n,t,e),e+=t.strings.length-2):t._$AI(n[e])),e++}}class un{get _$AU(){return this._$AM?._$AU??this._$Cv}constructor(n,e,t,o){this.type=2,this._$AH=tn,this._$AN=void 0,this._$AA=n,this._$AB=e,this._$AM=t,this.options=o,this._$Cv=o?.isConnected??!0}get parentNode(){let n=this._$AA.parentNode;const e=this._$AM;return void 0!==e&&11===n?.nodeType&&(n=e.parentNode),n}get startNode(){return this._$AA}get endNode(){return this._$AB}_$AI(n,e=this){n=ln(this,n,e),j(n)?n===tn||null==n||""===n?(this._$AH!==tn&&this._$AR(),this._$AH=tn):n!==this._$AH&&n!==en&&this._(n):void 0!==n._$litType$?this.$(n):void 0!==n.nodeType?this.T(n):G(n)?this.k(n):this._(n)}O(n){return this._$AA.parentNode.insertBefore(n,this._$AB)}T(n){this._$AH!==n&&(this._$AR(),this._$AH=this.O(n))}_(n){this._$AH!==tn&&j(this._$AH)?this._$AA.nextSibling.data=n:this.T($.createTextNode(n)),this._$AH=n}$(n){const{values:e,_$litType$:t}=n,o="number"==typeof t?this._$AC(n):(void 0===t.el&&(t.el=dn.createElement(an(t.h,t.h[0]),this.options)),t);if(this._$AH?._$AD===o)this._$AH.p(e);else{const n=new cn(o,this),t=n.u(this.options);n.p(e),this.T(t),this._$AH=n}}_$AC(n){let e=on.get(n.strings);return void 0===e&&on.set(n.strings,e=new dn(n)),e}k(n){q(this._$AH)||(this._$AH=[],this._$AR());const e=this._$AH;let t,o=0;for(const r of n)o===e.length?e.push(t=new un(this.O(R()),this.O(R()),this,this.options)):t=e[o],t._$AI(r),o++;o<e.length&&(this._$AR(t&&t._$AB.nextSibling,o),e.length=o)}_$AR(n=this._$AA.nextSibling,e){for(this._$AP?.(!1,!0,e);n!==this._$AB;){const e=I(n).nextSibling;I(n).remove(),n=e}}setConnected(n){void 0===this._$AM&&(this._$Cv=n,this._$AP?.(n))}}class pn{get tagName(){return this.element.tagName}get _$AU(){return this._$AM._$AU}constructor(n,e,t,o,r){this.type=1,this._$AH=tn,this._$AN=void 0,this.element=n,this.name=e,this._$AM=o,this.options=r,t.length>2||""!==t[0]||""!==t[1]?(this._$AH=Array(t.length-1).fill(new String),this.strings=t):this._$AH=tn}_$AI(n,e=this,t,o){const r=this.strings;let a=!1;if(void 0===r)n=ln(this,n,e,0),a=!j(n)||n!==this._$AH&&n!==en,a&&(this._$AH=n);else{const o=n;let i,s;for(n=r[0],i=0;i<r.length-1;i++)s=ln(this,o[t+i],e,i),s===en&&(s=this._$AH[i]),a||=!j(s)||s!==this._$AH[i],s===tn?n=tn:n!==tn&&(n+=(s??"")+r[i+1]),this._$AH[i]=s}a&&!o&&this.j(n)}j(n){n===tn?this.element.removeAttribute(this.name):this.element.setAttribute(this.name,n??"")}}class An extends pn{constructor(){super(...arguments),this.type=3}j(n){this.element[this.name]=n===tn?void 0:n}}class mn extends pn{constructor(){super(...arguments),this.type=4}j(n){this.element.toggleAttribute(this.name,!!n&&n!==tn)}}class hn extends pn{constructor(n,e,t,o,r){super(n,e,t,o,r),this.type=5}_$AI(n,e=this){if((n=ln(this,n,e,0)??tn)===en)return;const t=this._$AH,o=n===tn&&t!==tn||n.capture!==t.capture||n.once!==t.once||n.passive!==t.passive,r=n!==tn&&(t===tn||o);o&&this.element.removeEventListener(this.name,this,t),r&&this.element.addEventListener(this.name,this,n),this._$AH=n}handleEvent(n){"function"==typeof this._$AH?this._$AH.call(this.options?.host??this.element,n):this._$AH.handleEvent(n)}}class fn{constructor(n,e,t){this.element=n,this.type=6,this._$AN=void 0,this._$AM=e,this.options=t}get _$AU(){return this._$AM._$AU}_$AI(n){ln(this,n)}}const gn={M:O,P:U,A:M,C:1,L:sn,R:cn,D:G,V:ln,I:un,H:pn,N:mn,U:hn,B:An,F:fn},bn=L.litHtmlPolyfillSupport;bn?.(dn,un),(L.litHtmlVersions??=[]).push("3.3.2");var Cn=a(9426),wn=a(5663);const{I:yn}=gn,vn=2;class En{constructor(n){}get _$AU(){return this._$AM._$AU}_$AT(n,e,t){this._$Ct=n,this._$AM=e,this._$Ci=t}_$AS(n,e){return this.update(n,e)}update(n,e){return this.render(...e)}}const Bn=(n,e)=>{const t=n._$AN;if(void 0===t)return!1;for(const n of t)n._$AO?.(e,!1),Bn(n,e);return!0},xn=n=>{let e,t;do{if(void 0===(e=n._$AM))break;t=e._$AN,t.delete(n),n=e}while(0===t?.size)},kn=n=>{for(let e;e=n._$AM;n=e){let t=e._$AN;if(void 0===t)e._$AN=t=new Set;else if(t.has(n))break;t.add(n),Dn(e)}};function Pn(n){void 0!==this._$AN?(xn(this),this._$AM=n,kn(this)):this._$AM=n}function Tn(n,e=!1,t=0){const o=this._$AH,r=this._$AN;if(void 0!==r&&0!==r.size)if(e)if(Array.isArray(o))for(let n=t;n<o.length;n++)Bn(o[n],!1),xn(o[n]);else null!=o&&(Bn(o,!1),xn(o));else Bn(this,n)}const Dn=n=>{n.type==vn&&(n._$AP??=Tn,n._$AQ??=Pn)};class Sn extends En{constructor(){super(...arguments),this._$AN=void 0}_$AT(n,e,t){super._$AT(n,e,t),kn(this),this.isConnected=n._$AU}_$AO(n,e=!0){n!==this.isConnected&&(this.isConnected=n,n?this.reconnected?.():this.disconnected?.()),e&&(Bn(this,n),xn(this))}setValue(n){if((n=>void 0===n.strings)(this._$Ct))this._$Ct._$AI(n,this);else{const e=[...this._$Ct._$AH];e[this._$Ci]=n,this._$Ct._$AI(e,this,0)}}disconnected(){}reconnected(){}}class Fn{constructor(n){this.G=n}disconnect(){this.G=void 0}reconnect(n){this.G=n}deref(){return this.G}}class Ln{constructor(){this.Y=void 0,this.Z=void 0}get(){return this.Y}pause(){this.Y??=new Promise(n=>this.Z=n)}resume(){this.Z?.(),this.Y=this.Z=void 0}}const In=(n=>(...e)=>({_$litDirective$:n,values:e}))(class extends Sn{constructor(){super(...arguments),this._$CK=new Fn(this),this._$CX=new Ln}render(n,e){return en}update(n,[e,t]){if(this.isConnected||this.disconnected(),e===this._$CJ)return en;this._$CJ=e;let o=0;const{_$CK:r,_$CX:a}=this;return(async(n,e)=>{for await(const t of n)if(!1===await e(t))return})(e,async n=>{for(;a.get();)await a.get();const i=r.deref();if(void 0!==i){if(i._$CJ!==e)return!1;void 0!==t&&(n=t(n,o)),i.commitValue(n,o),o++}return!0}),en}commitValue(n,e){this.setValue(n)}disconnected(){this._$CK.disconnect(),this._$CX.pause()}reconnected(){this._$CK.reconnect(this),this._$CX.resume()}}),Nn="Current user not found! Not logged in?",_n="You need to either pick a group or enter one.",On="There was an error creating group.",Un="There was an error creating the address book.",Mn="Please enter an address book URI.",zn="Unable to determine user workspace for new address book.",$n="Friend already exists",Rn="Contact already exists",jn="Add me to your friends",qn="Login to add me to your friends",Gn="Add me to your contacts",Hn="Login to add me to your contacts",Wn="Login to chat with me",Vn="Already part of contacts",Yn="Add webID to contact",Zn="Chat with me",Qn="Resume",Kn="Social Accounts",Xn="Friends";function Jn(n,e,t){const o=Cn.widgets.errorMessageBlock(e.dom,t);o.setAttribute("role","alert"),o.setAttribute("aria-live","assertive"),o.setAttribute("tabindex","0"),setTimeout(()=>{o.focus()},100),n.appendChild(o)}function ne(n,e){const t=document.createElement("div");t.setAttribute("role","status"),t.setAttribute("aria-live","polite"),t.setAttribute("tabindex","0"),t.classList.add("actionButton","licOkay"),t.innerHTML=e,setTimeout(()=>{t.focus()},100),n.appendChild(t)}function ee(n){for(;n.childNodes.length>2;)n.removeChild(n.lastChild)}function te(n){return!!n}const oe=(n,{dom:e})=>{const t=e.createElement("div");return Cn.widgets.attachmentList(e,n,t,{doc:n.doc(),modify:!1,predicate:Cn.ns.foaf("knows"),noun:"friend"}),""===t.textContent?null:(t.querySelectorAll("li").forEach((n,e)=>{n.classList.add("friendItem");const t=n.querySelector("a");t&&t.textContent?n.setAttribute("aria-label",`Friend: ${t.textContent.trim()}`):n.textContent?n.setAttribute("aria-label",`Friend: ${n.textContent.trim()}`):n.setAttribute("aria-label",`Friend ${e+1}`)}),t)};var re=a(6077);const ae=(n,e)=>{const t=Cn.utils.label(n),o=Cn.widgets.findImage(n),r=e.anyValue(n,Cn.ns.vcard("role")),a=e.anyValue(n,Cn.ns.vcard("organization-name")),i=e.any(n,Cn.ns.vcard("hasAddress")),s=null!=i?e.anyValue(i,Cn.ns.vcard("country-name")):null,d=null!=i?e.anyValue(i,Cn.ns.vcard("locality")):null,{backgroundColor:l,highlightColor:c}=function(n,e){const t=e.anyValue(n,Cn.ns.solid("profileBackgroundColor"),null,n.doc()),o=e.anyValue(n,Cn.ns.solid("profileHighlightColor"),null,n.doc());return{backgroundColor:de(t,""),highlightColor:de(o,"")}}(n,e),u=function(n){let e=wn.store.anyJS(n,Cn.ns.solid("preferredSubjectPronoun"))||"";if(e){const t=wn.store.anyJS(n,Cn.ns.solid("preferredObjectPronoun"));if(t){e+="/"+t;const o=wn.store.anyJS(n,Cn.ns.solid("preferredRelativePronoun"));o&&(e+="/"+o)}e=" ("+e+") "}return e||""}(n);return{name:t,imageSrc:o,introduction:se(r,a),location:ie(s,d),backgroundColor:l,pronouns:u,highlightColor:c}};function ie(n,e){return n&&e?`${e}, ${n}`:n||e||null}function se(n,e){return n&&e?`${n} at ${e}`:e||n||null}function de(n,e){return n&&(0,re.validateHTMLColorHex)(n)?n:e}var le=a(5491);const ce=(0,le.Namespace)("http://www.w3.org/ns/org#"),ue=["PastRole","CurrentRole","FutureRole"];function pe(n,e){return n?"("+n.value.slice(0,10)+" to "+(e?e.value.slice(0,10):"")+")":""}function Ae(n,e){const t=e.elements;if(Array.isArray(t))return t.flatMap(e=>Ae(n,e));if(!n.any(e,Cn.ns.rdf("first")))return[e];const o=[];let r=e;for(;r;){const e=n.any(r,Cn.ns.rdf("first"));e&&o.push(...Ae(n,e));const t=n.any(r,Cn.ns.rdf("rest"));if(!t||"NamedNode"===t.termType&&t.value===Cn.ns.rdf("nil").value)break;r=t}return o}function me(n,e){const t=function(n,e){const t=n.each(null,ce("member"),e,null),o={PastRole:[],CurrentRole:[],FutureRole:[]};for(const e of t){let t,r,a,i,s;const d=n.any(e,Cn.ns.schema("startDate")),l=n.any(e,Cn.ns.schema("endDate")),c=pe(d,l),u=n.any(e,ce("organization"));u&&(r=n.anyJS(u,Cn.ns.schema("name")),t=n.any(u,Cn.ns.schema("uri")),s=n.any(u,Cn.ns.solid("publicId"))),s&&(a=n.anyJS(s,Cn.ns.schema("name")));const p=a||r,A=n.any(e,ce("role"));A&&(i=n.anyJS(A,Cn.ns.schema("name")));const m=n.anyJS(e,Cn.ns.vcard("role")),h={startDate:d,endDate:l,orgName:p,roleText:m&&i?i+" - "+m:m||i,dates:c,orgHomePage:t};for(const t of ue)n.holds(e,Cn.ns.rdf("type"),Cn.ns.solid(t))&&o[t].push(h)}return o}(e,n);for(const n of ue)t[n].sort(function(n,e){return n.endDate&&e.endDate?n.endDate>e.endDate?-1:1:n.startDate>e.startDate?-1:1});const o=e.each(n,Cn.ns.schema("skills")).map(n=>function(n,e){if("Literal"===e.termType)return e.value;const t=n.anyJS(e,Cn.ns.solid("publicId"));if(t){const e=n.anyJS(t,Cn.ns.schema("name"));if(e)return e}const o=n.anyJS(e,Cn.ns.vcard("role"));return o&&o[0]>""?o:""}(e,n)).filter(n=>""!==n),r=e.each(n,Cn.ns.schema("knowsLanguage")).flatMap(n=>Ae(e,n)).map(n=>function(n,e){if("Literal"===e.termType)return e.value;const t=n.anyJS(e,Cn.ns.solid("publicId"));return t?Cn.utils.label(t,!0):""}(e,n));return{rolesByType:t,skills:o,languages:Array.from(new Set(r))}}const he='@prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>.\n@prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#>.\n@prefix foaf: <http://xmlns.com/foaf/0.1/>.\n@prefix owl: <http://www.w3.org/2002/07/owl#>.\n@prefix solid: <http://www.w3.org/ns/solid/terms#>.\n@prefix ui: <http://www.w3.org/ns/ui#>.\n@prefix schema: <http://schema.org/>.\n@prefix vcard: <http://www.w3.org/2006/vcard/ns#>.\n@prefix org: <http://www.w3.org/ns/org#>.\n@prefix : <#>.\n\n########### ATTENTION - we cannot rename this ontology file name without migrating existing data on existing accounts\n\n########### Social Media - other accounts\n#\n# Twitter, linked In, Orkid, Mastodon, Matrix, Bluesky, Instagram, Facebook, Github,\n# Snapchat, TikTok, etc\n\n:this\n <http://purl.org/dc/elements/1.1/title> "Social media form" ;\n a ui:Form ;\n ui:parts (\n :SocialsForm\n ).\n\n:SocialsForm a ui:Multiple;\n ui:label "online account";\n ui:property foaf:account; # the triple is created with the foaf:acccounts predicate\n ui:ordered true; # Allow user to order occounts most important first.\n ui:part :AccountsForm.\n\n:AccountsForm a ui:Group; \n ui:weight 1; \n ui:parts ( \n :AccountField \n :AccountIdField ).\n\n:AccountField a ui:Classifier; \n ui:label "Choose account"@en;\n ui:multiple false ; \n ui:category foaf:Account. # the accounts are described by the foaf:Account predicate\n\n# this is what is needed to make a dropdown box\nfoaf:Account a rdfs:Class;\n rdfs:label "Online Account Provider";\n owl:disjointUnionOf ( \n :BlueSkyAccount :DiggAccount :FacebookAccount :GithubAccount :InstagramAccount\n :LinkedInAccount :MastodonAccount :MatrixAccount :MediumAccount :NostrAccount \n :OrcidAccount :PinterestAccount :RedditAccount :SnapchatAccount :StravaAccount \n :TiktokAccount :TumblrAccount :TwitterAccount :OtherAccount) .\n\n:AccountIdField a ui:Options; \n ui:dependingOn rdf:type; \n ui:case\n [ ui:for :BlueSkyAccount; ui:use :BlueSkyIdField ],\n [ ui:for :DiggAccount; ui:use :DiggIdField],\n [ ui:for :FacebookAccount; ui:use :FacebookIdField ],\n [ ui:for :GithubAccount; ui:use :GithubIdField ],\n [ ui:for :InstagramAccount; ui:use :InstagramIdField ],\n [ ui:for :LinkedInAccount; ui:use :LinkedInIdField ],\n [ ui:for :MastodonAccount; ui:use :MastodonIdField ],\n [ ui:for :MatrixAccount; ui:use :MatrixIdField ],\n [ ui:for :MediumAccount; ui:use :MediumIdField ],\n [ ui:for :NostrAccount; ui:use :NostrIdField ],\n [ ui:for :OrcidAccount; ui:use :OrcidIdField ],\n [ ui:for :PinterestAccount; ui:use :PinterestIdField ],\n [ ui:for :RedditAccount; ui:use :RedditIdField ],\n [ ui:for :StravaAccount; ui:use :StravaIdField ],\n [ ui:for :SnapchatAccount; ui:use :SnapchatIdField ],\n [ ui:for :TiktokAccount; ui:use :TiktokIdField ],\n [ ui:for :TumblrAccount; ui:use :TumblrIdField ],\n [ ui:for :TwitterAccount; ui:use :TwitterIdField ],\n [ ui:for :OtherAccount; ui:use :OtherIdForm ] .\n\n:BlueSkyAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Bluesky";\n foaf:userProfilePrefix "https://bsky.app/profile/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/bluesky-1.svg>;\n foaf:homepage <https://bsky.app/> .\n\n:DiggAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Digg";\n foaf:userProfilePrefix "https://www.digg.com/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/digg-icon.svg>;\n foaf:homepage <https://www.digg.com/> .\n\n:FacebookAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Facebook";\n foaf:userProfilePrefix "https://www.facebook.com/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/facebook-2020-2-1.svg>;\n foaf:homepage <https://www.facebook.com/> .\n\n:GithubAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Github";\n foaf:userProfilePrefix "https://www.github.com/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/github-icon.svg>;\n foaf:homepage <https://github.com/> .\n\n:InstagramAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Instagram";\n foaf:userProfilePrefix "https://www.instagram.com/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/instagram-2016-5.svg>;\n foaf:homepage <https://www.instagram.com/> .\n\n:LinkedInAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "LinkedIn";\n foaf:userProfilePrefix "https://www.linkedin.com/in/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/linkedin-icon.svg>;\n foaf:homepage <https://linkedin.com/> .\n\n:MastodonAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Mastodon" ;\n foaf:userProfilePrefix "https://mastodon.social/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/mastodon-2.svg>;\n foaf:homepage <https://joinmastodon.org/> .\n\n:MatrixAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Matrix" ;\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/matrix-logo-black.svg> ;\n foaf:userProfilePrefix "https://matrix.to/#/" ;\n foaf:homepage <https://matrix.org/> .\n\n:MediumAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Medium";\n foaf:userProfilePrefix "https://medium.com/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/medium-logo-wordmark-black.svg>;\n foaf:homepage <https://medium.com/> .\n\n:NostrAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Nostr";\n foaf:userProfilePrefix "https://primal.net/p/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/nostr-icon-purple-on-white.svg>;\n foaf:homepage <https://nostr.net/> .\n\n:OrcidAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "ORCiD";\n foaf:userProfilePrefix "https://orcid.org/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/ORCID-1.svg>;\n foaf:homepage <https://orcid.org/> .\n\n:PinterestAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Pinterest";\n foaf:userProfilePrefix "https://pin.it/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/pinterest-2-1.svg>;\n foaf:homepage <https://pinterest.com/> .\n\n:RedditAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Reddit";\n foaf:userProfilePrefix "https://www.reddit.com/user/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/reddit-4.svg>;\n foaf:homepage <https://reddit.com/> .\n\n:SnapchatAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Snapchat";\n foaf:userProfilePrefix "https://www.snapchat.com/add/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/snapchat-1.svg>;\n foaf:homepage <https://www.snapchat.com/> .\n\n:StravaAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Strava";\n foaf:userProfilePrefix "https://www.strava.com/athletes/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/strava-2.svg>;\n foaf:homepage <https://strava.com/> .\n\n:TiktokAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "TikTok";\n foaf:userProfilePrefix "https://www.tiktok.com/@";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/tiktok-icon-2.svg>;\n foaf:homepage <https://www.tiktok.com/> .\n\n:TumblrAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Tumblr";\n foaf:userProfilePrefix "https://www.tumblr.com/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/tumblr-icon.svg>;\n foaf:homepage <https://www.tumblr.com/> .\n\n:TwitterAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "X";\n foaf:userProfilePrefix "https://x.com/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/x-2.svg>;\n foaf:homepage <https://x.com/> .\n\n:OtherAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Other" ;\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/noun_1689339.svg> .\n\n:BlueSkyIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "@[a-z0-9A-Z_-](.[a-z0-9A-Z_-])*".\n\n:DiggIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "@[a-z0-9A-Z_-](.[a-z0-9A-Z_-])*".\n\n:FacebookIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:property foaf:accountName ; \n ui:pattern "[a-z0-9A-Z_-]*".\n\n:GithubIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "[a-z0-9A-Z_-]*".\n\n:InstagramIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "[a-z0-9A-Z_-]*".\n\n:LinkedInIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "[a-z0-9A-Z_-]*(.[a-z0-9A-Z_-])*".\n\n:MastodonIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "@[a-z0-9A-Z_-]*(.[a-z0-9A-Z_-])*".\n\n:MatrixIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "@[a-z0-9A-Z_-]*(.[a-z0-9A-Z_-])*".\n\n:MediumIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "@[a-z0-9A-Z_-]*(.[a-z0-9A-Z_-])*".\n\n:NostrIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "[a-z0-9A-Z_-]*(.[a-z0-9A-Z_-])*".\n\n:OrcidIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "[a-z0-9A-Z_-]*".\n\n:PinterestIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "[a-z0-9A-Z_-]*".\n\n:RedditIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "[a-z0-9A-Z_-]*".\n\n:StravaIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "[a-z0-9A-Z_-]*".\n\n:SnapchatIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "@[a-z0-9A-Z_-]*".\n\n:TiktokIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "@[a-z0-9A-Z_-]*".\n\n:TumblrIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "@[a-z0-9A-Z_-]*".\n\n:TwitterIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "@[a-z0-9A-Z_-]*".\n\n# an unknown online account needs more info\n\n:OtherIdForm a ui:Group; \n ui:weight 0; \n ui:parts ( \n :OtherIdField \n :OtherIconField \n :OtherLabelField ).\n\n:OtherIdField\n a ui:NamedNodeURIField ;\n ui:label "Account link";\n ui:maxLength "200" ;\n ui:property foaf:homepage.\n\n:OtherIconField\n a ui:NamedNodeURIField ;\n ui:label "Icon link";\n ui:maxLength "200" ;\n ui:property foaf:icon.\n\n:OtherLabelField\n a ui:SingleLineTextField ;\n ui:label "Name";\n ui:maxLength "200" ;\n ui:property rdfs:label.\n\n# ends\n',fe="https://solidos.github.io/profile-pane/src/ontology/";function ge(n,e,t,o,r,a,i,s){const d=fe+o,l=s||"this",c=(0,le.Namespace)(d+"#")(l);be(r,t,o,d),Cn.widgets.appendForm(a,n,{},e,c,i,(n,e)=>{n||Cn.widgets.errorMessageBlock(a,e)})}function be(n,e,t,o){const r=o||fe+t,a=(0,le.sym)(r);n.holds(void 0,void 0,void 0,a)||(0,le.parse)(e,n,r,"text/turtle",()=>null)}const Ce=Cn.icons.iconBase+"noun_10636_grey.svg";function we(n,e){function t(n){const t=e.any(n,Cn.ns.foaf("name"))||e.any(n,Cn.ns.rdfs("label"));if(t)return t.value;const o=e.each(n,Cn.ns.rdf("type"));for(const n of o){const t=e.any(n,Cn.ns.rdfs("label"));return t?t.value:Cn.utils.label(n)}return"Unknown Account"}function o(n){const t=e.any(n,Cn.ns.foaf("icon"));if(t)return t.value;const o=e.each(n,Cn.ns.rdf("type"));if(o.length>0)for(const n of o){const t=e.any(n,Cn.ns.foaf("icon"));if(null!==t)return t.value}return Ce}function r(n){const t=e.any(n,Cn.ns.foaf("homepage"));if(t)return t.value;const o=e.anyJS(n,Cn.ns.foaf("accountName"),null,n.doc())||"No_account_Name",r=e.each(n,Cn.ns.rdf("type"));for(const n of r)if("NamedNode"===n.termType){const t=e.any(n,Cn.ns.foaf("userProfilePrefix"));if(t)return t.value+o.trim()}return e.anyJS(n,Cn.ns.foaf("homepage"),null,n.doc())||""}function a(n){return{name:t(n),icon:o(n),homepage:r(n)}}be(e,he,"socialMedia.ttl");let i=e.each(n,Cn.ns.foaf("account")).flatMap(n=>function(n,e){const t=new Set;return function e(o){const r=`${o.termType||typeof o}:${o.value||String(o)}`;if(t.has(r))return[];t.add(r);const a=o.elements;if(Array.isArray(a))return a.flatMap(n=>e(n));if(!n.any(o,Cn.ns.rdf("first")))return[o];const i=[];let s=o;for(;s;){const t=n.any(s,Cn.ns.rdf("first"));t&&i.push(...e(t));const o=n.any(s,Cn.ns.rdf("rest"));if(!o||"NamedNode"===o.termType&&o.value===Cn.ns.rdf("nil").value)break;s=o}return i}(e)}(e,n));const s=new Set,d=[];for(const n of i)if("NamedNode"===n.termType){const t=e.any(n,Cn.ns.foaf("accountName")),o=t?t.value:"";s.has(o)||(s.add(o),d.push(a(n)))}return d.length?{accounts:d}:{accounts:[]}}const{iconForClass:ye}=Cn.widgets,{typeIndex:ve}=wn.solidLogicSingleton,{getScopedAppInstances:Ee}=ve,Be={};for(const n in ye){const e=n.split(":")[0],t=n.split(":")[1],o=Cn.ns[e](t);Be[o.uri]=le.uri.join(ye[n],Cn.icons.iconBase)}async function xe(n){return{stuff:(await Ee(null,n)).map(n=>{const e=(t=n.type||Cn.ns.rdf("Resource"),Be[t.uri]||Cn.icons.iconBase+"noun_10636.svg");var t;return{href:n.instance.uri,name:Cn.utils.label(n.instance),icon:e,instance:n.instance}})}}let ke=document.createElement("section");const Pe=(n,e)=>{let t=Te(wn.authn.currentUser())?jn.toUpperCase():qn.toUpperCase();const o=Cn.widgets.button(e.dom,void 0,t,function(t){t.preventDefault(),async function(n,e){const t=wn.authn.currentUser(),o=e.session.store;if(!Te(t))throw new Error(Nn);if(await De(o,t,n))throw new Error($n);{await o.fetcher.load(t);const e=o.updater,r=[(0,le.st)(t,Cn.ns.foaf("knows"),n,t.doc())];try{await e.update([],r)}catch(n){let e=n;throw e.toString().includes("Unauthenticated")&&(e=Nn),new Error(e)}}}(n,e).then(()=>{ee(ke),ne(ke,"Friend was added!"),r()}).catch(n=>{ee(ke),Jn(ke,e,n)})},{needsBorder:!0});function r(){const t=wn.authn.currentUser(),r=e.session.store;Te(t)?De(r,t,n).then(n=>{o.innerHTML=n?"Already part of friends".toUpperCase():jn.toUpperCase()}):o.innerHTML=qn.toUpperCase()}return o.refresh=r(),o};function Te(n){return!!n}async function De(n,e,t){return await n.fetcher.load(e),0!==n.whether(e,Cn.ns.foaf("knows"),t,e.doc())}const Se=(n,e)=>{const t=n.dom.getElementById("error-display-section");if(t)t.classList.add("contactsShowErrors"),t.textContent=e;else{Jn(n.dom.getElementById("add-to-contacts-button-container"),n,e)}},Fe="contacts-popup-overlay",Le="contactsOverlayActive",Ie=n=>{const e=n.dom.createElement("section");return e.setAttribute("id","addressbook-details-section"),e.setAttribute("role","addressBookDetails"),e.setAttribute("aria-live","polite"),e.setAttribute("tabindex","0"),e.classList.add("contactsAddressBookDetails"),e},Ne=(n,e,t,o)=>{const r=n.dom.createElement("button");return r.setAttribute("id","contacts-create-addressbook-button"),r.setAttribute("type","button"),r.setAttribute("role","button"),r.setAttribute("aria-label","Create a new address book"),r.setAttribute("tabindex","0"),r.textContent="Create Address Book",r.classList.add("contactsActionButton","contactsAddressBookCreationButton"),r.addEventListener("click",async r=>{r.preventDefault();const a=He(n,t,e,o),i=n.dom.getElementById("contacts-selector-dialog");Je(n),i.appendChild(a)}),r},_e=(n,e,t,o)=>{const r=n.dom.createElement("button");return r.setAttribute("id","contacts-addressbook-uri-entry-button"),r.setAttribute("type","button"),r.setAttribute("role","button"),r.setAttribute("aria-label","Enter an address book URI to add the contact to a specific address book"),r.setAttribute("tabindex","0"),r.textContent="Enter Address Book URI",r.classList.add("contactsActionButton","contactsAddressBookUriEntryButton"),r.addEventListener("click",async r=>{r.preventDefault();const a=n.dom.getElementById("contacts-selector-dialog"),i=Oe(n,e,t,o);Je(n),a.appendChild(i)}),r},Oe=(n,e,t,o)=>{const r=n.dom.createElement("div");r.setAttribute("role","addressBookUriEntry"),r.setAttribute("aria-live","polite"),r.setAttribute("tabindex","0"),r.setAttribute("aria-label","Address book URI entry div"),r.setAttribute("aria-describedby","addressbook-uri-entry-div"),r.setAttribute("id","contacts-addressbook-uri-entry"),r.classList.add("contactsPopupDialog","contactsAddressBookUriEntry");const a=We(n,r,"contactsAddressBookUriEntryCloseButton");return r.appendChild(a),r.appendChild(Ue(n,e,t,o)),r},Ue=(n,e,t,o)=>{const r=n.dom.createElement("form");r.setAttribute("id","contacts-address-uri-entry-form"),r.classList.add("contactsAddressBookUriEntryForm"),r.method="post",r.addEventListener("submit",async r=>{r.preventDefault();const a=n.dom.querySelector("#addressBookUriInput").value;if(a){const r="#this"===a.substring(a.length-5,a.length)?a:a+"#this",i=await ut(n,e,t,r),s=n.dom.querySelector("#addressbook-list");if(s){n.dom.getElementById("contacts-addressbook-uri-entry").remove(),nt(n);const t=n.dom.getElementById("contacts-create-addressbook-button"),r=n.dom.getElementById("contacts-addressbook-uri-entry-button");t.remove(),r.remove(),s.appendChild(Ge(n,e,i.addressBooksData,i.addressBook,a,o)),s.appendChild(Ne(n,e,i.addressBooksData,o)),s.appendChild(_e(n,e,i.addressBooksData,o))}}else Se(n,Mn)});const a=n.dom.createElement("label");a.classList.add("label"),a.setAttribute("for","addressBookUriInput");const i=n.dom.createElement("input");return i.type="text",i.name="addressBookUri",i.id="addressBookUriInput",i.placeholder="Enter address book URI to find your address book",i.classList.add("input","contactsAddressBookUriInput"),i.addEventListener("click",()=>{je(n)}),r.appendChild(a),r.appendChild(i),r.appendChild(Me(n)),r},Me=n=>{const e=n.dom.createElement("button");return e.setAttribute("id","contacts-addressbook-entry-button"),e.setAttribute("role","button"),e.setAttribute("aria-label","Create Address Book from entered URI"),e.setAttribute("tabindex","0"),e.classList.add("contactsActionButton","contactsAddressBookUriEntryAddButton"),e.setAttribute("type","submit"),e.addEventListener("click",async e=>{e.preventDefault();const t=n.dom.querySelector("#contacts-address-uri-entry-form");t&&t.requestSubmit()}),e.innerHTML="Add",e},ze=(n,e,t,o,r)=>{const a=n.dom.createElement("div");a.setAttribute("class","contactsAddressBookList"),a.setAttribute("role","addressBooksList"),a.setAttribute("aria-live","polite"),a.setAttribute("tabindex","0"),a.setAttribute("aria-label","Address book list to select which address book to add the contact to"),a.setAttribute("aria-describedby","addressbook-list"),a.setAttribute("id","addressbook-list"),a.innerHTML="Address Books",o.public.forEach((r,i)=>{a.appendChild(Ge(n,e,o,r,i,t))}),o.private.forEach((r,i)=>{a.appendChild(Ge(n,e,o,r,i,t))});const i=Ne(n,e,o,t),s=_e(n,e,o,t);return a.appendChild(i),a.appendChild(s),a},$e=(n,e,t,o)=>{const r=n.dom.createElement("button");return r.setAttribute("id","contacts-create-group-button"),r.setAttribute("type","button"),r.setAttribute("role","button"),r.setAttribute("aria-label","Create a new group in the selected address book"),r.setAttribute("tabindex","0"),r.textContent="Create Group",r.classList.add("contactsActionButton","contactsCreateGroupCreationButton"),r.addEventListener("click",async r=>{r.preventDefault();const a=n.dom.getElementById("contacts-selector-dialog");n.dom.getElementById("new-group-form")||(Je(n),a.appendChild(Ve(n,e,t,o)))}),r},Re=n=>{const e=n.dom.createElement("section");e.setAttribute("role","errorDisplay"),e.setAttribute("aria-live","assertive"),e.setAttribute("tabindex","0"),e.setAttribute("aria-label","Section to display error messages related to contact creation"),e.setAttribute("id","error-display-section"),e.classList.add("contactsErrorDisplay");const t=n.dom.createElement("button");return t.setAttribute("type","button"),t.setAttribute("aria-label","Close error message display"),t.setAttribute("tabindex","0"),t.setAttribute("role","button"),t.classList.add("contactsCloseErrorDisplayButton"),t.textContent="x",t.addEventListener("click",n=>{n.preventDefault(),e.classList.remove("contactsShowErrors")}),e.appendChild(t),e},je=n=>{const e=n.dom.getElementById("error-display-section");e.classList.contains("contactsShowErrors")&&(e.classList.remove("contactsShowErrors"),e.innerHTML="")},qe=(n,e,t,o)=>{const r=n.dom.createElement("button");return r.setAttribute("type","submit"),r.setAttribute("id","add-contact"),r.setAttribute("role","button"),r.setAttribute("aria-label","Add contact to selected address book"),r.setAttribute("tabindex","0"),r.classList.add("contactsActionButton","contactsNewContactCreationButton"),r.addEventListener("click",async r=>{r.preventDefault();const a=mt(t,o.webID),i=ht(t,o.name);if(Ze(n,e,t,o,a,i))return;let s=null,d=[];n.dom.querySelectorAll(".selectedAddressBook").forEach(n=>{s=n.getAttribute("id")});if(n.dom.querySelectorAll(".selectedGroup").forEach(n=>{d.push(n.getAttribute("id"))}),d.length){const r={addressBookUri:s,groupUris:d};try{const a=await async function(n,e,t,o,r){let a=null;const i={name:o.name};try{const t=r.groupUris.length?r.groupUris:void 0;return t?(a=await e.createNewContact({addressBookUri:r.addressBookUri,contact:i,groupUris:t}),await n.session.store.fetcher.load(a),await pt(n,t,a,o.webID),(o.emails.length||o.phoneNumbers.length)&&await async function(n,e,t){const o=n.session.store,r=new le.NamedNode(e),a=r.doc(),i=9999999999999,s=1e12,d=()=>{const n=Math.floor(Math.random()*(i-s+1))+s;return(0,le.sym)(`${a.uri}#id${n}`)};let l=[];try{t.emails.map(n=>{const e=d();l.push((0,le.st)(r,Cn.ns.vcard("hasEmail"),e,a)),l.push((0,le.st)(e,Cn.ns.rdf("type"),n.type,a)),l.push((0,le.st)(e,Cn.ns.vcard("value"),n.email,a))}),t.phoneNumbers.map(n=>{const e=d();l.push((0,le.st)(r,Cn.ns.vcard("hasTelephone"),e,a)),l.push((0,le.st)(e,Cn.ns.rdf("type"),n.type,a)),l.push((0,le.st)(e,Cn.ns.vcard("value"),n.phoneNumber,a))}),await o.updater.update([],l)}catch(e){Se(n,e)}}(n,a,o),a):void Se(n,_n)}catch(e){Se(n,e)}}(n,e,0,o,r);Qe(n,t,o,a)}catch(e){Se(n,`There was an error creating contact.\n${e}`)}}else Se(n,_n)}),r.textContent="Add Contact",r},Ge=(n,e,t,o,r,a)=>{const i=n.dom.createElement("button");return i.setAttribute("value",o.name),i.setAttribute("id",r),i.setAttribute("role","button"),i.setAttribute("type","submit"),i.setAttribute("aria-label","Select address book "+o.name),i.setAttribute("tabindex","0"),i.classList.add("contactsButton"),i.addEventListener("click",o=>{o.preventDefault();const r=o.target,i=r.classList.contains("contactsSelectedButton"),s=n.dom.getElementById("addressbook-details-section");let d=null;const l=n.dom.getElementById("group-list");l&&l.remove();if(n.dom.querySelectorAll(".selectedAddressBook").forEach(n=>{n.classList.remove("contactsSelectedButton","selectedAddressBook")}),i){r.classList.remove("contactsSelectedButton","selectedAddressBook");const e=n.dom.getElementById("new-group-form");e&&(e.remove(),nt(n))}else{const i=n.dom.getElementById("new-addressbook-form");i&&(i.remove(),nt(n)),r.classList.add("contactsSelectedButton","selectedAddressBook");const l=o.target.id;d=t.public.get(l),d||(d=t.private.get(l));const c=n.dom.getElementById("group-list");c&&c.remove();const u=((n,e,t,o,r)=>{const a=n.dom.createElement("div");return a.setAttribute("class","contactsGroupList"),a.setAttribute("role","groupList"),a.setAttribute("aria-live","polite"),a.setAttribute("tabindex","0"),a.setAttribute("aria-label","Group list to select which groups in the address book to add the contact to"),a.setAttribute("aria-describedby","group-list"),a.setAttribute("id","group-list"),a.innerHTML="Groups",o&&o.groups.map(e=>{a.appendChild(Ke(n,e))}),a.appendChild($e(n,e,t,r)),a})(n,e,t,d,a);s.appendChild(u)}}),i.innerHTML=o.name,i},He=(n,e,t,o)=>{const r=n.dom.createElement("form");r.method="post",r.innerHTML="Create a new address book",r.setAttribute("id","new-addressbook-form"),r.classList.add("contactsPopupDialog","contactsNewAddressForm");const a=n.dom.createElement("label");a.classList.add("label"),a.setAttribute("for","addressBookNameInput");const i=n.dom.createElement("input");i.type="text",i.name="addressBookName",i.id="addressBookNameInput",i.placeholder="New address book name",i.classList.add("input","contactsAddressBookInput"),i.required=!0;const s=n.dom.createElement("label");s.classList.add("label"),s.setAttribute("for","addressBookContainerInput");const d=n.dom.createElement("input");d.type="text",d.name="addressBookContainer",d.id="addressBookContainerInput",d.placeholder="Address book container",d.classList.add("input","contactsAddressBookInput"),d.required=!0;const l=n.dom.createElement("label");l.classList.add("label"),l.setAttribute("for","groupNameInput");const c=n.dom.createElement("input");c.type="text",c.name="groupName",c.id="groupNameInput",c.placeholder="New group name",c.classList.add("input","contactsGroupInput"),c.required=!0;const u=n.dom.createElement("button");u.setAttribute("id","submit-addressbook"),u.setAttribute("role","button"),u.setAttribute("type","submit"),u.setAttribute("aria-label","Create a new address book with the entered name, container, type and group"),u.setAttribute("tabindex","0"),u.classList.add("contactsActionButton","contactsAddressBookCreationSubmitButton"),u.addEventListener("click",n=>{n.preventDefault(),r.requestSubmit()}),u.innerHTML="Create Address Book";const p=We(n,r,"contactsAddressBookCreationCloseButton");return r.appendChild(p),r.appendChild(a),r.appendChild(i),r.appendChild(s),r.appendChild(d),r.appendChild(l),r.appendChild(c),r.appendChild(u),r.addEventListener("submit",async a=>{a.preventDefault();let i=null,s=null;const d=n.dom.querySelector("#addressBookNameInput").value,l=n.dom.querySelector("#addressBookContainerInput").value,c=n.dom.querySelector("#groupNameInput").value;if(d)try{i=await async function(n,e,t){var o,r;const a=wn.authn.currentUser(),i=null===(o=null==a?void 0:a.site())||void 0===o?void 0:o.value;let s=null;const d=n.dom.getElementById("new-addressbook-form");try{if(!a||!i)throw new Error(zn);const o=i.endsWith("/")?i:`${i}/`,l=`${o}${(e||"address-book").trim().toLowerCase().replace(/[^a-z0-9]+/g,"-").replace(/^-+|-+$/g,"")||"address-book"}/`,c=await rt().mintNew(n,{me:a,dom:n.dom,div:d,newBase:l,instanceClass:Cn.ns.vcard("AddressBook"),instanceName:t});s=(null===(r=null==c?void 0:c.newInstance)||void 0===r?void 0:r.uri)||`${l}index.ttl#this`,await async function(n,e,t){const o=n.session.store,r=(0,le.sym)(e),a=r.doc(),i=null==t?void 0:t.trim();if(!i)return;try{await o.fetcher.load(a);const n=[...o.statementsMatching(r,Cn.ns.dc("title"),null,a),...o.statementsMatching(r,Cn.ns.vcard("fn"),null,a)],e=[(0,le.st)(r,Cn.ns.dc("title"),(0,le.literal)(i),a),(0,le.st)(r,Cn.ns.vcard("fn"),(0,le.literal)(i),a)];await o.updater.update(n,e)}catch(e){Se(n,e)}}(n,s,t)}catch(e){Se(n,Un+"\n"+e)}return s}(n,l,d);const a=await ut(n,t,e,i);if(c){s=await t.createNewGroup({addressBookUri:i,groupName:c});if(!await gt(e,i,{name:c,uri:s}))return void Se(n,On)}const u=n.dom.querySelector("#addressbook-list"),p=n.dom.querySelector("#group-list");if(u){r.remove(),nt(n);const s=n.dom.getElementById("contacts-create-addressbook-button"),d=n.dom.getElementById("contacts-addressbook-uri-entry-button");s.remove(),d.remove(),u.appendChild(Ge(n,t,e,a.addressBook,i,o)),u.appendChild(s),u.appendChild(d)}if(p){const e=n.dom.getElementById("contacts-create-group-button");e.remove(),p.appendChild(Ke(n,{uri:s,name:c})),p.appendChild(e)}}catch(e){Se(n,e)}}),r},We=(n,e,t)=>{const o=n.dom.createElement("button");o.setAttribute("id","close-addressbook"),o.setAttribute("role","button"),o.setAttribute("type","button");const r="contactsCloseButton"===t?"Close contacts dialog":"Close dialog";return o.setAttribute("aria-label",r),o.setAttribute("tabindex","0"),o.classList.add("contactsCloseButton",t),o.addEventListener("click",o=>{if(o.preventDefault(),e&&(e.remove(),nt(n)),"contactsCloseButton"===t){const e=n.dom.getElementById("add-to-contacts-button");e&&e.removeAttribute("disabled")}}),o.innerHTML="x",o},Ve=(n,e,t,o)=>{const r=n.dom.createElement("form");r.addEventListener("submit",async a=>{a.preventDefault();let i=null;n.dom.querySelectorAll(".selectedAddressBook").forEach(n=>{i=n.getAttribute("id")});const s=n.dom.querySelector("#groupNameInput").value;if(i){if(s)try{const a={name:s,uri:await e.createNewGroup({addressBookUri:i,groupName:s})};if(!gt(t,i,a))return void Se(n,Mn);const d=n.dom.getElementById("contacts-create-group-button");d&&d.remove();const l=n.dom.querySelector("#group-list");l&&(l.appendChild(Ke(n,a)),l.appendChild($e(n,e,t,o))),r.remove(),nt(n)}catch(e){Se(n,`${On}\n${e}`)}}else Se(n,Mn)}),r.innerHTML="Create a new group",r.setAttribute("id","new-group-form"),r.classList.add("contactsPopupDialog","contactsNewGroupForm");const a=n.dom.createElement("label");a.classList.add("label"),a.setAttribute("for","groupNameInput");const i=n.dom.createElement("input");i.type="text",i.name="groupName",i.id="groupNameInput",i.placeholder="New group name",i.classList.add("input","contactsGroupInput");const s=Ye(n,r),d=We(n,r,"contactsGroupCreationCloseButton");return r.appendChild(a),r.appendChild(i),r.appendChild(s),r.appendChild(d),r},Ye=(n,e)=>{const t=n.dom.createElement("button");return t.setAttribute("id","contacts-create-group-button"),t.setAttribute("type","button"),t.setAttribute("role","button"),t.setAttribute("aria-label","Create a new group in the selected address book"),t.setAttribute("tabindex","0"),t.textContent="Create Group",t.classList.add("contactsActionButton","contactsCreateGroupCreationButton"),t.addEventListener("click",async n=>{n.preventDefault(),e.requestSubmit()}),t},Ze=(n,e,t,o,r,a)=>{if(r)return Se(n,Rn),!0;if(a){const r=n.dom.getElementById("contacts-selector-dialog"),i=n.dom.createElement("div");i.setAttribute("role","alert"),i.setAttribute("aria-live","assertive"),i.setAttribute("tabindex","0"),i.setAttribute("aria-label","Alert message indicating that the contact already exists"),i.setAttribute("id","contacts-contact-exists"),i.classList.add("contactsContactExistsAlert"),i.innerHTML=`${o.name} already exists. \n Do you want to add their WebID?`;const s=n.dom.createElement("button");s.setAttribute("id","contacts-confirm-add-webid-button"),s.setAttribute("role","button"),s.setAttribute("type","button"),s.setAttribute("aria-label","Confirm adding the contact webID to the existing contact"),s.setAttribute("tabindex","0"),s.classList.add("contactsConfirmButton"),s.innerHTML="Yes",s.addEventListener("click",async r=>{r.preventDefault(),await ft(n,e,t,o.webID,a),Qe(n,t,o,t.contactWebIDs.get(o.webID)),At(n,t,o)});const d=n.dom.createElement("button");d.setAttribute("id","contacts-cancel-add-webid-button"),d.setAttribute("role","button"),d.setAttribute("type","button"),d.setAttribute("aria-label","Cancel adding the contact webID to the existing contact"),d.setAttribute("tabindex","0"),d.classList.add("contactsCancelButton"),d.innerHTML="No",d.addEventListener("click",e=>{e.preventDefault(),r.remove(),Jn(Xe(n),n,"Contact was not added"),setTimeout(()=>{ee(Xe(n))},2e3),At(n,t,o)});const l=n.dom.createElement("div");return l.setAttribute("id","contacts-contact-exists-actions"),l.setAttribute("role","group"),l.setAttribute("aria-label","Actions for existing contact alert"),l.setAttribute("tabindex","0"),l.classList.add("contactsContactExistsActions"),l.appendChild(s),l.appendChild(d),i.appendChild(l),Je(n),r.appendChild(i),!0}return!1},Qe=(n,e,t,o)=>{e.contactWebIDs.set(t.webID,o);n.dom.getElementById("contacts-selector-dialog").remove();const r=Xe(n);ne(r,"Contact was added!");n.dom.getElementById("add-to-contacts-button").removeAttribute("disabled"),setTimeout(()=>{ee(r)},2e3),At(n,e,t)},Ke=(n,e)=>{const t=n.dom.createElement("button");return t.setAttribute("value",e.name),t.setAttribute("id",e.uri),t.setAttribute("type","button"),t.setAttribute("role","button"),t.setAttribute("aria-label","Select group "+e.name),t.setAttribute("tabindex","0"),t.classList.add("contactsButton"),t.addEventListener("click",async e=>{e.preventDefault();const t=e.target;t.classList.contains("contactsSelectedButton")?(t.classList.remove("contactsSelectedButton","selectedGroup"),((n,e)=>{const t=n.dom.querySelectorAll(".selectedGroup"),o=n.dom.querySelector("#groupNameInput").value;0!==t.length||o||Se(n,e)})(n,_n)):(t.classList.add("contactsSelectedButton","selectedGroup"),je(n))}),t.innerHTML=e.name,t};function Xe(n){return n.dom.getElementById("add-to-contacts-button-container")}const Je=n=>{const e=n.dom.getElementById("contacts-selector-dialog");if(!e)return;e.classList.add(Le);if(e.querySelector(`#${Fe}`))return;const t=n.dom.createElement("div");t.setAttribute("role","popupOverlay"),t.setAttribute("aria-label","Overlay to focus on the active popup message and disable interaction with the rest of the dialog"),t.setAttribute("tabindex","0"),t.setAttribute("id",Fe),t.classList.add("contactsPopupOverlay"),e.appendChild(t)},nt=n=>{const e=n.dom.getElementById("contacts-selector-dialog");if(!e)return;if(e.querySelector(".contactsPopupDialog, .contactsContactExistsAlert"))return;const t=e.querySelector(`#${Fe}`);t&&t.remove(),e.classList.remove(Le)};var et=a(1699),tt={};tt.styleTagTransform=A(),tt.setAttributes=l(),tt.insert=s().bind(null,"head"),tt.domAPI=o(),tt.insertStyleElement=u();e()(et.A,tt);et.A&&et.A.locals&&et.A.locals;var ot=a(3955),rt=a.n(ot);async function at(n,e,t,o,r){const a=((n,e,t,o)=>{const r=n.dom.createElement("dialog");r.setAttribute("role","dialog"),r.setAttribute("aria-live","polite"),r.setAttribute("aria-label","Contact address book selection dialog"),r.setAttribute("aria-describedby","addressbook-contacts-selection"),r.classList.add("contactsAddressBookSelector"),r.setAttribute("id","contacts-selector-dialog"),n.dom.getElementById("add-to-contacts-button").setAttribute("disabled","");const a=We(n,r,"contactsCloseButton"),i=n.dom.createElement("div");i.setAttribute("id","addressbook-creation-div"),i.setAttribute("role","addressBookCreation"),i.setAttribute("aria-live","polite"),i.setAttribute("tabindex","0"),i.setAttribute("aria-label","Address book creation section"),i.setAttribute("aria-describedby","addressbook-details-section"),i.classList.add("contactsAddressBookCreationDiv");const s=qe(n,e,o,t),d=Ie(n),l=Re(n),c=ze(n,e,t,o,d);return d.appendChild(c),i.appendChild(d),i.appendChild(s),r.appendChild(a),r.appendChild(i),r.appendChild(l),r})(n,e,t,o);r.appendChild(a),a.setAttribute("open","")}async function it(n,e,t){let o=null;try{o=await e.readAddressBook(t)}catch(e){Se(n,`There was an error reading your address book.\n${e}`)}return o}async function st(n,e){let t=null,o=null,r=null;try{return await n.session.store.fetcher.load(e.uri.substring(0,e.uri.length-5)),o=new le.NamedNode(e.uri),r=n.session.store.any(o,Cn.ns.vcard("url"),void 0,o.doc()),r?(t=n.session.store.anyValue(r,Cn.ns.vcard("value"),void 0,o.doc()),{webID:t,uri:e.uri}):null}catch(t){Se(n,`There was an error loading the contact: ${e.uri}\n${t}`)}}async function dt(n,e){if(!wn.authn.currentUser())return null;let t=null;try{t=await async function(n,e){const t=[],o=wn.authn.currentUser(),r=n.dom,a={target:o,me:o,noun:"address book",div:r.getElementById("add-to-contacts-button-container"),dom:r};let i={public:new Map,private:new Map,contactWebIDs:new Map,contactNames:new Map};try{await n.session.store.fetcher.load(o);let r={publicUris:((await Cn.login.findAppInstances(a,Cn.ns.vcard("AddressBook"))).instances||[]).map(n=>n.value),privateUris:[]};const s=r.publicUris.map(t=>it(n,e,t));(await Promise.all(s)).map(n=>{n&&(i.public.set(n.uri,{name:n.title,groups:n.groups,contacts:n.contacts}),n.contacts.map(n=>{i.contactNames.set(n.name,n.uri),t.push(n)}))});const d=r.privateUris.map(t=>it(n,e,t));(await Promise.all(d)).map(n=>{n&&(i.private.set(n.uri,{name:n.title,groups:n.groups,contacts:n.contacts}),n.contacts.map(n=>{i.contactNames.set(n.name,n.uri),t.push(n)}))}),i=await lt(n,i,t)}catch(e){Se(n,e)}return i}(n,e)}catch(e){Se(n,`There was an error getting your address books.\n${e}`)}return t}async function lt(n,e,t){const o=t.map(st.bind(null,n));return(await Promise.all(o)).map(n=>{(null==n?void 0:n.webID)&&e.contactWebIDs.set(n.webID.trim(),n.uri)}),e}async function ct(n,e){let t=[],o=[],r=null,a=null,i=null;const s=Cn.utils.label(e),d=n.each(e,Cn.ns.vcard("hasEmail"),null,e.doc())||null,l=n.each(e,Cn.ns.vcard("hasTelephone"),null,e.doc())||null;d.map(o=>{a=n.any(o,Cn.ns.vcard("value"),null,e.doc()),r=n.any(o,Cn.ns.rdf("type"),null,e.doc()),t.push({type:r,email:a})}),l.map(t=>{i=n.any(t,Cn.ns.vcard("value"),null,e.doc()),r=n.any(t,Cn.ns.rdf("type"),null,e.doc()),o.push({type:r,phoneNumber:i})});const c=e.value;return{name:s,emails:t,phoneNumbers:o,webID:c}}async function ut(n,e,t,o){let r=[],a=null;try{const i=await it(n,e,o);if(!i)return{addressBooksData:t,addressBook:null};a={name:i.title,groups:i.groups,contacts:i.contacts},t.private.set(o,a),i.contacts.map(n=>{t.contactNames.set(n.name,n.uri),r.push(n)}),t=await lt(n,t,r)}catch(e){Se(n,"There was an error processing your address book.\n"+e)}return{addressBooksData:t,addressBook:a}}async function pt(n,e,t,o){const r=n.session.store,a=new le.NamedNode(t),i=(0,le.sym)(o),s=r.bnode();let d=null;try{if(null==e?void 0:e.length)for(const t of e){await n.session.store.fetcher.load(t),d=new le.NamedNode(t);const e=d.doc(),o=n.session.store.statementsMatching(d,Cn.ns.vcard("hasMember"),a,e),s=[(0,le.st)(d,Cn.ns.vcard("hasMember"),i,e),(0,le.st)(i,Cn.ns.owl("sameAs"),a,e)];await r.updater.update(o,s)}const t=[(0,le.st)(a,Cn.ns.vcard("url"),s,a.doc()),(0,le.st)(s,Cn.ns.rdf("type"),Cn.ns.vcard("WebID"),a.doc()),(0,le.st)(s,Cn.ns.vcard("value"),(0,le.literal)(o),a.doc())];await r.updater.update([],t)}catch(e){Se(n,e)}}function At(n,e,t){const o=wn.authn.currentUser(),r=n.dom.getElementById("add-to-contacts-button");if(te(o)){const n=mt(e,t.webID),o=ht(e,t.name);n?(r.innerHTML=Vn.toUpperCase(),r.onclick=null):o?(r.innerHTML=Yn.toUpperCase(),r.removeAttribute("disabled")):r.innerHTML=Gn.toUpperCase()}else r.innerHTML=Hn.toUpperCase()}function mt(n,e){return!!(null==e?void 0:e.trim())&&n.contactWebIDs.has(e.trim())}function ht(n,e){let t=null,o=null;const r=e.replace(/\s/g,"").toLowerCase().trim();return n.contactNames.forEach((n,e)=>{if(t=e.replace(/\s/g,"").toLowerCase().trim(),r===t)return o=n}),o}async function ft(n,e,t,o,r){try{const a=await async function(n,e,t){let o=[],r=null,a=[];e.public.forEach((n,e)=>{n.contacts.map(e=>{e.uri===t&&(r=n)})}),e.private.forEach((n,e)=>{n.contacts.map(e=>{e.uri===t&&(r=n)})}),a=r.groups;const i=a.map(async e=>({groupUri:(e=await n.readGroup(e.uri)).uri,group:e}));return(await Promise.all(i)).map(n=>{n.group.members.map(e=>{e.uri===t&&(o.includes(n.groupUri)||o.push(n.groupUri))})}),o}(e,t,r);await pt(n,a,r,o)}catch(e){Se(n,e)}}function gt(n,e,t){const o=n.public.get(e);if(o){return o.groups.some(n=>n.uri===t.uri)||n.public.set(e,{...o,groups:[...o.groups,t]}),!0}const r=n.private.get(e);if(r){return r.groups.some(n=>n.uri===t.uri)||n.private.set(e,{...r,groups:[...r.groups,t]}),!0}return!1}const bt=(0,le.Namespace)("http://www.w3.org/2006/vcard/ns#"),Ct=(0,le.Namespace)("http://purl.org/dc/elements/1.1/");const wt=new(a(8068))({length:10});function yt(){return wt.rnd(6)}class vt{constructor(n,e){this.store=n,this.addressBookNode=e,this.addressBookDoc=e.doc()}proposeNewContactNode(){return this.proposeNewNode("Person")}proposeNewGroupNode(){return this.proposeNewNode("Group")}proposeNewNode(n){const e=yt(),t=this.addressBookNode.dir()?.uri;return(0,le.sym)(`${t}${n}/${e}/index.ttl#this`)}queryTitle(){return this.store.anyValue(this.addressBookNode,Ct("title"),void 0,this.addressBookDoc)??""}queryNameEmailIndex(){const n=this.store.any(this.addressBookNode,bt("nameEmailIndex"),void 0,this.addressBookDoc);return(0,le.isNamedNode)(n)?n:null}queryContacts(){const n=this.queryNameEmailIndex();return n&&(0,le.isNamedNode)(n)?this.store.each(null,bt("inAddressBook"),this.addressBookNode,n).filter(n=>(0,le.isNamedNode)(n)).map(e=>({name:this.store.anyValue(e,bt("fn"),null,n)??"",uri:e.value})):[]}queryGroupIndex(){const n=this.store.any(this.addressBookNode,bt("groupIndex"),void 0,this.addressBookDoc);return(0,le.isNamedNode)(n)?n:null}queryGroups(){const n=this.queryGroupIndex();return n&&(0,le.isNamedNode)(n)?this.store.each(this.addressBookNode,bt("includesGroup"),null,n).filter(n=>(0,le.isNamedNode)(n)).map(e=>({name:this.store.anyValue(e,bt("fn"),null,n)??"",uri:e.value})):[]}}const Et="mailto:",Bt="tel:";class xt{constructor(n,e){this.store=n,this.contactNode=e,this.contactDoc=e.doc()}queryName(){return this.store.anyValue(this.contactNode,bt("fn"),void 0,this.contactDoc)??""}queryEmails(){const n=this.getValuesOf(bt("hasEmail"));return 0===n.length?[]:n.map(n=>{const e=this.getValueNode(n);if(function(n){return(0,le.isNamedNode)(n)&&n.value.startsWith(Et)}(e))return{uri:n,value:e.value.split(Et)[1]}}).filter(n=>!!n)}queryPhoneNumbers(){const n=this.getValuesOf(bt("hasTelephone"));return 0===n.length?[]:n.map(n=>{const e=this.getValueNode(n);if(function(n){return(0,le.isNamedNode)(n)&&n.value.startsWith(Bt)}(e))return{uri:n,value:e.value.split(Bt)[1]}}).filter(n=>!!n)}getValuesOf(n){return this.store.statementsMatching(this.contactNode,n,void 0,this.contactDoc).map(n=>n.object.value)}getValueNode(n){return this.store.any((0,le.sym)(n),bt("value"),void 0,this.contactDoc)}}class kt{constructor(n,e){this.store=n,this.groupNode=e,this.groupDoc=e.doc()}queryName(){return this.store.anyValue(this.groupNode,bt("fn"),void 0,this.groupDoc)??""}queryMembers(){return this.store.each(this.groupNode,bt("hasMember"),null,this.groupDoc).filter(n=>(0,le.isNamedNode)(n)).map(n=>({uri:n.value,name:this.store.anyValue(n,bt("fn"),null,this.groupDoc)??""}))}}async function Pt(n,e,t){await e.updateMany(t.deletions,t.insertions),t.filesToCreate.map(e=>{!function(n,e){n.webOperation("PUT",e,{contentType:"text/turtle"})}(n,e.url)})}const Tt=(0,le.Namespace)("http://www.w3.org/1999/02/22-rdf-syntax-ns#"),Dt=(0,le.Namespace)("http://www.w3.org/ns/solid/terms#"),St=(0,le.Namespace)("http://www.w3.org/ns/pim/space#"),Ft=(0,le.Namespace)("http://www.w3.org/ns/ldp#");class Lt{constructor(n,e,t){this.store=n,this.webIdNode=e,this.preferencesDoc=t}queryPrivateTypeIndex(){const n=this.store.any(this.webIdNode,Dt("privateTypeIndex"),null,this.preferencesDoc);return(0,le.isNamedNode)(n)?n:null}}class It{constructor(n,e){this.webIdNode=n,this.store=e}queryPublicTypeIndex(){const n=Dt("publicTypeIndex");return this.queryNamedNode(n)}queryPreferencesFile(){const n=St("preferencesFile");return this.queryNamedNode(n)}queryNamedNode(n){const e=this.store.any(this.webIdNode,n,null,this.webIdNode.doc());return(0,le.isNamedNode)(e)?e:null}}class Nt{constructor(n,e){this.store=n,this.typeIndexDoc=e}queryInstancesForClass(n){return this.store.each(null,Dt("forClass"),n,this.typeIndexDoc).flatMap(n=>(0,le.isNamedNode)(n)?this.getInstanceValues(n):[])}getInstanceValues(n){return this.store.each(n,Dt("instance"),null,this.typeIndexDoc).map(n=>n.value)}}class _t{constructor(n){this.store=n.store,this.fetcher=n.fetcher,this.updater=n.updater}async fetchNode(n){return async function(n,e){e&&await n.load(e.value)}(this.fetcher,n)}async fetchAll(n){return Promise.all(n.map(n=>this.fetchNode(n)))}async isContainer(n){const e=(0,le.sym)(n);return await this.fetcher.load(e.value),this.store.holds(e,Tt("type"),Ft("Container"),e.doc())}}function Ot(n,e){const t=n.queryName();return{insertions:[(0,le.st)(e.groupNode,bt("hasMember"),n.contactNode,e.groupNode.doc()),(0,le.st)(n.contactNode,bt("fn"),(0,le.lit)(t),e.groupNode.doc())],deletions:[],filesToCreate:[]}}const Ut=bt("AddressBook");const Mt=class{constructor(n){this.support=new _t(n),this.store=n.store,this.fetcher=n.fetcher,this.updater=n.updater}async readAddressBook(n){const e=(0,le.sym)(n);await this.support.fetchNode(e);const t=new vt(this.store,e),o=t.queryTitle(),r=t.queryNameEmailIndex(),a=t.queryGroupIndex();await this.support.fetchAll([r,a]);return{uri:n,title:o,contacts:t.queryContacts(),groups:t.queryGroups()}}async createAddressBook({containerUri:n,name:e,ownerWebId:t}){const o=function(n,e){const t=yt(),o=`${n}${t}/index.ttl#this`,r=`${n}${t}/people.ttl`,a=`${n}${t}/groups.ttl`;return{uri:o,deletions:[],insertions:[(0,le.st)((0,le.sym)(o),(0,le.sym)("http://www.w3.org/1999/02/22-rdf-syntax-ns#type"),bt("AddressBook"),(0,le.sym)(o).doc()),(0,le.st)((0,le.sym)(o),Ct("title"),(0,le.lit)(e),(0,le.sym)(o).doc()),(0,le.st)((0,le.sym)(o),bt("nameEmailIndex"),(0,le.sym)(r),(0,le.sym)(o).doc()),(0,le.st)((0,le.sym)(o),bt("groupIndex"),(0,le.sym)(a),(0,le.sym)(o).doc())],filesToCreate:[{url:r},{url:a}]}}(n,e);return await Pt(this.fetcher,this.updater,o),t&&await this.updatePrivateTypeIndex(t,o.uri),o.uri}async updatePrivateTypeIndex(n,e){const t=(0,le.sym)(n);await this.support.fetchNode(t);const o=new It(t,this.store).queryPreferencesFile(),r=await this.fetchPrivateTypeIndex(t,o);if(!r)throw new Error(`Private type not found for WebID ${n}.`);const a=function(n,e,t){const o=(0,le.sym)(`${n.value}#${yt()}`);return{deletions:[],filesToCreate:[],insertions:[(0,le.st)(o,Tt("type"),Dt("TypeRegistration"),n),(0,le.st)(o,Dt("forClass"),t,n),(0,le.st)(o,Dt("instance"),(0,le.sym)(e),n)]}}(r,e,Ut);await Pt(this.fetcher,this.updater,a)}async createNewContact({addressBookUri:n,contact:e,groupUris:t}){const o=await this.executeCreateNewContact(n,e);return await this.executeAddContactToGroups(t,o),o.contactNode.uri}async executeAddContactToGroups(n,e){const t=(n??[]).map(n=>(0,le.sym)(n));await this.support.fetchAll(t);const o=t.map(n=>{const t=new kt(this.store,n),o=Ot(e,t);return Pt(this.fetcher,this.updater,o)});await Promise.allSettled(o)}async executeCreateNewContact(n,e){const t=(0,le.sym)(n);await this.support.fetchNode(t);const o=function(n,e){const t=n.proposeNewContactNode(),o=n.queryNameEmailIndex();if(!o)throw new Error("name-email index is missing or invalid");const r=[(0,le.st)(t,bt("inAddressBook"),n.addressBookNode,o),(0,le.st)(t,bt("fn"),(0,le.lit)(e.name),o),(0,le.st)(t,bt("fn"),(0,le.lit)(e.name),t.doc()),(0,le.st)(t,Tt("type"),bt("Individual"),t.doc())];if(e.email){const n=(0,le.sym)(t.doc().uri+"#email");r.push((0,le.st)(t,bt("hasEmail"),n,t.doc()),(0,le.st)(n,bt("value"),(0,le.sym)("mailto:"+e.email),t.doc()))}if(e.phoneNumber){const n=(0,le.sym)(t.doc().uri+"#phone");r.push((0,le.st)(t,bt("hasTelephone"),n,t.doc()),(0,le.st)(n,bt("value"),(0,le.sym)("tel:"+e.phoneNumber),t.doc()))}return{uri:t.uri,deletions:[],insertions:r,filesToCreate:[]}}(new vt(this.store,t),e);return await Pt(this.fetcher,this.updater,o),new xt(this.store,(0,le.sym)(o.uri))}async readContact(n){const e=(0,le.sym)(n);await this.support.fetchNode(e);const t=new xt(this.store,e);return{uri:n,name:t.queryName(),emails:t.queryEmails(),phoneNumbers:t.queryPhoneNumbers()}}async createNewGroup({addressBookUri:n,groupName:e}){const t=(0,le.sym)(n);await this.support.fetchNode(t);const o=function(n,e){const t=n.queryGroupIndex();if(!t)throw new Error("group index is missing or invalid");const o=n.proposeNewGroupNode(),r=o.doc();return{uri:o.uri,insertions:[(0,le.st)(o,bt("fn"),(0,le.lit)(e),t),(0,le.st)(o,bt("fn"),(0,le.lit)(e),r),(0,le.st)(o,Tt("type"),bt("Group"),r),(0,le.st)(n.addressBookNode,bt("includesGroup"),o,t)],deletions:[],filesToCreate:[]}}(new vt(this.store,t),e);return await Pt(this.fetcher,this.updater,o),o.uri}async readGroup(n){const e=(0,le.sym)(n);await this.support.fetchNode(e);const t=new kt(this.store,e);return{uri:n,name:t.queryName(),members:t.queryMembers()}}async addContactToGroup({contactUri:n,groupUri:e}){const t=(0,le.sym)(n),o=(0,le.sym)(e);await this.support.fetchNode(t);const r=Ot(new xt(this.store,t),new kt(this.store,o));await Pt(this.fetcher,this.updater,r)}async removeContactFromGroup({contactUri:n,groupUri:e}){const t=(0,le.sym)(n),o=(0,le.sym)(e);await this.support.fetchNode(o);const r=function(n,e){const t=n.contactNode.uri,o=e.queryMembers().find(n=>n.uri===t);if(!o)throw new Error("member not found in group");return{insertions:[],deletions:[(0,le.st)(e.groupNode,bt("hasMember"),n.contactNode,e.groupNode.doc()),(0,le.st)(n.contactNode,bt("fn"),(0,le.lit)(o.name),e.groupNode.doc())],filesToCreate:[]}}(new xt(this.store,t),new kt(this.store,o));await Pt(this.fetcher,this.updater,r)}async addNewPhoneNumber({contactUri:n,newPhoneNumber:e}){const t=function(n,e){const t=yt(),o=`${n.doc().uri}#${t}`;return{uri:o,insertions:[(0,le.st)(n,bt("hasTelephone"),(0,le.sym)(o),n.doc()),(0,le.st)((0,le.sym)(o),bt("value"),(0,le.sym)("tel:"+e),n.doc())],deletions:[],filesToCreate:[]}}((0,le.sym)(n),e);return await Pt(this.fetcher,this.updater,t),t.uri}async addNewEmailAddress({contactUri:n,newEmailAddress:e}){const t=function(n,e){const t=yt(),o=`${n.doc().uri}#${t}`;return{uri:o,insertions:[(0,le.st)(n,bt("hasEmail"),(0,le.sym)(o),n.doc()),(0,le.st)((0,le.sym)(o),bt("value"),(0,le.sym)("mailto:"+e),n.doc())],deletions:[],filesToCreate:[]}}((0,le.sym)(n),e);return await Pt(this.fetcher,this.updater,t),t.uri}async removePhoneNumber({contactUri:n,phoneNumberUri:e}){const t=(0,le.sym)(n),o=(0,le.sym)(e);await this.support.fetchNode(o);const r=function(n,e,t){return{insertions:[],deletions:[...t.statementsMatching(e,null,null,e.doc()),(0,le.st)(n,bt("hasTelephone"),e,n.doc())],filesToCreate:[]}}(t,o,this.store);await Pt(this.fetcher,this.updater,r)}async removeEmailAddress({contactUri:n,emailAddressUri:e}){const t=(0,le.sym)(n),o=(0,le.sym)(e);await this.support.fetchNode(o);const r=function(n,e,t){return{insertions:[],deletions:[...t.statementsMatching(e,null,null,e.doc()),(0,le.st)(n,bt("hasEmail"),e,n.doc())],filesToCreate:[]}}(t,o,this.store);await Pt(this.fetcher,this.updater,r)}async updatePhoneNumber({phoneNumberUri:n,newPhoneNumber:e}){const t=(0,le.sym)(n);await this.support.fetchNode(t);const o=function(n,e,t){const o=t.any(n,bt("value")),r=o?[(0,le.st)(n,bt("value"),o,n.doc())]:[];return{insertions:[(0,le.st)(n,bt("value"),(0,le.sym)("tel:"+e),n.doc())],deletions:r,filesToCreate:[]}}(t,e,this.store);await Pt(this.fetcher,this.updater,o)}async updateEmailAddress({emailAddressUri:n,newEmailAddress:e}){const t=(0,le.sym)(n);await this.support.fetchNode(t);const o=function(n,e,t){const o=t.any(n,bt("value")),r=o?[(0,le.st)(n,bt("value"),o,n.doc())]:[];return{insertions:[(0,le.st)(n,bt("value"),(0,le.sym)("mailto:"+e),n.doc())],deletions:r,filesToCreate:[]}}(t,e,this.store);await Pt(this.fetcher,this.updater,o)}async listAddressBooks(n){const e=(0,le.sym)(n);await this.support.fetchNode(e);const t=new It(e,this.store),o=t.queryPublicTypeIndex(),r=t.queryPreferencesFile(),a=this.fetchIndexedAddressBooks(o),i=this.fetchPrivateTypeIndex(e,r),[s,d]=await Promise.allSettled([a,i]),l="fulfilled"===d.status?await this.fetchIndexedAddressBooks(d.value):[];return{publicUris:"fulfilled"===s.status?s.value:[],privateUris:l}}async fetchIndexedAddressBooks(n){return n?(await this.support.fetchNode(n),new Nt(this.store,n).queryInstancesForClass(Ut)):[]}async fetchPrivateTypeIndex(n,e){if(!e)return null;await this.support.fetchNode(e);return new Lt(this.store,n,e).queryPrivateTypeIndex()}async renameContact({contactUri:n,newName:e}){const t=(0,le.sym)(n);await this.support.fetchNode(t);const o=function(n,e,t){const o=n.statementsMatching(e,bt("fn"),null,null);return{insertions:o.map(n=>(0,le.st)(n.subject,n.predicate,(0,le.lit)(t),n.graph)),deletions:o,filesToCreate:[]}}(this.store,t,e);await Pt(this.fetcher,this.updater,o)}};let zt=document.createElement("section");const $t=async(n,e)=>{const t=wn.authn.currentUser();let o=null,r=null;const a=e.session.store,i=a.fetcher,s=a.updater,d=new Mt({store:a,fetcher:i,updater:s});try{o=await dt(e,d),r=await ct(a,n)}catch(n){Se(e,n)}let l=te(t)?Gn.toUpperCase():Hn.toUpperCase();const c=Cn.widgets.button(e.dom,void 0,l,function(t){t.preventDefault(),async function(n,e,t,o){const r=wn.authn.currentUser(),a=e.session.store;if(!te(r))throw new Error(Nn);if(mt(o,n.value))throw new Error(Rn);await a.fetcher.load(r);try{const r=await ct(a,n),i=ht(o,r.name);i?await ft(e,t,o,r.webID,i):await at(e,t,r,o,zt)}catch(n){let e=n;throw e.toString().includes("Unauthenticated")&&(e=Nn),new Error(e)}}(n,e,d,o).catch(n=>{ee(zt),Jn(zt,e,n)})},{needsBorder:!0});return c.setAttribute("id","add-to-contacts-button"),c.refresh=function(){if(te(t)){const n=!!r&&mt(o,r.webID),e=!!r&&ht(o,r.name);n?(c.innerHTML=Vn.toUpperCase(),c.onclick=null,c.setAttribute("disabled","true")):c.innerHTML=e?Yn.toUpperCase():Gn.toUpperCase()}else c.innerHTML=Hn.toUpperCase()}(),c};function Rt(n){if(3===(n=n.replace(/^#/,"")).length&&(n=n.split("").map(n=>n+n).join("")),6!==n.length)return null;const e=parseInt(n,16);return{r:e>>16&255,g:e>>8&255,b:255&e}}function jt({r:n,g:e,b:t}){const o=[n,e,t].map(function(n){return(n/=255)<=.03928?n/12.92:Math.pow((n+.055)/1.055,2.4)});return.2126*o[0]+.7152*o[1]+.0722*o[2]}const qt=(n,e,t)=>{const o=n||"#000000",r=e||"#ffffff",a=Cn.utils.label(t),i=function(n,e){const t=Rt(n),o=Rt(e);if(!t||!o)return 1;const r=jt(t),a=jt(o);return(Math.max(r,a)+.05)/(Math.min(r,a)+.05)}(o,r);i<4.5&&console.warn(`QRCodeCard: The contrast ratio between highlightColor (${o}) and backgroundColor (${r}) is ${i.toFixed(2)}, which is below the WCAG 2.1 recommended minimum of 4.5:1 for normal text.`);const s="FN:"+a+"\r\n",d="URL:"+t.uri+"r\n";setTimeout(()=>{const n=document.querySelector('.QRCode [role="img"]');if(n){const e=n.hasAttribute("aria-label"),t=n.hasAttribute("alt");e||t||console.warn("QRCodeCard: The QR code element should have an accessible label (aria-label or alt attribute) for screen readers.")}else console.warn('QRCodeCard: No element with role="img" found for the QR code. Ensure the QR code is rendered as an <img> or <canvas> with proper ARIA attributes.')},0);return nn`
|
|
1
|
+
!function(n,e){"object"==typeof exports&&"object"==typeof module?module.exports=e(require("UI"),require("SolidLogic"),require("rdflib")):"function"==typeof define&&define.amd?define(["UI","SolidLogic","rdflib"],e):"object"==typeof exports?exports.ProfilePane=e(require("UI"),require("SolidLogic"),require("rdflib")):n.ProfilePane=e(n.UI,n.SolidLogic,n.rdflib)}(this,(n,e,t)=>(()=>{var o={3955(n,e,t){var o;globalThis,o=(n,e,t)=>(()=>{"use strict";var o={903(n,e,t){t.d(e,{A:()=>s});var o=t(354),r=t.n(o),a=t(314),i=t.n(a)()(r());i.push([n.id,'/* Visually hidden utility for accessibility */\n.visually-hidden {\n position: absolute !important;\n height: 1px; width: 1px;\n overflow: hidden;\n clip: rect(1px, 1px, 1px, 1px);\n white-space: nowrap;\n border: 0;\n padding: 0;\n margin: -1px;\n}\n\n/* Focus indicator for keyboard navigation */\n.personRow:focus, .dataCell:focus, tr[tabindex="0"]:focus {\n outline: 2px solid #1976d2;\n outline-offset: 2px;\n background: #e3f2fd;\n}\n/* contactsPane styles — extracted from inline styles in contactsPane.js */\n/* Uses CSS custom properties from the global stylesheet (dev-global.css / mashlib) */\n\n/* ── Layout: Three-column browser ────────────────────────────── */\n\n.contactPane .bookTable {\n border-collapse: collapse;\n margin-right: 0;\n max-height: 9in;\n}\n\n.contactPane .groupsHeader {\n min-width: 10em;\n padding-bottom: 0.2em;\n}\n\n.contactPane .peopleHeader {\n min-width: 18em;\n}\n\n.contactPane .peopleMain {\n overflow: scroll;\n}\n\n.contactPane .cardMain {\n margin: 0;\n}\n\n.contactPane .groupsMain,\n.contactPane .groupsFooter {\n padding: 0.1em;\n}\n\n/* ── Search ──────────────────────────────────────────────────── */\n\n.contactPane .searchInput {\n border: 0.1em solid var(--color-text-muted);\n border-radius: var(--border-radius-base);\n width: 100%;\n font-size: var(--font-size-base);\n padding: 0.1em 0.6em;\n margin: 0.2em;\n}\n\n/* ── Data cells ──────────────────────────────────────────────── */\n\n.contactPane .dataCell {\n padding: 0.1em;\n}\n\n/* ── Rendered sub-pane ───────────────────────────────────────── */\n\n.contactPane .renderPane {\n border: 0.1em solid var(--color-text-muted);\n border-radius: var(--border-radius-base);\n}\n\n/* ── Delete button ───────────────────────────────────────────── */\n\n.contactPane .deleteButton {\n height: 2em;\n}\n\n/* ── Sharing button & icon ───────────────────────────────────── */\n\n.contactPane .sharingButton {\n padding: var(--spacing-md);\n margin: var(--spacing-md);\n}\n\n.contactPane .sharingButtonIcon {\n width: var(--spacing-lg);\n height: var(--spacing-lg);\n}\n\n/* ── "All" groups button ─────────────────────────────────────── */\n\n.contactPane .allGroupsButton {\n margin-left: var(--spacing-md);\n font-size: var(--font-size-base);\n}\n\n.contactPane .allGroupsButton--loading {\n background-color: #ff8;\n}\n\n.contactPane .allGroupsButton--active {\n background-color: var(--color-text);\n color: var(--color-background);\n}\n\n.contactPane .allGroupsButton--loaded {\n background-color: #cfc;\n}\n\n/* ── Selection & visibility states ───────────────────────────── */\n\n.contactPane .selected {\n background-color: #cce;\n}\n\n.contactPane .group-loading {\n background-color: #ffe;\n}\n\n.contactPane .hidden {\n display: none;\n}\n\n/* ── Mint new address book ───────────────────────────────────── */\n\n.contactPane .claimSuccess {\n font-size: 140%;\n}\n\n.contactPane .addressBook-grid {\n max-width: max-content;\n\n}\n\n.contactPane .addressBookSection {\n width: 100%;\n max-width: 100%;\n box-sizing: border-box;\n margin-bottom: var(--spacing-md);\n box-sizing: border-box;\n margin-bottom: var(--spacing-md);\n}\n\n@media (min-width: 900px) {\n .contactPane .addressBookSection {\n margin-bottom: 0;\n }\n}\n\n/* Section Title - primary colored heading */\n.contactPane .section-title {\n font-size: 1.25em;\n font-weight: 600;\n color: var(--color-primary);\n margin: 0;\n}\n\n/* Card Section Background */\n.contactPane .section-bg {\n background: var(--color-section-bg);\n border-radius: var(--border-radius-full);\n box-shadow: var(--box-shadow);\n padding: var(--spacing-md);\n}\n\n.contactPane td {\n border: 1px dotted #999;\n}\n\n/* Primary Button */\n.btn-primary {\n min-height: var(--min-touch-target);\n padding: var(--spacing-sm) var(--spacing-md);\n border: 1px solid var(--color-primary);\n border-radius: var(--border-radius-base);\n background: var(--color-primary);\n color: white;\n font-weight: 600;\n cursor: pointer;\n transition: all var(--animation-duration) ease;\n}\n\n.btn-primary:hover {\n background: color-mix(in srgb, var(--color-primary) 90%, black);\n box-shadow: 0 2px 4px rgba(124, 77, 255, 0.2);\n}\n\n.btn-primary:active {\n box-shadow: 0 1px 2px rgba(124, 77, 255, 0.2);\n}\n\n.btn-primary:disabled {\n opacity: 0.6;\n cursor: not-allowed;\n transform: none;\n}\n\n/* Secondary button */\n.btn-secondary {\n min-height: var(--min-touch-target);\n padding: var(--spacing-sm) var(--spacing-md);\n border: var(--border-width-thin) solid var(--color-secondary);\n border-radius: var(--border-radius-base);\n background: var(--color-secondary);\n color: var(--color-background);\n font-weight: var(--font-weight-bold);\n cursor: pointer;\n transition: all var(--animation-duration) ease;\n text-decoration: none;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n}\n\n.btn-secondary:hover {\n background: color-mix(in srgb, var(--color-secondary) 85%, black);\n}\n\n.btn-secondary:disabled {\n opacity: var(--opacity-disabled);\n cursor: not-allowed;\n}\n\n/* Action Button Focus - used by ChatWithMe, ProfileCard */\n.action-button-focus:focus,\n.action-button-focus:focus-visible {\n outline: 3px solid var(--color-primary) !important;\n outline-offset: 2px !important;\n box-shadow: 0 0 0 2px var(--color-background), 0 0 0 5px rgba(124, 77, 255, 0.25) !important;\n z-index: 1;\n}',"",{version:3,sources:["webpack://./src/styles/contactsPane.css"],names:[],mappings:"AAAA,8CAA8C;AAC9C;EACE,6BAA6B;EAC7B,WAAW,EAAE,UAAU;EACvB,gBAAgB;EAChB,8BAA8B;EAC9B,mBAAmB;EACnB,SAAS;EACT,UAAU;EACV,YAAY;AACd;;AAEA,4CAA4C;AAC5C;EACE,0BAA0B;EAC1B,mBAAmB;EACnB,mBAAmB;AACrB;AACA,0EAA0E;AAC1E,qFAAqF;;AAErF,mEAAmE;;AAEnE;EACE,yBAAyB;EACzB,eAAe;EACf,eAAe;AACjB;;AAEA;EACE,eAAe;EACf,qBAAqB;AACvB;;AAEA;EACE,eAAe;AACjB;;AAEA;EACE,gBAAgB;AAClB;;AAEA;EACE,SAAS;AACX;;AAEA;;EAEE,cAAc;AAChB;;AAEA,mEAAmE;;AAEnE;EACE,2CAA2C;EAC3C,wCAAwC;EACxC,WAAW;EACX,gCAAgC;EAChC,oBAAoB;EACpB,aAAa;AACf;;AAEA,mEAAmE;;AAEnE;EACE,cAAc;AAChB;;AAEA,mEAAmE;;AAEnE;EACE,2CAA2C;EAC3C,wCAAwC;AAC1C;;AAEA,mEAAmE;;AAEnE;EACE,WAAW;AACb;;AAEA,mEAAmE;;AAEnE;EACE,0BAA0B;EAC1B,yBAAyB;AAC3B;;AAEA;EACE,wBAAwB;EACxB,yBAAyB;AAC3B;;AAEA,mEAAmE;;AAEnE;EACE,8BAA8B;EAC9B,gCAAgC;AAClC;;AAEA;EACE,sBAAsB;AACxB;;AAEA;EACE,mCAAmC;EACnC,8BAA8B;AAChC;;AAEA;EACE,sBAAsB;AACxB;;AAEA,mEAAmE;;AAEnE;EACE,sBAAsB;AACxB;;AAEA;EACE,sBAAsB;AACxB;;AAEA;EACE,aAAa;AACf;;AAEA,mEAAmE;;AAEnE;EACE,eAAe;AACjB;;AAEA;EACE,sBAAsB;;AAExB;;AAEA;EACE,WAAW;EACX,eAAe;EACf,sBAAsB;EACtB,gCAAgC;EAChC,sBAAsB;EACtB,gCAAgC;AAClC;;AAEA;EACE;IACE,gBAAgB;EAClB;AACF;;AAEA,4CAA4C;AAC5C;EACE,iBAAiB;EACjB,gBAAgB;EAChB,2BAA2B;EAC3B,SAAS;AACX;;AAEA,4BAA4B;AAC5B;EACE,mCAAmC;EACnC,wCAAwC;EACxC,6BAA6B;EAC7B,0BAA0B;AAC5B;;AAEA;EACE,uBAAuB;AACzB;;AAEA,mBAAmB;AACnB;EACE,mCAAmC;EACnC,4CAA4C;EAC5C,sCAAsC;EACtC,wCAAwC;EACxC,gCAAgC;EAChC,YAAY;EACZ,gBAAgB;EAChB,eAAe;EACf,8CAA8C;AAChD;;AAEA;EACE,+DAA+D;EAC/D,6CAA6C;AAC/C;;AAEA;EACE,6CAA6C;AAC/C;;AAEA;EACE,YAAY;EACZ,mBAAmB;EACnB,eAAe;AACjB;;AAEA,qBAAqB;AACrB;EACE,mCAAmC;EACnC,4CAA4C;EAC5C,6DAA6D;EAC7D,wCAAwC;EACxC,kCAAkC;EAClC,8BAA8B;EAC9B,oCAAoC;EACpC,eAAe;EACf,8CAA8C;EAC9C,qBAAqB;EACrB,oBAAoB;EACpB,mBAAmB;EACnB,uBAAuB;AACzB;;AAEA;EACE,iEAAiE;AACnE;;AAEA;EACE,gCAAgC;EAChC,mBAAmB;AACrB;;AAEA,0DAA0D;AAC1D;;EAEE,kDAAkD;EAClD,8BAA8B;EAC9B,4FAA4F;EAC5F,UAAU;AACZ",sourcesContent:['/* Visually hidden utility for accessibility */\n.visually-hidden {\n position: absolute !important;\n height: 1px; width: 1px;\n overflow: hidden;\n clip: rect(1px, 1px, 1px, 1px);\n white-space: nowrap;\n border: 0;\n padding: 0;\n margin: -1px;\n}\n\n/* Focus indicator for keyboard navigation */\n.personRow:focus, .dataCell:focus, tr[tabindex="0"]:focus {\n outline: 2px solid #1976d2;\n outline-offset: 2px;\n background: #e3f2fd;\n}\n/* contactsPane styles — extracted from inline styles in contactsPane.js */\n/* Uses CSS custom properties from the global stylesheet (dev-global.css / mashlib) */\n\n/* ── Layout: Three-column browser ────────────────────────────── */\n\n.contactPane .bookTable {\n border-collapse: collapse;\n margin-right: 0;\n max-height: 9in;\n}\n\n.contactPane .groupsHeader {\n min-width: 10em;\n padding-bottom: 0.2em;\n}\n\n.contactPane .peopleHeader {\n min-width: 18em;\n}\n\n.contactPane .peopleMain {\n overflow: scroll;\n}\n\n.contactPane .cardMain {\n margin: 0;\n}\n\n.contactPane .groupsMain,\n.contactPane .groupsFooter {\n padding: 0.1em;\n}\n\n/* ── Search ──────────────────────────────────────────────────── */\n\n.contactPane .searchInput {\n border: 0.1em solid var(--color-text-muted);\n border-radius: var(--border-radius-base);\n width: 100%;\n font-size: var(--font-size-base);\n padding: 0.1em 0.6em;\n margin: 0.2em;\n}\n\n/* ── Data cells ──────────────────────────────────────────────── */\n\n.contactPane .dataCell {\n padding: 0.1em;\n}\n\n/* ── Rendered sub-pane ───────────────────────────────────────── */\n\n.contactPane .renderPane {\n border: 0.1em solid var(--color-text-muted);\n border-radius: var(--border-radius-base);\n}\n\n/* ── Delete button ───────────────────────────────────────────── */\n\n.contactPane .deleteButton {\n height: 2em;\n}\n\n/* ── Sharing button & icon ───────────────────────────────────── */\n\n.contactPane .sharingButton {\n padding: var(--spacing-md);\n margin: var(--spacing-md);\n}\n\n.contactPane .sharingButtonIcon {\n width: var(--spacing-lg);\n height: var(--spacing-lg);\n}\n\n/* ── "All" groups button ─────────────────────────────────────── */\n\n.contactPane .allGroupsButton {\n margin-left: var(--spacing-md);\n font-size: var(--font-size-base);\n}\n\n.contactPane .allGroupsButton--loading {\n background-color: #ff8;\n}\n\n.contactPane .allGroupsButton--active {\n background-color: var(--color-text);\n color: var(--color-background);\n}\n\n.contactPane .allGroupsButton--loaded {\n background-color: #cfc;\n}\n\n/* ── Selection & visibility states ───────────────────────────── */\n\n.contactPane .selected {\n background-color: #cce;\n}\n\n.contactPane .group-loading {\n background-color: #ffe;\n}\n\n.contactPane .hidden {\n display: none;\n}\n\n/* ── Mint new address book ───────────────────────────────────── */\n\n.contactPane .claimSuccess {\n font-size: 140%;\n}\n\n.contactPane .addressBook-grid {\n max-width: max-content;\n\n}\n\n.contactPane .addressBookSection {\n width: 100%;\n max-width: 100%;\n box-sizing: border-box;\n margin-bottom: var(--spacing-md);\n box-sizing: border-box;\n margin-bottom: var(--spacing-md);\n}\n\n@media (min-width: 900px) {\n .contactPane .addressBookSection {\n margin-bottom: 0;\n }\n}\n\n/* Section Title - primary colored heading */\n.contactPane .section-title {\n font-size: 1.25em;\n font-weight: 600;\n color: var(--color-primary);\n margin: 0;\n}\n\n/* Card Section Background */\n.contactPane .section-bg {\n background: var(--color-section-bg);\n border-radius: var(--border-radius-full);\n box-shadow: var(--box-shadow);\n padding: var(--spacing-md);\n}\n\n.contactPane td {\n border: 1px dotted #999;\n}\n\n/* Primary Button */\n.btn-primary {\n min-height: var(--min-touch-target);\n padding: var(--spacing-sm) var(--spacing-md);\n border: 1px solid var(--color-primary);\n border-radius: var(--border-radius-base);\n background: var(--color-primary);\n color: white;\n font-weight: 600;\n cursor: pointer;\n transition: all var(--animation-duration) ease;\n}\n\n.btn-primary:hover {\n background: color-mix(in srgb, var(--color-primary) 90%, black);\n box-shadow: 0 2px 4px rgba(124, 77, 255, 0.2);\n}\n\n.btn-primary:active {\n box-shadow: 0 1px 2px rgba(124, 77, 255, 0.2);\n}\n\n.btn-primary:disabled {\n opacity: 0.6;\n cursor: not-allowed;\n transform: none;\n}\n\n/* Secondary button */\n.btn-secondary {\n min-height: var(--min-touch-target);\n padding: var(--spacing-sm) var(--spacing-md);\n border: var(--border-width-thin) solid var(--color-secondary);\n border-radius: var(--border-radius-base);\n background: var(--color-secondary);\n color: var(--color-background);\n font-weight: var(--font-weight-bold);\n cursor: pointer;\n transition: all var(--animation-duration) ease;\n text-decoration: none;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n}\n\n.btn-secondary:hover {\n background: color-mix(in srgb, var(--color-secondary) 85%, black);\n}\n\n.btn-secondary:disabled {\n opacity: var(--opacity-disabled);\n cursor: not-allowed;\n}\n\n/* Action Button Focus - used by ChatWithMe, ProfileCard */\n.action-button-focus:focus,\n.action-button-focus:focus-visible {\n outline: 3px solid var(--color-primary) !important;\n outline-offset: 2px !important;\n box-shadow: 0 0 0 2px var(--color-background), 0 0 0 5px rgba(124, 77, 255, 0.25) !important;\n z-index: 1;\n}'],sourceRoot:""}]);const s=i},479(n,e,t){t.d(e,{A:()=>s});var o=t(354),r=t.n(o),a=t(314),i=t.n(a)()(r());i.push([n.id,"/* individual.js styles — extracted from inline styles */\n\n/* ── Individual pane container ───────────────────────────────── */\n\n.contactPane .individualPane {\n padding: var(--spacing-xs) var(--spacing-lg) var(--spacing-md) var(--spacing-lg);\n}","",{version:3,sources:["webpack://./src/styles/individual.css"],names:[],mappings:"AAAA,wDAAwD;;AAExD,mEAAmE;;AAEnE;EACE,gFAAgF;AAClF",sourcesContent:["/* individual.js styles — extracted from inline styles */\n\n/* ── Individual pane container ───────────────────────────────── */\n\n.contactPane .individualPane {\n padding: var(--spacing-xs) var(--spacing-lg) var(--spacing-md) var(--spacing-lg);\n}"],sourceRoot:""}]);const s=i},715(n,e,t){t.d(e,{A:()=>s});var o=t(354),r=t.n(o),a=t(314),i=t.n(a)()(r());i.push([n.id,"/* mugshotGallery.js styles — extracted from inline styles */\n/* Uses CSS custom properties from the global stylesheet (dev-global.css / mashlib) */\n\n/* ── Mugshot image ───────────────────────────────────────────── */\n\n.contactPane .mugshotImage {\n max-height: 10em;\n border-radius: var(--border-radius-full);\n margin: 0.7em;\n}\n","",{version:3,sources:["webpack://./src/styles/mugshotGallery.css"],names:[],mappings:"AAAA,4DAA4D;AAC5D,qFAAqF;;AAErF,mEAAmE;;AAEnE;EACE,gBAAgB;EAChB,wCAAwC;EACxC,aAAa;AACf",sourcesContent:["/* mugshotGallery.js styles — extracted from inline styles */\n/* Uses CSS custom properties from the global stylesheet (dev-global.css / mashlib) */\n\n/* ── Mugshot image ───────────────────────────────────────────── */\n\n.contactPane .mugshotImage {\n max-height: 10em;\n border-radius: var(--border-radius-full);\n margin: 0.7em;\n}\n"],sourceRoot:""}]);const s=i},434(n,e,t){t.d(e,{A:()=>s});var o=t(354),r=t.n(o),a=t(314),i=t.n(a)()(r());i.push([n.id,'/* Solid-UI form */\n.individualPane .hoverControl:not(:has(> img:first-child)) {\n border: 0.1em solid rgb(136, 136, 136) !important;\n}\n\n.individualPane .hoverControl:has(> img:first-child) {\n background-color: transparent !important;\n border: none !important;\n margin: 0 !important;\n border-radius: 0 !important;\n padding: 0.7em !important;\n min-height: var(--min-touch-target);\n min-width: var(--min-touch-target);\n cursor: pointer;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n}\n\n.individualPane .hoverControlHide {\n width: 1.5em !important;\n height: 1.5em !important;\n display: block;\n margin-top: 0 !important;\n margin-left: 0 !important;\n margin-right: 0 !important;\n margin-bottom: 0.3em !important;\n}\n\n.individualPane .hoverControl:has(> img:first-child) > span {\n display: inline-flex;\n align-items: center;\n margin-left: 0.3em;\n}\n\n.individualPane div[style*="padding: 0.5em"]:has(> img) {\n display: inline-flex;\n align-items: center;\n}\n\n.individualPane div[style*="padding: 0.5em"]:has(> img) > span {\n margin-left: 0.3em;\n}\n\n.individualPane .hoverControl:has(> img:first-child):hover {\n background-color: transparent !important;\n}\n\n.individualPane button:has(> img[src$=".svg"]) {\n background-color: transparent !important;\n border: none !important;\n margin: 0 !important;\n border-radius: 0 !important;\n}\n\n.individualPane button {\n min-height: var(--min-touch-target);\n min-width: var(--min-touch-target);\n}\n\n.individualPane input:not([type="color"]),\n.individualPane textarea,\n.individualPane select {\n max-width: 100%;\n min-width: 0;\n box-sizing: border-box ;\n font: inherit;\n color: var(--color-text);\n background-color: var(--color-card-bg) !important;\n border: 1px solid var(--color-border-pale);\n}\n\n.individualPane textarea {\n border-color: var(--color-border-pale) !important;\n margin: 0 !important;\n padding: 0 !important;\n}\n\n.individualPane input[type="date"],\n.individualPane input[type="month"],\n.individualPane input[type="week"],\n.individualPane input[type="time"],\n.individualPane input[type="datetime-local"] {\n min-height: var(--min-touch-target);\n}\n\n.individualPane .hoverControl:has(> img:first-child):focus-visible,\n.individualPane button:focus-visible,\n.individualPane input:not([type="color"]):focus-visible,\n.individualPane textarea:focus-visible,\n.individualPane select:focus-visible {\n outline: var(--focus-ring-width) solid var(--color-primary) !important;\n outline-offset: 2px;\n box-shadow: 0 0 0 1px var(--color-background);\n}\n\n.individualPane input[type="url"] {\n width: 100%;\n}\n\n.individualPane .formFieldValue {\n min-width: 0;\n margin-bottom: var(--spacing-sm);\n}\n\n.individualPane .formFieldValue table {\n margin: 0 !important;\n padding: 0 !important;\n}\n\n.individualPane .formFieldValue td {\n padding: 0 !important;\n}\n\n.individualPane .formFieldValue input:not([type="color"]),\n.individualPane .formFieldValue textarea,\n.individualPane .formFieldValue select {\n width: 100%;\n max-width: 100%;\n}\n\n.individualPane select#formSelect {\n width: 100%;\n max-width: 97%;\n box-sizing: border-box;\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n.individualPane span select {\n max-width: 96% !important;\n box-sizing: border-box;\n margin: 0 !important;\n}\n\n.individualPane .formFieldValue span select {\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n/* Remove border/padding from the first wrapper div (and its first child wrapper). */\n.individualPane > div:first-of-type,\n.individualPane > div:first-of-type > div:first-of-type {\n border: none !important;\n padding: 0 !important;\n}\n\n/* Align schema.org, solid terms, FOAF, vCard, and org field labels with their input values. */\n.individualPane :not(.choiceBox):has(> .formFieldName):has(> .formFieldValue) {\n display: flex;\n align-items: baseline;\n margin-bottom: var(--spacing-sm);\n}\n\n.individualPane :not(.choiceBox):has(> .formFieldName):has(> .formFieldValue) > .formFieldValue {\n margin-bottom: 0;\n}\n\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://schema.org/"]),\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/solid/terms#"]),\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://xmlns.com/foaf/0.1/"]),\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/2006/vcard/ns"]),\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/org#"]) {\n display: inline-flex;\n align-items: center;\n vertical-align: middle;\n}\n\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://schema.org/"]) + .formFieldValue,\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/solid/terms#"]) + .formFieldValue,\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://xmlns.com/foaf/0.1/"]) + .formFieldValue,\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/2006/vcard/ns"]) + .formFieldValue,\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/org#"]) + .formFieldValue {\n display: inline-flex;\n align-items: center;\n vertical-align: middle;\n flex: 1;\n min-width: 0;\n}\n\n.individualPane textarea,\n.individualPane .formFieldValue textarea {\n appearance: none;\n -webkit-appearance: none;\n border: .05em solid #88c !important;\n border-style: solid !important;\n border-width: .05em !important;\n border-color: #88c !important;\n border-radius: 0.2em !important;\n width: 100%;\n box-sizing: border-box;\n margin-top: var(--spacing-xs);\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n/* Center textarea label vertically in flex rows. */\n.individualPane div[style*="display: flex"][style*="flex-direction: row"]:has(textarea) {\n align-items: flex-start;\n}\n\n.individualPane div[style*="display: flex"][style*="flex-direction: row"]:has(textarea) > div:has(> a) {\n padding-left: var(--spacing-xs);\n}\n\n/* Keep autocomplete/table-based fields (e.g. Occupation) aligned to label text baseline. */\n.individualPane :not(.choiceBox):has(> .formFieldValue input[data-testid="autocomplete-input"]) {\n align-items: flex-start;\n}\n\n.individualPane :not(.choiceBox):has(> .formFieldValue input[data-testid="autocomplete-input"]) > .formFieldName {\n padding-top: 0.55em !important;\n}\n\n.individualPane .formFieldValue:has(input[data-testid="autocomplete-input"]) {\n align-self: flex-start;\n}\n\n.individualPane .formFieldValue table[data-testid="autocomplete-table"],\n.individualPane .formFieldValue input[data-testid="autocomplete-input"] {\n margin: 0 !important;\n}\n\n.individualPane .formFieldValue table[data-testid="autocomplete-table"] {\n vertical-align: baseline;\n}\n\n.individualPane input:not([type="color"]) {\n width: 100%;\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n.individualPane input:disabled,\n.individualPane textarea:disabled,\n.individualPane select:disabled,\n.individualPane input[readonly],\n.individualPane textarea[readonly],\n.individualPane input:read-only,\n.individualPane textarea:read-only {\n background-color: var(--color-background) !important;\n cursor: not-allowed;\n opacity: 0.75;\n border: 0.05em solid white !important;\n}\n\n.individualPane textarea,\n.individualPane .formFieldValue textarea {\n padding: 0.5em !important;\n}\n\n.webidControl table td div.contactPane.namedPane {\n border: none !important;\n}',"",{version:3,sources:["webpack://./src/styles/rdfFormsEnforced.css"],names:[],mappings:"AAAA,kBAAkB;AAClB;EACE,iDAAiD;AACnD;;AAEA;EACE,wCAAwC;EACxC,uBAAuB;EACvB,oBAAoB;EACpB,2BAA2B;EAC3B,yBAAyB;EACzB,mCAAmC;EACnC,kCAAkC;EAClC,eAAe;EACf,oBAAoB;EACpB,mBAAmB;EACnB,uBAAuB;AACzB;;AAEA;EACE,uBAAuB;EACvB,wBAAwB;EACxB,cAAc;EACd,wBAAwB;EACxB,yBAAyB;EACzB,0BAA0B;EAC1B,+BAA+B;AACjC;;AAEA;EACE,oBAAoB;EACpB,mBAAmB;EACnB,kBAAkB;AACpB;;AAEA;EACE,oBAAoB;EACpB,mBAAmB;AACrB;;AAEA;EACE,kBAAkB;AACpB;;AAEA;EACE,wCAAwC;AAC1C;;AAEA;EACE,wCAAwC;EACxC,uBAAuB;EACvB,oBAAoB;EACpB,2BAA2B;AAC7B;;AAEA;EACE,mCAAmC;EACnC,kCAAkC;AACpC;;AAEA;;;EAGE,eAAe;EACf,YAAY;EACZ,uBAAuB;EACvB,aAAa;EACb,wBAAwB;EACxB,iDAAiD;EACjD,0CAA0C;AAC5C;;AAEA;EACE,iDAAiD;EACjD,oBAAoB;EACpB,qBAAqB;AACvB;;AAEA;;;;;EAKE,mCAAmC;AACrC;;AAEA;;;;;EAKE,sEAAsE;EACtE,mBAAmB;EACnB,6CAA6C;AAC/C;;AAEA;EACE,WAAW;AACb;;AAEA;EACE,YAAY;EACZ,gCAAgC;AAClC;;AAEA;EACE,oBAAoB;EACpB,qBAAqB;AACvB;;AAEA;EACE,qBAAqB;AACvB;;AAEA;;;EAGE,WAAW;EACX,eAAe;AACjB;;AAEA;EACE,WAAW;EACX,cAAc;EACd,sBAAsB;EACtB,yBAAyB;EACzB,0BAA0B;AAC5B;;AAEA;EACE,yBAAyB;EACzB,sBAAsB;EACtB,oBAAoB;AACtB;;AAEA;EACE,yBAAyB;EACzB,0BAA0B;AAC5B;;AAEA,oFAAoF;AACpF;;EAEE,uBAAuB;EACvB,qBAAqB;AACvB;;AAEA,8FAA8F;AAC9F;EACE,aAAa;EACb,qBAAqB;EACrB,gCAAgC;AAClC;;AAEA;EACE,gBAAgB;AAClB;;AAEA;;;;;EAKE,oBAAoB;EACpB,mBAAmB;EACnB,sBAAsB;AACxB;;AAEA;;;;;EAKE,oBAAoB;EACpB,mBAAmB;EACnB,sBAAsB;EACtB,OAAO;EACP,YAAY;AACd;;AAEA;;EAEE,gBAAgB;EAChB,wBAAwB;EACxB,mCAAmC;EACnC,8BAA8B;EAC9B,8BAA8B;EAC9B,6BAA6B;EAC7B,+BAA+B;EAC/B,WAAW;EACX,sBAAsB;EACtB,6BAA6B;EAC7B,yBAAyB;EACzB,0BAA0B;AAC5B;;AAEA,mDAAmD;AACnD;EACE,uBAAuB;AACzB;;AAEA;EACE,+BAA+B;AACjC;;AAEA,2FAA2F;AAC3F;EACE,uBAAuB;AACzB;;AAEA;EACE,8BAA8B;AAChC;;AAEA;EACE,sBAAsB;AACxB;;AAEA;;EAEE,oBAAoB;AACtB;;AAEA;EACE,wBAAwB;AAC1B;;AAEA;EACE,WAAW;EACX,yBAAyB;EACzB,0BAA0B;AAC5B;;AAEA;;;;;;;EAOE,oDAAoD;EACpD,mBAAmB;EACnB,aAAa;EACb,qCAAqC;AACvC;;AAEA;;EAEE,yBAAyB;AAC3B;;AAEA;EACE,uBAAuB;AACzB",sourcesContent:['/* Solid-UI form */\n.individualPane .hoverControl:not(:has(> img:first-child)) {\n border: 0.1em solid rgb(136, 136, 136) !important;\n}\n\n.individualPane .hoverControl:has(> img:first-child) {\n background-color: transparent !important;\n border: none !important;\n margin: 0 !important;\n border-radius: 0 !important;\n padding: 0.7em !important;\n min-height: var(--min-touch-target);\n min-width: var(--min-touch-target);\n cursor: pointer;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n}\n\n.individualPane .hoverControlHide {\n width: 1.5em !important;\n height: 1.5em !important;\n display: block;\n margin-top: 0 !important;\n margin-left: 0 !important;\n margin-right: 0 !important;\n margin-bottom: 0.3em !important;\n}\n\n.individualPane .hoverControl:has(> img:first-child) > span {\n display: inline-flex;\n align-items: center;\n margin-left: 0.3em;\n}\n\n.individualPane div[style*="padding: 0.5em"]:has(> img) {\n display: inline-flex;\n align-items: center;\n}\n\n.individualPane div[style*="padding: 0.5em"]:has(> img) > span {\n margin-left: 0.3em;\n}\n\n.individualPane .hoverControl:has(> img:first-child):hover {\n background-color: transparent !important;\n}\n\n.individualPane button:has(> img[src$=".svg"]) {\n background-color: transparent !important;\n border: none !important;\n margin: 0 !important;\n border-radius: 0 !important;\n}\n\n.individualPane button {\n min-height: var(--min-touch-target);\n min-width: var(--min-touch-target);\n}\n\n.individualPane input:not([type="color"]),\n.individualPane textarea,\n.individualPane select {\n max-width: 100%;\n min-width: 0;\n box-sizing: border-box ;\n font: inherit;\n color: var(--color-text);\n background-color: var(--color-card-bg) !important;\n border: 1px solid var(--color-border-pale);\n}\n\n.individualPane textarea {\n border-color: var(--color-border-pale) !important;\n margin: 0 !important;\n padding: 0 !important;\n}\n\n.individualPane input[type="date"],\n.individualPane input[type="month"],\n.individualPane input[type="week"],\n.individualPane input[type="time"],\n.individualPane input[type="datetime-local"] {\n min-height: var(--min-touch-target);\n}\n\n.individualPane .hoverControl:has(> img:first-child):focus-visible,\n.individualPane button:focus-visible,\n.individualPane input:not([type="color"]):focus-visible,\n.individualPane textarea:focus-visible,\n.individualPane select:focus-visible {\n outline: var(--focus-ring-width) solid var(--color-primary) !important;\n outline-offset: 2px;\n box-shadow: 0 0 0 1px var(--color-background);\n}\n\n.individualPane input[type="url"] {\n width: 100%;\n}\n\n.individualPane .formFieldValue {\n min-width: 0;\n margin-bottom: var(--spacing-sm);\n}\n\n.individualPane .formFieldValue table {\n margin: 0 !important;\n padding: 0 !important;\n}\n\n.individualPane .formFieldValue td {\n padding: 0 !important;\n}\n\n.individualPane .formFieldValue input:not([type="color"]),\n.individualPane .formFieldValue textarea,\n.individualPane .formFieldValue select {\n width: 100%;\n max-width: 100%;\n}\n\n.individualPane select#formSelect {\n width: 100%;\n max-width: 97%;\n box-sizing: border-box;\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n.individualPane span select {\n max-width: 96% !important;\n box-sizing: border-box;\n margin: 0 !important;\n}\n\n.individualPane .formFieldValue span select {\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n/* Remove border/padding from the first wrapper div (and its first child wrapper). */\n.individualPane > div:first-of-type,\n.individualPane > div:first-of-type > div:first-of-type {\n border: none !important;\n padding: 0 !important;\n}\n\n/* Align schema.org, solid terms, FOAF, vCard, and org field labels with their input values. */\n.individualPane :not(.choiceBox):has(> .formFieldName):has(> .formFieldValue) {\n display: flex;\n align-items: baseline;\n margin-bottom: var(--spacing-sm);\n}\n\n.individualPane :not(.choiceBox):has(> .formFieldName):has(> .formFieldValue) > .formFieldValue {\n margin-bottom: 0;\n}\n\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://schema.org/"]),\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/solid/terms#"]),\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://xmlns.com/foaf/0.1/"]),\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/2006/vcard/ns"]),\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/org#"]) {\n display: inline-flex;\n align-items: center;\n vertical-align: middle;\n}\n\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://schema.org/"]) + .formFieldValue,\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/solid/terms#"]) + .formFieldValue,\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://xmlns.com/foaf/0.1/"]) + .formFieldValue,\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/2006/vcard/ns"]) + .formFieldValue,\n.individualPane :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/org#"]) + .formFieldValue {\n display: inline-flex;\n align-items: center;\n vertical-align: middle;\n flex: 1;\n min-width: 0;\n}\n\n.individualPane textarea,\n.individualPane .formFieldValue textarea {\n appearance: none;\n -webkit-appearance: none;\n border: .05em solid #88c !important;\n border-style: solid !important;\n border-width: .05em !important;\n border-color: #88c !important;\n border-radius: 0.2em !important;\n width: 100%;\n box-sizing: border-box;\n margin-top: var(--spacing-xs);\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n/* Center textarea label vertically in flex rows. */\n.individualPane div[style*="display: flex"][style*="flex-direction: row"]:has(textarea) {\n align-items: flex-start;\n}\n\n.individualPane div[style*="display: flex"][style*="flex-direction: row"]:has(textarea) > div:has(> a) {\n padding-left: var(--spacing-xs);\n}\n\n/* Keep autocomplete/table-based fields (e.g. Occupation) aligned to label text baseline. */\n.individualPane :not(.choiceBox):has(> .formFieldValue input[data-testid="autocomplete-input"]) {\n align-items: flex-start;\n}\n\n.individualPane :not(.choiceBox):has(> .formFieldValue input[data-testid="autocomplete-input"]) > .formFieldName {\n padding-top: 0.55em !important;\n}\n\n.individualPane .formFieldValue:has(input[data-testid="autocomplete-input"]) {\n align-self: flex-start;\n}\n\n.individualPane .formFieldValue table[data-testid="autocomplete-table"],\n.individualPane .formFieldValue input[data-testid="autocomplete-input"] {\n margin: 0 !important;\n}\n\n.individualPane .formFieldValue table[data-testid="autocomplete-table"] {\n vertical-align: baseline;\n}\n\n.individualPane input:not([type="color"]) {\n width: 100%;\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n.individualPane input:disabled,\n.individualPane textarea:disabled,\n.individualPane select:disabled,\n.individualPane input[readonly],\n.individualPane textarea[readonly],\n.individualPane input:read-only,\n.individualPane textarea:read-only {\n background-color: var(--color-background) !important;\n cursor: not-allowed;\n opacity: 0.75;\n border: 0.05em solid white !important;\n}\n\n.individualPane textarea,\n.individualPane .formFieldValue textarea {\n padding: 0.5em !important;\n}\n\n.webidControl table td div.contactPane.namedPane {\n border: none !important;\n}'],sourceRoot:""}]);const s=i},295(n,e,t){t.d(e,{A:()=>s});var o=t(354),r=t.n(o),a=t(314),i=t.n(a)()(r());i.push([n.id,"/* toolsPane.js styles — extracted from inline styles */\n/* Uses CSS custom properties from the global stylesheet (dev-global.css / mashlib) */\n\n/* ── Tools pane table ────────────────────────────────────────── */\n\n.contactPane .toolsTable {\n font-size: 120%;\n margin: var(--spacing-md);\n border: 0.1em solid var(--color-border-pale);\n}\n\n/* ── Tools header row ────────────────────────────────────────── */\n\n.contactPane .toolsHeader {\n min-width: 20em;\n padding: var(--spacing-md);\n font-size: 150%;\n border-bottom: 0.1em solid var(--color-error);\n margin-bottom: var(--spacing-xl);\n}\n\n/* ── Status block ────────────────────────────────────────────── */\n\n.contactPane .toolsStatusBlock {\n padding: var(--spacing-xl);\n}\n\n/* ── Tools buttons ───────────────────────────────────────────── */\n\n.contactPane .toolsButton {\n font-size: var(--font-size-base);\n margin: 0.8em;\n padding: var(--spacing-xs);\n}\n\n/* ── Load index button states ────────────────────────────────── */\n\n.contactPane .toolsButton--loading {\n background-color: #ffc;\n}\n\n.contactPane .toolsButton--error {\n background-color: #fcc;\n}\n\n.contactPane .toolsButton--success {\n background-color: #cfc;\n}\n","",{version:3,sources:["webpack://./src/styles/toolsPane.css"],names:[],mappings:"AAAA,uDAAuD;AACvD,qFAAqF;;AAErF,mEAAmE;;AAEnE;EACE,eAAe;EACf,yBAAyB;EACzB,4CAA4C;AAC9C;;AAEA,mEAAmE;;AAEnE;EACE,eAAe;EACf,0BAA0B;EAC1B,eAAe;EACf,6CAA6C;EAC7C,gCAAgC;AAClC;;AAEA,mEAAmE;;AAEnE;EACE,0BAA0B;AAC5B;;AAEA,mEAAmE;;AAEnE;EACE,gCAAgC;EAChC,aAAa;EACb,0BAA0B;AAC5B;;AAEA,mEAAmE;;AAEnE;EACE,sBAAsB;AACxB;;AAEA;EACE,sBAAsB;AACxB;;AAEA;EACE,sBAAsB;AACxB",sourcesContent:["/* toolsPane.js styles — extracted from inline styles */\n/* Uses CSS custom properties from the global stylesheet (dev-global.css / mashlib) */\n\n/* ── Tools pane table ────────────────────────────────────────── */\n\n.contactPane .toolsTable {\n font-size: 120%;\n margin: var(--spacing-md);\n border: 0.1em solid var(--color-border-pale);\n}\n\n/* ── Tools header row ────────────────────────────────────────── */\n\n.contactPane .toolsHeader {\n min-width: 20em;\n padding: var(--spacing-md);\n font-size: 150%;\n border-bottom: 0.1em solid var(--color-error);\n margin-bottom: var(--spacing-xl);\n}\n\n/* ── Status block ────────────────────────────────────────────── */\n\n.contactPane .toolsStatusBlock {\n padding: var(--spacing-xl);\n}\n\n/* ── Tools buttons ───────────────────────────────────────────── */\n\n.contactPane .toolsButton {\n font-size: var(--font-size-base);\n margin: 0.8em;\n padding: var(--spacing-xs);\n}\n\n/* ── Load index button states ────────────────────────────────── */\n\n.contactPane .toolsButton--loading {\n background-color: #ffc;\n}\n\n.contactPane .toolsButton--error {\n background-color: #fcc;\n}\n\n.contactPane .toolsButton--success {\n background-color: #cfc;\n}\n"],sourceRoot:""}]);const s=i},886(n,e,t){t.d(e,{A:()=>s});var o=t(354),r=t.n(o),a=t(314),i=t.n(a)()(r());i.push([n.id,"/* webidControl.js styles — extracted from inline styles */\n/* Uses CSS custom properties from the global stylesheet (dev-global.css / mashlib) */\n\n/* ── Named pane (rendered sub-pane) ──────────────────────────── */\n\n.contactPane .namedPane {\n border: 0.1em solid var(--color-text-muted);\n border-radius: var(--border-radius-base);\n}\n\n/* ── WebID / Public ID outer container ───────────────────────── */\n\n.contactPane .webidControl {\n border-radius: 0.3em;\n border: 0.1em solid #888;\n}\n\n/* ── Persona row ─────────────────────────────────────────────── */\n\n.contactPane .personaRow {\n padding: 0.2em;\n}\n\n.contactPane .personaRow--webid {\n background-color: #ffe6ff;\n}\n\n/* ── Full-width elements ─────────────────────────────────────── */\n\n.contactPane .fullWidth {\n width: 100%;\n}\n\n/* ── Open/close profile button ───────────────────────────────── */\n\n.contactPane .personaOpenButton {\n float: right;\n background-color: transparent;\n border: none;\n}\n\n/* ── Section heading ─────────────────────────────────────────── */\n\n.contactPane .webidHeading {\n font-size: 110%;\n font-weight: bold;\n color: var(--color-primary);\n padding: 0.2em;\n margin: 0.7em 0;\n}\n\n/* ── Prompt text ─────────────────────────────────────────────── */\n\n.contactPane .webidPrompt {\n padding: 0.7em;\n border: none;\n font-size: var(--font-size-base);\n white-space: pre-wrap;\n}\n","",{version:3,sources:["webpack://./src/styles/webidControl.css"],names:[],mappings:"AAAA,0DAA0D;AAC1D,qFAAqF;;AAErF,mEAAmE;;AAEnE;EACE,2CAA2C;EAC3C,wCAAwC;AAC1C;;AAEA,mEAAmE;;AAEnE;EACE,oBAAoB;EACpB,wBAAwB;AAC1B;;AAEA,mEAAmE;;AAEnE;EACE,cAAc;AAChB;;AAEA;EACE,yBAAyB;AAC3B;;AAEA,mEAAmE;;AAEnE;EACE,WAAW;AACb;;AAEA,mEAAmE;;AAEnE;EACE,YAAY;EACZ,6BAA6B;EAC7B,YAAY;AACd;;AAEA,mEAAmE;;AAEnE;EACE,eAAe;EACf,iBAAiB;EACjB,2BAA2B;EAC3B,cAAc;EACd,eAAe;AACjB;;AAEA,mEAAmE;;AAEnE;EACE,cAAc;EACd,YAAY;EACZ,gCAAgC;EAChC,qBAAqB;AACvB",sourcesContent:["/* webidControl.js styles — extracted from inline styles */\n/* Uses CSS custom properties from the global stylesheet (dev-global.css / mashlib) */\n\n/* ── Named pane (rendered sub-pane) ──────────────────────────── */\n\n.contactPane .namedPane {\n border: 0.1em solid var(--color-text-muted);\n border-radius: var(--border-radius-base);\n}\n\n/* ── WebID / Public ID outer container ───────────────────────── */\n\n.contactPane .webidControl {\n border-radius: 0.3em;\n border: 0.1em solid #888;\n}\n\n/* ── Persona row ─────────────────────────────────────────────── */\n\n.contactPane .personaRow {\n padding: 0.2em;\n}\n\n.contactPane .personaRow--webid {\n background-color: #ffe6ff;\n}\n\n/* ── Full-width elements ─────────────────────────────────────── */\n\n.contactPane .fullWidth {\n width: 100%;\n}\n\n/* ── Open/close profile button ───────────────────────────────── */\n\n.contactPane .personaOpenButton {\n float: right;\n background-color: transparent;\n border: none;\n}\n\n/* ── Section heading ─────────────────────────────────────────── */\n\n.contactPane .webidHeading {\n font-size: 110%;\n font-weight: bold;\n color: var(--color-primary);\n padding: 0.2em;\n margin: 0.7em 0;\n}\n\n/* ── Prompt text ─────────────────────────────────────────────── */\n\n.contactPane .webidPrompt {\n padding: 0.7em;\n border: none;\n font-size: var(--font-size-base);\n white-space: pre-wrap;\n}\n"],sourceRoot:""}]);const s=i},314(n){n.exports=function(n){var e=[];return e.toString=function(){return this.map(function(e){var t="",o=void 0!==e[5];return e[4]&&(t+="@supports (".concat(e[4],") {")),e[2]&&(t+="@media ".concat(e[2]," {")),o&&(t+="@layer".concat(e[5].length>0?" ".concat(e[5]):""," {")),t+=n(e),o&&(t+="}"),e[2]&&(t+="}"),e[4]&&(t+="}"),t}).join("")},e.i=function(n,t,o,r,a){"string"==typeof n&&(n=[[null,n,void 0]]);var i={};if(o)for(var s=0;s<this.length;s++){var d=this[s][0];null!=d&&(i[d]=!0)}for(var l=0;l<n.length;l++){var c=[].concat(n[l]);o&&i[c[0]]||(void 0!==a&&(void 0===c[5]||(c[1]="@layer".concat(c[5].length>0?" ".concat(c[5]):""," {").concat(c[1],"}")),c[5]=a),t&&(c[2]?(c[1]="@media ".concat(c[2]," {").concat(c[1],"}"),c[2]=t):c[2]=t),r&&(c[4]?(c[1]="@supports (".concat(c[4],") {").concat(c[1],"}"),c[4]=r):c[4]="".concat(r)),e.push(c))}},e}},354(n){n.exports=function(n){var e=n[1],t=n[3];if(!t)return e;if("function"==typeof btoa){var o=btoa(unescape(encodeURIComponent(JSON.stringify(t)))),r="sourceMappingURL=data:application/json;charset=utf-8;base64,".concat(o),a="/*# ".concat(r," */");return[e].concat([a]).join("\n")}return[e].join("\n")}},72(n){var e=[];function t(n){for(var t=-1,o=0;o<e.length;o++)if(e[o].identifier===n){t=o;break}return t}function o(n,o){for(var a={},i=[],s=0;s<n.length;s++){var d=n[s],l=o.base?d[0]+o.base:d[0],c=a[l]||0,u="".concat(l," ").concat(c);a[l]=c+1;var p=t(u),A={css:d[1],media:d[2],sourceMap:d[3],supports:d[4],layer:d[5]};if(-1!==p)e[p].references++,e[p].updater(A);else{var m=r(A,o);o.byIndex=s,e.splice(s,0,{identifier:u,updater:m,references:1})}i.push(u)}return i}function r(n,e){var t=e.domAPI(e);return t.update(n),function(e){if(e){if(e.css===n.css&&e.media===n.media&&e.sourceMap===n.sourceMap&&e.supports===n.supports&&e.layer===n.layer)return;t.update(n=e)}else t.remove()}}n.exports=function(n,r){var a=o(n=n||[],r=r||{});return function(n){n=n||[];for(var i=0;i<a.length;i++){var s=t(a[i]);e[s].references--}for(var d=o(n,r),l=0;l<a.length;l++){var c=t(a[l]);0===e[c].references&&(e[c].updater(),e.splice(c,1))}a=d}}},659(n){var e={};n.exports=function(n,t){var o=function(n){if(void 0===e[n]){var t=document.querySelector(n);if(window.HTMLIFrameElement&&t instanceof window.HTMLIFrameElement)try{t=t.contentDocument.head}catch(n){t=null}e[n]=t}return e[n]}(n);if(!o)throw new Error("Couldn't find a style target. This probably means that the value for the 'insert' parameter is invalid.");o.appendChild(t)}},540(n){n.exports=function(n){var e=document.createElement("style");return n.setAttributes(e,n.attributes),n.insert(e,n.options),e}},56(n,e,t){n.exports=function(n){var e=t.nc;e&&n.setAttribute("nonce",e)}},825(n){n.exports=function(n){if("undefined"==typeof document)return{update:function(){},remove:function(){}};var e=n.insertStyleElement(n);return{update:function(t){!function(n,e,t){var o="";t.supports&&(o+="@supports (".concat(t.supports,") {")),t.media&&(o+="@media ".concat(t.media," {"));var r=void 0!==t.layer;r&&(o+="@layer".concat(t.layer.length>0?" ".concat(t.layer):""," {")),o+=t.css,r&&(o+="}"),t.media&&(o+="}"),t.supports&&(o+="}");var a=t.sourceMap;a&&"undefined"!=typeof btoa&&(o+="\n/*# sourceMappingURL=data:application/json;base64,".concat(btoa(unescape(encodeURIComponent(JSON.stringify(a))))," */")),e.styleTagTransform(o,n,e.options)}(e,n,t)},remove:function(){!function(n){if(null===n.parentNode)return!1;n.parentNode.removeChild(n)}(e)}}}},113(n){n.exports=function(n,e){if(e.styleSheet)e.styleSheet.cssText=n;else{for(;e.firstChild;)e.removeChild(e.firstChild);e.appendChild(document.createTextNode(n))}}},53(n){n.exports=t},941(e){e.exports=n},104(n){n.exports=e}},r={};function a(n){var e=r[n];if(void 0!==e)return e.exports;var t=r[n]={id:n,exports:{}};return o[n](t,t.exports,a),t.exports}a.n=n=>{var e=n&&n.__esModule?()=>n.default:()=>n;return a.d(e,{a:e}),e},a.d=(n,e)=>{for(var t in e)a.o(e,t)&&!a.o(n,t)&&Object.defineProperty(n,t,{enumerable:!0,get:e[t]})},a.o=(n,e)=>Object.prototype.hasOwnProperty.call(n,e),a.nc=void 0;var i={};a.d(i,{default:()=>Tn});var s=a(941),d=a(104),l=a(53),c=a(72),u=a.n(c),p=a(825),A=a.n(p),m=a(659),h=a.n(m),f=a(56),g=a.n(f),b=a(540),C=a.n(b),w=a(113),y=a.n(w),v=a(886),E={};E.styleTagTransform=y(),E.setAttributes=g(),E.insert=h().bind(null,"head"),E.domAPI=A(),E.insertStyleElement=C(),u()(v.A,E),v.A&&v.A.locals&&v.A.locals;const B=d.ns,x=d.widgets,k=d.utils,P=s.store,T=x.publicData.wikidataClasses,D=x.publicData.wikidataParameters,S="Solid ID",F="In public data",L=d.icons.iconBase+"noun_1369241.svg",I=d.icons.iconBase+"noun_1369237.svg";function N(n,e){const t=function(n,e,t){return n.each(e,B.vcard("url"),null,e.doc()).filter(o=>n.holds(o,B.rdf("type"),t,e.doc())).map(t=>n.any(t,B.vcard("value"),null,e.doc())).filter(n=>!!n)}(n,e).concat(function(n,e,t){const o=new Set,r=new Set([e.uri]);for(;r.size;){const e=Array.from(r)[0];if(r.delete(e),o.has(e))continue;o.add(e);const a=n.sym(e);n.each(a,B.owl("sameAs"),null,t).concat(n.each(null,B.owl("sameAs"),a,t)).forEach(n=>{console.log(" OWL sameAs found "+n),r.add(n.uri)}),n.each(a,B.schema("sameAs"),null,t).concat(n.each(null,B.schema("sameAs"),a,t)).forEach(n=>{console.log(" Schema sameAs found "+n),r.add(n.uri)})}return o.delete(e.uri),Array.from(o).map(e=>n.sym(e))}(n,e,e.doc())),o=[...new Set(t.map(n=>n.value))].map(e=>n.sym(e));return o.sort(),o.filter(n=>!n.sameTerm(e)),o}function _(n){const e=n.doc();return P.holds(n,B.rdf("type"),B.vcard("Organization"),e)||P.holds(n,B.rdf("type"),B.schema("Organization"),e)}async function O(n,e,t){function o(o,a,i){const s=o.createElement("div");s.classList.add("fullWidth");const c=s.appendChild(o.createElement("table"));c.classList.add("fullWidth");const u=c.appendChild(function(e){const a=new l.Literal(e.uri),c=t.urlType.sameTerm(B.vcard("WebID")),u=t.editable?async function(){try{await async function(n,e,t,o){console.log(`Removing from ${n} their ${S}: ${e}.`);const r=o.each(n,B.vcard("url"),null,n.doc()).filter(e=>o.holds(e,B.rdf("type"),t,n.doc())).filter(t=>o.holds(t,B.vcard("value"),e,n.doc()));if(!r.length)throw new Error(`Person ${n} does not have ${S} ${e}.`);const a=r[0],i=[l.st(n,B.vcard("url"),a,n.doc()),l.st(a,B.rdf("type"),t,n.doc()),l.st(a,B.vcard("value"),e,n.doc())];await o.updater.update(i,[]);const s=o.each(null,B.vcard("hasMember"),o.sym(e));let d=[];const c=[];s.forEach(async t=>{d=d.concat(o.statementsMatching(o.sym(e),B.owl("sameAs"),n,t.doc())),c.push(l.st(t,B.vcard("hasMember"),n,t.doc())),o.statementsMatching(o.sym(e),B.owl("sameAs"),null,t.doc()).length<2&&(d=d.concat(o.statementsMatching(t,B.vcard("hasMember"),o.sym(e),t.doc())))}),await R(d,c)}(n,a,t.urlType,i)}catch(e){s.appendChild(x.errorMessageBlock(o,`Error removing Id ${a} from ${n}: ${e}`))}await r()}:null,p={deleteFunction:u,draggable:!0};c&&(p.title=e.uri.split("/")[2],p.image=x.faviconOrDefault(o,e.site()));const A=x.personTR(o,d.ns.foaf("knows"),e,p);return c&&(A.children[1].textConent=p.title,A.classList.add("personaRow--webid")),A.classList.add("personaRow"),A}(a));u.classList.add("fullWidth");const p=c.appendChild(o.createElement("tr")).appendChild(o.createElement("td"));let A;p.setAttribute("colspan",3);let m=!0;const h=u.children[2].appendChild(x.button(o,L,"View",function(n){m=!m,A.style.visibility=m?"visible":"collapse",h.children[0].src=m?I:L}));h.classList.add("personaOpenButton");const f=(_(n)||_(a),"profile");return x.publicData.loadPublicDataThing(i,n,a).then(n=>{try{A=function(n,e,t,o){const r=o.session.paneRegistry.byName(t).render(e,o);return r.classList.add("namedPane"),r}(0,a,f,e),console.log("main: ",A),A.classList.add("fullWidth"),console.log("renderIdControl: main element: ",A),p.appendChild(A)}catch(n){A=x.errorMessageBlock(o,`Problem displaying persona ${a}: ${n}`),p.appendChild(A)}},n=>{A=x.errorMessageBlock(o,`Error loading persona ${a}: ${n}`),p.appendChild(A)}),s}async function r(){const e=N(P,n);console.log("WebId personas: "+n+" -> "+e.map(n=>n.uri).join(",\n ")),c.style.display=e.length?"none":"",k.syncTableToArrayReOrdered(u,e,n=>o(a,n,P))}const{dom:a}=e;(t=t||{}).editable=P.updater.editable(n.doc().uri,P);const i=a.createElement("div");if(i.classList.add("webidControl"),0===N(P,n).length&&!t.editable)return i.style.display="none",i;const s=i.appendChild(a.createElement("h4"));s.textContent=t.idNoun,s.classList.add("webidHeading");const c=i.appendChild(a.createElement("p"));if(c.classList.add("webidPrompt"),c.textContent=t.longPrompt,i.appendChild(a.createElement("table")).classList.add("fullWidth"),t.editable){const e={editable:t.editable,manualURIEntry:!0,idNoun:t.idNoun,dbLookup:t.dbLookup},o={queryParams:t.queryParams||D,targetClass:t.class};try{i.appendChild(await x.renderAutocompleteControl(a,n,e,o,async function(n,e){try{await async function(n,e,t,o){try{new URL(e)}catch(n){throw new Error(`${S}: ${e} is not a valid url.`)}console.log(`Adding to ${n} a ${S}: ${e}.`);const r=o.bnode(),a=[l.st(n,B.vcard("url"),r,n.doc()),l.st(r,B.rdf("type"),t,n.doc()),l.st(r,B.vcard("value"),e,n.doc())],i=o.each(null,B.vcard("hasMember"),n);let s=[];i.forEach(t=>{s=s.concat(o.statementsMatching(t,B.vcard("hasMember"),n,t.doc())),a.push(l.st(t,B.vcard("hasMember"),o.sym(e),t.doc())),a.push(l.st(o.sym(e),B.owl("sameAs"),n,t.doc()))});try{await R(s,a)}catch(n){throw new Error(`Could not create webId ${S}: ${e}.`)}}(n,e,t.urlType,P)}catch(t){i.appendChild(x.errorMessageBlock(a,`Error adding Id ${e} to ${n}: ${t}`))}await r()}))}catch(n){console.error("renderAutocompleteControl failed:",n),i.appendChild(x.errorMessageBlock(a,"Error rendering autocomplete: "+n))}}const u=i.appendChild(a.createElement("div"));return await r(),i}const U=d.ns,M=d.utils,z=s.store,$=z.updater;async function R(n,e=[]){const t=n.concat(e).map(n=>n.why),o=[];t.forEach(n=>{o.find(e=>e.equals(n))||o.push(n)});const r=o.map(t=>z.updater.update(n.filter(n=>n.why.sameTerm(t)),e.filter(n=>n.why.sameTerm(t))));return Promise.all(r)}async function j(n,e){await z.fetcher.load(n.doc());const t=z.any(n,U.vcard("groupIndex")),o=function(n){return n.replace(/\W/gu,"_").replace(/_+/g,"_")}(e),r=z.sym(n.dir().uri+"Group/"+o+".ttl#this"),a=r.doc();try{await z.fetcher.load(t)}catch(n){throw new Error("Error loading group index!"+t.uri+": "+n)}if(z.holds(n,U.vcard("includesGroup"),r,t))return r;const i=[l.st(n,U.vcard("includesGroup"),r,t),l.st(r,U.rdf("type"),U.vcard("Group"),t),l.st(r,U.vcard("fn"),e,t)];try{await $.update([],i)}catch(n){throw new Error("Could not update group index "+n)}const s=[l.st(n,U.vcard("includesGroup"),r,a),l.st(r,U.rdf("type"),U.vcard("Group"),a),l.st(r,U.vcard("fn"),e,a)];try{await $.update([],s)}catch(n){throw new Error("Could not update group file: "+n)}return r}async function q(n,e){const t=[n.doc(),e.doc()];try{await z.fetcher.load(t)}catch(n){throw new Error("addPersonToGroup: "+n)}const o=z.findTypeURIs(n);if(!(U.vcard("Individual").uri in o)&&!(U.vcard("Organization").uri in o))return alert(`Can't add ${n} to a group: it has to be an individual or another group.`);const r=z.any(n,U.vcard("fn")),a=z.any(e,U.vcard("fn"));if(!r)return alert("No vcard name known for "+n);if(z.holds(n,U.vcard("fn"),null,e.doc()))return alert("ALREADY added "+r+" to group "+a);if(!confirm("Add "+r+" to group "+a+"?"))return;const i=[l.st(n,U.vcard("fn"),r,e.doc())],s=N(z,n).map(n=>n.value);s.length?s.forEach(t=>{i.push(l.st(z.sym(t),U.owl("sameAs"),n,e.doc())),i.push(l.st(e,U.vcard("hasMember"),z.sym(t),e.doc()))}):i.push(l.st(e,U.vcard("hasMember"),n,e.doc()));try{await $.update([],i),z.fetcher.unload(e.doc()),await z.fetcher.load(e.doc())}catch(n){throw new Error(`Error adding ${r} to group ${a}:`+n)}return n}function G(n,e){const t=n.each(e,U.vcard("hasMember"),null,e.doc());let o=[];t.forEach(t=>{o=n.any(t,U.vcard("fn"),null,e.doc())?o.concat(t):o.concat(n.each(t,U.owl("sameAs"),null,e.doc()))});const r=new Set(o.map(n=>n.uri));return o=[...r].map(e=>n.sym(e)),o}function H(n,e){const t=n.dir().dir().dir();return e.uri&&e.uri.startsWith(t.uri)}async function W(n){const e=[],t=[];return n.forEach(n=>{z.each(n,U.vcard("hasMember"),null,n.doc()).forEach(o=>{const r=function(n,e,t){return n.each(e,U.owl("sameAs"),null,t).concat(n.each(null,U.owl("sameAs"),e,t))}(z,o,n.doc());if(r.length&&H(n,o))for(const a of r)if(!H(n,a)){e.push(l.st(n,U.vcard("hasMember"),o,n.doc())),t.push(l.st(n,U.vcard("hasMember"),a,n.doc()));break}})}),{del:e,ins:t}}const{setACLUserPublic:V}=s.solidLogicSingleton.acl;var Y=a(715),Z={};Z.styleTagTransform=y(),Z.setAttributes=g(),Z.insert=h().bind(null,"head"),Z.domAPI=A(),Z.insertStyleElement=C(),u()(Y.A,Z),Y.A&&Y.A.locals&&Y.A.locals;const Q={"image/png":"png","image/jpeg":"jpg","image/gif":"gif","image/svg+xml":"svg","image/webp":"webp","image/bmp":"bmp","image/tiff":"tiff","application/pdf":"pdf","text/plain":"txt","text/html":"html","application/json":"json","application/octet-stream":"bin"},K=Object.fromEntries(Object.entries(Q).map(([n,e])=>[e,n])),X=n=>Q[n]||!1,J=n=>{const e=n.split(".").pop().toLowerCase();return K[e]||!1},nn=d.ns,en=d.utils,tn=s.store;function on(n,e){function t(e){console.log(e),f.appendChild(d.widgets.errorMessageBlock(n,e,"pink"))}async function o(n,e,t){const o=[l.st(n,nn.vcard("hasPhoto"),e,n.doc())];try{t?await tn.updater.update(o,[]):await tn.updater.update([],o)}catch(n){const t=" Write back image link FAIL "+e+", Error: "+n;console.log(t),alert(t)}}function r(n){tn.fetcher.nowOrWhenFetched(n.doc(),function(t,o){if(t){const t=tn.findTypeURIs(n);for(const n in t)console.log(" drop object type includes: "+n);console.log("Default: assume web page "+n),tn.add(e,nn.wf("attachment"),n,e.doc())}else console.log("Error looking up dropped thing "+n+": "+o)})}function a(n,o,r){const a=X(o);let i,s;o!==J(n)&&(n+="_."+a,console.log("MIME TYPE MISMATCH -- adding extension: "+n));const d=o.startsWith("image");let l,c;for(d?(i="image_",s=nn.vcard("hasPhoto")):(i="attachment_",s=nn.wf("attachment")),l=0;c=tn.sym(e.dir().uri+n),tn.holds(e,nn.vcard("hasPhoto"),c);l++)n=i+l+"."+a;console.log("Putting "+r.byteLength+" bytes of "+o+" to "+c),tn.fetcher.webOperation("PUT",c.uri,{data:r,contentType:o}).then(function(n){n.ok?(console.log(" Upload: put OK: "+c),tn.add(e,s,c,e.doc()),tn.fetcher.putBack(e.doc(),{contentType:"text/turtle"}).then(function(n){d&&g.refresh()},function(n){console.log(" Write back image link FAIL "+c+", Error: "+n)})):t("Error uploading "+c+":"+n.status)})}async function i(n){for(const e of n){let n=l.sym(e);if(console.log("Dropped on mugshot thing "+n),e.startsWith("http")&&e.indexOf("#")<0){e.startsWith("http:")&&(n=l.sym("https:"+e.slice(5)));const o={withCredentials:!1,credentials:"omit"};let i;try{i=await tn.fetcher.webOperation("GET",n.uri,o)}catch(e){return t(`Gallery: fetch error trying to read picture ${n} data: ${e}`),void r(n)}const s=i.headers.get("Content-Type");let d=n.uri.split("/").slice(-1)[0];d=d.split("?")[0];const c=await i.arrayBuffer();return i.ok?void a(d,s,c):(alert("Cant download, so will link image. "+n+":"+i.status),void r(n))}alert("Not a web document URI, cannot copy as picture: "+n),r(n)}}function c(n){for(let e=0;e<n.length;e++){const t=n[e];console.log(" contacts: Filename: "+t.name+", type: "+(t.type||"n/a")+" size: "+t.size+" bytes, last modified: "+(t.lastModifiedDate?t.lastModifiedDate.toLocaleDateString():"n/a"));const o=new FileReader;o.onload=function(n){return function(e){const t=e.target.result;console.log(" File read byteLength : "+t.byteLength),a(encodeURIComponent(n.name),n.type,t)}}(t),o.readAsArrayBuffer(t)}}function u(e){const t=n.createElement("img");return t.classList.add("mugshotImage"),d.widgets.makeDropTarget(t,i,c),e&&(s.store.fetcher._fetch(e.uri).then(function(n){return n.blob()}).then(function(n){const e=URL.createObjectURL(n);t.setAttribute("src",e)}),d.widgets.makeDraggable(t,e)),t}function p(){let n=tn.each(e,nn.vcard("hasPhoto"));n.sort(),n=n.slice(0,5),0===n.length?(g.innerHTML="",h&&g.appendChild(b)):en.syncTableToArray(g,n,u)}function A(){return tn.sym(e.dir().uri+"Image_"+Date.now()+".png")}async function m(n){n&&(await o(e,n),p())}const h=tn.updater.editable(e.doc().uri,tn),f=n.createElement("div"),g=f.appendChild(n.createElement("div")),b=u();return d.widgets.setImage(b,e),p(),g.refresh=p,h&&f.appendChild(function(){const t=n.createElement("table"),r=t.appendChild(n.createElement("tr")),a=r.appendChild(n.createElement("td")),i=r.appendChild(n.createElement("td")),s=r.appendChild(n.createElement("td"));a.appendChild(d.media.cameraButton(n,tn,A,m));try{i.appendChild(d.widgets.fileUploadButtonDiv(n,c))}catch(n){console.log("ignore fileUploadButtonDiv error for now",n)}return s.appendChild(function(){const t=d.widgets.button(n,d.icons.iconBase+"noun_925021.svg","Drag here to delete");return d.widgets.makeDropTarget(t,async function(n){const t=tn.each(e,nn.vcard("hasPhoto")).map(n=>n.uri);for(const r of n){if(!t.includes(r))return void alert("Only drop images in this contact onto this trash can.");if(confirm(`Permanently DELETE image ${r} completely?`)){console.log("Unlinking image file "+r),await o(e,tn.sym(r),!0);try{console.log("Deleting image file "+r),await tn.fetcher.webOperation("DELETE",r)}catch(n){alert("Unable to delete picture! "+n)}}}p()},null),t}()),t}()),f}const rn=d.ns,an=d.utils,sn=s.store;function dn(n){let e=sn.statementsMatching(null,rn.owl("sameAs"),n).map(n=>n.why).concat(sn.each(null,rn.vcard("hasMember"),n));const t=new Set(e.map(n=>n.uri));return e=[...t].map(n=>sn.sym(n)),e}async function ln(n,e){function t(e){const t={deleteFunction:function(){!async function(e,t){const s=a.any(e,rn.vcard("fn")),l=a.any(t,rn.vcard("fn")),c=a.each(null,rn.owl("sameAs"),e,t.doc());let u=[];c.forEach(n=>{a.statementsMatching(n,rn.owl("sameAs"),e,t.doc())&&(u=u.concat(n))});let p=e;if(u.length>0&&(p=u[0]),a.each(null,rn.vcard("hasMember"),p).length<2)alert("Must be a member of at least one group. Add to another group first.");else if(confirm("Remove "+s+" from group "+l+"?")){let e=a.statementsMatching(n,void 0,void 0,t.doc()).concat(a.statementsMatching(void 0,void 0,n,t.doc()));u.forEach(n=>{a.statementsMatching(n,rn.owl("sameAs"),void 0,t.doc()).length<2&&(e=e.concat(a.statementsMatching(void 0,void 0,n,t.doc())))}),a.updater.update(e,[],function(n,e,o){if(!e){const n="Error removing member from group "+t+": "+o;i.parentNode.appendChild(d.widgets.errorMessageBlock(r,n,"pink"))}}),console.log("Removed "+s+" from group "+l),a.fetcher.unload(t.doc()),await a.fetcher.load(t.doc()),o()}}(n,e)},noun:"membership"};return d.widgets.personTR(r,null,e,t)}function o(){an.syncTableToArray(i,dn(n),t)}const{dom:r}=e,a=e.session.store,i=r.createElement("table");return await async function(n=null){if(!n&&!(n=a.any(void 0,rn.vcard("includesGroup"))))return;const e=a.any(n,rn.vcard("groupIndex")),t=n?a.each(n,rn.vcard("includesGroup"),null,e):[];await a.fetcher.load(t)}(),i.refresh=o,o(),i}const cn='# This turtle file defines the forms used in the contacts management\n#\n# Individuals and orgs are in one file as they both\n# share some forms (address etc) and also interactions (roles)\n\n# Forms documentation: https://solidos.github.io/solid-ui/docs/forms-intro.html\n\n@prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>.\n@prefix dct: <http://purl.org/dc/terms/>.\n@prefix foaf: <http://xmlns.com/foaf/0.1/>.\n@prefix owl: <http://www.w3.org/2002/07/owl#>.\n@prefix prov: <http://www.w3.org/ns/prov#>.\n@prefix ui: <http://www.w3.org/ns/ui#>.\n@prefix schema: <http://schema.org/>.\n@prefix solid: <http://www.w3.org/ns/solid/terms#>.\n@prefix vcard: <http://www.w3.org/2006/vcard/ns#>.\n@prefix : <#>.\n\n\n############# For individual:\n:individualForm a ui:Form ;\n dct:title "Contact details for a person" ;\n ui:parts (\n :fullNameField\n :roleField\n :orgNameField\n # :addressesComment\n :addresses\n # :emailComment\n :eMails\n # :telephoneComment\n :telephones\n :birthdayField\n # :noteComment\n :noteField \n ) .\n\n :fullNameField\n a ui:SingleLineTextField ;\n ui:label "Name";\n ui:maxLength "128" ;\n ui:property vcard:fn .\n\n :roleField\n a ui:SingleLineTextField ;\n ui:suppressEmptyUneditable true;\n ui:maxLength "128" ;\n ui:property vcard:role .\n\n :orgNameField\n a ui:SingleLineTextField ;\n ui:suppressEmptyUneditable true;\n ui:maxLength "128" ;\n ui:property vcard:organization-name .\n\n :addresses a ui:Multiple ;\n dct:title "Address details" ;\n ui:part :oneAddress ;\n ui:property vcard:hasAddress .\n\n :oneAddress a ui:Group ;\n ui:parts ( \n :id1409437207443 :id1409437292400 \n :id1409437421996 :id1409437467649 \n :id1409437569420 ). \n\n :id1409437207443\n a ui:SingleLineTextField ;\n ui:maxLength "128" ;\n ui:property vcard:street-address .\n\n :id1409437292400\n a ui:SingleLineTextField ;\n ui:maxLength "128" ;\n ui:property vcard:locality .\n\n :id1409437421996\n a ui:SingleLineTextField ;\n ui:maxLength "25" ;\n ui:property vcard:postal-code .\n\n :id1409437467649\n a ui:SingleLineTextField ;\n ui:maxLength "128" ;\n ui:property vcard:region .\n\n :id1409437569420\n a ui:SingleLineTextField ;\n ui:maxLength "128" ;\n ui:property vcard:country-name .\n\n\n :eMails a ui:Multiple ;\n ui:part :oneEMail ;\n ui:property vcard:hasEmail .\n\n :oneEMail a ui:Group ; # hint: side by side is good\n ui:part :emailValue, :emailType ;\n ui:parts ( :emailType :emailValue ).\n\n :emailValue\n a ui:EmailField ; ui:label "email";\n ui:property vcard:value .\n\n :emailType\n a ui:Classifier ;\n ui:canMintNew "0" ;\n ui:category vcard:Type ;\n ui:from vcard:Type ;\n ui:property rdf:type .\n\n :telephones a ui:Multiple ;\n ui:part :onetelephone ;\n ui:property vcard:hasTelephone .\n\n :onetelephone\n a ui:Group ;\n ui:part :telephoneValue, :telephoneType ;\n ui:parts ( :telephoneType :telephoneValue ).\n\n :telephoneValue\n a ui:PhoneField ;\n ui:property vcard:value .\n\n :telephoneType\n a ui:Classifier ;\n ui:canMintNew "0" ;\n ui:category vcard:TelephoneType ;\n ui:from vcard:Type ;\n ui:property rdf:type .\n\n :birthdayField a ui:DateField;\n ui:label "Born"@en;\n ui:suppressEmptyUneditable true;\n ui:property vcard:bday .\n\n :noteField\n a ui:MultiLineTextField ;\n ui:suppressEmptyUneditable true;\n ui:property vcard:note .\n\n# Ontology additions or interpretations needed for the form to work well\n\n# The ontology file doesn\'t make them disjoint. This makes the selector be a choice.\nvcard:TelephoneType owl:disjointUnionOf ( vcard:Cell vcard:Home vcard:Work) .\nvcard:Type owl:disjointUnionOf (vcard:Home vcard:Work) . # for email\n\n# Better field labels\nvcard:Cell ui:label "mobile"@en . # app will make initial caps if necessary\nvcard:hasAddress ui:label "address"@en .\nvcard:bday ui:label "born"@en.\nvcard:hasEmail ui:label "email"@en .\nvcard:hasTelephone ui:label "phone"@en .\nvcard:note ui:label "notes"@en .\n\n\n############ For organizations\n\n:organizationForm a ui:Form ; \n dct:title "Contact details for an organization";\n ui:parts (\n :OrgClassifier\n :fullNameField\n :homePageURIField\n :addresses\n :eMails\n :telephones\n :noteField ) .\n\n :OrgClassifier a ui:Classifier; \n ui:label "What sort of organization?"@en;\n ui:category solid:InterestingOrganization .\n\n :homePageURIField a ui:NamedNodeURIField;\n ui:label "Homepage"@en;\n ui:property schema:url .\n\n# Ontology data to drive the :OrgClassifier classifier\n solid:InterestingOrganization owl:disjointUnionOf (\n # Airline - a Corporation\n # Consortium - a Corporation or a NGO\n schema:Corporation\n schema:EducationalOrganization\n schema:ResearchOrganization # Proposed. https://github.com/schemaorg/schemaorg/issues/2877\n # FundingScheme - eh?\n schema:GovernmentOrganization\n # LibrarySystem\n # LocalBusiness - Corporation\n # MedicalOrganization - a Corporation or a NGO\n schema:NGO\n # NewsMediaOrganization - a Corporation or a NGO\n schema:PerformingGroup # a band\n schema:Project # like Solid\n schema:SportsOrganization) .\n';var un=a(479),pn={};pn.styleTagTransform=y(),pn.setAttributes=g(),pn.insert=h().bind(null,"head"),pn.domAPI=A(),pn.insertStyleElement=C(),u()(un.A,pn),un.A&&un.A.locals&&un.A.locals;var An=a(434),mn={};mn.styleTagTransform=y(),mn.setAttributes=g(),mn.insert=h().bind(null,"head"),mn.domAPI=A(),mn.insertStyleElement=C(),u()(An.A,mn),An.A&&An.A.locals&&An.A.locals;const hn="https://solidos.github.io/contacts-pane/src/ontology/";function fn(n,e,t,o){const r=o||hn+t,a=(0,l.sym)(r);n.holds(void 0,void 0,void 0,a)||(0,l.parse)(e,n,r,"text/turtle",()=>null)}const gn=d.ns,bn=s.store,Cn="individualAndOrganizationForm.ttl";async function wn(n,e,t,o){const r=bn.findTypeURIs(t),a=!(!r[gn.vcard("Organization").uri]&&!r[gn.schema("Organization").uri]),i=bn.updater.editable(t.doc().uri,bn);fn(bn,cn,Cn);const c=d.ns.vcard("Type").doc().uri;fn(bn,'@prefix : <http://www.w3.org/2006/vcard/ns#> .\n@prefix owl: <http://www.w3.org/2002/07/owl#> .\n@prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#> .\n@prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#> .\n@prefix xml: <http://www.w3.org/XML/1998/namespace> .\n@prefix xsd: <http://www.w3.org/2001/XMLSchema#> .\n\n:Acquaintance a owl:Class ;\n rdfs:label "Acquaintance"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Agent a owl:Class ;\n rdfs:label "Agent"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:BBS a owl:Class ;\n rdfs:label "BBS"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :TelephoneType ;\n owl:deprecated true .\n\n:Car a owl:Class ;\n rdfs:label "Car"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :TelephoneType ;\n owl:deprecated true .\n\n:Cell a owl:Class ;\n rdfs:label "Cell"@en ;\n rdfs:comment "Also called mobile telephone"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :TelephoneType .\n\n:Child a owl:Class ;\n rdfs:label "Child"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Colleague a owl:Class ;\n rdfs:label "Colleague"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Contact a owl:Class ;\n rdfs:label "Contact"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Coresident a owl:Class ;\n rdfs:label "Coresident"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Coworker a owl:Class ;\n rdfs:label "Coworker"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Crush a owl:Class ;\n rdfs:label "Crush"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Date a owl:Class ;\n rdfs:label "Date"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Dom a owl:Class ;\n rdfs:label "Dom"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Type ;\n owl:deprecated true .\n\n:Emergency a owl:Class ;\n rdfs:label "Emergency"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Fax a owl:Class ;\n rdfs:label "Fax"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :TelephoneType .\n\n:Female a owl:Class ;\n rdfs:label "Female"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Gender .\n\n:Friend a owl:Class ;\n rdfs:label "Friend"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Home a owl:Class ;\n rdfs:label "Home"@en ;\n rdfs:comment "This implies that the property is related to an individual\'s personal life"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Type .\n\n:ISDN a owl:Class ;\n rdfs:label "ISDN"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Type ;\n owl:deprecated true .\n\n:Internet a owl:Class ;\n rdfs:label "Internet"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Type ;\n owl:deprecated true .\n\n:Intl a owl:Class ;\n rdfs:label "Intl"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Type ;\n owl:deprecated true .\n\n:Kin a owl:Class ;\n rdfs:label "Kin"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Label a owl:Class ;\n rdfs:label "Label"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Type ;\n owl:deprecated true .\n\n:Male a owl:Class ;\n rdfs:label "Male"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Gender .\n\n:Me a owl:Class ;\n rdfs:label "Me"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Met a owl:Class ;\n rdfs:label "Met"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Modem a owl:Class ;\n rdfs:label "Modem"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :TelephoneType ;\n owl:deprecated true .\n\n:Msg a owl:Class ;\n rdfs:label "Msg"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :TelephoneType ;\n owl:deprecated true .\n\n:Muse a owl:Class ;\n rdfs:label "Muse"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Neighbor a owl:Class ;\n rdfs:label "Neighbor"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:None a owl:Class ;\n rdfs:label "None"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Gender .\n\n:Other a owl:Class ;\n rdfs:label "Other"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Gender .\n\n:PCS a owl:Class ;\n rdfs:label "PCS"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :TelephoneType ;\n owl:deprecated true .\n\n:Pager a owl:Class ;\n rdfs:label "Pager"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :TelephoneType .\n\n:Parcel a owl:Class ;\n rdfs:label "Parcel"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Type ;\n owl:deprecated true .\n\n:Parent a owl:Class ;\n rdfs:label "Parent"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Postal a owl:Class ;\n rdfs:label "Postal"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Type ;\n owl:deprecated true .\n\n:Pref a owl:Class ;\n rdfs:label "Pref"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Type ;\n owl:deprecated true .\n\n:Sibling a owl:Class ;\n rdfs:label "Sibling"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Spouse a owl:Class ;\n rdfs:label "Spouse"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Sweetheart a owl:Class ;\n rdfs:label "Sweetheart"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :RelatedType .\n\n:Tel a owl:Class ;\n rdfs:label "Tel"@en ;\n rdfs:comment "This class is deprecated. Use the hasTelephone object property."@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:deprecated true .\n\n:Text a owl:Class ;\n rdfs:label "Text"@en ;\n rdfs:comment "Also called sms telephone"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :TelephoneType .\n\n:TextPhone a owl:Class ;\n rdfs:label "Text phone"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :TelephoneType .\n\n:Unknown a owl:Class ;\n rdfs:label "Unknown"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Gender .\n\n:Video a owl:Class ;\n rdfs:label "Video"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :TelephoneType .\n\n:Voice a owl:Class ;\n rdfs:label "Voice"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :TelephoneType .\n\n:Work a owl:Class ;\n rdfs:label "Work"@en ;\n rdfs:comment "This implies that the property is related to an individual\'s work place"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Type .\n\n:X400 a owl:Class ;\n rdfs:label "X400"@en ;\n rdfs:comment "This class is deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Type ;\n owl:deprecated true .\n\n:adr a owl:ObjectProperty ;\n rdfs:label "address"@en ;\n rdfs:comment "This object property has been mapped"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :hasAddress .\n\n:agent a owl:ObjectProperty ;\n rdfs:label "agent"@en ;\n rdfs:comment "This object property has been deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:deprecated true .\n\n:anniversary a owl:DatatypeProperty ;\n rdfs:label "anniversary"@en ;\n rdfs:comment "The date of marriage, or equivalent, of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range [ a rdfs:Datatype ;\n owl:unionOf ( xsd:dateTime xsd:gYear ) ] .\n\n:bday a owl:DatatypeProperty ;\n rdfs:label "birth date"@en ;\n rdfs:comment "To specify the birth date of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range [ a rdfs:Datatype ;\n owl:unionOf ( xsd:dateTime xsd:dateTimeStamp xsd:gYear ) ] .\n\n:category a owl:DatatypeProperty ;\n rdfs:label "category"@en ;\n rdfs:comment "The category information about the object, also known as tags"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:class a owl:DatatypeProperty ;\n rdfs:label "class"@en ;\n rdfs:comment "This data property has been deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:deprecated true .\n\n:email a owl:ObjectProperty ;\n rdfs:label "email"@en ;\n rdfs:comment "This object property has been mapped"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :hasEmail .\n\n:extended-address a owl:DatatypeProperty ;\n rdfs:label "extended address"@en ;\n rdfs:comment "This data property has been deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:deprecated true .\n\n:geo a owl:ObjectProperty ;\n rdfs:label "geo"@en ;\n rdfs:comment "This object property has been mapped"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :hasGeo .\n\n:hasAdditionalName a owl:ObjectProperty ;\n rdfs:label "has additional name"@en ;\n rdfs:comment "Used to support property parameters for the additional name data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasCalendarBusy a owl:ObjectProperty ;\n rdfs:label "has calendar busy"@en ;\n rdfs:comment "To specify the busy time associated with the object. (Was called FBURL in RFC6350)"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasCalendarLink a owl:ObjectProperty ;\n rdfs:label "has calendar link"@en ;\n rdfs:comment "To specify the calendar associated with the object. (Was called CALURI in RFC6350)"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasCalendarRequest a owl:ObjectProperty ;\n rdfs:label "has calendar request"@en ;\n rdfs:comment "To specify the calendar user address to which a scheduling request be sent for the object. (Was called CALADRURI in RFC6350)"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasCategory a owl:ObjectProperty ;\n rdfs:label "has category"@en ;\n rdfs:comment "Used to support property parameters for the category data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasCountryName a owl:ObjectProperty ;\n rdfs:label "has country name"@en ;\n rdfs:comment "Used to support property parameters for the country name data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasFN a owl:ObjectProperty ;\n rdfs:label "has formatted name"@en ;\n rdfs:comment "Used to support property parameters for the formatted name data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasFamilyName a owl:ObjectProperty ;\n rdfs:label "has family name"@en ;\n rdfs:comment "Used to support property parameters for the family name data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasGender a owl:ObjectProperty ;\n rdfs:label "has gender"@en ;\n rdfs:comment "To specify the sex or gender identity of the object. URIs are recommended to enable interoperable sex and gender codes to be used."@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasGivenName a owl:ObjectProperty ;\n rdfs:label "has given name"@en ;\n rdfs:comment "Used to support property parameters for the given name data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasHonorificPrefix a owl:ObjectProperty ;\n rdfs:label "has honorific prefix"@en ;\n rdfs:comment "Used to support property parameters for the honorific prefix data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasHonorificSuffix a owl:ObjectProperty ;\n rdfs:label "has honorific suffix"@en ;\n rdfs:comment "Used to support property parameters for the honorific suffix data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasInstantMessage a owl:ObjectProperty ;\n rdfs:label "has messaging"@en ;\n rdfs:comment "To specify the instant messaging and presence protocol communications with the object. (Was called IMPP in RFC6350)"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasLanguage a owl:ObjectProperty ;\n rdfs:label "has language"@en ;\n rdfs:comment "Used to support property parameters for the language data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasLocality a owl:ObjectProperty ;\n rdfs:label "has locality"@en ;\n rdfs:comment "Used to support property parameters for the locality data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasNickname a owl:ObjectProperty ;\n rdfs:label "has nickname"@en ;\n rdfs:comment "Used to support property parameters for the nickname data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:seeAlso :nickname .\n\n:hasNote a owl:ObjectProperty ;\n rdfs:label "has note"@en ;\n rdfs:comment "Used to support property parameters for the note data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasOrganizationName a owl:ObjectProperty ;\n rdfs:label "has organization name"@en ;\n rdfs:comment "Used to support property parameters for the organization name data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasOrganizationUnit a owl:ObjectProperty ;\n rdfs:label "has organization unit name"@en ;\n rdfs:comment "Used to support property parameters for the organization unit name data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasPostalCode a owl:ObjectProperty ;\n rdfs:label "has postal code"@en ;\n rdfs:comment "Used to support property parameters for the postal code data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasRegion a owl:ObjectProperty ;\n rdfs:label "has region"@en ;\n rdfs:comment "Used to support property parameters for the region data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasRelated a owl:ObjectProperty ;\n rdfs:label "has related"@en ;\n rdfs:comment "To specify a relationship between another entity and the entity represented by this object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasRole a owl:ObjectProperty ;\n rdfs:label "has role"@en ;\n rdfs:comment "Used to support property parameters for the role data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasSource a owl:ObjectProperty ;\n rdfs:label "has source"@en ;\n rdfs:comment "To identify the source of directory information of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasStreetAddress a owl:ObjectProperty ;\n rdfs:label "has street address"@en ;\n rdfs:comment "Used to support property parameters for the street address data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasTitle a owl:ObjectProperty ;\n rdfs:label "has title"@en ;\n rdfs:comment "Used to support property parameters for the title data property"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasUID a owl:ObjectProperty ;\n rdfs:label "has uid"@en ;\n rdfs:comment "To specify a value that represents a globally unique identifier corresponding to the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasValue a owl:ObjectProperty ;\n rdfs:label "has value"@en ;\n rdfs:comment "Used to indicate the resource value of an object property that requires property parameters"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:label a owl:DatatypeProperty ;\n rdfs:label "label"@en ;\n rdfs:comment "This data property has been deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:deprecated true .\n\n:language a owl:DatatypeProperty ;\n rdfs:label "language"@en ;\n rdfs:comment "To specify the language that may be used for contacting the object. May also be used as a property parameter."@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:latitude a owl:DatatypeProperty ;\n rdfs:label "latitude"@en ;\n rdfs:comment "This data property has been deprecated. See hasGeo"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:deprecated true .\n\n:longitude a owl:DatatypeProperty ;\n rdfs:label "longitude"@en ;\n rdfs:comment "This data property has been deprecated. See hasGeo"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:deprecated true .\n\n:mailer a owl:DatatypeProperty ;\n rdfs:label "mailer"@en ;\n rdfs:comment "This data property has been deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:deprecated true .\n\n:note a owl:DatatypeProperty ;\n rdfs:label "note"@en ;\n rdfs:comment "A note associated with the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:org a owl:ObjectProperty ;\n rdfs:label "organization"@en ;\n rdfs:comment "This object property has been mapped. Use the organization-name data property."@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :organization-name .\n\n:organization-unit a owl:DatatypeProperty ;\n rdfs:label "organizational unit name"@en ;\n rdfs:comment "To specify the organizational unit name associated with the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string ;\n rdfs:subPropertyOf :organization-name .\n\n:post-office-box a owl:DatatypeProperty ;\n rdfs:label "post office box"@en ;\n rdfs:comment "This data property has been deprecated"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:deprecated true .\n\n:prodid a owl:DatatypeProperty ;\n rdfs:label "product id"@en ;\n rdfs:comment "To specify the identifier for the product that created the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:rev a owl:DatatypeProperty ;\n rdfs:label "revision"@en ;\n rdfs:comment "To specify revision information about the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:dateTime .\n\n:role a owl:DatatypeProperty ;\n rdfs:label "role"@en ;\n rdfs:comment "To specify the function or part played in a particular situation by the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:sort-string a owl:DatatypeProperty ;\n rdfs:label "sort as"@en ;\n rdfs:comment "To specify the string to be used for national-language-specific sorting. Used as a property parameter only."@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:title a owl:DatatypeProperty ;\n rdfs:label "title"@en ;\n rdfs:comment "To specify the position or job of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:tz a owl:DatatypeProperty ;\n rdfs:label "time zone"@en ;\n rdfs:comment "To indicate time zone information that is specific to the object. May also be used as a property parameter."@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:value a owl:DatatypeProperty ;\n rdfs:label "value"@en ;\n rdfs:comment "Used to indicate the literal value of a data property that requires property parameters"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:Address a owl:Class ;\n rdfs:label "Address"@en ;\n rdfs:comment "To specify the components of the delivery address for the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentClass [ a owl:Class ;\n owl:unionOf ( [ a owl:Class ;\n owl:intersectionOf ( [ a owl:Restriction ;\n owl:onProperty :country-name ;\n owl:someValuesFrom xsd:string ] [ a owl:Restriction ;\n owl:maxCardinality "1"^^xsd:nonNegativeInteger ;\n owl:onProperty :country-name ] ) ] [ a owl:Class ;\n owl:intersectionOf ( [ a owl:Restriction ;\n owl:onProperty :locality ;\n owl:someValuesFrom xsd:string ] [ a owl:Restriction ;\n owl:maxCardinality "1"^^xsd:nonNegativeInteger ;\n owl:onProperty :locality ] ) ] [ a owl:Class ;\n owl:intersectionOf ( [ a owl:Restriction ;\n owl:onProperty :postal-code ;\n owl:someValuesFrom xsd:string ] [ a owl:Restriction ;\n owl:maxCardinality "1"^^xsd:nonNegativeInteger ;\n owl:onProperty :postal-code ] ) ] [ a owl:Class ;\n owl:intersectionOf ( [ a owl:Restriction ;\n owl:onProperty :region ;\n owl:someValuesFrom xsd:string ] [ a owl:Restriction ;\n owl:maxCardinality "1"^^xsd:nonNegativeInteger ;\n owl:onProperty :region ] ) ] [ a owl:Class ;\n owl:intersectionOf ( [ a owl:Restriction ;\n owl:onProperty :street-address ;\n owl:someValuesFrom xsd:string ] [ a owl:Restriction ;\n owl:maxCardinality "1"^^xsd:nonNegativeInteger ;\n owl:onProperty :street-address ] ) ] ) ] .\n\n:Email a owl:Class ;\n rdfs:label "Email"@en ;\n rdfs:comment "To specify the electronic mail address for communication with the object the vCard represents. Use the hasEmail object property."@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:deprecated true .\n\n:Group a owl:Class ;\n rdfs:label "Group"@en ;\n rdfs:comment "Object representing a group of persons or entities. A group object will usually contain hasMember properties to specify the members of the group."@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Kind ;\n owl:disjointWith :Individual,\n :Location,\n :Organization ;\n owl:equivalentClass [ a owl:Class ;\n owl:intersectionOf ( [ a owl:Restriction ;\n owl:onProperty :hasMember ;\n owl:someValuesFrom :Kind ] [ a owl:Restriction ;\n owl:minQualifiedCardinality "1"^^xsd:nonNegativeInteger ;\n owl:onClass :Kind ;\n owl:onProperty :hasMember ] ) ] .\n\n:Individual a owl:Class ;\n rdfs:label "Individual"@en ;\n rdfs:comment "An object representing a single person or entity"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Kind ;\n owl:disjointWith :Location,\n :Organization .\n\n:Name a owl:Class ;\n rdfs:label "Name"@en ;\n rdfs:comment "To specify the components of the name of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentClass [ a owl:Class ;\n owl:unionOf ( [ a owl:Class ;\n owl:intersectionOf ( [ a owl:Restriction ;\n owl:onProperty :additional-name ;\n owl:someValuesFrom xsd:string ] [ a owl:Restriction ;\n owl:minCardinality "0"^^xsd:nonNegativeInteger ;\n owl:onProperty :additional-name ] ) ] [ a owl:Class ;\n owl:intersectionOf ( [ a owl:Restriction ;\n owl:onProperty :family-name ;\n owl:someValuesFrom xsd:string ] [ a owl:Restriction ;\n owl:maxCardinality "1"^^xsd:nonNegativeInteger ;\n owl:onProperty :family-name ] ) ] [ a owl:Class ;\n owl:intersectionOf ( [ a owl:Restriction ;\n owl:onProperty :given-name ;\n owl:someValuesFrom xsd:string ] [ a owl:Restriction ;\n owl:maxCardinality "1"^^xsd:nonNegativeInteger ;\n owl:onProperty :given-name ] ) ] [ a owl:Class ;\n owl:intersectionOf ( [ a owl:Restriction ;\n owl:onProperty :honorific-prefix ;\n owl:someValuesFrom xsd:string ] [ a owl:Restriction ;\n owl:minCardinality "0"^^xsd:nonNegativeInteger ;\n owl:onProperty :honorific-prefix ] ) ] [ a owl:Class ;\n owl:intersectionOf ( [ a owl:Restriction ;\n owl:onProperty :honorific-suffix ;\n owl:someValuesFrom xsd:string ] [ a owl:Restriction ;\n owl:minCardinality "0"^^xsd:nonNegativeInteger ;\n owl:onProperty :honorific-suffix ] ) ] ) ] .\n\n:VCard a owl:Class ;\n rdfs:label "VCard"@en ;\n rdfs:comment "The vCard class is equivalent to the new Kind class, which is the parent for the four explicit types of vCards (Individual, Organization, Location, Group)"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentClass :Kind .\n\n:fn a owl:DatatypeProperty ;\n rdfs:label "formatted name"@en ;\n rdfs:comment "The formatted text corresponding to the name of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:hasAddress a owl:ObjectProperty ;\n rdfs:label "has address"@en ;\n rdfs:comment "To specify the components of the delivery address for the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range :Address .\n\n:hasEmail a owl:ObjectProperty ;\n rdfs:label "has email"@en ;\n rdfs:comment "To specify the electronic mail address for communication with the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range :Email .\n\n:hasGeo a owl:ObjectProperty ;\n rdfs:label "has geo"@en ;\n rdfs:comment "To specify information related to the global positioning of the object. May also be used as a property parameter."@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:hasKey a owl:ObjectProperty ;\n rdfs:label "has key"@en ;\n rdfs:comment "To specify a public key or authentication certificate associated with the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :key .\n\n:hasLogo a owl:ObjectProperty ;\n rdfs:label "has logo"@en ;\n rdfs:comment "To specify a graphic image of a logo associated with the object "@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :logo .\n\n:hasName a owl:ObjectProperty ;\n rdfs:label "has name"@en ;\n rdfs:comment "To specify the components of the name of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range :Name ;\n owl:equivalentProperty :n .\n\n:hasPhoto a owl:ObjectProperty ;\n rdfs:label "has photo"@en ;\n rdfs:comment "To specify an image or photograph information that annotates some aspect of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :photo .\n\n:hasSound a owl:ObjectProperty ;\n rdfs:label "has sound"@en ;\n rdfs:comment "To specify a digital sound content information that annotates some aspect of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :sound .\n\n:hasTelephone a owl:ObjectProperty ;\n rdfs:label "has telephone"@en ;\n rdfs:comment "To specify the telephone number for telephony communication with the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :tel .\n\n:hasURL a owl:ObjectProperty ;\n rdfs:label "has url"@en ;\n rdfs:comment "To specify a uniform resource locator associated with the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :url .\n\n:key a owl:ObjectProperty ;\n rdfs:label "key"@en ;\n rdfs:comment "This object property has been mapped"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :hasKey .\n\n:logo a owl:ObjectProperty ;\n rdfs:label "logo"@en ;\n rdfs:comment "This object property has been mapped"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :hasLogo .\n\n:n a owl:ObjectProperty ;\n rdfs:label "name"@en ;\n rdfs:comment "This object property has been mapped"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :hasName .\n\n:nickname a owl:DatatypeProperty ;\n rdfs:label "nickname"@en ;\n rdfs:comment "The nick name associated with the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:photo a owl:ObjectProperty ;\n rdfs:label "photo"@en ;\n rdfs:comment "This object property has been mapped"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :hasPhoto .\n\n:sound a owl:ObjectProperty ;\n rdfs:label "sound"@en ;\n rdfs:comment "This object property has been mapped"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :hasSound .\n\n:tel a owl:ObjectProperty ;\n rdfs:label "telephone"@en ;\n rdfs:comment "This object property has been mapped"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :hasTelephone .\n\n:url a owl:ObjectProperty ;\n rdfs:label "url"@en ;\n rdfs:comment "This object property has been mapped"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentProperty :hasURL .\n\n:Location a owl:Class ;\n rdfs:label "Location"@en ;\n rdfs:comment "An object representing a named geographical place"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Kind ;\n owl:disjointWith :Organization .\n\n:additional-name a owl:DatatypeProperty ;\n rdfs:label "additional name"@en ;\n rdfs:comment "The additional name associated with the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:country-name a owl:DatatypeProperty ;\n rdfs:label "country name"@en ;\n rdfs:comment "The country name associated with the address of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:family-name a owl:DatatypeProperty ;\n rdfs:label "family name"@en ;\n rdfs:comment "The family name associated with the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:given-name a owl:DatatypeProperty ;\n rdfs:label "given name"@en ;\n rdfs:comment "The given name associated with the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:hasMember a owl:ObjectProperty ;\n rdfs:label "has member"@en ;\n rdfs:comment "To include a member in the group this object represents. (This property can only be used by Group individuals)"@en ;\n rdfs:domain :Group ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range :Kind .\n\n:honorific-prefix a owl:DatatypeProperty ;\n rdfs:label "honorific prefix"@en ;\n rdfs:comment "The honorific prefix of the name associated with the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:honorific-suffix a owl:DatatypeProperty ;\n rdfs:label "honorific suffix"@en ;\n rdfs:comment "The honorific suffix of the name associated with the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:locality a owl:DatatypeProperty ;\n rdfs:label "locality"@en ;\n rdfs:comment "The locality (e.g. city or town) associated with the address of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:organization-name a owl:DatatypeProperty ;\n rdfs:label "organization name"@en ;\n rdfs:comment "To specify the organizational name associated with the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:postal-code a owl:DatatypeProperty ;\n rdfs:label "postal code"@en ;\n rdfs:comment "The postal code associated with the address of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:region a owl:DatatypeProperty ;\n rdfs:label "region"@en ;\n rdfs:comment "The region (e.g. state or province) associated with the address of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:street-address a owl:DatatypeProperty ;\n rdfs:label "street address"@en ;\n rdfs:comment "The street address associated with the address of the object"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:range xsd:string .\n\n:Organization a owl:Class ;\n rdfs:label "Organization"@en ;\n rdfs:comment """An object representing an organization. An organization is a single entity, and might represent a business or government, a department or division within a business or government, a club, an association, or the like.\n"""@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n rdfs:subClassOf :Kind .\n\n:Gender a owl:Class ;\n rdfs:label "Gender"@en ;\n rdfs:comment "Used for gender codes. The URI of the gender code must be used as the value for Gender."@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:Kind a owl:Class ;\n rdfs:label "Kind"@en ;\n rdfs:comment "The parent class for all objects"@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> ;\n owl:equivalentClass [ a owl:Restriction ;\n owl:minQualifiedCardinality "1"^^xsd:nonNegativeInteger ;\n owl:onDataRange xsd:string ;\n owl:onProperty :fn ],\n :VCard .\n\n:Type a owl:Class ;\n rdfs:label "Type"@en ;\n rdfs:comment "Used for type codes. The URI of the type code must be used as the value for Type."@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:TelephoneType a owl:Class ;\n rdfs:label "Phone"@en ;\n rdfs:comment "Used for telephone type codes. The URI of the telephone type code must be used as the value for the Telephone Type."@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n:RelatedType a owl:Class ;\n rdfs:label "Relation Type"@en ;\n rdfs:comment "Used for relation type codes. The URI of the relation type code must be used as the value for the Relation Type."@en ;\n rdfs:isDefinedBy <http://www.w3.org/2006/vcard/ns> .\n\n<http://www.w3.org/2006/vcard/ns> a owl:Ontology ;\n rdfs:label "Ontology for vCard"@en ;\n rdfs:comment "Ontology for vCard based on RFC6350"@en ;\n owl:versionInfo "Final"@en .\n\n\n',"vcard.ttl",c);try{await bn.fetcher.load(t.doc())}catch(t){u="Error: Failed to load profile card: "+t,console.log(u),e.appendChild(d.widgets.errorMessageBlock(n,u,"pink"))}var u;e.classList.add("individualPane"),s.authn.checkUser(),e.appendChild(on(n,t));const p=a?"organizationForm":"individualForm";!function(n,e,t,o,r,a,i,s){const c=hn+o,u=s||"this",p=(0,l.Namespace)(c+"#")(u);fn(r,t,o,c),d.widgets.appendForm(a,n,{},e,p,i,(n,e)=>{n||d.widgets.errorMessageBlock(a,e)})}(e,t,cn,Cn,s.store,n,t.doc(),p),e.appendChild(await ln(t,o)),d.widgets.attachmentList(n,t,e,{modify:i}),a?e.appendChild(await async function(n,e){let t=P.sym("http://www.wikidata.org/wiki/Q43229"),o="Organization";for(const e in T)P.holds(n,B.rdf("type"),B.schema(e),n.doc())&&(t=P.sym(T[e]),o=e,console.log(` renderPublicIdControl bingo: ${e} -> ${t}`));return O(n,e,{longPrompt:`If you know the ${F} of this ${o}, you can do more stuff with it.\n To record its ${F}, drag it onto the plus, or click the magnifyinng glass\n to search for it in WikiData.`,idNoun:F,urlType:B.vcard("PublicId"),dbLookup:!0,class:t,queryParams:D})}(t,o)):e.appendChild(await async function(n,e){return O(n,e,{longPrompt:`If you know someone's ${S}, you can do more stuff with them.\n To record their ${S}, drag it onto the plus, or click the plus\n to enter it by hand.`,idNoun:S,urlType:B.vcard("WebID")})}(t,o))}var yn=a(295),vn={};function En(n,e,t,o,r,a){const i=r.dom,c=s.store,u=d.ns,p=u.vcard,A=i.createElement("div"),m=A.appendChild(i.createElement("table"));m.classList.add("toolsTable");const h=m.appendChild(i.createElement("tr"));h.textContent=d.utils.label(o)+" - tools",h.classList.add("toolsHeader");const f=m.appendChild(i.createElement("tr")).appendChild(i.createElement("div"));f.classList.add("toolsStatusBlock");const g=m.appendChild(i.createElement("tr")),b=g.appendChild(i.createElement("table"));m.appendChild(i.createElement("tr"));const C={target:o,me:a,noun:"address book",div:A,dom:i,statusRegion:f};function w(n){console.log(n),f.appendChild(d.widgets.errorMessageBlock(i,n,"pink"))}return async function(){b.appendChild(d.aclControl.ACLControlBox5(o.dir(),r,"book",c,function(n,e){n||(b.innerHTML="ACL control box Failed: "+e)}));try{await d.login.registrationControl(C,o,u.vcard("AddressBook"))}catch(n){d.widgets.complain(C,"registrationControl: "+n)}console.log("Registration control finished.");const a=g.appendChild(i.createElement("pre"));function m(n){console.log(n),a.textContent+=n+"\n"}const h=A.appendChild(i.createElement("button"));h.textContent="Load main index",h.classList.add("toolsButton"),h.addEventListener("click",async function(n){h.classList.add("toolsButton--loading"),h.classList.remove("toolsButton--error","toolsButton--success");const e=c.any(o,u.vcard("nameEmailIndex"));try{await c.fetcher.load(e)}catch(n){h.classList.remove("toolsButton--loading"),h.classList.add("toolsButton--error"),m("Error: People index has NOT been loaded"+n+"\n")}h.classList.remove("toolsButton--loading"),h.classList.add("toolsButton--success"),m(" People index has been loaded\n")});const f=A.appendChild(i.createElement("button"));f.textContent="Statistics",f.classList.add("toolsButton"),f.addEventListener("click",function(){m(c.each(void 0,p("inAddressBook"),o).length+" cards loaded. ");let n=c.each(o,p("includesGroup"));const t=new Set(n.map(n=>n.uri));n=[...t].map(n=>c.sym(n)),m(n.length+" total groups. ");const r=[];for(const n in e)r.push(n);m(r.length+" selected groups. ")});const y=A.appendChild(i.createElement("button"));y.textContent="Check individual card access of selected groups",y.classList.add("toolsButton"),y.addEventListener("click",async function(n){function t(n){d.acl.fixIndividualCardACL(n,m,function(e,t){m(e?"Success for "+d.utils.label(n):"Failure for "+d.utils.label(n)+": "+t)})}const o=[];for(const n in e)o.push(n);for(let n=0;n<o.length;n++){const e=c.sym(o[n]),r=G(c,e);m(d.utils.label(e)+": "+r.length+" members");for(let n=0;n<r.length;n++){const e=r[n];m(d.utils.label(e)),t(e)}}});const v=A.appendChild(i.createElement("button"));async function E(n){const e=c.any(n,u.vcard("groupIndex")),t=c.any(n,u.vcard("nameEmailIndex"));try{await c.fetcher.load([t,e]);const o=c.each(n,u.vcard("includesGroup"));await c.fetcher.load(o)}catch(n){w("Error loading stuff:"+n)}const o={},r=[];let a=c.each(n,p("includesGroup"));const i=new Set(a.map(n=>n.uri));a=[...i].map(n=>c.sym(n)),m(a.length+" total groups. ");for(let n=0;n<a.length;n++){const e=a[n],t=G(c,e);m(d.utils.label(e)+": "+t.length+" members");for(let n=0;n<t.length;n++)c.allAliases(t[n]).forEach(function(n){o[n.uri]=e})}const s=c.each(void 0,p("inAddressBook"),n);m(s.length+" total cards");for(let n=0;n<s.length;n++)o[s[n].uri]||(r.push(s[n]),m(" groupless "+d.utils.label(s[n])));return m(r.length+" groupless cards."),r}v.textContent="Find duplicate cards",v.classList.add("toolsButton"),v.addEventListener("click",function(n){const e={};e.book=o,e.nameEmailIndex=c.any(o,u.vcard("nameEmailIndex")),m("Loading name index..."),s.store.fetcher.nowOrWhenFetched(e.nameEmailIndex,void 0,function(n,t){function r(n){let t;return Promise.resolve().then(()=>{const o=n.uri.replace("/Group/","/NewGroup/");t=c.sym(o);let r=[];for(let t=0;t<e.uniques.length;t++)r=r.concat(c.connectedStatements(e.uniques[t],n.doc()));const a=new l.Serializer(c).setBase(n.uri);m(" Regenerating group of uniques..."+t);const i=a.statementsToN3(r);return c.fetcher.webOperation("PUT",t,{data:i,contentType:"text/turtle"})}).then(()=>(m(" Done uniques group "+t),!0)).catch(n=>{m("Error saving : "+n)})}m("Loaded name index."),e.cards=[],e.duplicates=[],e.definitive=[],e.nameless=[],e.exactDuplicates=[],e.nameOnlyDuplicates=[],e.uniquesSet=[],e.groupProblems=[],e.nameDupLog=c.sym(o.dir().uri+"dedup-nameDupLog.ttl"),e.exactDupLog=c.sym(o.dir().uri+"dedup-exactDupLog.ttl"),e.nameOnlyErrors=[],e.nameLessZeroData=[],e.nameLessIndex=[],e.namelessUniques=[],e.nameOnlyDuplicatesGroupDiff=[];const a=function(){let n=[];return e.book&&([e.book].forEach(function(e){const t=(e?c.each(e,u.vcard("includesGroup")):[]).map(function(n){return[e,c.any(n,u.vcard("fn")),n]});n=n.concat(t)}),n.sort()),n}();e.groupObjects=a.map(n=>n[2]),m("Loading "+e.groupObjects.length+" groups... "),c.fetcher.load(e.groupObjects).then(function(){return new Promise(function(n){let t,o,r;for(e.cards=c.each(void 0,p("inAddressBook"),e.book),m(e.cards.length+" total cards"),t=0;t<e.cards.length;t++)o=e.cards[t],r=c.anyValue(o,u.vcard("fn")),r?e.definitive[r]===o||(e.definitive[r]?(e.duplicates.length,e.duplicates.push(o)):e.definitive[r]=o):e.nameless.push(o);e.duplicateSet=[];for(let n=0;n<e.duplicates.length;n++)e.duplicateSet[e.duplicates[n].uri]=e.duplicates[n];e.namelessSet=[];for(let n=0;n<e.nameless.length;n++)e.namelessSet[e.nameless[n].uri]=e.nameless[n];e.uniques=[],e.uniqueSet=[];for(let n=0;n<e.cards.length;n++){const t=e.cards[n].uri;e.duplicateSet[t]||e.namelessSet[t]||(e.uniques.push(e.cards[n]),e.uniqueSet[t]=e.cards[n])}m("Uniques: "+e.uniques.length),m(e.nameless.length+" nameless cards."),m(e.duplicates.length+" name-duplicate cards, leaving "+(e.cards.length-e.duplicates.length)),n(!0)})}).then(function(){return new Promise(function(n){m("Groups loaded");for(let n=0;n<e.uniques.length;n++)e.uniquesSet[e.uniques[n].uri]=!0;e.groupMembers=[],c.each(null,u.vcard("hasMember")).forEach(n=>{e.groupMembers=e.groupMembers.concat(G(c,n))}),m(" Naive group members "+e.groupMembers.length),e.groupMemberSet=[];for(let n=0;n<e.groupMembers.length;n++)e.groupMemberSet[e.groupMembers[n].uri]=e.groupMembers[n];e.groupMembers2=[];for(const n in e.groupMemberSet)e.groupMembers2.push(e.groupMemberSet[n]);if(m(" Compact group members "+e.groupMembers2.length),l.keepThisCodeForLaterButDisableFerossConstantConditionPolice){for(let n=0;n<e.groupMembers.length;n++){const t=e.groupMembers[n];e.uniquesSet[t.uri]||(m(" Not in uniques: "+t),e.groupProblems.push(t),e.duplicateSet[t.uri]?m(" ** IN duplicates alas:"+t):m(" **** WTF?"))}m("Problem cards: "+e.groupProblems.length)}n(!0)})}).then(function n(){return e.namelessToCheck=e.namelessToCheck||e.nameless.slice(),m("Nameless check left: "+e.namelessToCheck.length),new Promise(function(t){const o=e.namelessToCheck.shift();if(!o){if(m("namelessUniques: "+e.namelessUniques.length),m("namelessUniques: "+e.namelessUniques),e.namelessUniques.length>0&&confirm("Add all "+e.namelessUniques.length+" nameless cards to the rescued set?")){e.uniques=e.uniques.concat(e.namelessUniques);for(let n=0;n<e.namelessUniques.length;n++)e.uniqueSet[e.namelessUniques[n].uri]=!0}return t(!0)}var r;(r=o,new Promise(function(n){c.fetcher.load(r).then(function(t){m(" Nameless check "+r);const o={};o[u.vcard("hasUID").uri]=!0,o[u.dc("created").uri]=!0,o[u.dc("modified").uri]=!0;const a=(i=r,c.statementsMatching(null,null,null,i.doc()).filter(function(n){return!o[n.predicate.uri]}));var i;if(!a.length)return m(" Zero length "+r),e.nameLessZeroData.push(r),n(!1);const s=new l.Serializer(c).setBase(r.doc().uri).statementsToN3(a),d=e.nameLessIndex[s];if(d){m(" Matches with "+d);const t=c.each(null,u.vcard("hasMember"),r),o=c.each(null,u.vcard("hasMember"),d);for(let a=0;a<t.length;a++){let i=!1;for(let n=0;n<o.length;n++)o[n].sameTerm(t[a])&&(i=!0);if(!i)return m("This one groups: "+t),m("Other one groups: "+o),m("Cant skip this one because it has a group, "+t[a]+", which the other does not."),e.nameOnlyDuplicatesGroupDiff.push(r),n(!1)}console.log("Group check done -- exact duplicate: "+r)}else m("First nameless like: "+r.doc()),m("___________________________________________"),m(s),m("___________________________________________"),e.nameLessIndex[s]=r,e.namelessUniques.push(r);n(!0)}).catch(function(t){m("Cant load a nameless card!: "+t),e.nameOnlyErrors.push(r),n(!1)})})).then(function(e){m(" Nameless check returns "+e),n()})})}).then(()=>new Promise(function(n,e){confirm("Write new clean versions?")?n(!0):e(new Error("User cancelled writing clean versions"))})).then(function(){let n;return Promise.resolve().then(()=>{n=c.sym(e.book.dir().uri+"clean-people.ttl");let t=[];for(let n=0;n<e.uniques.length;n++)t=t.concat(c.connectedStatements(e.uniques[n],e.nameEmailIndex));const o=new l.Serializer(c).setBase(e.nameEmailIndex.uri);m("Serializing index of uniques...");const r=o.statementsToN3(t);return c.fetcher.webOperation("PUT",n,{data:r,contentType:"text/turtle"})}).then(function(){return m("Done uniques log "+n),!0}).catch(function(n){m("Error saving uniques: "+n)})}).then(function(){return m("Saving ALL GROUPS"),Promise.all(e.groupObjects.map(r))}).then(function(){m("Done!")})})});const B=A.appendChild(i.createElement("button"));B.classList.add("toolsButton"),B.textContent="Find individuals with no group",B.addEventListener("click",function(r){m("Loading groups..."),n(e,t,async function(n,e){if(!n)return void m("Load all groups: failed: "+e);const t=c.any(o,u.vcard("nameEmailIndex"));try{await c.fetcher.load(t)}catch(n){w(n)}m("Loaded groups and name index."),E(o),m("Groupless list finished..")})});const x=A.appendChild(i.createElement("button"));x.classList.add("toolsButton"),x.textContent="Put all individuals with no group in a new group",x.addEventListener("click",n=>async function(n){const e=await E(n);if(0===e.length)return void m("No groupless cards found.");const t=await j(n,"ZSortThese");if(confirm(`Add the ${e.length} cards without groups to a ZSortThese group?`))for(const n of e)m(" adding "+n),await q(n,t);m("People moved to group.")}(o));const k=A.appendChild(i.createElement("button"));k.classList.add("toolsButton"),k.textContent="Revert groups to old data model",k.addEventListener("click",n=>async function(n){let e=c.each(n,p("includesGroup"));const t=new Set(e.map(n=>n.uri));e=[...t].map(n=>c.sym(n)),async function(n){let e=[],t=[];n.forEach(n=>{let o=c.statementsMatching(null,u.owl("sameAs"),null,n.doc()).map(n=>n.subject);const r=new Set(o.map(n=>n.uri));o=[...r].map(n=>c.sym(n)),o.forEach(o=>{c.each(o,u.vcard("fn"),null,n.doc()).length||(e=e.concat(c.statementsMatching(o,u.owl("sameAs"),null,n.doc()).concat(c.statementsMatching(void 0,void 0,o,n.doc()))),c.each(o,u.owl("sameAs"),null,n.doc()).forEach(e=>{t=t.concat(l.st(e,u.owl("sameAs"),o,n.doc())).concat(l.st(n,u.vcard("hasMember"),e,n.doc()))}))})}),e.length&&confirm("Groups can be updated to old data model ?")?(await c.updater.updateMany(e,t),alert("Update done")):e.length||alert("Nothing to update.\nAll Groups already use the old data model.")}(e)}(o))}(),A}vn.styleTagTransform=y(),vn.setAttributes=g(),vn.insert=h().bind(null,"head"),vn.domAPI=A(),vn.insertStyleElement=C(),u()(yn.A,vn),yn.A&&yn.A.locals&&yn.A.locals;var Bn=a(903),xn={};xn.styleTagTransform=y(),xn.setAttributes=g(),xn.insert=h().bind(null,"head"),xn.domAPI=A(),xn.insertStyleElement=C(),u()(Bn.A,xn),Bn.A&&Bn.A.locals&&Bn.A.locals;const kn=d.ns,Pn=d.utils,Tn={icon:d.icons.iconBase+"noun_99101.svg",name:"contact",label:function(n,e){const t=e.session.store.findTypeURIs(n);return t[kn.vcard("Individual").uri]||t[kn.vcard("Organization").uri]?"Contact":t[kn.foaf("Person").uri]||t[kn.schema("Person").uri]?"Person":t[kn.vcard("Group").uri]?"Group":t[kn.vcard("AddressBook").uri]?"Address book":null},mintClass:d.ns.vcard("AddressBook"),mintNew:function(n,e){return new Promise(function(t,o){d.login.ensureLoadedProfile(e).then(e=>{console.log("Logged in as "+e.me);const r=e.me,a=e.dom,i=e.div,s=n.session.store,c=d.ns,u=e.newBase||e.newInstance.dir().uri;if((e.instanceClass||c.vcard("AddressBook")).sameTerm(c.vcard("Group"))){const n=e.newInstance||s.sym(e.newBase+"index.ttl#this"),r=n.doc();return s.add(n,c.rdf("type"),c.vcard("Group"),r),s.add(n,c.vcard("fn"),e.instanceName||"untitled group",r),void s.fetcher.putBack(r,{contentType:"text/turtle"}).then(function(n){t(e)}).catch(function(n){o(new Error("Error creating document for new group "+n))})}function p(n){i.appendChild(d.widgets.errorMessageBlock(a,n,"pink"))}let A='@prefix vcard: <http://www.w3.org/2006/vcard/ns#>.\n @prefix ab: <http://www.w3.org/ns/pim/ab#>.\n @prefix dc: <http://purl.org/dc/elements/1.1/>.\n @prefix xsd: <http://www.w3.org/2001/XMLSchema#>.\n\n <#this> a vcard:AddressBook;\n dc:title "New address Book";\n vcard:nameEmailIndex <people.ttl>;\n vcard:groupIndex <groups.ttl>.\n';A+="<#this> <http://www.w3.org/ns/auth/acl#owner> <"+r.uri+">.\n\n";const m=s.sym(u+"index.ttl#this"),h=[{to:"index.ttl",content:A,contentType:"text/turtle"},{to:"groups.ttl",content:"",contentType:"text/turtle"},{to:"people.ttl",content:"",contentType:"text/turtle"},{to:"",existing:!0,aclOptions:{defaultForNew:!0}}];!function n(){function d(e,t){if(!t)return p("Error writing new file "+c.to),o(new Error("Error writing new file "+c.to));V(A,r,f).then(()=>n()).catch(n=>{const e="Error setting access permissions for "+c.to+" : "+n.message;return p(e),o(new Error(e))})}if(0===h.length)!function(n,o){console.log(`New ${o} created at ${n}`);const r=i.appendChild(a.createElement("p"));r.classList.add("claimSuccess"),r.innerHTML="Your <a href='"+n.uri+"'><b>new "+o+"</b></a> is ready. <br/><br/><a href='"+n.uri+"'>Go to new "+o+"</a>";const s=Object.assign({newInstance:n},e);t(s)}(m,"address book");else{var c=h.shift();console.log("Creating new file "+c.to+" in new instance ");var A=l.uri.join(c.to,u),f=c.aclOptions||{};"content"in c?s.fetcher.webOperation("PUT",A,{data:c.content,saveMetadata:!0,contentType:c.contentType}).then(()=>d(0,!0)):"existing"in c?d(0,!0):o(new Error("copy not expected buiding new app!!"))}}()},n=>{e.div.appendChild(d.widgets.errorMessageBlock(n))})})},render:function(n,e,t={}){const o=this;function r(n){p.appendChild(d.widgets.errorMessageBlock(c,n,"pink"))}function a(n,e){n||r("Error: "+e)}function i(n){return d.login.newAppInstance(c,{noun:"address book",appPathSegment:"contactorator.timbl.com"},function(e,t){o.mintNew(n,t,{me:A,div:p,dom:c})})}const c=e.dom,u=e.session.store,p=c.createElement("div"),A=s.authn.currentUser();return d.aclControl.preventBrowserDropEvents(c),p.setAttribute("class","contactPane"),async function(){d.aclControl.preventBrowserDropEvents(c);const o=u.findTypeURIs(n);let A=s.authn.currentUser();const m={target:n,me:A,noun:"address book",div:p,dom:c};function h(n,o,m){u.fetcher.load(n).then(function(o){!function(n,o,m){const h=Pn.label(kn.vcard("AddressBook"));let f=n[0];const g=u.any(f,kn.vcard("groupIndex"));let b={},C={};const w=m.foreignGroup||f;let y=u.any(w,kn.dc("title"))||u.any(w,kn.vcard("fn"));function v(n){if(n)return n;let e;for(const n in b){e=u.sym(n);const t=u.any(void 0,kn.vcard("includesGroup"),e);if(t)return t}throw new Error("findBookFromGroups: Cant find address book which this group is part of")}function E(n){const e=u.any(n,kn.vcard("fn"))||u.any(n,kn.foaf("name"))||u.any(n,kn.vcard("organization-name"));return e?e.value:"???"}function B(n){const e=vn.value.trim().toLowerCase();if(0===e.length)return!0;const t=e.split(" ");for(let e=0;e<t.length;e++){const o=t[e];if(n.toLowerCase().indexOf(o)<0)return!1}return!0}function x(n){gn.innerHTML="loading...",C={},C[n.uri]=!0,k();const e=f?N(n):n;u.fetcher.nowOrWhenFetched(e.doc(),void 0,function(t,o){if(gn.innerHTML="",!t)return a(t,"Can't load card: "+e+": "+o);gn.appendChild(S(c,e,"contact")),gn.appendChild(c.createElement("br")),gn.appendChild(d.widgets.linkIcon(c,e));const r=d.widgets.deleteButtonWithCheck(c,gn,"contact",async function(){const e=n.dir(),t=u.any(n,kn.vcard("fn"));if(confirm("Delete contact "+t+" completely?? "+e)){console.log("Deleting a contact "+t),await T();const o=u.any(f,kn.vcard("nameEmailIndex"));await u.fetcher.load(o);const r=dn(n);let a=[];r.forEach(e=>{Dn(u,n,e.doc()).forEach(n=>{1===Dn(u,n,e.doc()).length&&(a=a.concat(u.statementsMatching(e,kn.vcard("hasMember"),n,e.doc())))})}),await u.updater.updateMany(a),await L(n),await I(u,e),_(),gn.innerHTML="Contact Data Deleted."}});r.classList.add("deleteButton")})}function k(n){let e=0,t=null;for(let n=0;n<fn.children.length;n++){const o=fn.children[n],r=B(E(o.subject));r&&(e++,t=o),o.classList.toggle("selected",r&&!!C[o.subject.uri]),o.classList.toggle("hidden",!r)}1===e&&n&&x(t.subject)}function P(n,e,t){function o(e,o){o.classList.add("group-loading"),u.fetcher.nowOrWhenFetched(e.doc(),void 0,function(s,d){if(!s){const n="Can't load group file: "+e+": "+d;return i.push(n),a(s,n)}o.classList.remove("group-loading"),o.classList.add("selected"),n[e.uri]=!0,R(),_(),r-=1,r||t&&t(0===i.length,i)})}let r=e.children.length;var i=[];for(let n=0;n<e.children.length;n++){const t=e.children[n];o(t.subject,t)}}async function T(){await u.fetcher.load(g);const n=f?u.each(f,kn.vcard("includesGroup"),null,g):[];return await u.fetcher.load(n),n}function D(){let e=[];return m.foreignGroup&&e.push(["",u.any(m.foreignGroup,kn.vcard("fn")),m.foreignGroup]),f&&(n.forEach(function(n){const t=(n?u.each(n,kn.vcard("includesGroup"),null,g):[]).map(function(e){return[n,u.any(e,kn.vcard("fn")),e]});e=e.concat(t)}),e.sort()),e.map(n=>n[2])}function S(n,t,o){const r=e.session.paneRegistry.byName(o).render(t,e);return r.classList.add("renderPane"),r}function F(n,e){let t=E(n),o=E(e);if(t&&o){if(t=t.toLowerCase(),o=o.toLowerCase(),t>o)return 1;if(t<o)return-1}return n.uri>e.uri?1:n.uri<e.uri?-1:0}async function L(n){console.log("deleteThingAndDoc: "+n);const e=u.statementsMatching(n).concat(u.statementsMatching(void 0,void 0,n));try{await u.updater.updateMany(e),console.log("Deleting resoure "+n.doc()),await u.fetcher.delete(n.doc()),console.log("Delete thing "+n+": complete.")}catch(e){r("Error deleting thing "+n+": "+e)}}function I(n,e){return new Promise(function(t){n.fetcher.load(e).then(function(){const o=n.each(e,kn.ldp("contains")).map(e=>{if(n.holds(e,kn.rdf("type"),kn.ldp("BasicContainer")))return I(n,e);if(console.log("deleteRecirsive file: "+e),!confirm(" Really DELETE File "+e))throw new Error("User aborted delete file");return n.fetcher.webOperation("DELETE",e.uri)});if(console.log("deleteRecirsive folder: "+e),!confirm(" Really DELETE folder "+e))throw new Error("User aborted delete file");o.push(n.fetcher.webOperation("DELETE",e.uri)),Promise.all(o).then(n=>{t()})})})}function N(n,e){const t=u.allAliases(n),o=f.dir().uri;for(let n=0;n<t.length;n++)if(t[n].uri.slice(0,o.length)===o)return t[n];throw new Error("No local URI for "+n)}function _(){function n(n,e){n.addEventListener("click",function(n){n.preventDefault(),x(e)})}let e=[];Object.keys(b).map(n=>u.sym(n)).forEach(n=>{b[n.value]&&(e=e.concat(G(u,n)))}),e.sort(F);for(let n=0;n<e.length-1;)e[n].uri===e[n+1].uri?e.splice(n,1):n++;function t(e){const t=c.createElement("tr");t.setAttribute("role","listitem"),t.setAttribute("tabindex","0"),t.setAttribute("aria-label",E(e)),t.classList.add("personRow"),t.subject=e;const o=t.appendChild(c.createElement("td"));o.classList.add("dataCell");const r=c.createElement("span");return r.classList.add("visually-hidden"),r.textContent="Contact: ",o.appendChild(r),o.appendChild(c.createTextNode(E(e))),d.widgets.makeDraggable(t,e),t.addEventListener("keydown",function(n){"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),x(e))}),n(t,e),t}un.textContent="Contact name",Pn.syncTableToArrayReOrdered(fn,e,t),k()}function O(n,e){for(let t=0;t<n.children.length;t++){const o=n.children[t];o.subject&&o.classList.toggle("selected",!!e[o.subject.uri])}}function R(){return O(mn,b)}function H(){function n(n){async function t(e){e.forEach(function(e){console.log("Dropped on group: "+e);const t=u.sym(e);try{q(t,n)}catch(n){r(n)}_()})}function o(t){t.preventDefault();const o=u.sym(n.uri.split("#")[0]);t.metaKey||(b={}),b[n.uri]=!b[n.uri],R(),fn.innerHTML="",u.fetcher.nowOrWhenFetched(o.uri,void 0,function(r,i){if(!r)return a(r,"Can't load group file: "+o+": "+i);if(_(),!t.metaKey){gn.innerHTML="";let t=!1;const o=d.aclControl.ACLControlBox5(n,e,"group",u,function(n,e,t){n||(t&&t.status&&403===t.status?gn.innerHTML="No control access.":gn.innerHTML="Failed to load access control: "+e)}),r=gn.appendChild(c.createElement("button"));r.classList.add("sharingButton"),r.setAttribute("aria-label","Toggle group sharing settings");const a=r.appendChild(c.createElement("img"));a.classList.add("sharingButtonIcon"),a.setAttribute("src",d.icons.iconBase+"noun_123691.svg"),a.setAttribute("alt","Sharing icon"),r.addEventListener("click",function(){t=!t,t?gn.appendChild(o):gn.removeChild(o)})}})}const i=u.any(n,kn.vcard("fn")),s=c.createElement("tr");s.setAttribute("role","listitem"),s.setAttribute("tabindex","0"),s.setAttribute("aria-label",i?i.value:"Group"),s.subject=n,d.widgets.makeDraggable(s,n),s.classList.add("dataCell");const l=c.createElement("span");return l.classList.add("visually-hidden"),l.textContent="Group: ",s.appendChild(l),s.appendChild(c.createTextNode(i)),s.addEventListener("keydown",function(n){"Enter"!==n.key&&" "!==n.key||(n.preventDefault(),o(n))}),d.widgets.makeDropTarget(s,t),d.widgets.deleteButtonWithCheck(c,s,"group "+i,async function(){await L(n),H()}),s.addEventListener("click",o,!0),s}const t=D();Pn.syncTableToArrayReOrdered(mn,t,n),R()}async function V(){const n=await T(),{del:e,ins:t}=await W(n);e.length&&confirm(`Groups data model need to be updated? (${e.length})`)&&(await u.updater.updateMany(e,t),alert("Update done"))}async function Y(n){gn.innerHTML="";const t=u.any(f,kn.vcard("groupIndex"));try{await u.fetcher.load(t)}catch(n){console.log("Error: Group index NOT loaded:"+n+"\n")}console.log(" Group index has been loaded\n");const o=await d.widgets.askName(c,u,gn,d.ns.foaf("name"),kn.vcard("Group"),"group");if(!o)return;let r;try{r=await j(f,o)}catch(n){return console.log("Error: can't save new group:"+n),void(gn.innerHTML="Failed to save group"+n)}b={},b[r.uri]=!0,H(),gn.innerHTML="",gn.appendChild(d.aclControl.ACLControlBox5(r.doc(),e,"group",u,function(n,e){n||(gn.innerHTML="Group sharing setup failed: "+e)}))}async function Z(n){gn.innerHTML="";const e=v(f);try{await u.fetcher.load(e)}catch(n){throw new Error("Book won't load:"+e)}const t=u.any(e,kn.vcard("nameEmailIndex"));if(!t)throw new Error("Wot no nameEmailIndex?");await u.fetcher.load(t);const o=await d.widgets.askName(c,u,gn,d.ns.foaf("name"),n);if(!o)return;let r;gn.innerHTML="indexing...",f=v(f);try{r=await async function(n,e,t,o){await z.fetcher.load(n.doc());const r=z.any(n,U.vcard("nameEmailIndex")),a=M.genUuid(),i=z.sym(n.dir().uri+"Person/"+a+"/index.ttl#this"),s=i.doc(),d=[l.st(i,U.vcard("inAddressBook"),n,r),l.st(i,U.vcard("fn"),e,r),l.st(i,U.vcard("fn"),e,s),l.st(i,U.rdf("type"),o,s),l.st(s,U.dct("created"),new Date,s)];for(const n in t){const t=z.sym(n),o=t.doc();d.push(l.st(t,U.vcard("hasMember"),i,o),l.st(i,U.vcard("fn"),e,o))}try{await $.updateMany([],d)}catch(n){throw console.error("Error: can't update "+i+" as new contact:"+n),new Error("Updating new contact: "+n)}return i}(f,o,b,n)}catch(n){const e="Error: can't save new contact: "+n;console.log(e),alert(e)}C={},C[r.uri]=!0,_(),gn.innerHTML="",gn.appendChild(S(c,r,"contact"))}t.solo&&y&&"undefined"!=typeof document&&(document.title=y.value),y=y?y.value:h;const Q=c.createElement("main");Q.id="main-content",Q.classList.add("addressBook-grid"),Q.setAttribute("role","main"),Q.setAttribute("aria-label","Address Book"),Q.setAttribute("tabindex","-1"),p.appendChild(Q);const K=c.createElement("section");K.setAttribute("aria-labelledby","addressBook-section"),K.classList.add("addressBookSection","section-bg"),K.setAttribute("role","region"),K.setAttribute("tabindex","-1"),Q.appendChild(K);const X=c.createElement("header");X.classList.add("text-center","mb-md");const J=c.createElement("h2");J.id="addressBook-heading",J.setAttribute("tabindex","-1"),J.textContent=y,X.appendChild(J),K.appendChild(X);const nn=c.createElement("table");nn.classList.add("bookTable"),nn.setAttribute("role","table"),nn.setAttribute("aria-label","Contacts browser"),K.appendChild(nn);const en=c.createElement("caption");en.textContent="Contacts three-column browser",en.classList.add("visually-hidden"),nn.appendChild(en);const tn=c.createElement("thead"),on=c.createElement("tr");tn.appendChild(on),nn.appendChild(tn);const rn=c.createElement("tbody"),an=c.createElement("tr");rn.appendChild(an),nn.appendChild(rn);const sn=c.createElement("tfoot"),ln=c.createElement("tr");sn.appendChild(ln),nn.appendChild(sn);const cn=c.createElement("th");cn.setAttribute("scope","col"),cn.setAttribute("id","groupsHeader"),cn.textContent="Groups",cn.classList.add("groupsHeader"),on.appendChild(cn);const un=c.createElement("th");un.setAttribute("scope","col"),un.setAttribute("id","peopleHeader"),un.textContent="Name",un.classList.add("peopleHeader"),on.appendChild(un);const pn=c.createElement("th");pn.setAttribute("scope","col"),pn.setAttribute("id","cardHeader"),pn.textContent="Search for name",pn.classList.add("cardHeader"),on.appendChild(pn);const An=c.createElement("td");An.classList.add("groupsMain"),An.setAttribute("role","region"),An.setAttribute("aria-labelledby","groupsHeader");const mn=c.createElement("table");mn.setAttribute("role","list"),mn.setAttribute("aria-label","Groups list"),An.appendChild(mn),an.appendChild(An);const hn=c.createElement("td");hn.classList.add("peopleMain"),hn.setAttribute("role","region"),hn.setAttribute("aria-labelledby","peopleHeader");const fn=c.createElement("table");fn.setAttribute("role","list"),fn.setAttribute("aria-label","People list"),hn.appendChild(fn),an.appendChild(hn);const gn=c.createElement("td");gn.classList.add("cardMain"),gn.setAttribute("role","region"),gn.setAttribute("aria-labelledby","cardHeader"),an.appendChild(gn);const bn=c.createElement("td");bn.classList.add("groupsFooter"),ln.appendChild(bn);const Cn=c.createElement("td");ln.appendChild(Cn);const wn=c.createElement("td");ln.appendChild(wn);const yn=c.createElement("div");yn.classList.add("searchDiv"),pn.appendChild(yn);const vn=c.createElement("input");function Bn(n){cn.classList.toggle("hidden",!n),An.classList.toggle("hidden",!n),bn.classList.toggle("hidden",!n)}if(vn.setAttribute("type","text"),vn.setAttribute("aria-label","Search contacts"),vn.classList.add("searchInput"),yn.appendChild(vn),vn.addEventListener("input",function(n){k(!0)}),fn.addEventListener("keydown",function(n){const e=Array.from(fn.children),t=document.activeElement,o=e.indexOf(t);"ArrowDown"===n.key&&o<e.length-1?(e[o+1].focus(),n.preventDefault()):"ArrowUp"===n.key&&o>0&&(e[o-1].focus(),n.preventDefault())}),Bn(!0),m.foreignGroup&&(b[m.foreignGroup.uri]=!0),f){const n=cn.appendChild(c.createElement("button"));n.textContent="All",n.classList.add("allGroupsButton","actionButton","btn-secondary","action-button-focus"),n.addEventListener("click",function(e){n.state=n.state?0:1,fn.innerHTML="",n.state?(n.classList.add("allGroupsButton--loading"),P(b,mn,function(e,t){if(!e)return r(t);n.classList.remove("allGroupsButton--loading"),n.classList.add("allGroupsButton--active"),R()})):(n.classList.remove("allGroupsButton--loading","allGroupsButton--active"),n.classList.add("allGroupsButton--loaded"),b={},R())}),u.fetcher.nowOrWhenFetched(g.uri,f,function(n,e){if(!n)return console.log("Cannot load group index: "+e);H(),_()})}else H(),_(),console.log("No book, only one group -> hide list of groups"),Bn(!1);un.textContent="Contact name",un.classList.add("peopleHeader"),hn.classList.add("peopleMain");const xn=c.createElement("button"),Tn=c.createElement("div");xn.setAttribute("type","button"),A||xn.setAttribute("disabled","true"),s.authn.checkUser().then(n=>{n&&(A=n,xn.removeAttribute("disabled"))}),Tn.appendChild(xn),xn.innerHTML="New contact",xn.classList.add("actionButton","btn-secondary","action-button-focus"),Cn.appendChild(Tn),xn.addEventListener("click",async n=>Z(kn.vcard("Individual")),!1);const Sn=c.createElement("button"),Fn=c.createElement("div");if(Sn.setAttribute("type","button"),A||Sn.setAttribute("disabled","true"),s.authn.checkUser().then(n=>{n&&(A=n,Sn.removeAttribute("disabled"))}),Fn.appendChild(Sn),Sn.innerHTML="New organization",Sn.classList.add("actionButton","btn-secondary","action-button-focus"),Cn.appendChild(Fn),Sn.addEventListener("click",async n=>Z(kn.vcard("Organization")),!1),f){const n=bn.appendChild(c.createElement("button"));n.setAttribute("type","button"),n.innerHTML="New group",n.classList.add("actionButton","btn-secondary","action-button-focus"),n.addEventListener("click",Y,!1);const t=wn.appendChild(c.createElement("button"));t.setAttribute("type","button"),t.innerHTML="Tools",t.classList.add("actionButton","btn-secondary","action-button-focus"),t.addEventListener("click",function(n){gn.innerHTML="",gn.appendChild(En(P,b,mn,f,e,A))})}const Ln=i(f);Ln&&Ln.classList&&Ln.classList.add("actionButton","btn-secondary","action-button-focus"),wn.appendChild(Ln),p.appendChild(c.createElement("hr")),V().then(()=>{console.log("async checkDataModel done.")})}(n,0,m)}).catch(function(n){r(n)})}return o[kn.vcard("Individual").uri]||o[kn.foaf("Person").uri]||o[kn.schema("Person").uri]||o[kn.vcard("Organization").uri]||o[kn.schema("Organization").uri]?wn(c,p,n,e).then(()=>console.log("(individual rendered)")):o[kn.vcard("Group").uri]?d.login.findAppInstances(m,kn.vcard("AddressBook")).then(function(e){const t=e.instances,o={foreignGroup:n};t.length>0?h(t,0,o):h([],0,o)}).catch(function(n){d.widgets.complain(m,n)}):o[kn.vcard("AddressBook").uri]?h([n],0,{}):console.log("Error: Contact pane: No evidence that "+n+" is anything to do with contacts."),"undefined"!=typeof document&&document.location&&"http://localhost"===(""+document.location).slice(0,16)&&(A=u.any(n,d.ns.acl("owner")),console.log("Assuming user is "+A)),p}().then(()=>console.log("contactsPane Rendered "+n),n=>r(""+n)),p}};function Dn(n,e,t){return n.each(e,kn.owl("sameAs"),null,t).concat(n.each(null,kn.owl("sameAs"),e,t))}return i=i.default})(),n.exports=o(t(5663),t(9426),t(5491))},1267(n,e,t){"use strict";t.d(e,{A:()=>s});var o=t(1354),r=t.n(o),a=t(6314),i=t.n(a)()(r());i.push([n.id,"/* CVCard.css */\n/* Note: Uses utilities: .section-title for cvOrg styling */\n\n.cvSection {\n margin-bottom: 1.25em;\n}\n\n.cvRole {\n margin: var(--spacing-xs) 0;\n font-size: var(--font-size-base);\n line-height: var(--line-height-base);\n display: flex;\n flex-direction: column;\n gap: 0.2em;\n}\n\n.cvOrg {\n font-weight: 600;\n color: var(--color-primary);\n}\n\n.cvSkill, .cvLanguage {\n text-align: left;\n margin: var(--spacing-xs) 0;\n font-size: var(--font-size-base);\n line-height: var(--line-height-base);\n}\n\n.cvSection h3 {\n color: var(--color-text);\n font-size: var(--font-size-lg);\n font-weight: 600;\n line-height: var(--line-height-tight);\n margin-bottom: var(--spacing-xs);\n border-bottom: 1px solid var(--color-border-pale);\n padding-bottom: var(--spacing-xs);\n}\n","",{version:3,sources:["webpack://./src/styles/CVCard.css"],names:[],mappings:"AAAA,eAAe;AACf,2DAA2D;;AAE3D;EACE,qBAAqB;AACvB;;AAEA;EACE,2BAA2B;EAC3B,gCAAgC;EAChC,oCAAoC;EACpC,aAAa;EACb,sBAAsB;EACtB,UAAU;AACZ;;AAEA;EACE,gBAAgB;EAChB,2BAA2B;AAC7B;;AAEA;EACE,gBAAgB;EAChB,2BAA2B;EAC3B,gCAAgC;EAChC,oCAAoC;AACtC;;AAEA;EACE,wBAAwB;EACxB,8BAA8B;EAC9B,gBAAgB;EAChB,qCAAqC;EACrC,gCAAgC;EAChC,iDAAiD;EACjD,iCAAiC;AACnC",sourcesContent:["/* CVCard.css */\n/* Note: Uses utilities: .section-title for cvOrg styling */\n\n.cvSection {\n margin-bottom: 1.25em;\n}\n\n.cvRole {\n margin: var(--spacing-xs) 0;\n font-size: var(--font-size-base);\n line-height: var(--line-height-base);\n display: flex;\n flex-direction: column;\n gap: 0.2em;\n}\n\n.cvOrg {\n font-weight: 600;\n color: var(--color-primary);\n}\n\n.cvSkill, .cvLanguage {\n text-align: left;\n margin: var(--spacing-xs) 0;\n font-size: var(--font-size-base);\n line-height: var(--line-height-base);\n}\n\n.cvSection h3 {\n color: var(--color-text);\n font-size: var(--font-size-lg);\n font-weight: 600;\n line-height: var(--line-height-tight);\n margin-bottom: var(--spacing-xs);\n border-bottom: 1px solid var(--color-border-pale);\n padding-bottom: var(--spacing-xs);\n}\n"],sourceRoot:""}]);const s=i},3750(n,e,t){"use strict";t.d(e,{A:()=>s});var o=t(1354),r=t.n(o),a=t(6314),i=t.n(a)()(r());i.push([n.id,"/* ChatWithMe.css */\n/* Uses utilities: .section-centered, .loading-text, .btn-primary, .btn-transparent */\n\n.chatSection {\n overflow-x: auto;\n}\n","",{version:3,sources:["webpack://./src/styles/ChatWithMe.css"],names:[],mappings:"AAAA,mBAAmB;AACnB,qFAAqF;;AAErF;EACE,gBAAgB;AAClB",sourcesContent:["/* ChatWithMe.css */\n/* Uses utilities: .section-centered, .loading-text, .btn-primary, .btn-transparent */\n\n.chatSection {\n overflow-x: auto;\n}\n"],sourceRoot:""}]);const s=i},1699(n,e,t){"use strict";t.d(e,{A:()=>s});var o=t(1354),r=t.n(o),a=t(6314),i=t.n(a)()(r());i.push([n.id,'#add-to-contacts-button-container {\n position: relative;\n overflow: visible;\n}\n\n.contactsAddressBookSelector {\n width: fit-content;\n max-width: min(94vw, 48rem);\n min-width: 0;\n max-height: 80vh;\n overflow-y: auto;\n overflow-x: hidden;\n border-radius: var(--border-radius-base);\n box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;\n background: #F0F0F0;\n color: var(--color-primary);\n padding-top: 4em;\n align-items: stretch;\n box-sizing: border-box;\n gap: 7px;\n display: flex;\n flex-direction: column;\n font-weight: 600;\n position: absolute;\n top: 54%;\n bottom: auto;\n left: 50%;\n transform: translate(-50%, -50%);\n margin-top: 0;\n margin: 0;\n z-index: 200;\n opacity: 1;\n}\n\n@media (max-width: 900px) {\n .contactsAddressBookSelector {\n top: 54%;\n bottom: auto;\n left: 50%;\n transform: translate(-50%, -50%);\n }\n\n .contactsAddressBookDetails {\n flex-direction: column !important; /* Stacks items vertically on small screens */\n align-items: center !important;\n width: 100% !important;\n max-height: 60vh;\n overflow-y: auto;\n overflow-x: hidden; \n }\n\n .contactsAddressBookCreationDiv .contactsNewContactCreationButton {\n width: fit-content !important;\n min-width: 10em;\n margin-left: auto !important;\n margin-right: auto !important;\n align-self: center !important;\n display: inline-flex !important;\n justify-content: center !important;\n align-items: center !important;\n text-align: center;\n }\n}\n\n@media (max-width: 333px) {\n .contactsAddressBookSelector {\n width: 96vw;\n max-width: 96vw;\n min-width: 0;\n top: 50%;\n bottom: auto;\n left: 50%;\n transform: translate(-50%, -50%);\n padding-top: 3rem;\n position: fixed;\n overflow-x: hidden;\n }\n\n .contactsAddressBookDetails {\n width: 100% !important;\n min-width: 0;\n padding: 0.5rem;\n }\n .contactsAddressBookList,\n .contactsGroupList {\n min-width: 0;\n max-width: 100% !important;\n width: 100%;\n }\n}\n\n.contactsAddressBookCreationDiv {\n width: 100%;\n border-radius: var(--border-radius-base);\n background: #F0F0F0;\n box-sizing: border-box;\n padding: 5px;\n gap: 5px;\n display: flex;\n flex-direction: column;\n box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px;\n}\n\n.contactsHelpersButtonDiv {\n display: flex;\n flex-direction: row;\n gap: var(--spacing-md);\n justify-content: center;\n box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px;\n padding: var(--spacing-md);\n border-radius: var(--border-radius-base);\n}\n\n.contactsAddressBookCreationButton {\n flex-shrink: 0;\n background: color-mix(in srgb, var(--color-primary), white 85%) !important; \n color: var(--color-primary) !important;\n border-radius: 8px;\n text-align: left;\n cursor: pointer;\n white-space: nowrap;\n}\n\n.contactsAddressBookUriEntryButton {\n flex-shrink: 0;\n background: color-mix(in srgb, var(--color-primary), white 85%) !important; \n color: var(--color-primary) !important;\n border-radius: 8px;\n text-align: left;\n cursor: pointer;\n white-space: nowrap;\n}\n\n.contactsActionButton {\n background: var(--color-primary);\n color: white;\n border-radius: var(--border-radius-base);\n transition: all 0.3s ease-in-out;\n cursor: pointer;\n}\n\n.contactsActionButton:hover {\n transform: translateY(-2px);\n box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);\n}\n\n.contactsActionButton:active {\n box-shadow: 0 1px 2px white;\n}\n\n.contactsActionButton:focus,\n.contactsActionButton:focus-visible {\n outline: 3px solid var(--color-primary) !important;\n outline-offset: 2px !important;\n box-shadow: 0 0 0 2px white, 0 0 0 5px rgba(124, 77, 255, 0.25) !important;\n z-index: 1; \n}\n\n.contactsAddressBookDetails {\n width: 100%;\n min-width: 0;\n min-height: 0;\n border-radius: var(--border-radius-base);\n justify-content: flex-start;\n box-sizing: border-box;\n gap: 15px;\n display: flex;\n flex-direction: row;\n padding: var(--spacing-md);\n overflow-x: auto;\n overflow-y: auto;\n}\n\n.contactsAddressBookUriEntry {\n width: calc(100% - 1rem) !important;\n max-width: calc(100% - 1rem) !important;\n min-width: 0;\n box-sizing: border-box;\n padding-top: 3em !important;\n gap: 5px;\n display: flex;\n align-self: stretch;\n flex-direction: column;\n\n}\n\n.contactsAddressBookUriEntryForm {\n width: 100%;\n max-width: 100%;\n min-width: 0;\n background: #F0F0F0;\n box-sizing: border-box;\n gap: 5px;\n display: flex;\n flex-wrap: wrap;\n flex-direction: column;\n align-items: stretch;\n}\n\n.contactsAddressBookUriInput {\n width: clamp(14rem, 60vw, 22rem);\n max-width: 100%;\n min-width: 0;\n flex: 0 0 auto;\n align-self: flex-start;\n padding: 5px;\n gap: 15px;\n border-radius: var(--border-radius-base);\n border: 1px solid #ccc;\n}\n\n.contactsAddressBookUriEntryAddButton {\n width: 10%;\n min-width: 0;\n max-width: 4em;\n align-self: flex-end !important;\n margin-left: auto;\n display: inline-flex;\n justify-content: center;\n align-items: center;\n line-height: 1;\n}\n\n.contactsNewGroupForm {\n box-sizing: border-box;\n padding-top: 2.5rem !important;\n gap: 5px;\n display: flex;\n flex-direction: column;\n}\n\n.contactsCreateNewAddressBook {\n border-radius: var(--border-radius);\n color: white;\n padding: var(--spacing-md);\n justify-content: center;\n box-sizing: border-box;\n display: flex;\n flex-direction: column;\n box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px;\n}\n\n.contactsAddressBookList {\n width: 100%;\n max-width: fit-content !important;\n box-shadow: 2px 0 5px rgba(0, 0, 0, 0.1);\n min-width: 200px;\n box-sizing: border-box;\n gap: 4px;\n display: flex;\n flex-direction: column;\n}\n\n.contactsGroupList {\n width: auto;\n max-width: fit-content !important;\n min-width: 200px;\n box-shadow: 2px 0 5px rgba(0, 0, 0, 0.1);\n box-sizing: border-box;\n gap: 4px;\n display: flex;\n flex-direction: column;\n}\n\n.contactsErrorDisplay {\n width: 90%;\n align-self: flex-end;\n padding: 5px;\n position: absolute;\n background: pink;\n display: none;\n color: #787878;\n border-radius: var(--border-radius-base);\n box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px; \n z-index: 3;\n}\n\n.contactsShowErrors {\n display: flex !important;\n flex-direction: row;\n justify-content: center;\n}\n.contactsCloseErrorDisplayButton {\n position: absolute;\n top: 0.2rem;\n right: 0.2rem;\n background: transparent;\n color: #787878;\n border: none;\n font-size: var(--font-size-sm);\n cursor: pointer;\n z-index: 4;\n}\n\n.contactsCloseButton {\n box-shadow: var(--box-shadow);\n border-radius: var(--border-radius-base);\n color: #787878 !important;\n padding: 1em;\n font-size: var(--font-size-sm);\n position: absolute;\n top: 0; \n right: 0;\n display: inline-block;\n width: auto !important;\n height: auto !important;\n cursor: pointer;\n line-height: 1;\n left: auto;\n margin: 0;\n align-self: auto !important;\n background: transparent;\n color: #787878;\n border: none;\n z-index: 100 !important;\n}\n\n.contactsCloseButton:hover {\n box-shadow: 0 2px 4px var(--color-primary) !important;\n}\n\n.contactsCloseButton:focus,\n.contactsCloseButton:focus-visible {\n outline: 3px solid var(--color-primary) !important;\n outline-offset: 2px !important;\n box-shadow: 0 0 0 2px white, 0 0 0 5px rgba(124, 77, 255, 0.25) !important;\n z-index: 1;\n}\n\n.contactsNewAddressForm {\n padding-top: 3em !important;\n gap: 5px;\n display: flex;\n flex-direction: column;\n}\n\n.contactsButton {\n flex-shrink: 0;\n background: #F0F0F0;\n color: #787878;\n border-radius: 8px;\n text-align: left;\n padding: var(--spacing-md);\n cursor: pointer;\n white-space: nowrap;\n}\n\n.contactsButton:hover {\n color: var(--color-primary);\n background: color-mix(in srgb, var(--color-primary), white 85%) !important; \n} \n\n.contactsSelectedButton {\n background: color-mix(in srgb, var(--color-primary), white 60%) !important; \n color: var(--color-primary);\n}\n\n.contactsContactExistsAlert {\n background: #F0F0F0 !important;\n color: #787878;\n padding: 10px;\n border-radius: var(--border-radius-base);\n box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;\n z-index: 10;\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n width: 300px;\n display: flex;\n flex-direction: column;\n align-items: center;\n gap: 15px; \n text-wrap: pretty;\n}\n\n.contactsContactExistsActions {\n display: flex;\n flex-direction: row;\n flex-wrap: nowrap;\n justify-content: center;\n align-items: center;\n gap: 10px;\n width: auto;\n}\n\n.contactsContactExistsActions .contactsConfirmButton,\n.contactsContactExistsActions .contactsCancelButton {\n display: inline-flex !important;\n width: auto !important;\n min-width: fit-content;\n flex: 0 0 auto;\n margin: 0;\n white-space: nowrap;\n}\n\n.contactsAddressBookSelector [role="alert"] {\n border: none !important; /* Remove borders from alerts within the contacts dialog */\n}\n\n.contactsPopupOverlay {\n position: absolute;\n inset: 0;\n background: rgba(0, 0, 0, 0.2);\n z-index: 8;\n}\n\n.contactsAddressBookSelector.contactsOverlayActive > *:not(.contactsPopupOverlay):not(.contactsPopupDialog):not(.contactsContactExistsAlert) {\n pointer-events: none;\n user-select: none;\n}\n\n.contactsAddressBookSelector.contactsOverlayActive .contactsPopupDialog,\n.contactsAddressBookSelector.contactsOverlayActive .contactsContactExistsAlert,\n.contactsAddressBookSelector.contactsOverlayActive .contactsPopupDialog *,\n.contactsAddressBookSelector.contactsOverlayActive .contactsContactExistsAlert * {\n pointer-events: auto;\n}\n\n.contactsPopupDialog {\n background: #F5F5F5 !important;\n color: var(--color-primary);\n padding: 2em;\n border-radius: var(--border-radius-base);\n box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;\n z-index: 50;\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n width: auto;\n max-width: min(92vw, 34rem);\n max-height: calc(100vh - 6rem);\n overflow: auto;\n box-sizing: border-box;\n}\n\n@media (max-width: 600px) {\n .contactsAddressBookUriEntry {\n padding-top: 3rem !important;\n }\n\n .contactsPopupDialog {\n max-width: 92vw;\n max-height: 78vh;\n padding: 1.25rem;\n }\n}\n\n.contactsConfirmButton {\n background: var(--color-primary);\n color: white;\n border-radius: var(--border-radius-base);\n padding: var(--spacing-md);\n transition: all 0.3s ease-in-out;\n cursor: pointer;\n}\n\n.contactsConfirmButton:hover {\n transform: translateY(-2px);\n box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);\n}\n\n.contactsCancelButton {\n background: transparent;\n color: #787878;\n border-radius: var(--border-radius-base);\n padding: var(--spacing-md);\n border: 1px solid #ccc;\n transition: all 0.3s ease-in-out;\n cursor: pointer;\n}\n.contactsCancelButton:hover {\n background: color-mix(in srgb, var(--color-primary), white 85%) !important; \n color: var(--color-primary);\n} \n\n.contactsNewContactCreationButton {\n width: 10em !important;\n align-self: flex-end;\n line-height: 1;\n}\n\n.contactsCreateGroupCreationButton {\n flex-shrink: 0;\n background: color-mix(in srgb, var(--color-primary), white 85%) !important; \n color: var(--color-primary) !important;\n border-radius: 8px;\n text-align: left;\n cursor: pointer;\n white-space: nowrap;\n}\n\n.contactsCloseButton {\n position: absolute !important;\n top: 0 !important;\n right: 0 !important;\n left: auto;\n margin: 0;\n align-self: auto !important;\n background: transparent;\n color: #787878;\n font-size: var(--font-size-xs);\n border: none;\n font-size: var(--font-size-sm);\n cursor: pointer;\n z-index: 100 !important;\n padding: 0.35rem 0.5rem;\n line-height: 1;\n}\n\n',"",{version:3,sources:["webpack://./src/styles/ContactsCard.css"],names:[],mappings:"AAAA;EACE,kBAAkB;EAClB,iBAAiB;AACnB;;AAEA;EACE,kBAAkB;EAClB,2BAA2B;EAC3B,YAAY;EACZ,gBAAgB;EAChB,gBAAgB;EAChB,kBAAkB;EAClB,wCAAwC;EACxC,4CAA4C;EAC5C,mBAAmB;EACnB,2BAA2B;EAC3B,gBAAgB;EAChB,oBAAoB;EACpB,sBAAsB;EACtB,QAAQ;EACR,aAAa;EACb,sBAAsB;EACtB,gBAAgB;EAChB,kBAAkB;EAClB,QAAQ;EACR,YAAY;EACZ,SAAS;EACT,gCAAgC;EAChC,aAAa;EACb,SAAS;EACT,YAAY;EACZ,UAAU;AACZ;;AAEA;EACE;IACE,QAAQ;IACR,YAAY;IACZ,SAAS;IACT,gCAAgC;EAClC;;EAEA;IACE,iCAAiC,EAAE,6CAA6C;IAChF,8BAA8B;IAC9B,sBAAsB;IACtB,gBAAgB;IAChB,gBAAgB;IAChB,kBAAkB;EACpB;;EAEA;IACE,6BAA6B;IAC7B,eAAe;IACf,4BAA4B;IAC5B,6BAA6B;IAC7B,6BAA6B;IAC7B,+BAA+B;IAC/B,kCAAkC;IAClC,8BAA8B;IAC9B,kBAAkB;EACpB;AACF;;AAEA;EACE;IACE,WAAW;IACX,eAAe;IACf,YAAY;IACZ,QAAQ;IACR,YAAY;IACZ,SAAS;IACT,gCAAgC;IAChC,iBAAiB;IACjB,eAAe;IACf,kBAAkB;EACpB;;EAEA;IACE,sBAAsB;IACtB,YAAY;IACZ,eAAe;EACjB;EACA;;IAEE,YAAY;IACZ,0BAA0B;IAC1B,WAAW;EACb;AACF;;AAEA;EACE,WAAW;EACX,wCAAwC;EACxC,mBAAmB;EACnB,sBAAsB;EACtB,YAAY;EACZ,QAAQ;EACR,aAAa;EACb,sBAAsB;EACtB,2CAA2C;AAC7C;;AAEA;EACE,aAAa;EACb,mBAAmB;EACnB,sBAAsB;EACtB,uBAAuB;EACvB,2CAA2C;EAC3C,0BAA0B;EAC1B,wCAAwC;AAC1C;;AAEA;EACE,cAAc;EACd,0EAA0E;EAC1E,sCAAsC;EACtC,kBAAkB;EAClB,gBAAgB;EAChB,eAAe;EACf,mBAAmB;AACrB;;AAEA;EACE,cAAc;EACd,0EAA0E;EAC1E,sCAAsC;EACtC,kBAAkB;EAClB,gBAAgB;EAChB,eAAe;EACf,mBAAmB;AACrB;;AAEA;EACE,gCAAgC;EAChC,YAAY;EACZ,wCAAwC;EACxC,gCAAgC;EAChC,eAAe;AACjB;;AAEA;EACE,2BAA2B;EAC3B,wCAAwC;AAC1C;;AAEA;EACE,2BAA2B;AAC7B;;AAEA;;EAEE,kDAAkD;EAClD,8BAA8B;EAC9B,0EAA0E;EAC1E,UAAU;AACZ;;AAEA;EACE,WAAW;EACX,YAAY;EACZ,aAAa;EACb,wCAAwC;EACxC,2BAA2B;EAC3B,sBAAsB;EACtB,SAAS;EACT,aAAa;EACb,mBAAmB;EACnB,0BAA0B;EAC1B,gBAAgB;EAChB,gBAAgB;AAClB;;AAEA;EACE,mCAAmC;EACnC,uCAAuC;EACvC,YAAY;EACZ,sBAAsB;EACtB,2BAA2B;EAC3B,QAAQ;EACR,aAAa;EACb,mBAAmB;EACnB,sBAAsB;;AAExB;;AAEA;EACE,WAAW;EACX,eAAe;EACf,YAAY;EACZ,mBAAmB;EACnB,sBAAsB;EACtB,QAAQ;EACR,aAAa;EACb,eAAe;EACf,sBAAsB;EACtB,oBAAoB;AACtB;;AAEA;EACE,gCAAgC;EAChC,eAAe;EACf,YAAY;EACZ,cAAc;EACd,sBAAsB;EACtB,YAAY;EACZ,SAAS;EACT,wCAAwC;EACxC,sBAAsB;AACxB;;AAEA;EACE,UAAU;EACV,YAAY;EACZ,cAAc;EACd,+BAA+B;EAC/B,iBAAiB;EACjB,oBAAoB;EACpB,uBAAuB;EACvB,mBAAmB;EACnB,cAAc;AAChB;;AAEA;EACE,sBAAsB;EACtB,8BAA8B;EAC9B,QAAQ;EACR,aAAa;EACb,sBAAsB;AACxB;;AAEA;EACE,mCAAmC;EACnC,YAAY;EACZ,0BAA0B;EAC1B,uBAAuB;EACvB,sBAAsB;EACtB,aAAa;EACb,sBAAsB;EACtB,2CAA2C;AAC7C;;AAEA;EACE,WAAW;EACX,iCAAiC;EACjC,wCAAwC;EACxC,gBAAgB;EAChB,sBAAsB;EACtB,QAAQ;EACR,aAAa;EACb,sBAAsB;AACxB;;AAEA;EACE,WAAW;EACX,iCAAiC;EACjC,gBAAgB;EAChB,wCAAwC;EACxC,sBAAsB;EACtB,QAAQ;EACR,aAAa;EACb,sBAAsB;AACxB;;AAEA;EACE,UAAU;EACV,oBAAoB;EACpB,YAAY;EACZ,kBAAkB;EAClB,gBAAgB;EAChB,aAAa;EACb,cAAc;EACd,wCAAwC;EACxC,2CAA2C;EAC3C,UAAU;AACZ;;AAEA;EACE,wBAAwB;EACxB,mBAAmB;EACnB,uBAAuB;AACzB;AACA;EACE,kBAAkB;EAClB,WAAW;EACX,aAAa;EACb,uBAAuB;EACvB,cAAc;EACd,YAAY;EACZ,8BAA8B;EAC9B,eAAe;EACf,UAAU;AACZ;;AAEA;EACE,6BAA6B;EAC7B,wCAAwC;EACxC,yBAAyB;EACzB,YAAY;EACZ,8BAA8B;EAC9B,kBAAkB;EAClB,MAAM;EACN,QAAQ;EACR,qBAAqB;EACrB,sBAAsB;EACtB,uBAAuB;EACvB,eAAe;EACf,cAAc;EACd,UAAU;EACV,SAAS;EACT,2BAA2B;EAC3B,uBAAuB;EACvB,cAAc;EACd,YAAY;EACZ,uBAAuB;AACzB;;AAEA;EACE,qDAAqD;AACvD;;AAEA;;EAEE,kDAAkD;EAClD,8BAA8B;EAC9B,0EAA0E;EAC1E,UAAU;AACZ;;AAEA;EACE,2BAA2B;EAC3B,QAAQ;EACR,aAAa;EACb,sBAAsB;AACxB;;AAEA;EACE,cAAc;EACd,mBAAmB;EACnB,cAAc;EACd,kBAAkB;EAClB,gBAAgB;EAChB,0BAA0B;EAC1B,eAAe;EACf,mBAAmB;AACrB;;AAEA;EACE,2BAA2B;EAC3B,0EAA0E;AAC5E;;AAEA;CACC,0EAA0E;CAC1E,2BAA2B;AAC5B;;AAEA;EACE,8BAA8B;EAC9B,cAAc;EACd,aAAa;EACb,wCAAwC;EACxC,4CAA4C;EAC5C,WAAW;EACX,kBAAkB;EAClB,QAAQ;EACR,SAAS;EACT,gCAAgC;EAChC,YAAY;EACZ,aAAa;EACb,sBAAsB;EACtB,mBAAmB;EACnB,SAAS;EACT,iBAAiB;AACnB;;AAEA;EACE,aAAa;EACb,mBAAmB;EACnB,iBAAiB;EACjB,uBAAuB;EACvB,mBAAmB;EACnB,SAAS;EACT,WAAW;AACb;;AAEA;;EAEE,+BAA+B;EAC/B,sBAAsB;EACtB,sBAAsB;EACtB,cAAc;EACd,SAAS;EACT,mBAAmB;AACrB;;AAEA;EACE,uBAAuB,EAAE,0DAA0D;AACrF;;AAEA;EACE,kBAAkB;EAClB,QAAQ;EACR,8BAA8B;EAC9B,UAAU;AACZ;;AAEA;EACE,oBAAoB;EACpB,iBAAiB;AACnB;;AAEA;;;;EAIE,oBAAoB;AACtB;;AAEA;EACE,8BAA8B;EAC9B,2BAA2B;EAC3B,YAAY;EACZ,wCAAwC;EACxC,4CAA4C;EAC5C,WAAW;EACX,kBAAkB;EAClB,QAAQ;EACR,SAAS;EACT,gCAAgC;EAChC,WAAW;EACX,2BAA2B;EAC3B,8BAA8B;EAC9B,cAAc;EACd,sBAAsB;AACxB;;AAEA;EACE;IACE,4BAA4B;EAC9B;;EAEA;IACE,eAAe;IACf,gBAAgB;IAChB,gBAAgB;EAClB;AACF;;AAEA;EACE,gCAAgC;EAChC,YAAY;EACZ,wCAAwC;EACxC,0BAA0B;EAC1B,gCAAgC;EAChC,eAAe;AACjB;;AAEA;EACE,2BAA2B;EAC3B,wCAAwC;AAC1C;;AAEA;EACE,uBAAuB;EACvB,cAAc;EACd,wCAAwC;EACxC,0BAA0B;EAC1B,sBAAsB;EACtB,gCAAgC;EAChC,eAAe;AACjB;AACA;EACE,0EAA0E;EAC1E,2BAA2B;AAC7B;;AAEA;EACE,sBAAsB;EACtB,oBAAoB;EACpB,cAAc;AAChB;;AAEA;EACE,cAAc;EACd,0EAA0E;EAC1E,sCAAsC;EACtC,kBAAkB;EAClB,gBAAgB;EAChB,eAAe;EACf,mBAAmB;AACrB;;AAEA;EACE,6BAA6B;EAC7B,iBAAiB;EACjB,mBAAmB;EACnB,UAAU;EACV,SAAS;EACT,2BAA2B;EAC3B,uBAAuB;EACvB,cAAc;EACd,8BAA8B;EAC9B,YAAY;EACZ,8BAA8B;EAC9B,eAAe;EACf,uBAAuB;EACvB,uBAAuB;EACvB,cAAc;AAChB",sourcesContent:['#add-to-contacts-button-container {\n position: relative;\n overflow: visible;\n}\n\n.contactsAddressBookSelector {\n width: fit-content;\n max-width: min(94vw, 48rem);\n min-width: 0;\n max-height: 80vh;\n overflow-y: auto;\n overflow-x: hidden;\n border-radius: var(--border-radius-base);\n box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;\n background: #F0F0F0;\n color: var(--color-primary);\n padding-top: 4em;\n align-items: stretch;\n box-sizing: border-box;\n gap: 7px;\n display: flex;\n flex-direction: column;\n font-weight: 600;\n position: absolute;\n top: 54%;\n bottom: auto;\n left: 50%;\n transform: translate(-50%, -50%);\n margin-top: 0;\n margin: 0;\n z-index: 200;\n opacity: 1;\n}\n\n@media (max-width: 900px) {\n .contactsAddressBookSelector {\n top: 54%;\n bottom: auto;\n left: 50%;\n transform: translate(-50%, -50%);\n }\n\n .contactsAddressBookDetails {\n flex-direction: column !important; /* Stacks items vertically on small screens */\n align-items: center !important;\n width: 100% !important;\n max-height: 60vh;\n overflow-y: auto;\n overflow-x: hidden; \n }\n\n .contactsAddressBookCreationDiv .contactsNewContactCreationButton {\n width: fit-content !important;\n min-width: 10em;\n margin-left: auto !important;\n margin-right: auto !important;\n align-self: center !important;\n display: inline-flex !important;\n justify-content: center !important;\n align-items: center !important;\n text-align: center;\n }\n}\n\n@media (max-width: 333px) {\n .contactsAddressBookSelector {\n width: 96vw;\n max-width: 96vw;\n min-width: 0;\n top: 50%;\n bottom: auto;\n left: 50%;\n transform: translate(-50%, -50%);\n padding-top: 3rem;\n position: fixed;\n overflow-x: hidden;\n }\n\n .contactsAddressBookDetails {\n width: 100% !important;\n min-width: 0;\n padding: 0.5rem;\n }\n .contactsAddressBookList,\n .contactsGroupList {\n min-width: 0;\n max-width: 100% !important;\n width: 100%;\n }\n}\n\n.contactsAddressBookCreationDiv {\n width: 100%;\n border-radius: var(--border-radius-base);\n background: #F0F0F0;\n box-sizing: border-box;\n padding: 5px;\n gap: 5px;\n display: flex;\n flex-direction: column;\n box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px;\n}\n\n.contactsHelpersButtonDiv {\n display: flex;\n flex-direction: row;\n gap: var(--spacing-md);\n justify-content: center;\n box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px;\n padding: var(--spacing-md);\n border-radius: var(--border-radius-base);\n}\n\n.contactsAddressBookCreationButton {\n flex-shrink: 0;\n background: color-mix(in srgb, var(--color-primary), white 85%) !important; \n color: var(--color-primary) !important;\n border-radius: 8px;\n text-align: left;\n cursor: pointer;\n white-space: nowrap;\n}\n\n.contactsAddressBookUriEntryButton {\n flex-shrink: 0;\n background: color-mix(in srgb, var(--color-primary), white 85%) !important; \n color: var(--color-primary) !important;\n border-radius: 8px;\n text-align: left;\n cursor: pointer;\n white-space: nowrap;\n}\n\n.contactsActionButton {\n background: var(--color-primary);\n color: white;\n border-radius: var(--border-radius-base);\n transition: all 0.3s ease-in-out;\n cursor: pointer;\n}\n\n.contactsActionButton:hover {\n transform: translateY(-2px);\n box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);\n}\n\n.contactsActionButton:active {\n box-shadow: 0 1px 2px white;\n}\n\n.contactsActionButton:focus,\n.contactsActionButton:focus-visible {\n outline: 3px solid var(--color-primary) !important;\n outline-offset: 2px !important;\n box-shadow: 0 0 0 2px white, 0 0 0 5px rgba(124, 77, 255, 0.25) !important;\n z-index: 1; \n}\n\n.contactsAddressBookDetails {\n width: 100%;\n min-width: 0;\n min-height: 0;\n border-radius: var(--border-radius-base);\n justify-content: flex-start;\n box-sizing: border-box;\n gap: 15px;\n display: flex;\n flex-direction: row;\n padding: var(--spacing-md);\n overflow-x: auto;\n overflow-y: auto;\n}\n\n.contactsAddressBookUriEntry {\n width: calc(100% - 1rem) !important;\n max-width: calc(100% - 1rem) !important;\n min-width: 0;\n box-sizing: border-box;\n padding-top: 3em !important;\n gap: 5px;\n display: flex;\n align-self: stretch;\n flex-direction: column;\n\n}\n\n.contactsAddressBookUriEntryForm {\n width: 100%;\n max-width: 100%;\n min-width: 0;\n background: #F0F0F0;\n box-sizing: border-box;\n gap: 5px;\n display: flex;\n flex-wrap: wrap;\n flex-direction: column;\n align-items: stretch;\n}\n\n.contactsAddressBookUriInput {\n width: clamp(14rem, 60vw, 22rem);\n max-width: 100%;\n min-width: 0;\n flex: 0 0 auto;\n align-self: flex-start;\n padding: 5px;\n gap: 15px;\n border-radius: var(--border-radius-base);\n border: 1px solid #ccc;\n}\n\n.contactsAddressBookUriEntryAddButton {\n width: 10%;\n min-width: 0;\n max-width: 4em;\n align-self: flex-end !important;\n margin-left: auto;\n display: inline-flex;\n justify-content: center;\n align-items: center;\n line-height: 1;\n}\n\n.contactsNewGroupForm {\n box-sizing: border-box;\n padding-top: 2.5rem !important;\n gap: 5px;\n display: flex;\n flex-direction: column;\n}\n\n.contactsCreateNewAddressBook {\n border-radius: var(--border-radius);\n color: white;\n padding: var(--spacing-md);\n justify-content: center;\n box-sizing: border-box;\n display: flex;\n flex-direction: column;\n box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px;\n}\n\n.contactsAddressBookList {\n width: 100%;\n max-width: fit-content !important;\n box-shadow: 2px 0 5px rgba(0, 0, 0, 0.1);\n min-width: 200px;\n box-sizing: border-box;\n gap: 4px;\n display: flex;\n flex-direction: column;\n}\n\n.contactsGroupList {\n width: auto;\n max-width: fit-content !important;\n min-width: 200px;\n box-shadow: 2px 0 5px rgba(0, 0, 0, 0.1);\n box-sizing: border-box;\n gap: 4px;\n display: flex;\n flex-direction: column;\n}\n\n.contactsErrorDisplay {\n width: 90%;\n align-self: flex-end;\n padding: 5px;\n position: absolute;\n background: pink;\n display: none;\n color: #787878;\n border-radius: var(--border-radius-base);\n box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px; \n z-index: 3;\n}\n\n.contactsShowErrors {\n display: flex !important;\n flex-direction: row;\n justify-content: center;\n}\n.contactsCloseErrorDisplayButton {\n position: absolute;\n top: 0.2rem;\n right: 0.2rem;\n background: transparent;\n color: #787878;\n border: none;\n font-size: var(--font-size-sm);\n cursor: pointer;\n z-index: 4;\n}\n\n.contactsCloseButton {\n box-shadow: var(--box-shadow);\n border-radius: var(--border-radius-base);\n color: #787878 !important;\n padding: 1em;\n font-size: var(--font-size-sm);\n position: absolute;\n top: 0; \n right: 0;\n display: inline-block;\n width: auto !important;\n height: auto !important;\n cursor: pointer;\n line-height: 1;\n left: auto;\n margin: 0;\n align-self: auto !important;\n background: transparent;\n color: #787878;\n border: none;\n z-index: 100 !important;\n}\n\n.contactsCloseButton:hover {\n box-shadow: 0 2px 4px var(--color-primary) !important;\n}\n\n.contactsCloseButton:focus,\n.contactsCloseButton:focus-visible {\n outline: 3px solid var(--color-primary) !important;\n outline-offset: 2px !important;\n box-shadow: 0 0 0 2px white, 0 0 0 5px rgba(124, 77, 255, 0.25) !important;\n z-index: 1;\n}\n\n.contactsNewAddressForm {\n padding-top: 3em !important;\n gap: 5px;\n display: flex;\n flex-direction: column;\n}\n\n.contactsButton {\n flex-shrink: 0;\n background: #F0F0F0;\n color: #787878;\n border-radius: 8px;\n text-align: left;\n padding: var(--spacing-md);\n cursor: pointer;\n white-space: nowrap;\n}\n\n.contactsButton:hover {\n color: var(--color-primary);\n background: color-mix(in srgb, var(--color-primary), white 85%) !important; \n} \n\n.contactsSelectedButton {\n background: color-mix(in srgb, var(--color-primary), white 60%) !important; \n color: var(--color-primary);\n}\n\n.contactsContactExistsAlert {\n background: #F0F0F0 !important;\n color: #787878;\n padding: 10px;\n border-radius: var(--border-radius-base);\n box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;\n z-index: 10;\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n width: 300px;\n display: flex;\n flex-direction: column;\n align-items: center;\n gap: 15px; \n text-wrap: pretty;\n}\n\n.contactsContactExistsActions {\n display: flex;\n flex-direction: row;\n flex-wrap: nowrap;\n justify-content: center;\n align-items: center;\n gap: 10px;\n width: auto;\n}\n\n.contactsContactExistsActions .contactsConfirmButton,\n.contactsContactExistsActions .contactsCancelButton {\n display: inline-flex !important;\n width: auto !important;\n min-width: fit-content;\n flex: 0 0 auto;\n margin: 0;\n white-space: nowrap;\n}\n\n.contactsAddressBookSelector [role="alert"] {\n border: none !important; /* Remove borders from alerts within the contacts dialog */\n}\n\n.contactsPopupOverlay {\n position: absolute;\n inset: 0;\n background: rgba(0, 0, 0, 0.2);\n z-index: 8;\n}\n\n.contactsAddressBookSelector.contactsOverlayActive > *:not(.contactsPopupOverlay):not(.contactsPopupDialog):not(.contactsContactExistsAlert) {\n pointer-events: none;\n user-select: none;\n}\n\n.contactsAddressBookSelector.contactsOverlayActive .contactsPopupDialog,\n.contactsAddressBookSelector.contactsOverlayActive .contactsContactExistsAlert,\n.contactsAddressBookSelector.contactsOverlayActive .contactsPopupDialog *,\n.contactsAddressBookSelector.contactsOverlayActive .contactsContactExistsAlert * {\n pointer-events: auto;\n}\n\n.contactsPopupDialog {\n background: #F5F5F5 !important;\n color: var(--color-primary);\n padding: 2em;\n border-radius: var(--border-radius-base);\n box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;\n z-index: 50;\n position: absolute;\n top: 50%;\n left: 50%;\n transform: translate(-50%, -50%);\n width: auto;\n max-width: min(92vw, 34rem);\n max-height: calc(100vh - 6rem);\n overflow: auto;\n box-sizing: border-box;\n}\n\n@media (max-width: 600px) {\n .contactsAddressBookUriEntry {\n padding-top: 3rem !important;\n }\n\n .contactsPopupDialog {\n max-width: 92vw;\n max-height: 78vh;\n padding: 1.25rem;\n }\n}\n\n.contactsConfirmButton {\n background: var(--color-primary);\n color: white;\n border-radius: var(--border-radius-base);\n padding: var(--spacing-md);\n transition: all 0.3s ease-in-out;\n cursor: pointer;\n}\n\n.contactsConfirmButton:hover {\n transform: translateY(-2px);\n box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);\n}\n\n.contactsCancelButton {\n background: transparent;\n color: #787878;\n border-radius: var(--border-radius-base);\n padding: var(--spacing-md);\n border: 1px solid #ccc;\n transition: all 0.3s ease-in-out;\n cursor: pointer;\n}\n.contactsCancelButton:hover {\n background: color-mix(in srgb, var(--color-primary), white 85%) !important; \n color: var(--color-primary);\n} \n\n.contactsNewContactCreationButton {\n width: 10em !important;\n align-self: flex-end;\n line-height: 1;\n}\n\n.contactsCreateGroupCreationButton {\n flex-shrink: 0;\n background: color-mix(in srgb, var(--color-primary), white 85%) !important; \n color: var(--color-primary) !important;\n border-radius: 8px;\n text-align: left;\n cursor: pointer;\n white-space: nowrap;\n}\n\n.contactsCloseButton {\n position: absolute !important;\n top: 0 !important;\n right: 0 !important;\n left: auto;\n margin: 0;\n align-self: auto !important;\n background: transparent;\n color: #787878;\n font-size: var(--font-size-xs);\n border: none;\n font-size: var(--font-size-sm);\n cursor: pointer;\n z-index: 100 !important;\n padding: 0.35rem 0.5rem;\n line-height: 1;\n}\n\n'],sourceRoot:""}]);const s=i},1666(n,e,t){"use strict";t.d(e,{A:()=>s});var o=t(1354),r=t.n(o),a=t(6314),i=t.n(a)()(r());i.push([n.id,"/* FriendList.css */\n/* Uses utilities: .list-reset, .section-title, .zebra-stripe, .flex, .gap-xs, .mb-md */\n\n.friendItem {\n padding: var(--spacing-xs) 0;\n font-size: 1em;\n color: var(--color-text-muted);\n}\n\n.friendItem:last-child {\n border-bottom: none;\n}\n","",{version:3,sources:["webpack://./src/styles/FriendList.css"],names:[],mappings:"AAAA,mBAAmB;AACnB,uFAAuF;;AAEvF;EACE,4BAA4B;EAC5B,cAAc;EACd,8BAA8B;AAChC;;AAEA;EACE,mBAAmB;AACrB",sourcesContent:["/* FriendList.css */\n/* Uses utilities: .list-reset, .section-title, .zebra-stripe, .flex, .gap-xs, .mb-md */\n\n.friendItem {\n padding: var(--spacing-xs) 0;\n font-size: 1em;\n color: var(--color-text-muted);\n}\n\n.friendItem:last-child {\n border-bottom: none;\n}\n"],sourceRoot:""}]);const s=i},1937(n,e,t){"use strict";t.d(e,{A:()=>s});var o=t(1354),r=t.n(o),a=t(6314),i=t.n(a)()(r());i.push([n.id,"/* ProfileCard.css */\n/* Uses utilities: .action-button-focus, .btn-primary, .flex-column-center, .text-truncate, .text-center, .text-wrap-anywhere, .section-centered, .btn-transparent */\n\n.profileCard {\n /* Component container */\n}\n\n.image {\n width: 160px;\n height: 160px;\n border-radius: 50%;\n object-fit: cover;\n margin-bottom: var(--spacing-sm);\n box-shadow: var(--box-shadow-sm);\n border: 3px solid var(--color-primary);\n background: var(--color-card-bg);\n box-sizing: border-box;\n}\n\n.image-alt {\n width: 160px;\n height: 160px;\n display: flex;\n align-items: center;\n justify-content: center;\n border-radius: 50%;\n margin-bottom: var(--spacing-sm);\n box-shadow: var(--box-shadow-sm);\n border: 3px solid var(--color-primary);\n background: var(--color-card-bg);\n box-sizing: border-box;\n color: var(--color-text-secondary);\n}\n\n.name {\n font-size: var(--font-size-xl);\n font-weight: 700;\n line-height: var(--line-height-tight);\n text-decoration: underline;\n text-underline-offset: 0.2em;\n margin: 0;\n letter-spacing: var(--letter-spacing-wide);\n}\n\n.intro {\n color: var(--color-text-secondary);\n font-size: var(--font-size-base);\n line-height: var(--line-height-base);\n margin-bottom: var(--spacing-xs);\n max-width: 40ch;\n margin-left: auto;\n margin-right: auto;\n}\n\n.buttonSection {\n color: var(--color-text-secondary);\n font-size: 1em;\n margin-bottom: var(--spacing-xs);\n}\n\n.buttonSubSection {\n width: 100%;\n min-width: 0;\n display: grid;\n}\n\n.buttonSubSection button {\n width: 100%;\n min-width: 0;\n}\n\n.qrCodeSection {\n color: var(--color-text-secondary);\n font-size: 1em;\n margin-bottom: var(--spacing-xs);\n}\n\n.details {\n color: var(--color-text-muted);\n font-size: var(--font-size-base);\n line-height: var(--line-height-base);\n max-width: 45ch;\n margin-left: auto;\n margin-right: auto;\n}\n\n/* ProfileCard styles as regular CSS */\n.profile-card {\n border: 1px solid #ccc;\n padding: 16px;\n background: white;\n}\n","",{version:3,sources:["webpack://./src/styles/ProfileCard.css"],names:[],mappings:"AAAA,oBAAoB;AACpB,oKAAoK;;AAEpK;EACE,wBAAwB;AAC1B;;AAEA;EACE,YAAY;EACZ,aAAa;EACb,kBAAkB;EAClB,iBAAiB;EACjB,gCAAgC;EAChC,gCAAgC;EAChC,sCAAsC;EACtC,gCAAgC;EAChC,sBAAsB;AACxB;;AAEA;EACE,YAAY;EACZ,aAAa;EACb,aAAa;EACb,mBAAmB;EACnB,uBAAuB;EACvB,kBAAkB;EAClB,gCAAgC;EAChC,gCAAgC;EAChC,sCAAsC;EACtC,gCAAgC;EAChC,sBAAsB;EACtB,kCAAkC;AACpC;;AAEA;EACE,8BAA8B;EAC9B,gBAAgB;EAChB,qCAAqC;EACrC,0BAA0B;EAC1B,4BAA4B;EAC5B,SAAS;EACT,0CAA0C;AAC5C;;AAEA;EACE,kCAAkC;EAClC,gCAAgC;EAChC,oCAAoC;EACpC,gCAAgC;EAChC,eAAe;EACf,iBAAiB;EACjB,kBAAkB;AACpB;;AAEA;EACE,kCAAkC;EAClC,cAAc;EACd,gCAAgC;AAClC;;AAEA;EACE,WAAW;EACX,YAAY;EACZ,aAAa;AACf;;AAEA;EACE,WAAW;EACX,YAAY;AACd;;AAEA;EACE,kCAAkC;EAClC,cAAc;EACd,gCAAgC;AAClC;;AAEA;EACE,8BAA8B;EAC9B,gCAAgC;EAChC,oCAAoC;EACpC,eAAe;EACf,iBAAiB;EACjB,kBAAkB;AACpB;;AAEA,sCAAsC;AACtC;EACE,sBAAsB;EACtB,aAAa;EACb,iBAAiB;AACnB",sourcesContent:["/* ProfileCard.css */\n/* Uses utilities: .action-button-focus, .btn-primary, .flex-column-center, .text-truncate, .text-center, .text-wrap-anywhere, .section-centered, .btn-transparent */\n\n.profileCard {\n /* Component container */\n}\n\n.image {\n width: 160px;\n height: 160px;\n border-radius: 50%;\n object-fit: cover;\n margin-bottom: var(--spacing-sm);\n box-shadow: var(--box-shadow-sm);\n border: 3px solid var(--color-primary);\n background: var(--color-card-bg);\n box-sizing: border-box;\n}\n\n.image-alt {\n width: 160px;\n height: 160px;\n display: flex;\n align-items: center;\n justify-content: center;\n border-radius: 50%;\n margin-bottom: var(--spacing-sm);\n box-shadow: var(--box-shadow-sm);\n border: 3px solid var(--color-primary);\n background: var(--color-card-bg);\n box-sizing: border-box;\n color: var(--color-text-secondary);\n}\n\n.name {\n font-size: var(--font-size-xl);\n font-weight: 700;\n line-height: var(--line-height-tight);\n text-decoration: underline;\n text-underline-offset: 0.2em;\n margin: 0;\n letter-spacing: var(--letter-spacing-wide);\n}\n\n.intro {\n color: var(--color-text-secondary);\n font-size: var(--font-size-base);\n line-height: var(--line-height-base);\n margin-bottom: var(--spacing-xs);\n max-width: 40ch;\n margin-left: auto;\n margin-right: auto;\n}\n\n.buttonSection {\n color: var(--color-text-secondary);\n font-size: 1em;\n margin-bottom: var(--spacing-xs);\n}\n\n.buttonSubSection {\n width: 100%;\n min-width: 0;\n display: grid;\n}\n\n.buttonSubSection button {\n width: 100%;\n min-width: 0;\n}\n\n.qrCodeSection {\n color: var(--color-text-secondary);\n font-size: 1em;\n margin-bottom: var(--spacing-xs);\n}\n\n.details {\n color: var(--color-text-muted);\n font-size: var(--font-size-base);\n line-height: var(--line-height-base);\n max-width: 45ch;\n margin-left: auto;\n margin-right: auto;\n}\n\n/* ProfileCard styles as regular CSS */\n.profile-card {\n border: 1px solid #ccc;\n padding: 16px;\n background: white;\n}\n"],sourceRoot:""}]);const s=i},436(n,e,t){"use strict";t.d(e,{A:()=>s});var o=t(1354),r=t.n(o),a=t(6314),i=t.n(a)()(r());i.push([n.id,"/* ProfileView.css */\n/* Uses utilities: .section-bg, .text-center */\n\n.profileSection {\n \n}\n\n/* Horizontal layout for cards */\n.profile-grid .profileSection {\n width: 100%;\n max-width: 100%;\n box-sizing: border-box;\n margin-bottom: var(--spacing-md);\n box-sizing: border-box;\n margin-bottom: var(--spacing-md);\n}\n\n@media (min-width: 900px) {\n .profileSection {\n margin-bottom: 0;\n }\n}\n","",{version:3,sources:["webpack://./src/styles/ProfileView.css"],names:[],mappings:"AAAA,oBAAoB;AACpB,8CAA8C;;AAE9C;;AAEA;;AAEA,gCAAgC;AAChC;EACE,WAAW;EACX,eAAe;EACf,sBAAsB;EACtB,gCAAgC;EAChC,sBAAsB;EACtB,gCAAgC;AAClC;;AAEA;EACE;IACE,gBAAgB;EAClB;AACF",sourcesContent:["/* ProfileView.css */\n/* Uses utilities: .section-bg, .text-center */\n\n.profileSection {\n \n}\n\n/* Horizontal layout for cards */\n.profile-grid .profileSection {\n width: 100%;\n max-width: 100%;\n box-sizing: border-box;\n margin-bottom: var(--spacing-md);\n box-sizing: border-box;\n margin-bottom: var(--spacing-md);\n}\n\n@media (min-width: 900px) {\n .profileSection {\n margin-bottom: 0;\n }\n}\n"],sourceRoot:""}]);const s=i},1134(n,e,t){"use strict";t.d(e,{A:()=>s});var o=t(1354),r=t.n(o),a=t(6314),i=t.n(a)()(r());i.push([n.id,'/* QRCodeCard.css */\n/* Note: Uses utilities: .text-center */\n\n/* Caption under the QR code */\n.qrCaption {\n text-align: center;\n margin-top: 0;\n font-size: 0.95em;\n color: var(--color-text-secondary);\n}\n\n.QRCode {\n width: 100%;\n max-width: 320px;\n min-width: 180px;\n margin: 0 auto;\n display: block;\n}\n\n.QRCode [role="img"]:focus {\n outline: 2px solid var(--color-primary, #7C4DFF);\n outline-offset: 2px;\n box-shadow: 0 0 0 2px rgba(124,77,255,0.2);\n}',"",{version:3,sources:["webpack://./src/styles/QRCodeCard.css"],names:[],mappings:"AAAA,mBAAmB;AACnB,uCAAuC;;AAEvC,8BAA8B;AAC9B;EACE,kBAAkB;EAClB,aAAa;EACb,iBAAiB;EACjB,kCAAkC;AACpC;;AAEA;EACE,WAAW;EACX,gBAAgB;EAChB,gBAAgB;EAChB,cAAc;EACd,cAAc;AAChB;;AAEA;EACE,gDAAgD;EAChD,mBAAmB;EACnB,0CAA0C;AAC5C",sourcesContent:['/* QRCodeCard.css */\n/* Note: Uses utilities: .text-center */\n\n/* Caption under the QR code */\n.qrCaption {\n text-align: center;\n margin-top: 0;\n font-size: 0.95em;\n color: var(--color-text-secondary);\n}\n\n.QRCode {\n width: 100%;\n max-width: 320px;\n min-width: 180px;\n margin: 0 auto;\n display: block;\n}\n\n.QRCode [role="img"]:focus {\n outline: 2px solid var(--color-primary, #7C4DFF);\n outline-offset: 2px;\n box-shadow: 0 0 0 2px rgba(124,77,255,0.2);\n}'],sourceRoot:""}]);const s=i},1649(n,e,t){"use strict";t.d(e,{A:()=>s});var o=t(1354),r=t.n(o),a=t(6314),i=t.n(a)()(r());i.push([n.id,'/* SocialCard.css */\n/* Uses utilities: .list-reset, .text-wrap-anywhere, .flex, .gap-sm, .gap-lg, .rounded-sm */\n\n.socialList {\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n gap: var(--spacing-lg);\n justify-content: center;\n}\n\n.socialItem {\n display: flex;\n align-items: center;\n gap: var(--spacing-sm);\n font-size: 1.1em;\n}\n\n.socialItem span {\n min-width: 0;\n display: block;\n}\n\n.socialItem a {\n color: var(--color-primary);\n text-decoration: none;\n display: flex;\n align-items: center;\n gap: var(--spacing-sm);\n min-height: var(--min-touch-target);\n padding: var(--spacing-xs);\n border-radius: var(--border-radius-base);\n transition: background-color var(--animation-duration) ease;\n position: relative;\n flex: 1;\n min-width: 0;\n}\n\n.socialItem a:hover,\n.socialItem a:focus {\n text-decoration: underline;\n background-color: rgba(124, 77, 255, 0.1);\n}\n\n/* Screen reader only external link indication */\n.socialItem a[href^="http"]:after {\n content: " (external link)";\n position: absolute;\n left: -10000px;\n width: 1px;\n height: 1px;\n overflow: hidden;\n}\n\n.socialIcon {\n width: 2.5em;\n height: 2.5em;\n border-radius: var(--border-radius-base);\n background: var(--color-card-bg);\n flex-shrink: 0;\n}\n',"",{version:3,sources:["webpack://./src/styles/SocialCard.css"],names:[],mappings:"AAAA,mBAAmB;AACnB,2FAA2F;;AAE3F;EACE,aAAa;EACb,mBAAmB;EACnB,eAAe;EACf,sBAAsB;EACtB,uBAAuB;AACzB;;AAEA;EACE,aAAa;EACb,mBAAmB;EACnB,sBAAsB;EACtB,gBAAgB;AAClB;;AAEA;EACE,YAAY;EACZ,cAAc;AAChB;;AAEA;EACE,2BAA2B;EAC3B,qBAAqB;EACrB,aAAa;EACb,mBAAmB;EACnB,sBAAsB;EACtB,mCAAmC;EACnC,0BAA0B;EAC1B,wCAAwC;EACxC,2DAA2D;EAC3D,kBAAkB;EAClB,OAAO;EACP,YAAY;AACd;;AAEA;;EAEE,0BAA0B;EAC1B,yCAAyC;AAC3C;;AAEA,gDAAgD;AAChD;EACE,2BAA2B;EAC3B,kBAAkB;EAClB,cAAc;EACd,UAAU;EACV,WAAW;EACX,gBAAgB;AAClB;;AAEA;EACE,YAAY;EACZ,aAAa;EACb,wCAAwC;EACxC,gCAAgC;EAChC,cAAc;AAChB",sourcesContent:['/* SocialCard.css */\n/* Uses utilities: .list-reset, .text-wrap-anywhere, .flex, .gap-sm, .gap-lg, .rounded-sm */\n\n.socialList {\n display: flex;\n flex-direction: row;\n flex-wrap: wrap;\n gap: var(--spacing-lg);\n justify-content: center;\n}\n\n.socialItem {\n display: flex;\n align-items: center;\n gap: var(--spacing-sm);\n font-size: 1.1em;\n}\n\n.socialItem span {\n min-width: 0;\n display: block;\n}\n\n.socialItem a {\n color: var(--color-primary);\n text-decoration: none;\n display: flex;\n align-items: center;\n gap: var(--spacing-sm);\n min-height: var(--min-touch-target);\n padding: var(--spacing-xs);\n border-radius: var(--border-radius-base);\n transition: background-color var(--animation-duration) ease;\n position: relative;\n flex: 1;\n min-width: 0;\n}\n\n.socialItem a:hover,\n.socialItem a:focus {\n text-decoration: underline;\n background-color: rgba(124, 77, 255, 0.1);\n}\n\n/* Screen reader only external link indication */\n.socialItem a[href^="http"]:after {\n content: " (external link)";\n position: absolute;\n left: -10000px;\n width: 1px;\n height: 1px;\n overflow: hidden;\n}\n\n.socialIcon {\n width: 2.5em;\n height: 2.5em;\n border-radius: var(--border-radius-base);\n background: var(--color-card-bg);\n flex-shrink: 0;\n}\n'],sourceRoot:""}]);const s=i},6660(n,e,t){"use strict";t.d(e,{A:()=>s});var o=t(1354),r=t.n(o),a=t(6314),i=t.n(a)()(r());i.push([n.id,"/* StuffCard.css */\n/* Uses utilities: .zebra-stripe */\n\n.stuffTable {\n width: 100%;\n border-collapse: collapse;\n margin-bottom: var(--spacing-md);\n caption-side: top;\n}\n\n.stuffTable caption {\n font-weight: 600;\n padding: var(--spacing-sm);\n text-align: left;\n color: var(--color-text);\n}\n\n.stuffTable th,\n.stuffTable td {\n padding: var(--spacing-sm) var(--spacing-md);\n text-align: left;\n line-height: 1.4;\n}\n","",{version:3,sources:["webpack://./src/styles/StuffCard.css"],names:[],mappings:"AAAA,kBAAkB;AAClB,kCAAkC;;AAElC;EACE,WAAW;EACX,yBAAyB;EACzB,gCAAgC;EAChC,iBAAiB;AACnB;;AAEA;EACE,gBAAgB;EAChB,0BAA0B;EAC1B,gBAAgB;EAChB,wBAAwB;AAC1B;;AAEA;;EAEE,4CAA4C;EAC5C,gBAAgB;EAChB,gBAAgB;AAClB",sourcesContent:["/* StuffCard.css */\n/* Uses utilities: .zebra-stripe */\n\n.stuffTable {\n width: 100%;\n border-collapse: collapse;\n margin-bottom: var(--spacing-md);\n caption-side: top;\n}\n\n.stuffTable caption {\n font-weight: 600;\n padding: var(--spacing-sm);\n text-align: left;\n color: var(--color-text);\n}\n\n.stuffTable th,\n.stuffTable td {\n padding: var(--spacing-sm) var(--spacing-md);\n text-align: left;\n line-height: 1.4;\n}\n"],sourceRoot:""}]);const s=i},9053(n,e,t){"use strict";t.d(e,{A:()=>s});var o=t(1354),r=t.n(o),a=t(6314),i=t.n(a)()(r());i.push([n.id,'/* Solid-UI form sizing fixes scoped to Edit CV section */\n.profile-form .hoverControl:not(:has(> img:first-child)) {\n border: 0.1em solid rgb(136, 136, 136) !important;\n}\n\n.profile-form .hoverControl:has(> img:first-child) {\n background-color: transparent !important;\n border: none !important;\n margin: 0 !important;\n border-radius: 0 !important;\n padding: 0.7em !important;\n cursor: pointer;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n}\n\n.profile-form .hoverControlHide {\n width: 1.5em !important;\n height: 1.5em !important;\n display: block;\n margin-top: 0 !important;\n margin-left: 0 !important;\n margin-right: 0 !important;\n margin-bottom: 0.3em !important;\n}\n\n.profile-form .hoverControl:has(> img:first-child) > span {\n display: inline-flex;\n align-items: center;\n margin-left: 0.3em;\n}\n\n.profile-form div[style*="padding: 0.5em"]:has(> img) {\n display: inline-flex;\n align-items: center;\n}\n\n.profile-form div[style*="padding: 0.5em"]:has(> img) > span {\n margin-left: 0.3em;\n}\n\n.profile-form .hoverControl:has(> img:first-child):hover {\n background-color: transparent !important;\n}\n\n.profile-form button:has(> img[src$=".svg"]) {\n background-color: transparent !important;\n border: none !important;\n margin: 0 !important;\n border-radius: 0 !important;\n}\n\n.profile-form button {\n\n}\n\n.profile-form input:not([type="color"]),\n.profile-form textarea,\n.profile-form select {\n max-width: 100%;\n min-width: 0;\n box-sizing: border-box ;\n background-color: #eef !important;\n border: .05em solid #88c\n}\n\n.profile-form input[type="url"] {\n width: 100%;\n}\n\n.profile-form .formFieldValue {\n min-width: 0;\n margin-bottom: var(--spacing-sm);\n}\n\n.profile-form .formFieldValue table {\n margin: 0 !important;\n padding: 0 !important;\n}\n\n.profile-form .formFieldValue td {\n padding: 0 !important;\n}\n\n.profile-form .formFieldValue input:not([type="color"]),\n.profile-form .formFieldValue textarea,\n.profile-form .formFieldValue select {\n width: 100%;\n max-width: 100%;\n}\n\n.profile-form select#formSelect {\n width: 100%;\n max-width: 97%;\n box-sizing: border-box;\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n.profile-form span select {\n max-width: 96% !important;\n box-sizing: border-box;\n}\n\n/* Remove border/padding from the first wrapper div (and its first child wrapper). */\n.profile-form > div:first-of-type,\n.profile-form > div:first-of-type > div:first-of-type {\n border: none !important;\n padding: 0 !important;\n}\n\n/* Remove border/padding from the inner div of the first wrapper in the contact section. */\nsection[aria-labelledby="edit-profile-contact-heading"] .profile-form > div:first-of-type > div:first-of-type {\n border: none !important;\n padding: 0 !important;\n}\n\n/* In contactPane, remove border/padding from all direct child divs. */\n.contactPane > div {\n border: none !important;\n padding: 0 !important;\n}\n\n/* Align schema.org, solid terms, FOAF, vCard, and org field labels with their input values. */\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://schema.org/"]),\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/solid/terms#"]),\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://xmlns.com/foaf/0.1/"]),\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/2006/vcard/ns"]),\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/org#"]) {\n display: inline-flex;\n align-items: center;\n vertical-align: middle;\n}\n\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://schema.org/"]) + .formFieldValue,\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/solid/terms#"]) + .formFieldValue,\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://xmlns.com/foaf/0.1/"]) + .formFieldValue,\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/2006/vcard/ns"]) + .formFieldValue,\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/org#"]) + .formFieldValue {\n display: inline-flex;\n align-items: center;\n vertical-align: middle;\n}\n\n.profile-form textarea {\n width: 100%;\n box-sizing: border-box;\n margin-top: var(--spacing-xs);\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n/* Add horizontal gap between label and textarea for all label+textarea pairs. */\n.profile-form div:has(> a) + div:has(textarea) {\n margin-left: var(--spacing-sm);\n}\n\n/* Center textarea label vertically in flex rows. */\n.profile-form div[style*="display: flex"][style*="flex-direction: row"]:has(textarea) {\n align-items: flex-start;\n}\n\n.profile-form div[style*="display: flex"][style*="flex-direction: row"]:has(textarea) > div:has(> a) {\n padding-top: var(--spacing-xs);\n}\n\n.profile-form input:not([type="color"]) {\n width: 100%;\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n/* Remove padding from table cells within webidControl */\n.webidControl table td {\n padding: 0 !important;\n}\n\n/* Remove padding from contactPane divs inside webidControl table cells */\n.webidControl table td div.contactPane.namedPane.fullWidth.individualPane {\n padding: 0 !important;\n}\n\n.webidControl table td div.contactPane.namedPane {\n border: none !important;\n}\n',"",{version:3,sources:["webpack://./src/styles/rdfFormsEnforced.css"],names:[],mappings:"AAAA,yDAAyD;AACzD;EACE,iDAAiD;AACnD;;AAEA;EACE,wCAAwC;EACxC,uBAAuB;EACvB,oBAAoB;EACpB,2BAA2B;EAC3B,yBAAyB;EACzB,eAAe;EACf,oBAAoB;EACpB,mBAAmB;EACnB,uBAAuB;AACzB;;AAEA;EACE,uBAAuB;EACvB,wBAAwB;EACxB,cAAc;EACd,wBAAwB;EACxB,yBAAyB;EACzB,0BAA0B;EAC1B,+BAA+B;AACjC;;AAEA;EACE,oBAAoB;EACpB,mBAAmB;EACnB,kBAAkB;AACpB;;AAEA;EACE,oBAAoB;EACpB,mBAAmB;AACrB;;AAEA;EACE,kBAAkB;AACpB;;AAEA;EACE,wCAAwC;AAC1C;;AAEA;EACE,wCAAwC;EACxC,uBAAuB;EACvB,oBAAoB;EACpB,2BAA2B;AAC7B;;AAEA;;AAEA;;AAEA;;;EAGE,eAAe;EACf,YAAY;EACZ,uBAAuB;EACvB,iCAAiC;EACjC;AACF;;AAEA;EACE,WAAW;AACb;;AAEA;EACE,YAAY;EACZ,gCAAgC;AAClC;;AAEA;EACE,oBAAoB;EACpB,qBAAqB;AACvB;;AAEA;EACE,qBAAqB;AACvB;;AAEA;;;EAGE,WAAW;EACX,eAAe;AACjB;;AAEA;EACE,WAAW;EACX,cAAc;EACd,sBAAsB;EACtB,yBAAyB;EACzB,0BAA0B;AAC5B;;AAEA;EACE,yBAAyB;EACzB,sBAAsB;AACxB;;AAEA,oFAAoF;AACpF;;EAEE,uBAAuB;EACvB,qBAAqB;AACvB;;AAEA,0FAA0F;AAC1F;EACE,uBAAuB;EACvB,qBAAqB;AACvB;;AAEA,sEAAsE;AACtE;EACE,uBAAuB;EACvB,qBAAqB;AACvB;;AAEA,8FAA8F;AAC9F;;;;;EAKE,oBAAoB;EACpB,mBAAmB;EACnB,sBAAsB;AACxB;;AAEA;;;;;EAKE,oBAAoB;EACpB,mBAAmB;EACnB,sBAAsB;AACxB;;AAEA;EACE,WAAW;EACX,sBAAsB;EACtB,6BAA6B;EAC7B,yBAAyB;EACzB,0BAA0B;AAC5B;;AAEA,gFAAgF;AAChF;EACE,8BAA8B;AAChC;;AAEA,mDAAmD;AACnD;EACE,uBAAuB;AACzB;;AAEA;EACE,8BAA8B;AAChC;;AAEA;EACE,WAAW;EACX,yBAAyB;EACzB,0BAA0B;AAC5B;;AAEA,wDAAwD;AACxD;EACE,qBAAqB;AACvB;;AAEA,yEAAyE;AACzE;EACE,qBAAqB;AACvB;;AAEA;EACE,uBAAuB;AACzB",sourcesContent:['/* Solid-UI form sizing fixes scoped to Edit CV section */\n.profile-form .hoverControl:not(:has(> img:first-child)) {\n border: 0.1em solid rgb(136, 136, 136) !important;\n}\n\n.profile-form .hoverControl:has(> img:first-child) {\n background-color: transparent !important;\n border: none !important;\n margin: 0 !important;\n border-radius: 0 !important;\n padding: 0.7em !important;\n cursor: pointer;\n display: inline-flex;\n align-items: center;\n justify-content: center;\n}\n\n.profile-form .hoverControlHide {\n width: 1.5em !important;\n height: 1.5em !important;\n display: block;\n margin-top: 0 !important;\n margin-left: 0 !important;\n margin-right: 0 !important;\n margin-bottom: 0.3em !important;\n}\n\n.profile-form .hoverControl:has(> img:first-child) > span {\n display: inline-flex;\n align-items: center;\n margin-left: 0.3em;\n}\n\n.profile-form div[style*="padding: 0.5em"]:has(> img) {\n display: inline-flex;\n align-items: center;\n}\n\n.profile-form div[style*="padding: 0.5em"]:has(> img) > span {\n margin-left: 0.3em;\n}\n\n.profile-form .hoverControl:has(> img:first-child):hover {\n background-color: transparent !important;\n}\n\n.profile-form button:has(> img[src$=".svg"]) {\n background-color: transparent !important;\n border: none !important;\n margin: 0 !important;\n border-radius: 0 !important;\n}\n\n.profile-form button {\n\n}\n\n.profile-form input:not([type="color"]),\n.profile-form textarea,\n.profile-form select {\n max-width: 100%;\n min-width: 0;\n box-sizing: border-box ;\n background-color: #eef !important;\n border: .05em solid #88c\n}\n\n.profile-form input[type="url"] {\n width: 100%;\n}\n\n.profile-form .formFieldValue {\n min-width: 0;\n margin-bottom: var(--spacing-sm);\n}\n\n.profile-form .formFieldValue table {\n margin: 0 !important;\n padding: 0 !important;\n}\n\n.profile-form .formFieldValue td {\n padding: 0 !important;\n}\n\n.profile-form .formFieldValue input:not([type="color"]),\n.profile-form .formFieldValue textarea,\n.profile-form .formFieldValue select {\n width: 100%;\n max-width: 100%;\n}\n\n.profile-form select#formSelect {\n width: 100%;\n max-width: 97%;\n box-sizing: border-box;\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n.profile-form span select {\n max-width: 96% !important;\n box-sizing: border-box;\n}\n\n/* Remove border/padding from the first wrapper div (and its first child wrapper). */\n.profile-form > div:first-of-type,\n.profile-form > div:first-of-type > div:first-of-type {\n border: none !important;\n padding: 0 !important;\n}\n\n/* Remove border/padding from the inner div of the first wrapper in the contact section. */\nsection[aria-labelledby="edit-profile-contact-heading"] .profile-form > div:first-of-type > div:first-of-type {\n border: none !important;\n padding: 0 !important;\n}\n\n/* In contactPane, remove border/padding from all direct child divs. */\n.contactPane > div {\n border: none !important;\n padding: 0 !important;\n}\n\n/* Align schema.org, solid terms, FOAF, vCard, and org field labels with their input values. */\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://schema.org/"]),\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/solid/terms#"]),\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://xmlns.com/foaf/0.1/"]),\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/2006/vcard/ns"]),\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/org#"]) {\n display: inline-flex;\n align-items: center;\n vertical-align: middle;\n}\n\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://schema.org/"]) + .formFieldValue,\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/solid/terms#"]) + .formFieldValue,\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://xmlns.com/foaf/0.1/"]) + .formFieldValue,\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/2006/vcard/ns"]) + .formFieldValue,\n.profile-form :not(.choiceBox) > .formFieldName:has(a[href*="http://www.w3.org/ns/org#"]) + .formFieldValue {\n display: inline-flex;\n align-items: center;\n vertical-align: middle;\n}\n\n.profile-form textarea {\n width: 100%;\n box-sizing: border-box;\n margin-top: var(--spacing-xs);\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n/* Add horizontal gap between label and textarea for all label+textarea pairs. */\n.profile-form div:has(> a) + div:has(textarea) {\n margin-left: var(--spacing-sm);\n}\n\n/* Center textarea label vertically in flex rows. */\n.profile-form div[style*="display: flex"][style*="flex-direction: row"]:has(textarea) {\n align-items: flex-start;\n}\n\n.profile-form div[style*="display: flex"][style*="flex-direction: row"]:has(textarea) > div:has(> a) {\n padding-top: var(--spacing-xs);\n}\n\n.profile-form input:not([type="color"]) {\n width: 100%;\n margin-left: 0 !important;\n margin-right: 0 !important;\n}\n\n/* Remove padding from table cells within webidControl */\n.webidControl table td {\n padding: 0 !important;\n}\n\n/* Remove padding from contactPane divs inside webidControl table cells */\n.webidControl table td div.contactPane.namedPane.fullWidth.individualPane {\n padding: 0 !important;\n}\n\n.webidControl table td div.contactPane.namedPane {\n border: none !important;\n}\n'],sourceRoot:""}]);const s=i},5092(n,e,t){"use strict";t.d(e,{A:()=>s});var o=t(1354),r=t.n(o),a=t(6314),i=t.n(a)()(r());i.push([n.id,'/* Utility-first CSS classes for layout, spacing, and responsiveness */\n\n.actionButton {\n width: 100%;\n min-width: 180px;\n max-width: 320px;\n box-sizing: border-box;\n display: inline-block;\n}\n\n.selectedButton {\n background-color: var(--color-primary) !important;\n color: white !important;\n border: 1px solid white !important;\n}\n/* ===========================================\n PROFILE GRID LAYOUT\n =========================================== */\n\n.profile-grid {\n display: grid;\n grid-template-columns: repeat(auto-fit, minmax(30em, 1fr));\n gap: var(--spacing-lg);\n background: var(--color-background);\n}\n\n.profile-header,\n.profile-footer {\n grid-column: 1 / -1;\n}\n\n.center {\n justify-content: center;\n align-items: center;\n}\n\n.flex {\n display: flex;\n}\n.grid {\n display: grid;\n}\n\n/* Spacing utilities using CSS variables */\n.gap-xs { gap: var(--spacing-xs); }\n.gap-sm { gap: var(--spacing-sm); }\n.gap-md { gap: var(--spacing-md); }\n.gap-lg { gap: var(--spacing-lg); }\n.gap-xl { gap: var(--spacing-xl); }\n\n.mt-xs { margin-top: var(--spacing-xs); }\n.mt-sm { margin-top: var(--spacing-sm); }\n.mt-md { margin-top: var(--spacing-md); }\n.mt-lg { margin-top: var(--spacing-lg); }\n\n.mb-xs { margin-bottom: var(--spacing-xs); }\n.mb-sm { margin-bottom: var(--spacing-sm); }\n.mb-md { margin-bottom: var(--spacing-md); }\n.mb-lg { margin-bottom: var(--spacing-lg); }\n\n.p-xs { padding: var(--spacing-xs); }\n.p-sm { padding: var(--spacing-sm); }\n.p-md { padding: var(--spacing-md); }\n.p-lg { padding: var(--spacing-lg); }\n\n.rounded { border-radius: var(--border-radius-full); }\n.rounded-sm { border-radius: var(--border-radius-base); }\n\n.shadow { box-shadow: var(--box-shadow); }\n.shadow-sm { box-shadow: var(--box-shadow-sm); }\n\n.bg-primary {\n background: var(--color-primary);\n color: #fff;\n}\n.bg-card {\n background: var(--color-card-bg);\n}\n\n/* Accessibility utilities */\n.sr-only {\n position: absolute;\n width: 1px;\n height: 1px;\n padding: 0;\n margin: -1px;\n overflow: hidden;\n clip: rect(0, 0, 0, 0);\n white-space: nowrap;\n border: 0;\n}\n\n.min-touch-target {\n min-height: var(--min-touch-target);\n min-width: var(--min-touch-target);\n}\n\n/* Enhanced accessibility utilities */\n.visually-hidden {\n position: absolute !important;\n width: 1px !important;\n height: 1px !important;\n padding: 0 !important;\n margin: -1px !important;\n overflow: hidden !important;\n clip: rect(0, 0, 0, 0) !important;\n white-space: nowrap !important;\n border: 0 !important;\n}\n\n.visually-hidden.focusable:focus,\n.visually-hidden.focusable:active {\n position: static !important;\n width: auto !important;\n height: auto !important;\n padding: inherit !important;\n margin: inherit !important;\n overflow: visible !important;\n clip: auto !important;\n white-space: inherit !important;\n}\n\n/* Skip links utility */\n.skip-links {\n position: absolute;\n top: -100px;\n left: 0;\n z-index: 1000;\n}\n\n.skip-links a {\n position: absolute;\n left: 6px;\n top: 6px;\n padding: var(--spacing-sm);\n background: var(--color-primary);\n color: white;\n text-decoration: none;\n border-radius: var(--border-radius-base);\n}\n\n.skip-links a:focus {\n top: 6px;\n}\n\n.reduced-motion {\n animation: none !important;\n transition: none !important;\n}\n\n/* Focus management */\n.focus-ring {\n outline: 2px solid var(--color-primary);\n outline-offset: 2px;\n}\n\n.no-focus-ring {\n outline: none;\n}\n\n.no-focus-ring:focus-visible {\n outline: none;\n box-shadow: none;\n}\n\n/* ARIA live regions */\n.live-region {\n position: absolute;\n left: -10000px;\n width: 1px;\n height: 1px;\n overflow: hidden;\n}\n\n/* Note: Use aria-live="polite" or aria-live="assertive" HTML attributes with .live-region */\n\n/* Text scaling utilities */\n.text-scale-friendly {\n line-height: 1.5;\n max-width: 70ch; /* Optimal reading length */\n}\n\n/* Text accessibility utilities */\n.text-readable {\n line-height: var(--line-height-base);\n max-width: 65ch;\n}\n\n.text-lg {\n font-size: var(--font-size-lg);\n line-height: var(--line-height-base);\n}\n\n.text-small {\n font-size: max(var(--font-size-sm), var(--min-font-size));\n line-height: var(--min-line-height);\n}\n\n.text-contrast-high {\n color: var(--color-text);\n font-weight: 600;\n}\n\n:focus-visible {\n outline: var(--focus-ring-width) solid var(--color-primary);\n outline-offset: 2px;\n box-shadow: 0 0 0 1px var(--color-background);\n}\n\n:focus:not(:focus-visible) {\n outline: none;\n box-shadow: none;\n}\n\n/* Better focus for text elements */\n.focusable-text:focus {\n background-color: rgba(124, 77, 255, 0.1);\n outline: 2px solid var(--color-primary);\n outline-offset: 2px;\n border-radius: 2px;\n}\n\n/* High contrast text */\n.high-contrast {\n color: var(--color-text);\n background: var(--color-background);\n border: 1px solid var(--color-border-pale);\n}\n\n/* ===========================================\n CONSOLIDATED COMPONENT PATTERNS\n =========================================== */\n\n/* Primary Button - used by ChatWithMe, ProfileCard */\n.btn-primary {\n min-height: var(--min-touch-target);\n padding: var(--spacing-sm) var(--spacing-md);\n border: 1px solid var(--color-primary);\n border-radius: var(--border-radius-base);\n background: var(--color-primary);\n color: white;\n font-weight: 600;\n cursor: pointer;\n transition: all var(--animation-duration) ease;\n}\n\n.btn-primary:hover {\n background: color-mix(in srgb, var(--color-primary) 90%, black);\n box-shadow: 0 2px 4px rgba(124, 77, 255, 0.2);\n}\n\n.btn-primary:active {\n box-shadow: 0 1px 2px rgba(124, 77, 255, 0.2);\n}\n\n.btn-primary:disabled {\n opacity: 0.6;\n cursor: not-allowed;\n transform: none;\n}\n\n/* Action Button Focus - used by ChatWithMe, ProfileCard */\n.action-button-focus:focus,\n.action-button-focus:focus-visible {\n outline: 3px solid var(--color-primary) !important;\n outline-offset: 2px !important;\n box-shadow: 0 0 0 2px var(--color-background), 0 0 0 5px rgba(124, 77, 255, 0.25) !important;\n z-index: 1;\n}\n\n/* List Reset - used by FriendList, SocialCard, nav */\n.list-reset {\n list-style: none;\n padding: 0;\n margin: 0;\n}\n\n/* Zebra Striping - used by FriendList, StuffCard tables */\n.zebra-stripe tr:nth-child(even),\n.zebra-stripe > *:nth-child(even) {\n background-color: rgba(0, 0, 0, 0.02);\n}\n\n/* Section Title - primary colored heading */\n.section-title {\n font-size: 1.25em;\n font-weight: 600;\n color: var(--color-primary);\n margin: 0;\n}\n\n/* Text Overflow - used by ProfileCard, SocialCard */\n.text-truncate {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n}\n\n.text-wrap-anywhere {\n overflow-wrap: anywhere;\n word-break: break-word;\n}\n\n/* Loading Text - primary colored centered loading indicator */\n.loading-text {\n color: var(--color-primary);\n text-align: center;\n margin: var(--spacing-md) 0;\n}\n\n/* Centered Section - flex column with center alignment */\n.section-centered {\n display: flex;\n flex-direction: column;\n align-items: center;\n}\n\n/* Card Section Background */\n.section-bg {\n background: var(--color-section-bg);\n border-radius: var(--border-radius-full);\n box-shadow: var(--box-shadow);\n padding: var(--spacing-md);\n}\n\n\n/* Transparent button override (for solid-ui integration) */\n.btn-transparent {\n background-color: transparent;\n}\n\n.btn-transparent:hover {\n background-color: transparent;\n}\n\n/* input */\n.input {\n padding: 5px;\n min-height: var(--min-touch-target);\n height: 35px;\n box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px;\n border: none;\n border-radius: var(--border-radius-base);\n background: white;\n font-weight: 600;\n font-size: var(--font-size-sm);\n transition: box-shadow 0.3s ease;\n}\n\n.input:focus,\n.input:focus-visible {\n border-radius: var(--border-radius-base);\n box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px !important;\n z-index: 1;\n}\n\ninput[type="radio"] {\n accent-color: var(--color-secondary); /* Change to your desired color */\n}\n',"",{version:3,sources:["webpack://./src/styles/utilities.css"],names:[],mappings:"AAAA,sEAAsE;;AAEtE;EACE,WAAW;EACX,gBAAgB;EAChB,gBAAgB;EAChB,sBAAsB;EACtB,qBAAqB;AACvB;;AAEA;EACE,iDAAiD;EACjD,uBAAuB;EACvB,kCAAkC;AACpC;AACA;;gDAEgD;;AAEhD;EACE,aAAa;EACb,0DAA0D;EAC1D,sBAAsB;EACtB,mCAAmC;AACrC;;AAEA;;EAEE,mBAAmB;AACrB;;AAEA;EACE,uBAAuB;EACvB,mBAAmB;AACrB;;AAEA;EACE,aAAa;AACf;AACA;EACE,aAAa;AACf;;AAEA,0CAA0C;AAC1C,UAAU,sBAAsB,EAAE;AAClC,UAAU,sBAAsB,EAAE;AAClC,UAAU,sBAAsB,EAAE;AAClC,UAAU,sBAAsB,EAAE;AAClC,UAAU,sBAAsB,EAAE;;AAElC,SAAS,6BAA6B,EAAE;AACxC,SAAS,6BAA6B,EAAE;AACxC,SAAS,6BAA6B,EAAE;AACxC,SAAS,6BAA6B,EAAE;;AAExC,SAAS,gCAAgC,EAAE;AAC3C,SAAS,gCAAgC,EAAE;AAC3C,SAAS,gCAAgC,EAAE;AAC3C,SAAS,gCAAgC,EAAE;;AAE3C,QAAQ,0BAA0B,EAAE;AACpC,QAAQ,0BAA0B,EAAE;AACpC,QAAQ,0BAA0B,EAAE;AACpC,QAAQ,0BAA0B,EAAE;;AAEpC,WAAW,wCAAwC,EAAE;AACrD,cAAc,wCAAwC,EAAE;;AAExD,UAAU,6BAA6B,EAAE;AACzC,aAAa,gCAAgC,EAAE;;AAE/C;EACE,gCAAgC;EAChC,WAAW;AACb;AACA;EACE,gCAAgC;AAClC;;AAEA,4BAA4B;AAC5B;EACE,kBAAkB;EAClB,UAAU;EACV,WAAW;EACX,UAAU;EACV,YAAY;EACZ,gBAAgB;EAChB,sBAAsB;EACtB,mBAAmB;EACnB,SAAS;AACX;;AAEA;EACE,mCAAmC;EACnC,kCAAkC;AACpC;;AAEA,qCAAqC;AACrC;EACE,6BAA6B;EAC7B,qBAAqB;EACrB,sBAAsB;EACtB,qBAAqB;EACrB,uBAAuB;EACvB,2BAA2B;EAC3B,iCAAiC;EACjC,8BAA8B;EAC9B,oBAAoB;AACtB;;AAEA;;EAEE,2BAA2B;EAC3B,sBAAsB;EACtB,uBAAuB;EACvB,2BAA2B;EAC3B,0BAA0B;EAC1B,4BAA4B;EAC5B,qBAAqB;EACrB,+BAA+B;AACjC;;AAEA,uBAAuB;AACvB;EACE,kBAAkB;EAClB,WAAW;EACX,OAAO;EACP,aAAa;AACf;;AAEA;EACE,kBAAkB;EAClB,SAAS;EACT,QAAQ;EACR,0BAA0B;EAC1B,gCAAgC;EAChC,YAAY;EACZ,qBAAqB;EACrB,wCAAwC;AAC1C;;AAEA;EACE,QAAQ;AACV;;AAEA;EACE,0BAA0B;EAC1B,2BAA2B;AAC7B;;AAEA,qBAAqB;AACrB;EACE,uCAAuC;EACvC,mBAAmB;AACrB;;AAEA;EACE,aAAa;AACf;;AAEA;EACE,aAAa;EACb,gBAAgB;AAClB;;AAEA,sBAAsB;AACtB;EACE,kBAAkB;EAClB,cAAc;EACd,UAAU;EACV,WAAW;EACX,gBAAgB;AAClB;;AAEA,4FAA4F;;AAE5F,2BAA2B;AAC3B;EACE,gBAAgB;EAChB,eAAe,EAAE,2BAA2B;AAC9C;;AAEA,iCAAiC;AACjC;EACE,oCAAoC;EACpC,eAAe;AACjB;;AAEA;EACE,8BAA8B;EAC9B,oCAAoC;AACtC;;AAEA;EACE,yDAAyD;EACzD,mCAAmC;AACrC;;AAEA;EACE,wBAAwB;EACxB,gBAAgB;AAClB;;AAEA;EACE,2DAA2D;EAC3D,mBAAmB;EACnB,6CAA6C;AAC/C;;AAEA;EACE,aAAa;EACb,gBAAgB;AAClB;;AAEA,mCAAmC;AACnC;EACE,yCAAyC;EACzC,uCAAuC;EACvC,mBAAmB;EACnB,kBAAkB;AACpB;;AAEA,uBAAuB;AACvB;EACE,wBAAwB;EACxB,mCAAmC;EACnC,0CAA0C;AAC5C;;AAEA;;gDAEgD;;AAEhD,qDAAqD;AACrD;EACE,mCAAmC;EACnC,4CAA4C;EAC5C,sCAAsC;EACtC,wCAAwC;EACxC,gCAAgC;EAChC,YAAY;EACZ,gBAAgB;EAChB,eAAe;EACf,8CAA8C;AAChD;;AAEA;EACE,+DAA+D;EAC/D,6CAA6C;AAC/C;;AAEA;EACE,6CAA6C;AAC/C;;AAEA;EACE,YAAY;EACZ,mBAAmB;EACnB,eAAe;AACjB;;AAEA,0DAA0D;AAC1D;;EAEE,kDAAkD;EAClD,8BAA8B;EAC9B,4FAA4F;EAC5F,UAAU;AACZ;;AAEA,qDAAqD;AACrD;EACE,gBAAgB;EAChB,UAAU;EACV,SAAS;AACX;;AAEA,0DAA0D;AAC1D;;EAEE,qCAAqC;AACvC;;AAEA,4CAA4C;AAC5C;EACE,iBAAiB;EACjB,gBAAgB;EAChB,2BAA2B;EAC3B,SAAS;AACX;;AAEA,oDAAoD;AACpD;EACE,mBAAmB;EACnB,uBAAuB;EACvB,gBAAgB;AAClB;;AAEA;EACE,uBAAuB;EACvB,sBAAsB;AACxB;;AAEA,8DAA8D;AAC9D;EACE,2BAA2B;EAC3B,kBAAkB;EAClB,2BAA2B;AAC7B;;AAEA,yDAAyD;AACzD;EACE,aAAa;EACb,sBAAsB;EACtB,mBAAmB;AACrB;;AAEA,4BAA4B;AAC5B;EACE,mCAAmC;EACnC,wCAAwC;EACxC,6BAA6B;EAC7B,0BAA0B;AAC5B;;;AAGA,2DAA2D;AAC3D;EACE,6BAA6B;AAC/B;;AAEA;EACE,6BAA6B;AAC/B;;AAEA,UAAU;AACV;EACE,YAAY;EACZ,mCAAmC;EACnC,YAAY;EACZ,2CAA2C;EAC3C,YAAY;EACZ,wCAAwC;EACxC,iBAAiB;EACjB,gBAAgB;EAChB,8BAA8B;EAC9B,gCAAgC;AAClC;;AAEA;;EAEE,wCAAwC;EACxC,sDAAsD;EACtD,UAAU;AACZ;;AAEA;EACE,oCAAoC,EAAE,iCAAiC;AACzE",sourcesContent:['/* Utility-first CSS classes for layout, spacing, and responsiveness */\n\n.actionButton {\n width: 100%;\n min-width: 180px;\n max-width: 320px;\n box-sizing: border-box;\n display: inline-block;\n}\n\n.selectedButton {\n background-color: var(--color-primary) !important;\n color: white !important;\n border: 1px solid white !important;\n}\n/* ===========================================\n PROFILE GRID LAYOUT\n =========================================== */\n\n.profile-grid {\n display: grid;\n grid-template-columns: repeat(auto-fit, minmax(30em, 1fr));\n gap: var(--spacing-lg);\n background: var(--color-background);\n}\n\n.profile-header,\n.profile-footer {\n grid-column: 1 / -1;\n}\n\n.center {\n justify-content: center;\n align-items: center;\n}\n\n.flex {\n display: flex;\n}\n.grid {\n display: grid;\n}\n\n/* Spacing utilities using CSS variables */\n.gap-xs { gap: var(--spacing-xs); }\n.gap-sm { gap: var(--spacing-sm); }\n.gap-md { gap: var(--spacing-md); }\n.gap-lg { gap: var(--spacing-lg); }\n.gap-xl { gap: var(--spacing-xl); }\n\n.mt-xs { margin-top: var(--spacing-xs); }\n.mt-sm { margin-top: var(--spacing-sm); }\n.mt-md { margin-top: var(--spacing-md); }\n.mt-lg { margin-top: var(--spacing-lg); }\n\n.mb-xs { margin-bottom: var(--spacing-xs); }\n.mb-sm { margin-bottom: var(--spacing-sm); }\n.mb-md { margin-bottom: var(--spacing-md); }\n.mb-lg { margin-bottom: var(--spacing-lg); }\n\n.p-xs { padding: var(--spacing-xs); }\n.p-sm { padding: var(--spacing-sm); }\n.p-md { padding: var(--spacing-md); }\n.p-lg { padding: var(--spacing-lg); }\n\n.rounded { border-radius: var(--border-radius-full); }\n.rounded-sm { border-radius: var(--border-radius-base); }\n\n.shadow { box-shadow: var(--box-shadow); }\n.shadow-sm { box-shadow: var(--box-shadow-sm); }\n\n.bg-primary {\n background: var(--color-primary);\n color: #fff;\n}\n.bg-card {\n background: var(--color-card-bg);\n}\n\n/* Accessibility utilities */\n.sr-only {\n position: absolute;\n width: 1px;\n height: 1px;\n padding: 0;\n margin: -1px;\n overflow: hidden;\n clip: rect(0, 0, 0, 0);\n white-space: nowrap;\n border: 0;\n}\n\n.min-touch-target {\n min-height: var(--min-touch-target);\n min-width: var(--min-touch-target);\n}\n\n/* Enhanced accessibility utilities */\n.visually-hidden {\n position: absolute !important;\n width: 1px !important;\n height: 1px !important;\n padding: 0 !important;\n margin: -1px !important;\n overflow: hidden !important;\n clip: rect(0, 0, 0, 0) !important;\n white-space: nowrap !important;\n border: 0 !important;\n}\n\n.visually-hidden.focusable:focus,\n.visually-hidden.focusable:active {\n position: static !important;\n width: auto !important;\n height: auto !important;\n padding: inherit !important;\n margin: inherit !important;\n overflow: visible !important;\n clip: auto !important;\n white-space: inherit !important;\n}\n\n/* Skip links utility */\n.skip-links {\n position: absolute;\n top: -100px;\n left: 0;\n z-index: 1000;\n}\n\n.skip-links a {\n position: absolute;\n left: 6px;\n top: 6px;\n padding: var(--spacing-sm);\n background: var(--color-primary);\n color: white;\n text-decoration: none;\n border-radius: var(--border-radius-base);\n}\n\n.skip-links a:focus {\n top: 6px;\n}\n\n.reduced-motion {\n animation: none !important;\n transition: none !important;\n}\n\n/* Focus management */\n.focus-ring {\n outline: 2px solid var(--color-primary);\n outline-offset: 2px;\n}\n\n.no-focus-ring {\n outline: none;\n}\n\n.no-focus-ring:focus-visible {\n outline: none;\n box-shadow: none;\n}\n\n/* ARIA live regions */\n.live-region {\n position: absolute;\n left: -10000px;\n width: 1px;\n height: 1px;\n overflow: hidden;\n}\n\n/* Note: Use aria-live="polite" or aria-live="assertive" HTML attributes with .live-region */\n\n/* Text scaling utilities */\n.text-scale-friendly {\n line-height: 1.5;\n max-width: 70ch; /* Optimal reading length */\n}\n\n/* Text accessibility utilities */\n.text-readable {\n line-height: var(--line-height-base);\n max-width: 65ch;\n}\n\n.text-lg {\n font-size: var(--font-size-lg);\n line-height: var(--line-height-base);\n}\n\n.text-small {\n font-size: max(var(--font-size-sm), var(--min-font-size));\n line-height: var(--min-line-height);\n}\n\n.text-contrast-high {\n color: var(--color-text);\n font-weight: 600;\n}\n\n:focus-visible {\n outline: var(--focus-ring-width) solid var(--color-primary);\n outline-offset: 2px;\n box-shadow: 0 0 0 1px var(--color-background);\n}\n\n:focus:not(:focus-visible) {\n outline: none;\n box-shadow: none;\n}\n\n/* Better focus for text elements */\n.focusable-text:focus {\n background-color: rgba(124, 77, 255, 0.1);\n outline: 2px solid var(--color-primary);\n outline-offset: 2px;\n border-radius: 2px;\n}\n\n/* High contrast text */\n.high-contrast {\n color: var(--color-text);\n background: var(--color-background);\n border: 1px solid var(--color-border-pale);\n}\n\n/* ===========================================\n CONSOLIDATED COMPONENT PATTERNS\n =========================================== */\n\n/* Primary Button - used by ChatWithMe, ProfileCard */\n.btn-primary {\n min-height: var(--min-touch-target);\n padding: var(--spacing-sm) var(--spacing-md);\n border: 1px solid var(--color-primary);\n border-radius: var(--border-radius-base);\n background: var(--color-primary);\n color: white;\n font-weight: 600;\n cursor: pointer;\n transition: all var(--animation-duration) ease;\n}\n\n.btn-primary:hover {\n background: color-mix(in srgb, var(--color-primary) 90%, black);\n box-shadow: 0 2px 4px rgba(124, 77, 255, 0.2);\n}\n\n.btn-primary:active {\n box-shadow: 0 1px 2px rgba(124, 77, 255, 0.2);\n}\n\n.btn-primary:disabled {\n opacity: 0.6;\n cursor: not-allowed;\n transform: none;\n}\n\n/* Action Button Focus - used by ChatWithMe, ProfileCard */\n.action-button-focus:focus,\n.action-button-focus:focus-visible {\n outline: 3px solid var(--color-primary) !important;\n outline-offset: 2px !important;\n box-shadow: 0 0 0 2px var(--color-background), 0 0 0 5px rgba(124, 77, 255, 0.25) !important;\n z-index: 1;\n}\n\n/* List Reset - used by FriendList, SocialCard, nav */\n.list-reset {\n list-style: none;\n padding: 0;\n margin: 0;\n}\n\n/* Zebra Striping - used by FriendList, StuffCard tables */\n.zebra-stripe tr:nth-child(even),\n.zebra-stripe > *:nth-child(even) {\n background-color: rgba(0, 0, 0, 0.02);\n}\n\n/* Section Title - primary colored heading */\n.section-title {\n font-size: 1.25em;\n font-weight: 600;\n color: var(--color-primary);\n margin: 0;\n}\n\n/* Text Overflow - used by ProfileCard, SocialCard */\n.text-truncate {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden;\n}\n\n.text-wrap-anywhere {\n overflow-wrap: anywhere;\n word-break: break-word;\n}\n\n/* Loading Text - primary colored centered loading indicator */\n.loading-text {\n color: var(--color-primary);\n text-align: center;\n margin: var(--spacing-md) 0;\n}\n\n/* Centered Section - flex column with center alignment */\n.section-centered {\n display: flex;\n flex-direction: column;\n align-items: center;\n}\n\n/* Card Section Background */\n.section-bg {\n background: var(--color-section-bg);\n border-radius: var(--border-radius-full);\n box-shadow: var(--box-shadow);\n padding: var(--spacing-md);\n}\n\n\n/* Transparent button override (for solid-ui integration) */\n.btn-transparent {\n background-color: transparent;\n}\n\n.btn-transparent:hover {\n background-color: transparent;\n}\n\n/* input */\n.input {\n padding: 5px;\n min-height: var(--min-touch-target);\n height: 35px;\n box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px;\n border: none;\n border-radius: var(--border-radius-base);\n background: white;\n font-weight: 600;\n font-size: var(--font-size-sm);\n transition: box-shadow 0.3s ease;\n}\n\n.input:focus,\n.input:focus-visible {\n border-radius: var(--border-radius-base);\n box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px !important;\n z-index: 1;\n}\n\ninput[type="radio"] {\n accent-color: var(--color-secondary); /* Change to your desired color */\n}\n'],sourceRoot:""}]);const s=i},6314(n){"use strict";n.exports=function(n){var e=[];return e.toString=function(){return this.map(function(e){var t="",o=void 0!==e[5];return e[4]&&(t+="@supports (".concat(e[4],") {")),e[2]&&(t+="@media ".concat(e[2]," {")),o&&(t+="@layer".concat(e[5].length>0?" ".concat(e[5]):""," {")),t+=n(e),o&&(t+="}"),e[2]&&(t+="}"),e[4]&&(t+="}"),t}).join("")},e.i=function(n,t,o,r,a){"string"==typeof n&&(n=[[null,n,void 0]]);var i={};if(o)for(var s=0;s<this.length;s++){var d=this[s][0];null!=d&&(i[d]=!0)}for(var l=0;l<n.length;l++){var c=[].concat(n[l]);o&&i[c[0]]||(void 0!==a&&(void 0===c[5]||(c[1]="@layer".concat(c[5].length>0?" ".concat(c[5]):""," {").concat(c[1],"}")),c[5]=a),t&&(c[2]?(c[1]="@media ".concat(c[2]," {").concat(c[1],"}"),c[2]=t):c[2]=t),r&&(c[4]?(c[1]="@supports (".concat(c[4],") {").concat(c[1],"}"),c[4]=r):c[4]="".concat(r)),e.push(c))}},e}},1354(n){"use strict";n.exports=function(n){var e=n[1],t=n[3];if(!t)return e;if("function"==typeof btoa){var o=btoa(unescape(encodeURIComponent(JSON.stringify(t)))),r="sourceMappingURL=data:application/json;charset=utf-8;base64,".concat(o),a="/*# ".concat(r," */");return[e].concat([a]).join("\n")}return[e].join("\n")}},6320(n){"use strict";var e={single_source_shortest_paths:function(n,t,o){var r={},a={};a[t]=0;var i,s,d,l,c,u,p,A=e.PriorityQueue.make();for(A.push(t,0);!A.empty();)for(d in s=(i=A.pop()).value,l=i.cost,c=n[s]||{})c.hasOwnProperty(d)&&(u=l+c[d],p=a[d],(void 0===a[d]||p>u)&&(a[d]=u,A.push(d,u),r[d]=s));if(void 0!==o&&void 0===a[o]){var m=["Could not find a path from ",t," to ",o,"."].join("");throw new Error(m)}return r},extract_shortest_path_from_predecessor_list:function(n,e){for(var t=[],o=e;o;)t.push(o),n[o],o=n[o];return t.reverse(),t},find_path:function(n,t,o){var r=e.single_source_shortest_paths(n,t,o);return e.extract_shortest_path_from_predecessor_list(r,o)},PriorityQueue:{make:function(n){var t,o=e.PriorityQueue,r={};for(t in n=n||{},o)o.hasOwnProperty(t)&&(r[t]=o[t]);return r.queue=[],r.sorter=n.sorter||o.default_sorter,r},default_sorter:function(n,e){return n.cost-e.cost},push:function(n,e){var t={value:n,cost:e};this.queue.push(t),this.queue.sort(this.sorter)},pop:function(){return this.queue.shift()},empty:function(){return 0===this.queue.length}}};n.exports=e},7583(n,e,t){const o=t(1333),r=t(157),a=t(7899),i=t(6756);function s(n,e,t,a,i){const s=[].slice.call(arguments,1),d=s.length,l="function"==typeof s[d-1];if(!l&&!o())throw new Error("Callback required as last argument");if(!l){if(d<1)throw new Error("Too few arguments provided");return 1===d?(t=e,e=a=void 0):2!==d||e.getContext||(a=t,t=e,e=void 0),new Promise(function(o,i){try{const i=r.create(t,a);o(n(i,e,a))}catch(n){i(n)}})}if(d<2)throw new Error("Too few arguments provided");2===d?(i=t,t=e,e=a=void 0):3===d&&(e.getContext&&void 0===i?(i=a,a=void 0):(i=a,a=t,t=e,e=void 0));try{const o=r.create(t,a);i(null,n(o,e,a))}catch(n){i(n)}}r.create,s.bind(null,a.render),s.bind(null,a.renderToDataURL),e.toString=s.bind(null,function(n,e,t){return i.render(n,t)})},1333(n){n.exports=function(){return"function"==typeof Promise&&Promise.prototype&&Promise.prototype.then}},6421(n,e,t){const o=t(6886).getSymbolSize;e.getRowColCoords=function(n){if(1===n)return[];const e=Math.floor(n/7)+2,t=o(n),r=145===t?26:2*Math.ceil((t-13)/(2*e-2)),a=[t-7];for(let n=1;n<e-1;n++)a[n]=a[n-1]-r;return a.push(6),a.reverse()},e.getPositions=function(n){const t=[],o=e.getRowColCoords(n),r=o.length;for(let n=0;n<r;n++)for(let e=0;e<r;e++)0===n&&0===e||0===n&&e===r-1||n===r-1&&0===e||t.push([o[n],o[e]]);return t}},1433(n,e,t){const o=t(208),r=["0","1","2","3","4","5","6","7","8","9","A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P","Q","R","S","T","U","V","W","X","Y","Z"," ","$","%","*","+","-",".","/",":"];function a(n){this.mode=o.ALPHANUMERIC,this.data=n}a.getBitsLength=function(n){return 11*Math.floor(n/2)+n%2*6},a.prototype.getLength=function(){return this.data.length},a.prototype.getBitsLength=function(){return a.getBitsLength(this.data.length)},a.prototype.write=function(n){let e;for(e=0;e+2<=this.data.length;e+=2){let t=45*r.indexOf(this.data[e]);t+=r.indexOf(this.data[e+1]),n.put(t,11)}this.data.length%2&&n.put(r.indexOf(this.data[e]),6)},n.exports=a},9899(n){function e(){this.buffer=[],this.length=0}e.prototype={get:function(n){const e=Math.floor(n/8);return 1==(this.buffer[e]>>>7-n%8&1)},put:function(n,e){for(let t=0;t<e;t++)this.putBit(1==(n>>>e-t-1&1))},getLengthInBits:function(){return this.length},putBit:function(n){const e=Math.floor(this.length/8);this.buffer.length<=e&&this.buffer.push(0),n&&(this.buffer[e]|=128>>>this.length%8),this.length++}},n.exports=e},8820(n){function e(n){if(!n||n<1)throw new Error("BitMatrix size must be defined and greater than 0");this.size=n,this.data=new Uint8Array(n*n),this.reservedBit=new Uint8Array(n*n)}e.prototype.set=function(n,e,t,o){const r=n*this.size+e;this.data[r]=t,o&&(this.reservedBit[r]=!0)},e.prototype.get=function(n,e){return this.data[n*this.size+e]},e.prototype.xor=function(n,e,t){this.data[n*this.size+e]^=t},e.prototype.isReserved=function(n,e){return this.reservedBit[n*this.size+e]},n.exports=e},5822(n,e,t){const o=t(208);function r(n){this.mode=o.BYTE,this.data="string"==typeof n?(new TextEncoder).encode(n):new Uint8Array(n)}r.getBitsLength=function(n){return 8*n},r.prototype.getLength=function(){return this.data.length},r.prototype.getBitsLength=function(){return r.getBitsLength(this.data.length)},r.prototype.write=function(n){for(let e=0,t=this.data.length;e<t;e++)n.put(this.data[e],8)},n.exports=r},7518(n,e,t){const o=t(9953),r=[1,1,1,1,1,1,1,1,1,1,2,2,1,2,2,4,1,2,4,4,2,4,4,4,2,4,6,5,2,4,6,6,2,5,8,8,4,5,8,8,4,5,8,11,4,8,10,11,4,9,12,16,4,9,16,16,6,10,12,18,6,10,17,16,6,11,16,19,6,13,18,21,7,14,21,25,8,16,20,25,8,17,23,25,9,17,23,34,9,18,25,30,10,20,27,32,12,21,29,35,12,23,34,37,12,25,34,40,13,26,35,42,14,28,38,45,15,29,40,48,16,31,43,51,17,33,45,54,18,35,48,57,19,37,51,60,19,38,53,63,20,40,56,66,21,43,59,70,22,45,62,74,24,47,65,77,25,49,68,81],a=[7,10,13,17,10,16,22,28,15,26,36,44,20,36,52,64,26,48,72,88,36,64,96,112,40,72,108,130,48,88,132,156,60,110,160,192,72,130,192,224,80,150,224,264,96,176,260,308,104,198,288,352,120,216,320,384,132,240,360,432,144,280,408,480,168,308,448,532,180,338,504,588,196,364,546,650,224,416,600,700,224,442,644,750,252,476,690,816,270,504,750,900,300,560,810,960,312,588,870,1050,336,644,952,1110,360,700,1020,1200,390,728,1050,1260,420,784,1140,1350,450,812,1200,1440,480,868,1290,1530,510,924,1350,1620,540,980,1440,1710,570,1036,1530,1800,570,1064,1590,1890,600,1120,1680,1980,630,1204,1770,2100,660,1260,1860,2220,720,1316,1950,2310,750,1372,2040,2430];e.getBlocksCount=function(n,e){switch(e){case o.L:return r[4*(n-1)+0];case o.M:return r[4*(n-1)+1];case o.Q:return r[4*(n-1)+2];case o.H:return r[4*(n-1)+3];default:return}},e.getTotalCodewordsCount=function(n,e){switch(e){case o.L:return a[4*(n-1)+0];case o.M:return a[4*(n-1)+1];case o.Q:return a[4*(n-1)+2];case o.H:return a[4*(n-1)+3];default:return}}},9953(n,e){e.L={bit:1},e.M={bit:0},e.Q={bit:3},e.H={bit:2},e.isValid=function(n){return n&&void 0!==n.bit&&n.bit>=0&&n.bit<4},e.from=function(n,t){if(e.isValid(n))return n;try{return function(n){if("string"!=typeof n)throw new Error("Param is not a string");switch(n.toLowerCase()){case"l":case"low":return e.L;case"m":case"medium":return e.M;case"q":case"quartile":return e.Q;case"h":case"high":return e.H;default:throw new Error("Unknown EC Level: "+n)}}(n)}catch(n){return t}}},7756(n,e,t){const o=t(6886).getSymbolSize;e.getPositions=function(n){const e=o(n);return[[0,0],[e-7,0],[0,e-7]]}},4565(n,e,t){const o=t(6886),r=o.getBCHDigit(1335);e.getEncodedBits=function(n,e){const t=n.bit<<3|e;let a=t<<10;for(;o.getBCHDigit(a)-r>=0;)a^=1335<<o.getBCHDigit(a)-r;return 21522^(t<<10|a)}},2731(n,e){const t=new Uint8Array(512),o=new Uint8Array(256);!function(){let n=1;for(let e=0;e<255;e++)t[e]=n,o[n]=e,n<<=1,256&n&&(n^=285);for(let n=255;n<512;n++)t[n]=t[n-255]}(),e.log=function(n){if(n<1)throw new Error("log("+n+")");return o[n]},e.exp=function(n){return t[n]},e.mul=function(n,e){return 0===n||0===e?0:t[o[n]+o[e]]}},4861(n,e,t){const o=t(208),r=t(6886);function a(n){this.mode=o.KANJI,this.data=n}a.getBitsLength=function(n){return 13*n},a.prototype.getLength=function(){return this.data.length},a.prototype.getBitsLength=function(){return a.getBitsLength(this.data.length)},a.prototype.write=function(n){let e;for(e=0;e<this.data.length;e++){let t=r.toSJIS(this.data[e]);if(t>=33088&&t<=40956)t-=33088;else{if(!(t>=57408&&t<=60351))throw new Error("Invalid SJIS character: "+this.data[e]+"\nMake sure your charset is UTF-8");t-=49472}t=192*(t>>>8&255)+(255&t),n.put(t,13)}},n.exports=a},1332(n,e){e.Patterns={PATTERN000:0,PATTERN001:1,PATTERN010:2,PATTERN011:3,PATTERN100:4,PATTERN101:5,PATTERN110:6,PATTERN111:7};const t=3,o=3,r=40,a=10;function i(n,t,o){switch(n){case e.Patterns.PATTERN000:return(t+o)%2==0;case e.Patterns.PATTERN001:return t%2==0;case e.Patterns.PATTERN010:return o%3==0;case e.Patterns.PATTERN011:return(t+o)%3==0;case e.Patterns.PATTERN100:return(Math.floor(t/2)+Math.floor(o/3))%2==0;case e.Patterns.PATTERN101:return t*o%2+t*o%3==0;case e.Patterns.PATTERN110:return(t*o%2+t*o%3)%2==0;case e.Patterns.PATTERN111:return(t*o%3+(t+o)%2)%2==0;default:throw new Error("bad maskPattern:"+n)}}e.isValid=function(n){return null!=n&&""!==n&&!isNaN(n)&&n>=0&&n<=7},e.from=function(n){return e.isValid(n)?parseInt(n,10):void 0},e.getPenaltyN1=function(n){const e=n.size;let o=0,r=0,a=0,i=null,s=null;for(let d=0;d<e;d++){r=a=0,i=s=null;for(let l=0;l<e;l++){let e=n.get(d,l);e===i?r++:(r>=5&&(o+=t+(r-5)),i=e,r=1),e=n.get(l,d),e===s?a++:(a>=5&&(o+=t+(a-5)),s=e,a=1)}r>=5&&(o+=t+(r-5)),a>=5&&(o+=t+(a-5))}return o},e.getPenaltyN2=function(n){const e=n.size;let t=0;for(let o=0;o<e-1;o++)for(let r=0;r<e-1;r++){const e=n.get(o,r)+n.get(o,r+1)+n.get(o+1,r)+n.get(o+1,r+1);4!==e&&0!==e||t++}return t*o},e.getPenaltyN3=function(n){const e=n.size;let t=0,o=0,a=0;for(let r=0;r<e;r++){o=a=0;for(let i=0;i<e;i++)o=o<<1&2047|n.get(r,i),i>=10&&(1488===o||93===o)&&t++,a=a<<1&2047|n.get(i,r),i>=10&&(1488===a||93===a)&&t++}return t*r},e.getPenaltyN4=function(n){let e=0;const t=n.data.length;for(let o=0;o<t;o++)e+=n.data[o];return Math.abs(Math.ceil(100*e/t/5)-10)*a},e.applyMask=function(n,e){const t=e.size;for(let o=0;o<t;o++)for(let r=0;r<t;r++)e.isReserved(r,o)||e.xor(r,o,i(n,r,o))},e.getBestMask=function(n,t){const o=Object.keys(e.Patterns).length;let r=0,a=1/0;for(let i=0;i<o;i++){t(i),e.applyMask(i,n);const o=e.getPenaltyN1(n)+e.getPenaltyN2(n)+e.getPenaltyN3(n)+e.getPenaltyN4(n);e.applyMask(i,n),o<a&&(a=o,r=i)}return r}},208(n,e,t){const o=t(1878),r=t(7044);e.NUMERIC={id:"Numeric",bit:1,ccBits:[10,12,14]},e.ALPHANUMERIC={id:"Alphanumeric",bit:2,ccBits:[9,11,13]},e.BYTE={id:"Byte",bit:4,ccBits:[8,16,16]},e.KANJI={id:"Kanji",bit:8,ccBits:[8,10,12]},e.MIXED={bit:-1},e.getCharCountIndicator=function(n,e){if(!n.ccBits)throw new Error("Invalid mode: "+n);if(!o.isValid(e))throw new Error("Invalid version: "+e);return e>=1&&e<10?n.ccBits[0]:e<27?n.ccBits[1]:n.ccBits[2]},e.getBestModeForData=function(n){return r.testNumeric(n)?e.NUMERIC:r.testAlphanumeric(n)?e.ALPHANUMERIC:r.testKanji(n)?e.KANJI:e.BYTE},e.toString=function(n){if(n&&n.id)return n.id;throw new Error("Invalid mode")},e.isValid=function(n){return n&&n.bit&&n.ccBits},e.from=function(n,t){if(e.isValid(n))return n;try{return function(n){if("string"!=typeof n)throw new Error("Param is not a string");switch(n.toLowerCase()){case"numeric":return e.NUMERIC;case"alphanumeric":return e.ALPHANUMERIC;case"kanji":return e.KANJI;case"byte":return e.BYTE;default:throw new Error("Unknown mode: "+n)}}(n)}catch(n){return t}}},4357(n,e,t){const o=t(208);function r(n){this.mode=o.NUMERIC,this.data=n.toString()}r.getBitsLength=function(n){return 10*Math.floor(n/3)+(n%3?n%3*3+1:0)},r.prototype.getLength=function(){return this.data.length},r.prototype.getBitsLength=function(){return r.getBitsLength(this.data.length)},r.prototype.write=function(n){let e,t,o;for(e=0;e+3<=this.data.length;e+=3)t=this.data.substr(e,3),o=parseInt(t,10),n.put(o,10);const r=this.data.length-e;r>0&&(t=this.data.substr(e),o=parseInt(t,10),n.put(o,3*r+1))},n.exports=r},4713(n,e,t){const o=t(2731);e.mul=function(n,e){const t=new Uint8Array(n.length+e.length-1);for(let r=0;r<n.length;r++)for(let a=0;a<e.length;a++)t[r+a]^=o.mul(n[r],e[a]);return t},e.mod=function(n,e){let t=new Uint8Array(n);for(;t.length-e.length>=0;){const n=t[0];for(let r=0;r<e.length;r++)t[r]^=o.mul(e[r],n);let r=0;for(;r<t.length&&0===t[r];)r++;t=t.slice(r)}return t},e.generateECPolynomial=function(n){let t=new Uint8Array([1]);for(let r=0;r<n;r++)t=e.mul(t,new Uint8Array([1,o.exp(r)]));return t}},157(n,e,t){const o=t(6886),r=t(9953),a=t(9899),i=t(8820),s=t(6421),d=t(7756),l=t(1332),c=t(7518),u=t(4764),p=t(1427),A=t(4565),m=t(208),h=t(9801);function f(n,e,t){const o=n.size,r=A.getEncodedBits(e,t);let a,i;for(a=0;a<15;a++)i=1==(r>>a&1),a<6?n.set(a,8,i,!0):a<8?n.set(a+1,8,i,!0):n.set(o-15+a,8,i,!0),a<8?n.set(8,o-a-1,i,!0):a<9?n.set(8,15-a-1+1,i,!0):n.set(8,15-a-1,i,!0);n.set(o-8,8,1,!0)}function g(n,e,t){const r=new a;t.forEach(function(e){r.put(e.mode.bit,4),r.put(e.getLength(),m.getCharCountIndicator(e.mode,n)),e.write(r)});const i=8*(o.getSymbolTotalCodewords(n)-c.getTotalCodewordsCount(n,e));for(r.getLengthInBits()+4<=i&&r.put(0,4);r.getLengthInBits()%8!=0;)r.putBit(0);const s=(i-r.getLengthInBits())/8;for(let n=0;n<s;n++)r.put(n%2?17:236,8);return function(n,e,t){const r=o.getSymbolTotalCodewords(e),a=c.getTotalCodewordsCount(e,t),i=r-a,s=c.getBlocksCount(e,t),d=r%s,l=s-d,p=Math.floor(r/s),A=Math.floor(i/s),m=A+1,h=p-A,f=new u(h);let g=0;const b=new Array(s),C=new Array(s);let w=0;const y=new Uint8Array(n.buffer);for(let n=0;n<s;n++){const e=n<l?A:m;b[n]=y.slice(g,g+e),C[n]=f.encode(b[n]),g+=e,w=Math.max(w,e)}const v=new Uint8Array(r);let E,B,x=0;for(E=0;E<w;E++)for(B=0;B<s;B++)E<b[B].length&&(v[x++]=b[B][E]);for(E=0;E<h;E++)for(B=0;B<s;B++)v[x++]=C[B][E];return v}(r,n,e)}function b(n,e,t,r){let a;if(Array.isArray(n))a=h.fromArray(n);else{if("string"!=typeof n)throw new Error("Invalid data");{let o=e;if(!o){const e=h.rawSplit(n);o=p.getBestVersionForData(e,t)}a=h.fromString(n,o||40)}}const c=p.getBestVersionForData(a,t);if(!c)throw new Error("The amount of data is too big to be stored in a QR Code");if(e){if(e<c)throw new Error("\nThe chosen QR Code version cannot contain this amount of data.\nMinimum version required to store current data is: "+c+".\n")}else e=c;const u=g(e,t,a),A=o.getSymbolSize(e),m=new i(A);return function(n,e){const t=n.size,o=d.getPositions(e);for(let e=0;e<o.length;e++){const r=o[e][0],a=o[e][1];for(let e=-1;e<=7;e++)if(!(r+e<=-1||t<=r+e))for(let o=-1;o<=7;o++)a+o<=-1||t<=a+o||(e>=0&&e<=6&&(0===o||6===o)||o>=0&&o<=6&&(0===e||6===e)||e>=2&&e<=4&&o>=2&&o<=4?n.set(r+e,a+o,!0,!0):n.set(r+e,a+o,!1,!0))}}(m,e),function(n){const e=n.size;for(let t=8;t<e-8;t++){const e=t%2==0;n.set(t,6,e,!0),n.set(6,t,e,!0)}}(m),function(n,e){const t=s.getPositions(e);for(let e=0;e<t.length;e++){const o=t[e][0],r=t[e][1];for(let e=-2;e<=2;e++)for(let t=-2;t<=2;t++)-2===e||2===e||-2===t||2===t||0===e&&0===t?n.set(o+e,r+t,!0,!0):n.set(o+e,r+t,!1,!0)}}(m,e),f(m,t,0),e>=7&&function(n,e){const t=n.size,o=p.getEncodedBits(e);let r,a,i;for(let e=0;e<18;e++)r=Math.floor(e/3),a=e%3+t-8-3,i=1==(o>>e&1),n.set(r,a,i,!0),n.set(a,r,i,!0)}(m,e),function(n,e){const t=n.size;let o=-1,r=t-1,a=7,i=0;for(let s=t-1;s>0;s-=2)for(6===s&&s--;;){for(let t=0;t<2;t++)if(!n.isReserved(r,s-t)){let o=!1;i<e.length&&(o=1==(e[i]>>>a&1)),n.set(r,s-t,o),a--,-1===a&&(i++,a=7)}if(r+=o,r<0||t<=r){r-=o,o=-o;break}}}(m,u),isNaN(r)&&(r=l.getBestMask(m,f.bind(null,m,t))),l.applyMask(r,m),f(m,t,r),{modules:m,version:e,errorCorrectionLevel:t,maskPattern:r,segments:a}}e.create=function(n,e){if(void 0===n||""===n)throw new Error("No input text");let t,a,i=r.M;return void 0!==e&&(i=r.from(e.errorCorrectionLevel,r.M),t=p.from(e.version),a=l.from(e.maskPattern),e.toSJISFunc&&o.setToSJISFunction(e.toSJISFunc)),b(n,t,i,a)}},4764(n,e,t){const o=t(4713);function r(n){this.genPoly=void 0,this.degree=n,this.degree&&this.initialize(this.degree)}r.prototype.initialize=function(n){this.degree=n,this.genPoly=o.generateECPolynomial(this.degree)},r.prototype.encode=function(n){if(!this.genPoly)throw new Error("Encoder not initialized");const e=new Uint8Array(n.length+this.degree);e.set(n);const t=o.mod(e,this.genPoly),r=this.degree-t.length;if(r>0){const n=new Uint8Array(this.degree);return n.set(t,r),n}return t},n.exports=r},7044(n,e){const t="[0-9]+";let o="(?:[u3000-u303F]|[u3040-u309F]|[u30A0-u30FF]|[uFF00-uFFEF]|[u4E00-u9FAF]|[u2605-u2606]|[u2190-u2195]|u203B|[u2010u2015u2018u2019u2025u2026u201Cu201Du2225u2260]|[u0391-u0451]|[u00A7u00A8u00B1u00B4u00D7u00F7])+";o=o.replace(/u/g,"\\u");const r="(?:(?![A-Z0-9 $%*+\\-./:]|"+o+")(?:.|[\r\n]))+";e.KANJI=new RegExp(o,"g"),e.BYTE_KANJI=new RegExp("[^A-Z0-9 $%*+\\-./:]+","g"),e.BYTE=new RegExp(r,"g"),e.NUMERIC=new RegExp(t,"g"),e.ALPHANUMERIC=new RegExp("[A-Z $%*+\\-./:]+","g");const a=new RegExp("^"+o+"$"),i=new RegExp("^"+t+"$"),s=new RegExp("^[A-Z0-9 $%*+\\-./:]+$");e.testKanji=function(n){return a.test(n)},e.testNumeric=function(n){return i.test(n)},e.testAlphanumeric=function(n){return s.test(n)}},9801(n,e,t){const o=t(208),r=t(4357),a=t(1433),i=t(5822),s=t(4861),d=t(7044),l=t(6886),c=t(6320);function u(n){return unescape(encodeURIComponent(n)).length}function p(n,e,t){const o=[];let r;for(;null!==(r=n.exec(t));)o.push({data:r[0],index:r.index,mode:e,length:r[0].length});return o}function A(n){const e=p(d.NUMERIC,o.NUMERIC,n),t=p(d.ALPHANUMERIC,o.ALPHANUMERIC,n);let r,a;l.isKanjiModeEnabled()?(r=p(d.BYTE,o.BYTE,n),a=p(d.KANJI,o.KANJI,n)):(r=p(d.BYTE_KANJI,o.BYTE,n),a=[]);return e.concat(t,r,a).sort(function(n,e){return n.index-e.index}).map(function(n){return{data:n.data,mode:n.mode,length:n.length}})}function m(n,e){switch(e){case o.NUMERIC:return r.getBitsLength(n);case o.ALPHANUMERIC:return a.getBitsLength(n);case o.KANJI:return s.getBitsLength(n);case o.BYTE:return i.getBitsLength(n)}}function h(n,e){let t;const d=o.getBestModeForData(n);if(t=o.from(e,d),t!==o.BYTE&&t.bit<d.bit)throw new Error('"'+n+'" cannot be encoded with mode '+o.toString(t)+".\n Suggested mode is: "+o.toString(d));switch(t!==o.KANJI||l.isKanjiModeEnabled()||(t=o.BYTE),t){case o.NUMERIC:return new r(n);case o.ALPHANUMERIC:return new a(n);case o.KANJI:return new s(n);case o.BYTE:return new i(n)}}e.fromArray=function(n){return n.reduce(function(n,e){return"string"==typeof e?n.push(h(e,null)):e.data&&n.push(h(e.data,e.mode)),n},[])},e.fromString=function(n,t){const r=function(n){const e=[];for(let t=0;t<n.length;t++){const r=n[t];switch(r.mode){case o.NUMERIC:e.push([r,{data:r.data,mode:o.ALPHANUMERIC,length:r.length},{data:r.data,mode:o.BYTE,length:r.length}]);break;case o.ALPHANUMERIC:e.push([r,{data:r.data,mode:o.BYTE,length:r.length}]);break;case o.KANJI:e.push([r,{data:r.data,mode:o.BYTE,length:u(r.data)}]);break;case o.BYTE:e.push([{data:r.data,mode:o.BYTE,length:u(r.data)}])}}return e}(A(n,l.isKanjiModeEnabled())),a=function(n,e){const t={},r={start:{}};let a=["start"];for(let i=0;i<n.length;i++){const s=n[i],d=[];for(let n=0;n<s.length;n++){const l=s[n],c=""+i+n;d.push(c),t[c]={node:l,lastCount:0},r[c]={};for(let n=0;n<a.length;n++){const i=a[n];t[i]&&t[i].node.mode===l.mode?(r[i][c]=m(t[i].lastCount+l.length,l.mode)-m(t[i].lastCount,l.mode),t[i].lastCount+=l.length):(t[i]&&(t[i].lastCount=l.length),r[i][c]=m(l.length,l.mode)+4+o.getCharCountIndicator(l.mode,e))}}a=d}for(let n=0;n<a.length;n++)r[a[n]].end=0;return{map:r,table:t}}(r,t),i=c.find_path(a.map,"start","end"),s=[];for(let n=1;n<i.length-1;n++)s.push(a.table[i[n]].node);return e.fromArray(function(n){return n.reduce(function(n,e){const t=n.length-1>=0?n[n.length-1]:null;return t&&t.mode===e.mode?(n[n.length-1].data+=e.data,n):(n.push(e),n)},[])}(s))},e.rawSplit=function(n){return e.fromArray(A(n,l.isKanjiModeEnabled()))}},6886(n,e){let t;const o=[0,26,44,70,100,134,172,196,242,292,346,404,466,532,581,655,733,815,901,991,1085,1156,1258,1364,1474,1588,1706,1828,1921,2051,2185,2323,2465,2611,2761,2876,3034,3196,3362,3532,3706];e.getSymbolSize=function(n){if(!n)throw new Error('"version" cannot be null or undefined');if(n<1||n>40)throw new Error('"version" should be in range from 1 to 40');return 4*n+17},e.getSymbolTotalCodewords=function(n){return o[n]},e.getBCHDigit=function(n){let e=0;for(;0!==n;)e++,n>>>=1;return e},e.setToSJISFunction=function(n){if("function"!=typeof n)throw new Error('"toSJISFunc" is not a valid function.');t=n},e.isKanjiModeEnabled=function(){return void 0!==t},e.toSJIS=function(n){return t(n)}},1878(n,e){e.isValid=function(n){return!isNaN(n)&&n>=1&&n<=40}},1427(n,e,t){const o=t(6886),r=t(7518),a=t(9953),i=t(208),s=t(1878),d=o.getBCHDigit(7973);function l(n,e){return i.getCharCountIndicator(n,e)+4}function c(n,e){let t=0;return n.forEach(function(n){const o=l(n.mode,e);t+=o+n.getBitsLength()}),t}e.from=function(n,e){return s.isValid(n)?parseInt(n,10):e},e.getCapacity=function(n,e,t){if(!s.isValid(n))throw new Error("Invalid QR Code version");void 0===t&&(t=i.BYTE);const a=8*(o.getSymbolTotalCodewords(n)-r.getTotalCodewordsCount(n,e));if(t===i.MIXED)return a;const d=a-l(t,n);switch(t){case i.NUMERIC:return Math.floor(d/10*3);case i.ALPHANUMERIC:return Math.floor(d/11*2);case i.KANJI:return Math.floor(d/13);case i.BYTE:default:return Math.floor(d/8)}},e.getBestVersionForData=function(n,t){let o;const r=a.from(t,a.M);if(Array.isArray(n)){if(n.length>1)return function(n,t){for(let o=1;o<=40;o++)if(c(n,o)<=e.getCapacity(o,t,i.MIXED))return o}(n,r);if(0===n.length)return 1;o=n[0]}else o=n;return function(n,t,o){for(let r=1;r<=40;r++)if(t<=e.getCapacity(r,o,n))return r}(o.mode,o.getLength(),r)},e.getEncodedBits=function(n){if(!s.isValid(n)||n<7)throw new Error("Invalid QR Code version");let e=n<<12;for(;o.getBCHDigit(e)-d>=0;)e^=7973<<o.getBCHDigit(e)-d;return n<<12|e}},7899(n,e,t){const o=t(2726);e.render=function(n,e,t){let r=t,a=e;void 0!==r||e&&e.getContext||(r=e,e=void 0),e||(a=function(){try{return document.createElement("canvas")}catch(n){throw new Error("You need to specify a canvas element")}}()),r=o.getOptions(r);const i=o.getImageWidth(n.modules.size,r),s=a.getContext("2d"),d=s.createImageData(i,i);return o.qrToImageData(d.data,n,r),function(n,e,t){n.clearRect(0,0,e.width,e.height),e.style||(e.style={}),e.height=t,e.width=t,e.style.height=t+"px",e.style.width=t+"px"}(s,a,i),s.putImageData(d,0,0),a},e.renderToDataURL=function(n,t,o){let r=o;void 0!==r||t&&t.getContext||(r=t,t=void 0),r||(r={});const a=e.render(n,t,r),i=r.type||"image/png",s=r.rendererOpts||{};return a.toDataURL(i,s.quality)}},6756(n,e,t){const o=t(2726);function r(n,e){const t=n.a/255,o=e+'="'+n.hex+'"';return t<1?o+" "+e+'-opacity="'+t.toFixed(2).slice(1)+'"':o}function a(n,e,t){let o=n+e;return void 0!==t&&(o+=" "+t),o}e.render=function(n,e,t){const i=o.getOptions(e),s=n.modules.size,d=n.modules.data,l=s+2*i.margin,c=i.color.light.a?"<path "+r(i.color.light,"fill")+' d="M0 0h'+l+"v"+l+'H0z"/>':"",u="<path "+r(i.color.dark,"stroke")+' d="'+function(n,e,t){let o="",r=0,i=!1,s=0;for(let d=0;d<n.length;d++){const l=Math.floor(d%e),c=Math.floor(d/e);l||i||(i=!0),n[d]?(s++,d>0&&l>0&&n[d-1]||(o+=i?a("M",l+t,.5+c+t):a("m",r,0),r=0,i=!1),l+1<e&&n[d+1]||(o+=a("h",s),s=0)):r++}return o}(d,s,i.margin)+'"/>',p='viewBox="0 0 '+l+" "+l+'"',A='<svg xmlns="http://www.w3.org/2000/svg" '+(i.width?'width="'+i.width+'" height="'+i.width+'" ':"")+p+' shape-rendering="crispEdges">'+c+u+"</svg>\n";return"function"==typeof t&&t(null,A),A}},2726(n,e){function t(n){if("number"==typeof n&&(n=n.toString()),"string"!=typeof n)throw new Error("Color should be defined as hex string");let e=n.slice().replace("#","").split("");if(e.length<3||5===e.length||e.length>8)throw new Error("Invalid hex color: "+n);3!==e.length&&4!==e.length||(e=Array.prototype.concat.apply([],e.map(function(n){return[n,n]}))),6===e.length&&e.push("F","F");const t=parseInt(e.join(""),16);return{r:t>>24&255,g:t>>16&255,b:t>>8&255,a:255&t,hex:"#"+e.slice(0,6).join("")}}e.getOptions=function(n){n||(n={}),n.color||(n.color={});const e=void 0===n.margin||null===n.margin||n.margin<0?4:n.margin,o=n.width&&n.width>=21?n.width:void 0,r=n.scale||4;return{width:o,scale:o?4:r,margin:e,color:{dark:t(n.color.dark||"#000000ff"),light:t(n.color.light||"#ffffffff")},type:n.type,rendererOpts:n.rendererOpts||{}}},e.getScale=function(n,e){return e.width&&e.width>=n+2*e.margin?e.width/(n+2*e.margin):e.scale},e.getImageWidth=function(n,t){const o=e.getScale(n,t);return Math.floor((n+2*t.margin)*o)},e.qrToImageData=function(n,t,o){const r=t.modules.size,a=t.modules.data,i=e.getScale(r,o),s=Math.floor((r+2*o.margin)*i),d=o.margin*i,l=[o.color.light,o.color.dark];for(let e=0;e<s;e++)for(let t=0;t<s;t++){let c=4*(e*s+t),u=o.color.light;if(e>=d&&t>=d&&e<s-d&&t<s-d){u=l[a[Math.floor((e-d)/i)*r+Math.floor((t-d)/i)]?1:0]}n[c++]=u.r,n[c++]=u.g,n[c++]=u.b,n[c]=u.a}}},8068(n){"use strict";var e=(()=>{var n=Object.defineProperty,e=Object.getOwnPropertyDescriptor,t=Object.getOwnPropertyNames,o=Object.getOwnPropertySymbols,r=Object.prototype.hasOwnProperty,a=Object.prototype.propertyIsEnumerable,i=(e,t,o)=>t in e?n(e,t,{enumerable:!0,configurable:!0,writable:!0,value:o}):e[t]=o,s=(n,e)=>{for(var t in e||(e={}))r.call(e,t)&&i(n,t,e[t]);if(o)for(var t of o(e))a.call(e,t)&&i(n,t,e[t]);return n},d=(n,e,t)=>i(n,"symbol"!=typeof e?e+"":e,t),l={};((e,t)=>{for(var o in t)n(e,o,{get:t[o],enumerable:!0})})(l,{DEFAULT_OPTIONS:()=>u,DEFAULT_UUID_LENGTH:()=>c,default:()=>m});var c=6,u={dictionary:"alphanum",shuffle:!0,debug:!1,length:c,counter:0},p=class{constructor(n={}){d(this,"counter"),d(this,"debug"),d(this,"dict"),d(this,"version"),d(this,"dictIndex",0),d(this,"dictRange",[]),d(this,"lowerBound",0),d(this,"upperBound",0),d(this,"dictLength",0),d(this,"uuidLength"),d(this,"_digit_first_ascii",48),d(this,"_digit_last_ascii",58),d(this,"_alpha_lower_first_ascii",97),d(this,"_alpha_lower_last_ascii",123),d(this,"_hex_last_ascii",103),d(this,"_alpha_upper_first_ascii",65),d(this,"_alpha_upper_last_ascii",91),d(this,"_number_dict_ranges",{digits:[this._digit_first_ascii,this._digit_last_ascii]}),d(this,"_alpha_dict_ranges",{lowerCase:[this._alpha_lower_first_ascii,this._alpha_lower_last_ascii],upperCase:[this._alpha_upper_first_ascii,this._alpha_upper_last_ascii]}),d(this,"_alpha_lower_dict_ranges",{lowerCase:[this._alpha_lower_first_ascii,this._alpha_lower_last_ascii]}),d(this,"_alpha_upper_dict_ranges",{upperCase:[this._alpha_upper_first_ascii,this._alpha_upper_last_ascii]}),d(this,"_alphanum_dict_ranges",{digits:[this._digit_first_ascii,this._digit_last_ascii],lowerCase:[this._alpha_lower_first_ascii,this._alpha_lower_last_ascii],upperCase:[this._alpha_upper_first_ascii,this._alpha_upper_last_ascii]}),d(this,"_alphanum_lower_dict_ranges",{digits:[this._digit_first_ascii,this._digit_last_ascii],lowerCase:[this._alpha_lower_first_ascii,this._alpha_lower_last_ascii]}),d(this,"_alphanum_upper_dict_ranges",{digits:[this._digit_first_ascii,this._digit_last_ascii],upperCase:[this._alpha_upper_first_ascii,this._alpha_upper_last_ascii]}),d(this,"_hex_dict_ranges",{decDigits:[this._digit_first_ascii,this._digit_last_ascii],alphaDigits:[this._alpha_lower_first_ascii,this._hex_last_ascii]}),d(this,"_dict_ranges",{_number_dict_ranges:this._number_dict_ranges,_alpha_dict_ranges:this._alpha_dict_ranges,_alpha_lower_dict_ranges:this._alpha_lower_dict_ranges,_alpha_upper_dict_ranges:this._alpha_upper_dict_ranges,_alphanum_dict_ranges:this._alphanum_dict_ranges,_alphanum_lower_dict_ranges:this._alphanum_lower_dict_ranges,_alphanum_upper_dict_ranges:this._alphanum_upper_dict_ranges,_hex_dict_ranges:this._hex_dict_ranges}),d(this,"log",(...n)=>{const e=[...n];e[0]="[short-unique-id] ".concat(n[0]),!0!==this.debug||"undefined"==typeof console||null===console||console.log(...e)}),d(this,"_normalizeDictionary",(n,e)=>{let t;if(n&&Array.isArray(n)&&n.length>1)t=n;else{t=[],this.dictIndex=0;const e="_".concat(n,"_dict_ranges"),o=this._dict_ranges[e];let r=0;for(const[,n]of Object.entries(o)){const[e,t]=n;r+=Math.abs(t-e)}t=new Array(r);let a=0;for(const[,n]of Object.entries(o)){this.dictRange=n,this.lowerBound=this.dictRange[0],this.upperBound=this.dictRange[1];const e=this.lowerBound<=this.upperBound,o=this.lowerBound,r=this.upperBound;if(e)for(let n=o;n<r;n++)t[a++]=String.fromCharCode(n),this.dictIndex=n;else for(let n=o;n>r;n--)t[a++]=String.fromCharCode(n),this.dictIndex=n}t.length=a}if(e){for(let n=t.length-1;n>0;n--){const e=Math.floor(Math.random()*(n+1));[t[n],t[e]]=[t[e],t[n]]}}return t}),d(this,"setDictionary",(n,e)=>{this.dict=this._normalizeDictionary(n,e),this.dictLength=this.dict.length,this.setCounter(0)}),d(this,"seq",()=>this.sequentialUUID()),d(this,"sequentialUUID",()=>{const n=this.dictLength,e=this.dict;let t=this.counter;const o=[];do{const r=t%n;t=Math.trunc(t/n),o.push(e[r])}while(0!==t);const r=o.join("");return this.counter+=1,r}),d(this,"rnd",(n=this.uuidLength||c)=>this.randomUUID(n)),d(this,"randomUUID",(n=this.uuidLength||c)=>{if(null==n||n<1)throw new Error("Invalid UUID Length Provided");const e=new Array(n),t=this.dictLength,o=this.dict;for(let r=0;r<n;r++){const n=Math.floor(Math.random()*t);e[r]=o[n]}return e.join("")}),d(this,"fmt",(n,e)=>this.formattedUUID(n,e)),d(this,"formattedUUID",(n,e)=>{const t={$r:this.randomUUID,$s:this.sequentialUUID,$t:this.stamp};return n.replace(/\$[rs]\d{0,}|\$t0|\$t[1-9]\d{1,}/g,n=>{const o=n.slice(0,2),r=Number.parseInt(n.slice(2),10);return"$s"===o?t[o]().padStart(r,"0"):"$t"===o&&e?t[o](r,e):t[o](r)})}),d(this,"availableUUIDs",(n=this.uuidLength)=>Number.parseFloat(([...new Set(this.dict)].length**n).toFixed(0))),d(this,"_collisionCache",new Map),d(this,"approxMaxBeforeCollision",(n=this.availableUUIDs(this.uuidLength))=>{const e=n,t=this._collisionCache.get(e);if(void 0!==t)return t;const o=Number.parseFloat(Math.sqrt(Math.PI/2*n).toFixed(20));return this._collisionCache.set(e,o),o}),d(this,"collisionProbability",(n=this.availableUUIDs(this.uuidLength),e=this.uuidLength)=>Number.parseFloat((this.approxMaxBeforeCollision(n)/this.availableUUIDs(e)).toFixed(20))),d(this,"uniqueness",(n=this.availableUUIDs(this.uuidLength))=>{const e=Number.parseFloat((1-this.approxMaxBeforeCollision(n)/n).toFixed(20));return e>1?1:e<0?0:e}),d(this,"getVersion",()=>this.version),d(this,"stamp",(n,e)=>{const t=Math.floor(+(e||new Date)/1e3).toString(16);if("number"==typeof n&&0===n)return t;if("number"!=typeof n||n<10)throw new Error(["Param finalLength must be a number greater than or equal to 10,","or 0 if you want the raw hexadecimal timestamp"].join("\n"));const o=n-9,r=Math.round(Math.random()*(o>15?15:o)),a=this.randomUUID(o);return"".concat(a.substring(0,r)).concat(t).concat(a.substring(r)).concat(r.toString(16))}),d(this,"parseStamp",(n,e)=>{if(e&&!/t0|t[1-9]\d{1,}/.test(e))throw new Error("Cannot extract date from a formated UUID with no timestamp in the format");const t=e?e.replace(/\$[rs]\d{0,}|\$t0|\$t[1-9]\d{1,}/g,n=>{const e={$r:n=>[...Array(n)].map(()=>"r").join(""),$s:n=>[...Array(n)].map(()=>"s").join(""),$t:n=>[...Array(n)].map(()=>"t").join("")},t=n.slice(0,2),o=Number.parseInt(n.slice(2),10);return e[t](o)}).replace(/^(.*?)(t{8,})(.*)$/g,(e,t,o)=>n.substring(t.length,t.length+o.length)):n;if(8===t.length)return new Date(1e3*Number.parseInt(t,16));if(t.length<10)throw new Error("Stamp length invalid");const o=Number.parseInt(t.substring(t.length-1),16);return new Date(1e3*Number.parseInt(t.substring(o,o+8),16))}),d(this,"setCounter",n=>{this.counter=n}),d(this,"validate",(n,e)=>{const t=e?this._normalizeDictionary(e):this.dict;return n.split("").every(n=>t.includes(n))});const e=s(s({},u),n);this.counter=0,this.debug=!1,this.dict=[],this.version="5.3.2";const{dictionary:t,shuffle:o,length:r,counter:a}=e;this.uuidLength=r,this.setDictionary(t,o),this.setCounter(a),this.debug=e.debug,this.log(this.dict),this.log("Generator instantiated with Dictionary Size ".concat(this.dictLength," and counter set to ").concat(this.counter)),this.log=this.log.bind(this),this.setDictionary=this.setDictionary.bind(this),this.setCounter=this.setCounter.bind(this),this.seq=this.seq.bind(this),this.sequentialUUID=this.sequentialUUID.bind(this),this.rnd=this.rnd.bind(this),this.randomUUID=this.randomUUID.bind(this),this.fmt=this.fmt.bind(this),this.formattedUUID=this.formattedUUID.bind(this),this.availableUUIDs=this.availableUUIDs.bind(this),this.approxMaxBeforeCollision=this.approxMaxBeforeCollision.bind(this),this.collisionProbability=this.collisionProbability.bind(this),this.uniqueness=this.uniqueness.bind(this),this.getVersion=this.getVersion.bind(this),this.stamp=this.stamp.bind(this),this.parseStamp=this.parseStamp.bind(this)}};d(p,"default",p);var A,m=p;return A=l,((o,a,i,s)=>{if(a&&"object"==typeof a||"function"==typeof a)for(let d of t(a))r.call(o,d)||d===i||n(o,d,{get:()=>a[d],enumerable:!(s=e(a,d))||s.enumerable});return o})(n({},"__esModule",{value:!0}),A)})();n.exports=e.default,"undefined"!=typeof window&&(e=e.default)},5072(n){"use strict";var e=[];function t(n){for(var t=-1,o=0;o<e.length;o++)if(e[o].identifier===n){t=o;break}return t}function o(n,o){for(var a={},i=[],s=0;s<n.length;s++){var d=n[s],l=o.base?d[0]+o.base:d[0],c=a[l]||0,u="".concat(l," ").concat(c);a[l]=c+1;var p=t(u),A={css:d[1],media:d[2],sourceMap:d[3],supports:d[4],layer:d[5]};if(-1!==p)e[p].references++,e[p].updater(A);else{var m=r(A,o);o.byIndex=s,e.splice(s,0,{identifier:u,updater:m,references:1})}i.push(u)}return i}function r(n,e){var t=e.domAPI(e);t.update(n);return function(e){if(e){if(e.css===n.css&&e.media===n.media&&e.sourceMap===n.sourceMap&&e.supports===n.supports&&e.layer===n.layer)return;t.update(n=e)}else t.remove()}}n.exports=function(n,r){var a=o(n=n||[],r=r||{});return function(n){n=n||[];for(var i=0;i<a.length;i++){var s=t(a[i]);e[s].references--}for(var d=o(n,r),l=0;l<a.length;l++){var c=t(a[l]);0===e[c].references&&(e[c].updater(),e.splice(c,1))}a=d}}},7659(n){"use strict";var e={};n.exports=function(n,t){var o=function(n){if(void 0===e[n]){var t=document.querySelector(n);if(window.HTMLIFrameElement&&t instanceof window.HTMLIFrameElement)try{t=t.contentDocument.head}catch(n){t=null}e[n]=t}return e[n]}(n);if(!o)throw new Error("Couldn't find a style target. This probably means that the value for the 'insert' parameter is invalid.");o.appendChild(t)}},540(n){"use strict";n.exports=function(n){var e=document.createElement("style");return n.setAttributes(e,n.attributes),n.insert(e,n.options),e}},5056(n,e,t){"use strict";n.exports=function(n){var e=t.nc;e&&n.setAttribute("nonce",e)}},7825(n){"use strict";n.exports=function(n){if("undefined"==typeof document)return{update:function(){},remove:function(){}};var e=n.insertStyleElement(n);return{update:function(t){!function(n,e,t){var o="";t.supports&&(o+="@supports (".concat(t.supports,") {")),t.media&&(o+="@media ".concat(t.media," {"));var r=void 0!==t.layer;r&&(o+="@layer".concat(t.layer.length>0?" ".concat(t.layer):""," {")),o+=t.css,r&&(o+="}"),t.media&&(o+="}"),t.supports&&(o+="}");var a=t.sourceMap;a&&"undefined"!=typeof btoa&&(o+="\n/*# sourceMappingURL=data:application/json;base64,".concat(btoa(unescape(encodeURIComponent(JSON.stringify(a))))," */")),e.styleTagTransform(o,n,e.options)}(e,n,t)},remove:function(){!function(n){if(null===n.parentNode)return!1;n.parentNode.removeChild(n)}(e)}}}},1113(n){"use strict";n.exports=function(n,e){if(e.styleSheet)e.styleSheet.cssText=n;else{for(;e.firstChild;)e.removeChild(e.firstChild);e.appendChild(document.createTextNode(n))}}},6077(n){n.exports=function(n){var e={};function t(o){if(e[o])return e[o].exports;var r=e[o]={i:o,l:!1,exports:{}};return n[o].call(r.exports,r,r.exports,t),r.l=!0,r.exports}return t.m=n,t.c=e,t.d=function(n,e,o){t.o(n,e)||Object.defineProperty(n,e,{enumerable:!0,get:o})},t.r=function(n){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(n,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(n,"__esModule",{value:!0})},t.t=function(n,e){if(1&e&&(n=t(n)),8&e)return n;if(4&e&&"object"==typeof n&&n&&n.__esModule)return n;var o=Object.create(null);if(t.r(o),Object.defineProperty(o,"default",{enumerable:!0,value:n}),2&e&&"string"!=typeof n)for(var r in n)t.d(o,r,function(e){return n[e]}.bind(null,r));return o},t.n=function(n){var e=n&&n.__esModule?function(){return n.default}:function(){return n};return t.d(e,"a",e),e},t.o=function(n,e){return Object.prototype.hasOwnProperty.call(n,e)},t.p="",t(t.s=0)}([function(n,e,t){"use strict";t.r(e),t.d(e,"validateHTMLColorName",function(){return i}),t.d(e,"validateHTMLColorSpecialName",function(){return s}),t.d(e,"validateHTMLColorHex",function(){return d}),t.d(e,"validateHTMLColorRgb",function(){return h}),t.d(e,"validateHTMLColorHsl",function(){return f}),t.d(e,"validateHTMLColorHwb",function(){return g}),t.d(e,"validateHTMLColorLab",function(){return b}),t.d(e,"validateHTMLColorLch",function(){return C}),t.d(e,"validateHTMLColor",function(){return w});const o=n=>n&&"string"==typeof n,r=["AliceBlue","AntiqueWhite","Aqua","Aquamarine","Azure","Beige","Bisque","Black","BlanchedAlmond","Blue","BlueViolet","Brown","BurlyWood","CadetBlue","Chartreuse","Chocolate","Coral","CornflowerBlue","Cornsilk","Crimson","Cyan","DarkBlue","DarkCyan","DarkGoldenrod","DarkGray","DarkGrey","DarkGreen","DarkKhaki","DarkMagenta","DarkOliveGreen","DarkOrange","DarkOrchid","DarkRed","DarkSalmon","DarkSeaGreen","DarkSlateBlue","DarkSlateGray","DarkSlateGrey","DarkTurquoise","DarkViolet","DeepPink","DeepSkyBlue","DimGray","DimGrey","DodgerBlue","FireBrick","FloralWhite","ForestGreen","Fuchsia","Gainsboro","GhostWhite","Gold","Goldenrod","Gray","Grey","Green","GreenYellow","HoneyDew","HotPink","IndianRed","Indigo","Ivory","Khaki","Lavender","LavenderBlush","LawnGreen","LemonChiffon","LightBlue","LightCoral","LightCyan","LightGoldenrodYellow","LightGray","LightGrey","LightGreen","LightPink","LightSalmon","LightSalmon","LightSeaGreen","LightSkyBlue","LightSlateGray","LightSlateGrey","LightSteelBlue","LightYellow","Lime","LimeGreen","Linen","Magenta","Maroon","MediumAquamarine","MediumBlue","MediumOrchid","MediumPurple","MediumSeaGreen","MediumSlateBlue","MediumSlateBlue","MediumSpringGreen","MediumTurquoise","MediumVioletRed","MidnightBlue","MintCream","MistyRose","Moccasin","NavajoWhite","Navy","OldLace","Olive","OliveDrab","Orange","OrangeRed","Orchid","PaleGoldenrod","PaleGreen","PaleTurquoise","PaleVioletRed","PapayaWhip","PeachPuff","Peru","Pink","Plum","PowderBlue","Purple","RebeccaPurple","Red","RosyBrown","RoyalBlue","SaddleBrown","Salmon","SandyBrown","SeaGreen","SeaShell","Sienna","Silver","SkyBlue","SlateBlue","SlateGray","SlateGrey","Snow","SpringGreen","SteelBlue","Tan","Teal","Thistle","Tomato","Turquoise","Violet","Wheat","White","WhiteSmoke","Yellow","YellowGreen"],a=["currentColor","inherit","transparent"],i=n=>{let e=!1;return o(n)&&r.map(t=>(n.toLowerCase()===t.toLowerCase()&&(e=!0),null)),e},s=n=>{let e=!1;return o(n)&&a.map(t=>(n.toLowerCase()===t.toLowerCase()&&(e=!0),null)),e},d=n=>{if(o(n)){return n&&/^#([\da-f]{3}){1,2}$|^#([\da-f]{4}){1,2}$/i.test(n)}return!1},l="(([\\d]{0,5})((\\.([\\d]{1,5}))?))",c=`(${l}%)`,u="(([0-9]|[1-9][0-9]|100)%)",p=`(${u}|(0?((\\.([\\d]{1,5}))?))|1)`,A=`([\\s]{0,5})\\)?)(([\\s]{0,5})(\\/?)([\\s]{1,5})(((${u}))|(0?((\\.([\\d]{1,5}))?))|1))?([\\s]{0,5})\\)`,m="(-?(([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-9][0-9]|3[0-5][0-9])((\\.([\\d]{1,5}))?)|360)(deg)?)",h=n=>{if(o(n)){const e="([\\s]{0,5})([\\d]{1,5})%?([\\s]{0,5}),?",t="((([\\s]{0,5}),?([\\s]{0,5}))|(([\\s]{1,5})))",o=new RegExp(`^(rgb)a?\\(${e}${t}${e}${t}${e}${t}((\\/?([\\s]{0,5})(0?\\.?([\\d]{1,5})%?([\\s]{0,5}))?|1|0))?\\)$`);return n&&o.test(n)}return!1},f=n=>{if(o(n)){const e=new RegExp(`^(hsl)a?\\((([\\s]{0,5})(${m}|(([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-9][0-9]|3[0-9][0-9]|400)grad)|((([0-5])?\\.([\\d]{1,5})|6\\.([0-9]|1[0-9]|2[0-8])|[0-6])rad)|((0?((\\.([\\d]{1,5}))?)|1)turn))((([\\s]{0,5}),([\\s]{0,5}))|(([\\s]{1,5}))))(([\\s]{0,5})(0|${u})((([\\s]{0,5}),([\\s]{0,5}))|(([\\s]{1,5}))))(([\\s]{0,5})(0|${u})([\\s]{0,5})\\)?)(([\\s]{0,5})(\\/?|,?)([\\s]{0,5})(((${u}))|(0?((\\.([\\d]{1,5}))?))|1))?\\)$`);return n&&e.test(n)}return!1},g=n=>{if(o(n)){const e=new RegExp(`^(hwb\\(([\\s]{0,5})${m}([\\s]{1,5}))((0|${u})([\\s]{1,5}))((0|${u})${A}$`);return n&&e.test(n)}return!1},b=n=>{if(o(n)){const e="(-?(([0-9]|[1-9][0-9]|1[0-5][0-9])((\\.([\\d]{1,5}))?)?|160))",t=new RegExp(`^(lab\\(([\\s]{0,5})${c}([\\s]{1,5})${e}([\\s]{1,5})${e}${A}$`);return n&&t.test(n)}return!1},C=n=>{if(o(n)){const e=new RegExp(`^lch\\((([\\s]{0,5})${"((([0-9]|[1-9][0-9])?((\\.([\\d]{1,5}))?)|100)(%)?)"}([\\s]{1,5})${""+l}([\\s]{1,5})${`((${m})|(0|${p})|(([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-9][0-9]|3[0-5][0-9])((\\.([\\d]{1,5}))?)|360))`}([\\s]{0,5})(${`(\\/([\\s]{0,5})${p})`})?)\\)$`);return n&&e.test(n)}return!1},w=n=>!!(n&&d(n)||h(n)||f(n)||g(n)||b(n)||C(n));e.default=n=>!!(n&&d(n)||i(n)||s(n)||h(n)||f(n)||g(n)||b(n)||C(n))}])},5663(n){"use strict";n.exports=e},9426(e){"use strict";e.exports=n},5491(n){"use strict";n.exports=t}},r={};function a(n){var e=r[n];if(void 0!==e)return e.exports;var t=r[n]={id:n,exports:{}};return o[n](t,t.exports,a),t.exports}a.n=n=>{var e=n&&n.__esModule?()=>n.default:()=>n;return a.d(e,{a:e}),e},a.d=(n,e)=>{for(var t in e)a.o(e,t)&&!a.o(n,t)&&Object.defineProperty(n,t,{enumerable:!0,get:e[t]})},a.o=(n,e)=>Object.prototype.hasOwnProperty.call(n,e),a.nc=void 0;var i={};return(()=>{"use strict";a.d(i,{default:()=>co});var n=a(5072),e=a.n(n),t=a(7825),o=a.n(t),r=a(7659),s=a.n(r),d=a(5056),l=a.n(d),c=a(540),u=a.n(c),p=a(1113),A=a.n(p),m=a(1267),h={};h.styleTagTransform=A(),h.setAttributes=l(),h.insert=s().bind(null,"head"),h.domAPI=o(),h.insertStyleElement=u();e()(m.A,h);m.A&&m.A.locals&&m.A.locals;var f=a(3750),g={};g.styleTagTransform=A(),g.setAttributes=l(),g.insert=s().bind(null,"head"),g.domAPI=o(),g.insertStyleElement=u();e()(f.A,g);f.A&&f.A.locals&&f.A.locals;var b=a(1666),C={};C.styleTagTransform=A(),C.setAttributes=l(),C.insert=s().bind(null,"head"),C.domAPI=o(),C.insertStyleElement=u();e()(b.A,C);b.A&&b.A.locals&&b.A.locals;var w=a(1937),y={};y.styleTagTransform=A(),y.setAttributes=l(),y.insert=s().bind(null,"head"),y.domAPI=o(),y.insertStyleElement=u();e()(w.A,y);w.A&&w.A.locals&&w.A.locals;var v=a(436),E={};E.styleTagTransform=A(),E.setAttributes=l(),E.insert=s().bind(null,"head"),E.domAPI=o(),E.insertStyleElement=u();e()(v.A,E);v.A&&v.A.locals&&v.A.locals;var B=a(1134),x={};x.styleTagTransform=A(),x.setAttributes=l(),x.insert=s().bind(null,"head"),x.domAPI=o(),x.insertStyleElement=u();e()(B.A,x);B.A&&B.A.locals&&B.A.locals;var k=a(1649),P={};P.styleTagTransform=A(),P.setAttributes=l(),P.insert=s().bind(null,"head"),P.domAPI=o(),P.insertStyleElement=u();e()(k.A,P);k.A&&k.A.locals&&k.A.locals;var T=a(6660),D={};D.styleTagTransform=A(),D.setAttributes=l(),D.insert=s().bind(null,"head"),D.domAPI=o(),D.insertStyleElement=u();e()(T.A,D);T.A&&T.A.locals&&T.A.locals;var S=a(5092),F={};F.styleTagTransform=A(),F.setAttributes=l(),F.insert=s().bind(null,"head"),F.domAPI=o(),F.insertStyleElement=u();e()(S.A,F);S.A&&S.A.locals&&S.A.locals;const L=globalThis,I=n=>n,N=L.trustedTypes,_=N?N.createPolicy("lit-html",{createHTML:n=>n}):void 0,O="$lit$",U=`lit$${Math.random().toFixed(9).slice(2)}$`,M="?"+U,z=`<${M}>`,$=document,R=()=>$.createComment(""),j=n=>null===n||"object"!=typeof n&&"function"!=typeof n,q=Array.isArray,G=n=>q(n)||"function"==typeof n?.[Symbol.iterator],H="[ \t\n\f\r]",W=/<(?:(!--|\/[^a-zA-Z])|(\/?[a-zA-Z][^>\s]*)|(\/?$))/g,V=/-->/g,Y=/>/g,Z=RegExp(`>|${H}(?:([^\\s"'>=/]+)(${H}*=${H}*(?:[^ \t\n\f\r"'\`<>=]|("|')|))|$)`,"g"),Q=/'/g,K=/"/g,X=/^(?:script|style|textarea|title)$/i,J=n=>(e,...t)=>({_$litType$:n,strings:e,values:t}),nn=J(1),en=(J(2),J(3),Symbol.for("lit-noChange")),tn=Symbol.for("lit-nothing"),on=new WeakMap,rn=$.createTreeWalker($,129);function an(n,e){if(!q(n)||!n.hasOwnProperty("raw"))throw Error("invalid template strings array");return void 0!==_?_.createHTML(e):e}const sn=(n,e)=>{const t=n.length-1,o=[];let r,a=2===e?"<svg>":3===e?"<math>":"",i=W;for(let e=0;e<t;e++){const t=n[e];let s,d,l=-1,c=0;for(;c<t.length&&(i.lastIndex=c,d=i.exec(t),null!==d);)c=i.lastIndex,i===W?"!--"===d[1]?i=V:void 0!==d[1]?i=Y:void 0!==d[2]?(X.test(d[2])&&(r=RegExp("</"+d[2],"g")),i=Z):void 0!==d[3]&&(i=Z):i===Z?">"===d[0]?(i=r??W,l=-1):void 0===d[1]?l=-2:(l=i.lastIndex-d[2].length,s=d[1],i=void 0===d[3]?Z:'"'===d[3]?K:Q):i===K||i===Q?i=Z:i===V||i===Y?i=W:(i=Z,r=void 0);const u=i===Z&&n[e+1].startsWith("/>")?" ":"";a+=i===W?t+z:l>=0?(o.push(s),t.slice(0,l)+O+t.slice(l)+U+u):t+U+(-2===l?e:u)}return[an(n,a+(n[t]||"<?>")+(2===e?"</svg>":3===e?"</math>":"")),o]};class dn{constructor({strings:n,_$litType$:e},t){let o;this.parts=[];let r=0,a=0;const i=n.length-1,s=this.parts,[d,l]=sn(n,e);if(this.el=dn.createElement(d,t),rn.currentNode=this.el.content,2===e||3===e){const n=this.el.content.firstChild;n.replaceWith(...n.childNodes)}for(;null!==(o=rn.nextNode())&&s.length<i;){if(1===o.nodeType){if(o.hasAttributes())for(const n of o.getAttributeNames())if(n.endsWith(O)){const e=l[a++],t=o.getAttribute(n).split(U),i=/([.?@])?(.*)/.exec(e);s.push({type:1,index:r,name:i[2],strings:t,ctor:"."===i[1]?An:"?"===i[1]?mn:"@"===i[1]?hn:pn}),o.removeAttribute(n)}else n.startsWith(U)&&(s.push({type:6,index:r}),o.removeAttribute(n));if(X.test(o.tagName)){const n=o.textContent.split(U),e=n.length-1;if(e>0){o.textContent=N?N.emptyScript:"";for(let t=0;t<e;t++)o.append(n[t],R()),rn.nextNode(),s.push({type:2,index:++r});o.append(n[e],R())}}}else if(8===o.nodeType)if(o.data===M)s.push({type:2,index:r});else{let n=-1;for(;-1!==(n=o.data.indexOf(U,n+1));)s.push({type:7,index:r}),n+=U.length-1}r++}}static createElement(n,e){const t=$.createElement("template");return t.innerHTML=n,t}}function ln(n,e,t=n,o){if(e===en)return e;let r=void 0!==o?t._$Co?.[o]:t._$Cl;const a=j(e)?void 0:e._$litDirective$;return r?.constructor!==a&&(r?._$AO?.(!1),void 0===a?r=void 0:(r=new a(n),r._$AT(n,t,o)),void 0!==o?(t._$Co??=[])[o]=r:t._$Cl=r),void 0!==r&&(e=ln(n,r._$AS(n,e.values),r,o)),e}class cn{constructor(n,e){this._$AV=[],this._$AN=void 0,this._$AD=n,this._$AM=e}get parentNode(){return this._$AM.parentNode}get _$AU(){return this._$AM._$AU}u(n){const{el:{content:e},parts:t}=this._$AD,o=(n?.creationScope??$).importNode(e,!0);rn.currentNode=o;let r=rn.nextNode(),a=0,i=0,s=t[0];for(;void 0!==s;){if(a===s.index){let e;2===s.type?e=new un(r,r.nextSibling,this,n):1===s.type?e=new s.ctor(r,s.name,s.strings,this,n):6===s.type&&(e=new fn(r,this,n)),this._$AV.push(e),s=t[++i]}a!==s?.index&&(r=rn.nextNode(),a++)}return rn.currentNode=$,o}p(n){let e=0;for(const t of this._$AV)void 0!==t&&(void 0!==t.strings?(t._$AI(n,t,e),e+=t.strings.length-2):t._$AI(n[e])),e++}}class un{get _$AU(){return this._$AM?._$AU??this._$Cv}constructor(n,e,t,o){this.type=2,this._$AH=tn,this._$AN=void 0,this._$AA=n,this._$AB=e,this._$AM=t,this.options=o,this._$Cv=o?.isConnected??!0}get parentNode(){let n=this._$AA.parentNode;const e=this._$AM;return void 0!==e&&11===n?.nodeType&&(n=e.parentNode),n}get startNode(){return this._$AA}get endNode(){return this._$AB}_$AI(n,e=this){n=ln(this,n,e),j(n)?n===tn||null==n||""===n?(this._$AH!==tn&&this._$AR(),this._$AH=tn):n!==this._$AH&&n!==en&&this._(n):void 0!==n._$litType$?this.$(n):void 0!==n.nodeType?this.T(n):G(n)?this.k(n):this._(n)}O(n){return this._$AA.parentNode.insertBefore(n,this._$AB)}T(n){this._$AH!==n&&(this._$AR(),this._$AH=this.O(n))}_(n){this._$AH!==tn&&j(this._$AH)?this._$AA.nextSibling.data=n:this.T($.createTextNode(n)),this._$AH=n}$(n){const{values:e,_$litType$:t}=n,o="number"==typeof t?this._$AC(n):(void 0===t.el&&(t.el=dn.createElement(an(t.h,t.h[0]),this.options)),t);if(this._$AH?._$AD===o)this._$AH.p(e);else{const n=new cn(o,this),t=n.u(this.options);n.p(e),this.T(t),this._$AH=n}}_$AC(n){let e=on.get(n.strings);return void 0===e&&on.set(n.strings,e=new dn(n)),e}k(n){q(this._$AH)||(this._$AH=[],this._$AR());const e=this._$AH;let t,o=0;for(const r of n)o===e.length?e.push(t=new un(this.O(R()),this.O(R()),this,this.options)):t=e[o],t._$AI(r),o++;o<e.length&&(this._$AR(t&&t._$AB.nextSibling,o),e.length=o)}_$AR(n=this._$AA.nextSibling,e){for(this._$AP?.(!1,!0,e);n!==this._$AB;){const e=I(n).nextSibling;I(n).remove(),n=e}}setConnected(n){void 0===this._$AM&&(this._$Cv=n,this._$AP?.(n))}}class pn{get tagName(){return this.element.tagName}get _$AU(){return this._$AM._$AU}constructor(n,e,t,o,r){this.type=1,this._$AH=tn,this._$AN=void 0,this.element=n,this.name=e,this._$AM=o,this.options=r,t.length>2||""!==t[0]||""!==t[1]?(this._$AH=Array(t.length-1).fill(new String),this.strings=t):this._$AH=tn}_$AI(n,e=this,t,o){const r=this.strings;let a=!1;if(void 0===r)n=ln(this,n,e,0),a=!j(n)||n!==this._$AH&&n!==en,a&&(this._$AH=n);else{const o=n;let i,s;for(n=r[0],i=0;i<r.length-1;i++)s=ln(this,o[t+i],e,i),s===en&&(s=this._$AH[i]),a||=!j(s)||s!==this._$AH[i],s===tn?n=tn:n!==tn&&(n+=(s??"")+r[i+1]),this._$AH[i]=s}a&&!o&&this.j(n)}j(n){n===tn?this.element.removeAttribute(this.name):this.element.setAttribute(this.name,n??"")}}class An extends pn{constructor(){super(...arguments),this.type=3}j(n){this.element[this.name]=n===tn?void 0:n}}class mn extends pn{constructor(){super(...arguments),this.type=4}j(n){this.element.toggleAttribute(this.name,!!n&&n!==tn)}}class hn extends pn{constructor(n,e,t,o,r){super(n,e,t,o,r),this.type=5}_$AI(n,e=this){if((n=ln(this,n,e,0)??tn)===en)return;const t=this._$AH,o=n===tn&&t!==tn||n.capture!==t.capture||n.once!==t.once||n.passive!==t.passive,r=n!==tn&&(t===tn||o);o&&this.element.removeEventListener(this.name,this,t),r&&this.element.addEventListener(this.name,this,n),this._$AH=n}handleEvent(n){"function"==typeof this._$AH?this._$AH.call(this.options?.host??this.element,n):this._$AH.handleEvent(n)}}class fn{constructor(n,e,t){this.element=n,this.type=6,this._$AN=void 0,this._$AM=e,this.options=t}get _$AU(){return this._$AM._$AU}_$AI(n){ln(this,n)}}const gn={M:O,P:U,A:M,C:1,L:sn,R:cn,D:G,V:ln,I:un,H:pn,N:mn,U:hn,B:An,F:fn},bn=L.litHtmlPolyfillSupport;bn?.(dn,un),(L.litHtmlVersions??=[]).push("3.3.2");var Cn=a(9426),wn=a(5663);const{I:yn}=gn,vn=2;class En{constructor(n){}get _$AU(){return this._$AM._$AU}_$AT(n,e,t){this._$Ct=n,this._$AM=e,this._$Ci=t}_$AS(n,e){return this.update(n,e)}update(n,e){return this.render(...e)}}const Bn=(n,e)=>{const t=n._$AN;if(void 0===t)return!1;for(const n of t)n._$AO?.(e,!1),Bn(n,e);return!0},xn=n=>{let e,t;do{if(void 0===(e=n._$AM))break;t=e._$AN,t.delete(n),n=e}while(0===t?.size)},kn=n=>{for(let e;e=n._$AM;n=e){let t=e._$AN;if(void 0===t)e._$AN=t=new Set;else if(t.has(n))break;t.add(n),Dn(e)}};function Pn(n){void 0!==this._$AN?(xn(this),this._$AM=n,kn(this)):this._$AM=n}function Tn(n,e=!1,t=0){const o=this._$AH,r=this._$AN;if(void 0!==r&&0!==r.size)if(e)if(Array.isArray(o))for(let n=t;n<o.length;n++)Bn(o[n],!1),xn(o[n]);else null!=o&&(Bn(o,!1),xn(o));else Bn(this,n)}const Dn=n=>{n.type==vn&&(n._$AP??=Tn,n._$AQ??=Pn)};class Sn extends En{constructor(){super(...arguments),this._$AN=void 0}_$AT(n,e,t){super._$AT(n,e,t),kn(this),this.isConnected=n._$AU}_$AO(n,e=!0){n!==this.isConnected&&(this.isConnected=n,n?this.reconnected?.():this.disconnected?.()),e&&(Bn(this,n),xn(this))}setValue(n){if((n=>void 0===n.strings)(this._$Ct))this._$Ct._$AI(n,this);else{const e=[...this._$Ct._$AH];e[this._$Ci]=n,this._$Ct._$AI(e,this,0)}}disconnected(){}reconnected(){}}class Fn{constructor(n){this.G=n}disconnect(){this.G=void 0}reconnect(n){this.G=n}deref(){return this.G}}class Ln{constructor(){this.Y=void 0,this.Z=void 0}get(){return this.Y}pause(){this.Y??=new Promise(n=>this.Z=n)}resume(){this.Z?.(),this.Y=this.Z=void 0}}const In=(n=>(...e)=>({_$litDirective$:n,values:e}))(class extends Sn{constructor(){super(...arguments),this._$CK=new Fn(this),this._$CX=new Ln}render(n,e){return en}update(n,[e,t]){if(this.isConnected||this.disconnected(),e===this._$CJ)return en;this._$CJ=e;let o=0;const{_$CK:r,_$CX:a}=this;return(async(n,e)=>{for await(const t of n)if(!1===await e(t))return})(e,async n=>{for(;a.get();)await a.get();const i=r.deref();if(void 0!==i){if(i._$CJ!==e)return!1;void 0!==t&&(n=t(n,o)),i.commitValue(n,o),o++}return!0}),en}commitValue(n,e){this.setValue(n)}disconnected(){this._$CK.disconnect(),this._$CX.pause()}reconnected(){this._$CK.reconnect(this),this._$CX.resume()}}),Nn="Current user not found! Not logged in?",_n="You need to either pick a group or enter one.",On="There was an error creating group.",Un="There was an error creating the address book.",Mn="Please enter an address book URI.",zn="Unable to determine user workspace for new address book.",$n="Friend already exists",Rn="Contact already exists",jn="Add me to your friends",qn="Login to add me to your friends",Gn="Add me to your contacts",Hn="Login to add me to your contacts",Wn="Login to chat with me",Vn="Already part of contacts",Yn="Add webID to contact",Zn="Chat with me",Qn="Resume",Kn="Social Accounts",Xn="Friends";function Jn(n,e,t){const o=Cn.widgets.errorMessageBlock(e.dom,t);o.setAttribute("role","alert"),o.setAttribute("aria-live","assertive"),o.setAttribute("tabindex","0"),setTimeout(()=>{o.focus()},100),n.appendChild(o)}function ne(n,e){const t=document.createElement("div");t.setAttribute("role","status"),t.setAttribute("aria-live","polite"),t.setAttribute("tabindex","0"),t.classList.add("actionButton","licOkay"),t.innerHTML=e,setTimeout(()=>{t.focus()},100),n.appendChild(t)}function ee(n){for(;n.childNodes.length>2;)n.removeChild(n.lastChild)}function te(n){return!!n}const oe=(n,{dom:e})=>{const t=e.createElement("div");return Cn.widgets.attachmentList(e,n,t,{doc:n.doc(),modify:!1,predicate:Cn.ns.foaf("knows"),noun:"friend"}),""===t.textContent?null:(t.querySelectorAll("li").forEach((n,e)=>{n.classList.add("friendItem");const t=n.querySelector("a");t&&t.textContent?n.setAttribute("aria-label",`Friend: ${t.textContent.trim()}`):n.textContent?n.setAttribute("aria-label",`Friend: ${n.textContent.trim()}`):n.setAttribute("aria-label",`Friend ${e+1}`)}),t)};var re=a(6077);const ae=(n,e)=>{const t=Cn.utils.label(n),o=Cn.widgets.findImage(n),r=e.anyValue(n,Cn.ns.vcard("role")),a=e.anyValue(n,Cn.ns.vcard("organization-name")),i=e.any(n,Cn.ns.vcard("hasAddress")),s=null!=i?e.anyValue(i,Cn.ns.vcard("country-name")):null,d=null!=i?e.anyValue(i,Cn.ns.vcard("locality")):null,{backgroundColor:l,highlightColor:c}=function(n,e){const t=e.anyValue(n,Cn.ns.solid("profileBackgroundColor"),null,n.doc()),o=e.anyValue(n,Cn.ns.solid("profileHighlightColor"),null,n.doc());return{backgroundColor:de(t,""),highlightColor:de(o,"")}}(n,e),u=function(n){let e=wn.store.anyJS(n,Cn.ns.solid("preferredSubjectPronoun"))||"";if(e){const t=wn.store.anyJS(n,Cn.ns.solid("preferredObjectPronoun"));if(t){e+="/"+t;const o=wn.store.anyJS(n,Cn.ns.solid("preferredRelativePronoun"));o&&(e+="/"+o)}e=" ("+e+") "}return e||""}(n);return{name:t,imageSrc:o,introduction:se(r,a),location:ie(s,d),backgroundColor:l,pronouns:u,highlightColor:c}};function ie(n,e){return n&&e?`${e}, ${n}`:n||e||null}function se(n,e){return n&&e?`${n} at ${e}`:e||n||null}function de(n,e){return n&&(0,re.validateHTMLColorHex)(n)?n:e}var le=a(5491);const ce=(0,le.Namespace)("http://www.w3.org/ns/org#"),ue=["PastRole","CurrentRole","FutureRole"];function pe(n,e){return n?"("+n.value.slice(0,10)+" to "+(e?e.value.slice(0,10):"")+")":""}function Ae(n,e){const t=e.elements;if(Array.isArray(t))return t.flatMap(e=>Ae(n,e));if(!n.any(e,Cn.ns.rdf("first")))return[e];const o=[];let r=e;for(;r;){const e=n.any(r,Cn.ns.rdf("first"));e&&o.push(...Ae(n,e));const t=n.any(r,Cn.ns.rdf("rest"));if(!t||"NamedNode"===t.termType&&t.value===Cn.ns.rdf("nil").value)break;r=t}return o}function me(n,e){const t=function(n,e){const t=n.each(null,ce("member"),e,null),o={PastRole:[],CurrentRole:[],FutureRole:[]};for(const e of t){let t,r,a,i,s;const d=n.any(e,Cn.ns.schema("startDate")),l=n.any(e,Cn.ns.schema("endDate")),c=pe(d,l),u=n.any(e,ce("organization"));u&&(r=n.anyJS(u,Cn.ns.schema("name")),t=n.any(u,Cn.ns.schema("uri")),s=n.any(u,Cn.ns.solid("publicId"))),s&&(a=n.anyJS(s,Cn.ns.schema("name")));const p=a||r,A=n.any(e,ce("role"));A&&(i=n.anyJS(A,Cn.ns.schema("name")));const m=n.anyJS(e,Cn.ns.vcard("role")),h={startDate:d,endDate:l,orgName:p,roleText:m&&i?i+" - "+m:m||i,dates:c,orgHomePage:t};for(const t of ue)n.holds(e,Cn.ns.rdf("type"),Cn.ns.solid(t))&&o[t].push(h)}return o}(e,n);for(const n of ue)t[n].sort(function(n,e){return n.endDate&&e.endDate?n.endDate>e.endDate?-1:1:n.startDate>e.startDate?-1:1});const o=e.each(n,Cn.ns.schema("skills")).map(n=>function(n,e){if("Literal"===e.termType)return e.value;const t=n.anyJS(e,Cn.ns.solid("publicId"));if(t){const e=n.anyJS(t,Cn.ns.schema("name"));if(e)return e}const o=n.anyJS(e,Cn.ns.vcard("role"));return o&&o[0]>""?o:""}(e,n)).filter(n=>""!==n),r=e.each(n,Cn.ns.schema("knowsLanguage")).flatMap(n=>Ae(e,n)).map(n=>function(n,e){if("Literal"===e.termType)return e.value;const t=n.anyJS(e,Cn.ns.solid("publicId"));return t?Cn.utils.label(t,!0):""}(e,n));return{rolesByType:t,skills:o,languages:Array.from(new Set(r))}}const he='@prefix rdf: <http://www.w3.org/1999/02/22-rdf-syntax-ns#>.\n@prefix rdfs: <http://www.w3.org/2000/01/rdf-schema#>.\n@prefix foaf: <http://xmlns.com/foaf/0.1/>.\n@prefix owl: <http://www.w3.org/2002/07/owl#>.\n@prefix solid: <http://www.w3.org/ns/solid/terms#>.\n@prefix ui: <http://www.w3.org/ns/ui#>.\n@prefix schema: <http://schema.org/>.\n@prefix vcard: <http://www.w3.org/2006/vcard/ns#>.\n@prefix org: <http://www.w3.org/ns/org#>.\n@prefix : <#>.\n\n########### ATTENTION - we cannot rename this ontology file name without migrating existing data on existing accounts\n\n########### Social Media - other accounts\n#\n# Twitter, linked In, Orkid, Mastodon, Matrix, Bluesky, Instagram, Facebook, Github,\n# Snapchat, TikTok, etc\n\n:this\n <http://purl.org/dc/elements/1.1/title> "Social media form" ;\n a ui:Form ;\n ui:parts (\n :SocialsForm\n ).\n\n:SocialsForm a ui:Multiple;\n ui:label "online account";\n ui:property foaf:account; # the triple is created with the foaf:acccounts predicate\n ui:ordered true; # Allow user to order occounts most important first.\n ui:part :AccountsForm.\n\n:AccountsForm a ui:Group; \n ui:weight 1; \n ui:parts ( \n :AccountField \n :AccountIdField ).\n\n:AccountField a ui:Classifier; \n ui:label "Choose account"@en;\n ui:multiple false ; \n ui:category foaf:Account. # the accounts are described by the foaf:Account predicate\n\n# this is what is needed to make a dropdown box\nfoaf:Account a rdfs:Class;\n rdfs:label "Online Account Provider";\n owl:disjointUnionOf ( \n :BlueSkyAccount :DiggAccount :FacebookAccount :GithubAccount :InstagramAccount\n :LinkedInAccount :MastodonAccount :MatrixAccount :MediumAccount :NostrAccount \n :OrcidAccount :PinterestAccount :RedditAccount :SnapchatAccount :StravaAccount \n :TiktokAccount :TumblrAccount :TwitterAccount :OtherAccount) .\n\n:AccountIdField a ui:Options; \n ui:dependingOn rdf:type; \n ui:case\n [ ui:for :BlueSkyAccount; ui:use :BlueSkyIdField ],\n [ ui:for :DiggAccount; ui:use :DiggIdField],\n [ ui:for :FacebookAccount; ui:use :FacebookIdField ],\n [ ui:for :GithubAccount; ui:use :GithubIdField ],\n [ ui:for :InstagramAccount; ui:use :InstagramIdField ],\n [ ui:for :LinkedInAccount; ui:use :LinkedInIdField ],\n [ ui:for :MastodonAccount; ui:use :MastodonIdField ],\n [ ui:for :MatrixAccount; ui:use :MatrixIdField ],\n [ ui:for :MediumAccount; ui:use :MediumIdField ],\n [ ui:for :NostrAccount; ui:use :NostrIdField ],\n [ ui:for :OrcidAccount; ui:use :OrcidIdField ],\n [ ui:for :PinterestAccount; ui:use :PinterestIdField ],\n [ ui:for :RedditAccount; ui:use :RedditIdField ],\n [ ui:for :StravaAccount; ui:use :StravaIdField ],\n [ ui:for :SnapchatAccount; ui:use :SnapchatIdField ],\n [ ui:for :TiktokAccount; ui:use :TiktokIdField ],\n [ ui:for :TumblrAccount; ui:use :TumblrIdField ],\n [ ui:for :TwitterAccount; ui:use :TwitterIdField ],\n [ ui:for :OtherAccount; ui:use :OtherIdForm ] .\n\n:BlueSkyAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Bluesky";\n foaf:userProfilePrefix "https://bsky.app/profile/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/bluesky-1.svg>;\n foaf:homepage <https://bsky.app/> .\n\n:DiggAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Digg";\n foaf:userProfilePrefix "https://www.digg.com/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/digg-icon.svg>;\n foaf:homepage <https://www.digg.com/> .\n\n:FacebookAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Facebook";\n foaf:userProfilePrefix "https://www.facebook.com/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/facebook-2020-2-1.svg>;\n foaf:homepage <https://www.facebook.com/> .\n\n:GithubAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Github";\n foaf:userProfilePrefix "https://www.github.com/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/github-icon.svg>;\n foaf:homepage <https://github.com/> .\n\n:InstagramAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Instagram";\n foaf:userProfilePrefix "https://www.instagram.com/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/instagram-2016-5.svg>;\n foaf:homepage <https://www.instagram.com/> .\n\n:LinkedInAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "LinkedIn";\n foaf:userProfilePrefix "https://www.linkedin.com/in/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/linkedin-icon.svg>;\n foaf:homepage <https://linkedin.com/> .\n\n:MastodonAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Mastodon" ;\n foaf:userProfilePrefix "https://mastodon.social/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/mastodon-2.svg>;\n foaf:homepage <https://joinmastodon.org/> .\n\n:MatrixAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Matrix" ;\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/matrix-logo-black.svg> ;\n foaf:userProfilePrefix "https://matrix.to/#/" ;\n foaf:homepage <https://matrix.org/> .\n\n:MediumAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Medium";\n foaf:userProfilePrefix "https://medium.com/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/medium-logo-wordmark-black.svg>;\n foaf:homepage <https://medium.com/> .\n\n:NostrAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Nostr";\n foaf:userProfilePrefix "https://primal.net/p/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/nostr-icon-purple-on-white.svg>;\n foaf:homepage <https://nostr.net/> .\n\n:OrcidAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "ORCiD";\n foaf:userProfilePrefix "https://orcid.org/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/ORCID-1.svg>;\n foaf:homepage <https://orcid.org/> .\n\n:PinterestAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Pinterest";\n foaf:userProfilePrefix "https://pin.it/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/pinterest-2-1.svg>;\n foaf:homepage <https://pinterest.com/> .\n\n:RedditAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Reddit";\n foaf:userProfilePrefix "https://www.reddit.com/user/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/reddit-4.svg>;\n foaf:homepage <https://reddit.com/> .\n\n:SnapchatAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Snapchat";\n foaf:userProfilePrefix "https://www.snapchat.com/add/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/snapchat-1.svg>;\n foaf:homepage <https://www.snapchat.com/> .\n\n:StravaAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Strava";\n foaf:userProfilePrefix "https://www.strava.com/athletes/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/strava-2.svg>;\n foaf:homepage <https://strava.com/> .\n\n:TiktokAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "TikTok";\n foaf:userProfilePrefix "https://www.tiktok.com/@";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/tiktok-icon-2.svg>;\n foaf:homepage <https://www.tiktok.com/> .\n\n:TumblrAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Tumblr";\n foaf:userProfilePrefix "https://www.tumblr.com/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/tumblr-icon.svg>;\n foaf:homepage <https://www.tumblr.com/> .\n\n:TwitterAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "X";\n foaf:userProfilePrefix "https://x.com/";\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/social/x-2.svg>;\n foaf:homepage <https://x.com/> .\n\n:OtherAccount rdfs:subClassOf foaf:Account ;\n rdfs:label "Other" ;\n foaf:icon <https://solidos.github.io/solid-ui/src/icons/noun_1689339.svg> .\n\n:BlueSkyIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "@[a-z0-9A-Z_-](.[a-z0-9A-Z_-])*".\n\n:DiggIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "@[a-z0-9A-Z_-](.[a-z0-9A-Z_-])*".\n\n:FacebookIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:property foaf:accountName ; \n ui:pattern "[a-z0-9A-Z_-]*".\n\n:GithubIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "[a-z0-9A-Z_-]*".\n\n:InstagramIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "[a-z0-9A-Z_-]*".\n\n:LinkedInIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "[a-z0-9A-Z_-]*(.[a-z0-9A-Z_-])*".\n\n:MastodonIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "@[a-z0-9A-Z_-]*(.[a-z0-9A-Z_-])*".\n\n:MatrixIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "@[a-z0-9A-Z_-]*(.[a-z0-9A-Z_-])*".\n\n:MediumIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "@[a-z0-9A-Z_-]*(.[a-z0-9A-Z_-])*".\n\n:NostrIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "[a-z0-9A-Z_-]*(.[a-z0-9A-Z_-])*".\n\n:OrcidIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "[a-z0-9A-Z_-]*".\n\n:PinterestIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "[a-z0-9A-Z_-]*".\n\n:RedditIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "[a-z0-9A-Z_-]*".\n\n:StravaIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "[a-z0-9A-Z_-]*".\n\n:SnapchatIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "@[a-z0-9A-Z_-]*".\n\n:TiktokIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "@[a-z0-9A-Z_-]*".\n\n:TumblrIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "@[a-z0-9A-Z_-]*".\n\n:TwitterIdField\n a ui:SingleLineTextField ;\n ui:label "Username";\n ui:maxLength "200" ;\n ui:property foaf:accountName ; \n ui:pattern "@[a-z0-9A-Z_-]*".\n\n# an unknown online account needs more info\n\n:OtherIdForm a ui:Group; \n ui:weight 0; \n ui:parts ( \n :OtherIdField \n :OtherIconField \n :OtherLabelField ).\n\n:OtherIdField\n a ui:NamedNodeURIField ;\n ui:label "Account link";\n ui:maxLength "200" ;\n ui:property foaf:homepage.\n\n:OtherIconField\n a ui:NamedNodeURIField ;\n ui:label "Icon link";\n ui:maxLength "200" ;\n ui:property foaf:icon.\n\n:OtherLabelField\n a ui:SingleLineTextField ;\n ui:label "Name";\n ui:maxLength "200" ;\n ui:property rdfs:label.\n\n# ends\n',fe="https://solidos.github.io/profile-pane/src/ontology/";function ge(n,e,t,o,r,a,i,s){const d=fe+o,l=s||"this",c=(0,le.Namespace)(d+"#")(l);be(r,t,o,d),Cn.widgets.appendForm(a,n,{},e,c,i,(n,e)=>{n||Cn.widgets.errorMessageBlock(a,e)})}function be(n,e,t,o){const r=o||fe+t,a=(0,le.sym)(r);n.holds(void 0,void 0,void 0,a)||(0,le.parse)(e,n,r,"text/turtle",()=>null)}const Ce=Cn.icons.iconBase+"noun_10636_grey.svg";function we(n,e){function t(n){const t=e.any(n,Cn.ns.foaf("name"))||e.any(n,Cn.ns.rdfs("label"));if(t)return t.value;const o=e.each(n,Cn.ns.rdf("type"));for(const n of o){const t=e.any(n,Cn.ns.rdfs("label"));return t?t.value:Cn.utils.label(n)}return"Unknown Account"}function o(n){const t=e.any(n,Cn.ns.foaf("icon"));if(t)return t.value;const o=e.each(n,Cn.ns.rdf("type"));if(o.length>0)for(const n of o){const t=e.any(n,Cn.ns.foaf("icon"));if(null!==t)return t.value}return Ce}function r(n){const t=e.any(n,Cn.ns.foaf("homepage"));if(t)return t.value;const o=e.anyJS(n,Cn.ns.foaf("accountName"),null,n.doc())||"No_account_Name",r=e.each(n,Cn.ns.rdf("type"));for(const n of r)if("NamedNode"===n.termType){const t=e.any(n,Cn.ns.foaf("userProfilePrefix"));if(t)return t.value+o.trim()}return e.anyJS(n,Cn.ns.foaf("homepage"),null,n.doc())||""}function a(n){return{name:t(n),icon:o(n),homepage:r(n)}}be(e,he,"socialMedia.ttl");let i=e.each(n,Cn.ns.foaf("account")).flatMap(n=>function(n,e){const t=new Set;return function e(o){const r=`${o.termType||typeof o}:${o.value||String(o)}`;if(t.has(r))return[];t.add(r);const a=o.elements;if(Array.isArray(a))return a.flatMap(n=>e(n));if(!n.any(o,Cn.ns.rdf("first")))return[o];const i=[];let s=o;for(;s;){const t=n.any(s,Cn.ns.rdf("first"));t&&i.push(...e(t));const o=n.any(s,Cn.ns.rdf("rest"));if(!o||"NamedNode"===o.termType&&o.value===Cn.ns.rdf("nil").value)break;s=o}return i}(e)}(e,n));const s=new Set,d=[];for(const n of i)if("NamedNode"===n.termType){const t=e.any(n,Cn.ns.foaf("accountName")),o=t?t.value:"";s.has(o)||(s.add(o),d.push(a(n)))}return d.length?{accounts:d}:{accounts:[]}}const{iconForClass:ye}=Cn.widgets,{typeIndex:ve}=wn.solidLogicSingleton,{getScopedAppInstances:Ee}=ve,Be={};for(const n in ye){const e=n.split(":")[0],t=n.split(":")[1],o=Cn.ns[e](t);Be[o.uri]=le.uri.join(ye[n],Cn.icons.iconBase)}async function xe(n){return{stuff:(await Ee(null,n)).map(n=>{const e=(t=n.type||Cn.ns.rdf("Resource"),Be[t.uri]||Cn.icons.iconBase+"noun_10636.svg");var t;return{href:n.instance.uri,name:Cn.utils.label(n.instance),icon:e,instance:n.instance}})}}let ke=document.createElement("section");const Pe=(n,e)=>{let t=Te(wn.authn.currentUser())?jn.toUpperCase():qn.toUpperCase();const o=Cn.widgets.button(e.dom,void 0,t,function(t){t.preventDefault(),async function(n,e){const t=wn.authn.currentUser(),o=e.session.store;if(!Te(t))throw new Error(Nn);if(await De(o,t,n))throw new Error($n);{await o.fetcher.load(t);const e=o.updater,r=[(0,le.st)(t,Cn.ns.foaf("knows"),n,t.doc())];try{await e.update([],r)}catch(n){let e=n;throw e.toString().includes("Unauthenticated")&&(e=Nn),new Error(e)}}}(n,e).then(()=>{ee(ke),ne(ke,"Friend was added!"),r()}).catch(n=>{ee(ke),Jn(ke,e,n)})},{needsBorder:!0});function r(){const t=wn.authn.currentUser(),r=e.session.store;Te(t)?De(r,t,n).then(n=>{o.innerHTML=n?"Already part of friends".toUpperCase():jn.toUpperCase()}):o.innerHTML=qn.toUpperCase()}return o.refresh=r(),o};function Te(n){return!!n}async function De(n,e,t){return await n.fetcher.load(e),0!==n.whether(e,Cn.ns.foaf("knows"),t,e.doc())}const Se=(n,e)=>{const t=n.dom.getElementById("error-display-section");if(t)t.classList.add("contactsShowErrors"),t.textContent=e;else{Jn(n.dom.getElementById("add-to-contacts-button-container"),n,e)}},Fe="contacts-popup-overlay",Le="contactsOverlayActive",Ie=n=>{const e=n.dom.createElement("section");return e.setAttribute("id","addressbook-details-section"),e.setAttribute("role","addressBookDetails"),e.setAttribute("aria-live","polite"),e.setAttribute("tabindex","0"),e.classList.add("contactsAddressBookDetails"),e},Ne=(n,e,t,o)=>{const r=n.dom.createElement("button");return r.setAttribute("id","contacts-create-addressbook-button"),r.setAttribute("type","button"),r.setAttribute("role","button"),r.setAttribute("aria-label","Create a new address book"),r.setAttribute("tabindex","0"),r.textContent="Create Address Book",r.classList.add("contactsActionButton","contactsAddressBookCreationButton"),r.addEventListener("click",async r=>{r.preventDefault();const a=He(n,t,e,o),i=n.dom.getElementById("contacts-selector-dialog");Je(n),i.appendChild(a)}),r},_e=(n,e,t,o)=>{const r=n.dom.createElement("button");return r.setAttribute("id","contacts-addressbook-uri-entry-button"),r.setAttribute("type","button"),r.setAttribute("role","button"),r.setAttribute("aria-label","Enter an address book URI to add the contact to a specific address book"),r.setAttribute("tabindex","0"),r.textContent="Enter Address Book URI",r.classList.add("contactsActionButton","contactsAddressBookUriEntryButton"),r.addEventListener("click",async r=>{r.preventDefault();const a=n.dom.getElementById("contacts-selector-dialog"),i=Oe(n,e,t,o);Je(n),a.appendChild(i)}),r},Oe=(n,e,t,o)=>{const r=n.dom.createElement("div");r.setAttribute("role","addressBookUriEntry"),r.setAttribute("aria-live","polite"),r.setAttribute("tabindex","0"),r.setAttribute("aria-label","Address book URI entry div"),r.setAttribute("aria-describedby","addressbook-uri-entry-div"),r.setAttribute("id","contacts-addressbook-uri-entry"),r.classList.add("contactsPopupDialog","contactsAddressBookUriEntry");const a=We(n,r,"contactsAddressBookUriEntryCloseButton");return r.appendChild(a),r.appendChild(Ue(n,e,t,o)),r},Ue=(n,e,t,o)=>{const r=n.dom.createElement("form");r.setAttribute("id","contacts-address-uri-entry-form"),r.classList.add("contactsAddressBookUriEntryForm"),r.method="post",r.addEventListener("submit",async r=>{r.preventDefault();const a=n.dom.querySelector("#addressBookUriInput").value;if(a){const r="#this"===a.substring(a.length-5,a.length)?a:a+"#this",i=await ut(n,e,t,r),s=n.dom.querySelector("#addressbook-list");if(s){n.dom.getElementById("contacts-addressbook-uri-entry").remove(),nt(n);const t=n.dom.getElementById("contacts-create-addressbook-button"),r=n.dom.getElementById("contacts-addressbook-uri-entry-button");t.remove(),r.remove(),s.appendChild(Ge(n,e,i.addressBooksData,i.addressBook,a,o)),s.appendChild(Ne(n,e,i.addressBooksData,o)),s.appendChild(_e(n,e,i.addressBooksData,o))}}else Se(n,Mn)});const a=n.dom.createElement("label");a.classList.add("label"),a.setAttribute("for","addressBookUriInput");const i=n.dom.createElement("input");return i.type="text",i.name="addressBookUri",i.id="addressBookUriInput",i.placeholder="Enter address book URI to find your address book",i.classList.add("input","contactsAddressBookUriInput"),i.addEventListener("click",()=>{je(n)}),r.appendChild(a),r.appendChild(i),r.appendChild(Me(n)),r},Me=n=>{const e=n.dom.createElement("button");return e.setAttribute("id","contacts-addressbook-entry-button"),e.setAttribute("role","button"),e.setAttribute("aria-label","Create Address Book from entered URI"),e.setAttribute("tabindex","0"),e.classList.add("contactsActionButton","contactsAddressBookUriEntryAddButton"),e.setAttribute("type","submit"),e.addEventListener("click",async e=>{e.preventDefault();const t=n.dom.querySelector("#contacts-address-uri-entry-form");t&&t.requestSubmit()}),e.innerHTML="Add",e},ze=(n,e,t,o,r)=>{const a=n.dom.createElement("div");a.setAttribute("class","contactsAddressBookList"),a.setAttribute("role","addressBooksList"),a.setAttribute("aria-live","polite"),a.setAttribute("tabindex","0"),a.setAttribute("aria-label","Address book list to select which address book to add the contact to"),a.setAttribute("aria-describedby","addressbook-list"),a.setAttribute("id","addressbook-list"),a.innerHTML="Address Books",o.public.forEach((r,i)=>{a.appendChild(Ge(n,e,o,r,i,t))}),o.private.forEach((r,i)=>{a.appendChild(Ge(n,e,o,r,i,t))});const i=Ne(n,e,o,t),s=_e(n,e,o,t);return a.appendChild(i),a.appendChild(s),a},$e=(n,e,t,o)=>{const r=n.dom.createElement("button");return r.setAttribute("id","contacts-create-group-button"),r.setAttribute("type","button"),r.setAttribute("role","button"),r.setAttribute("aria-label","Create a new group in the selected address book"),r.setAttribute("tabindex","0"),r.textContent="Create Group",r.classList.add("contactsActionButton","contactsCreateGroupCreationButton"),r.addEventListener("click",async r=>{r.preventDefault();const a=n.dom.getElementById("contacts-selector-dialog");n.dom.getElementById("new-group-form")||(Je(n),a.appendChild(Ve(n,e,t,o)))}),r},Re=n=>{const e=n.dom.createElement("section");e.setAttribute("role","errorDisplay"),e.setAttribute("aria-live","assertive"),e.setAttribute("tabindex","0"),e.setAttribute("aria-label","Section to display error messages related to contact creation"),e.setAttribute("id","error-display-section"),e.classList.add("contactsErrorDisplay");const t=n.dom.createElement("button");return t.setAttribute("type","button"),t.setAttribute("aria-label","Close error message display"),t.setAttribute("tabindex","0"),t.setAttribute("role","button"),t.classList.add("contactsCloseErrorDisplayButton"),t.textContent="x",t.addEventListener("click",n=>{n.preventDefault(),e.classList.remove("contactsShowErrors")}),e.appendChild(t),e},je=n=>{const e=n.dom.getElementById("error-display-section");e.classList.contains("contactsShowErrors")&&(e.classList.remove("contactsShowErrors"),e.innerHTML="")},qe=(n,e,t,o)=>{const r=n.dom.createElement("button");return r.setAttribute("type","submit"),r.setAttribute("id","add-contact"),r.setAttribute("role","button"),r.setAttribute("aria-label","Add contact to selected address book"),r.setAttribute("tabindex","0"),r.classList.add("contactsActionButton","contactsNewContactCreationButton"),r.addEventListener("click",async r=>{r.preventDefault();const a=mt(t,o.webID),i=ht(t,o.name);if(Ze(n,e,t,o,a,i))return;let s=null,d=[];n.dom.querySelectorAll(".selectedAddressBook").forEach(n=>{s=n.getAttribute("id")});if(n.dom.querySelectorAll(".selectedGroup").forEach(n=>{d.push(n.getAttribute("id"))}),d.length){const r={addressBookUri:s,groupUris:d};try{const a=await async function(n,e,t,o,r){let a=null;const i={name:o.name};try{const t=r.groupUris.length?r.groupUris:void 0;return t?(a=await e.createNewContact({addressBookUri:r.addressBookUri,contact:i,groupUris:t}),await n.session.store.fetcher.load(a),await pt(n,t,a,o.webID),(o.emails.length||o.phoneNumbers.length)&&await async function(n,e,t){const o=n.session.store,r=new le.NamedNode(e),a=r.doc(),i=9999999999999,s=1e12,d=()=>{const n=Math.floor(Math.random()*(i-s+1))+s;return(0,le.sym)(`${a.uri}#id${n}`)};let l=[];try{t.emails.map(n=>{const e=d();l.push((0,le.st)(r,Cn.ns.vcard("hasEmail"),e,a)),l.push((0,le.st)(e,Cn.ns.rdf("type"),n.type,a)),l.push((0,le.st)(e,Cn.ns.vcard("value"),n.email,a))}),t.phoneNumbers.map(n=>{const e=d();l.push((0,le.st)(r,Cn.ns.vcard("hasTelephone"),e,a)),l.push((0,le.st)(e,Cn.ns.rdf("type"),n.type,a)),l.push((0,le.st)(e,Cn.ns.vcard("value"),n.phoneNumber,a))}),await o.updater.update([],l)}catch(e){Se(n,e)}}(n,a,o),a):void Se(n,_n)}catch(e){Se(n,e)}}(n,e,0,o,r);Qe(n,t,o,a)}catch(e){Se(n,`There was an error creating contact.\n${e}`)}}else Se(n,_n)}),r.textContent="Add Contact",r},Ge=(n,e,t,o,r,a)=>{const i=n.dom.createElement("button");return i.setAttribute("value",o.name),i.setAttribute("id",r),i.setAttribute("role","button"),i.setAttribute("type","submit"),i.setAttribute("aria-label","Select address book "+o.name),i.setAttribute("tabindex","0"),i.classList.add("contactsButton"),i.addEventListener("click",o=>{o.preventDefault();const r=o.target,i=r.classList.contains("contactsSelectedButton"),s=n.dom.getElementById("addressbook-details-section");let d=null;const l=n.dom.getElementById("group-list");l&&l.remove();if(n.dom.querySelectorAll(".selectedAddressBook").forEach(n=>{n.classList.remove("contactsSelectedButton","selectedAddressBook")}),i){r.classList.remove("contactsSelectedButton","selectedAddressBook");const e=n.dom.getElementById("new-group-form");e&&(e.remove(),nt(n))}else{const i=n.dom.getElementById("new-addressbook-form");i&&(i.remove(),nt(n)),r.classList.add("contactsSelectedButton","selectedAddressBook");const l=o.target.id;d=t.public.get(l),d||(d=t.private.get(l));const c=n.dom.getElementById("group-list");c&&c.remove();const u=((n,e,t,o,r)=>{const a=n.dom.createElement("div");return a.setAttribute("class","contactsGroupList"),a.setAttribute("role","groupList"),a.setAttribute("aria-live","polite"),a.setAttribute("tabindex","0"),a.setAttribute("aria-label","Group list to select which groups in the address book to add the contact to"),a.setAttribute("aria-describedby","group-list"),a.setAttribute("id","group-list"),a.innerHTML="Groups",o&&o.groups.map(e=>{a.appendChild(Ke(n,e))}),a.appendChild($e(n,e,t,r)),a})(n,e,t,d,a);s.appendChild(u)}}),i.innerHTML=o.name,i},He=(n,e,t,o)=>{const r=n.dom.createElement("form");r.method="post",r.innerHTML="Create a new address book",r.setAttribute("id","new-addressbook-form"),r.classList.add("contactsPopupDialog","contactsNewAddressForm");const a=n.dom.createElement("label");a.classList.add("label"),a.setAttribute("for","addressBookNameInput");const i=n.dom.createElement("input");i.type="text",i.name="addressBookName",i.id="addressBookNameInput",i.placeholder="New address book name",i.classList.add("input","contactsAddressBookInput"),i.required=!0;const s=n.dom.createElement("label");s.classList.add("label"),s.setAttribute("for","addressBookContainerInput");const d=n.dom.createElement("input");d.type="text",d.name="addressBookContainer",d.id="addressBookContainerInput",d.placeholder="Address book container",d.classList.add("input","contactsAddressBookInput"),d.required=!0;const l=n.dom.createElement("label");l.classList.add("label"),l.setAttribute("for","groupNameInput");const c=n.dom.createElement("input");c.type="text",c.name="groupName",c.id="groupNameInput",c.placeholder="New group name",c.classList.add("input","contactsGroupInput"),c.required=!0;const u=n.dom.createElement("button");u.setAttribute("id","submit-addressbook"),u.setAttribute("role","button"),u.setAttribute("type","submit"),u.setAttribute("aria-label","Create a new address book with the entered name, container, type and group"),u.setAttribute("tabindex","0"),u.classList.add("contactsActionButton","contactsAddressBookCreationSubmitButton"),u.addEventListener("click",n=>{n.preventDefault(),r.requestSubmit()}),u.innerHTML="Create Address Book";const p=We(n,r,"contactsAddressBookCreationCloseButton");return r.appendChild(p),r.appendChild(a),r.appendChild(i),r.appendChild(s),r.appendChild(d),r.appendChild(l),r.appendChild(c),r.appendChild(u),r.addEventListener("submit",async a=>{a.preventDefault();let i=null,s=null;const d=n.dom.querySelector("#addressBookNameInput").value,l=n.dom.querySelector("#addressBookContainerInput").value,c=n.dom.querySelector("#groupNameInput").value;if(d)try{i=await async function(n,e,t){var o,r;const a=wn.authn.currentUser(),i=null===(o=null==a?void 0:a.site())||void 0===o?void 0:o.value;let s=null;const d=n.dom.getElementById("new-addressbook-form");try{if(!a||!i)throw new Error(zn);const o=i.endsWith("/")?i:`${i}/`,l=`${o}${(e||"address-book").trim().toLowerCase().replace(/[^a-z0-9]+/g,"-").replace(/^-+|-+$/g,"")||"address-book"}/`,c=await rt().mintNew(n,{me:a,dom:n.dom,div:d,newBase:l,instanceClass:Cn.ns.vcard("AddressBook"),instanceName:t});s=(null===(r=null==c?void 0:c.newInstance)||void 0===r?void 0:r.uri)||`${l}index.ttl#this`,await async function(n,e,t){const o=n.session.store,r=(0,le.sym)(e),a=r.doc(),i=null==t?void 0:t.trim();if(!i)return;try{await o.fetcher.load(a);const n=[...o.statementsMatching(r,Cn.ns.dc("title"),null,a),...o.statementsMatching(r,Cn.ns.vcard("fn"),null,a)],e=[(0,le.st)(r,Cn.ns.dc("title"),(0,le.literal)(i),a),(0,le.st)(r,Cn.ns.vcard("fn"),(0,le.literal)(i),a)];await o.updater.update(n,e)}catch(e){Se(n,e)}}(n,s,t)}catch(e){Se(n,Un+"\n"+e)}return s}(n,l,d);const a=await ut(n,t,e,i);if(c){s=await t.createNewGroup({addressBookUri:i,groupName:c});if(!await gt(e,i,{name:c,uri:s}))return void Se(n,On)}const u=n.dom.querySelector("#addressbook-list"),p=n.dom.querySelector("#group-list");if(u){r.remove(),nt(n);const s=n.dom.getElementById("contacts-create-addressbook-button"),d=n.dom.getElementById("contacts-addressbook-uri-entry-button");s.remove(),d.remove(),u.appendChild(Ge(n,t,e,a.addressBook,i,o)),u.appendChild(s),u.appendChild(d)}if(p){const e=n.dom.getElementById("contacts-create-group-button");e.remove(),p.appendChild(Ke(n,{uri:s,name:c})),p.appendChild(e)}}catch(e){Se(n,e)}}),r},We=(n,e,t)=>{const o=n.dom.createElement("button");o.setAttribute("id","close-addressbook"),o.setAttribute("role","button"),o.setAttribute("type","button");const r="contactsCloseButton"===t?"Close contacts dialog":"Close dialog";return o.setAttribute("aria-label",r),o.setAttribute("tabindex","0"),o.classList.add("contactsCloseButton",t),o.addEventListener("click",o=>{if(o.preventDefault(),e&&(e.remove(),nt(n)),"contactsCloseButton"===t){const e=n.dom.getElementById("add-to-contacts-button");e&&e.removeAttribute("disabled")}}),o.innerHTML="x",o},Ve=(n,e,t,o)=>{const r=n.dom.createElement("form");r.addEventListener("submit",async a=>{a.preventDefault();let i=null;n.dom.querySelectorAll(".selectedAddressBook").forEach(n=>{i=n.getAttribute("id")});const s=n.dom.querySelector("#groupNameInput").value;if(i){if(s)try{const a={name:s,uri:await e.createNewGroup({addressBookUri:i,groupName:s})};if(!gt(t,i,a))return void Se(n,Mn);const d=n.dom.getElementById("contacts-create-group-button");d&&d.remove();const l=n.dom.querySelector("#group-list");l&&(l.appendChild(Ke(n,a)),l.appendChild($e(n,e,t,o))),r.remove(),nt(n)}catch(e){Se(n,`${On}\n${e}`)}}else Se(n,Mn)}),r.innerHTML="Create a new group",r.setAttribute("id","new-group-form"),r.classList.add("contactsPopupDialog","contactsNewGroupForm");const a=n.dom.createElement("label");a.classList.add("label"),a.setAttribute("for","groupNameInput");const i=n.dom.createElement("input");i.type="text",i.name="groupName",i.id="groupNameInput",i.placeholder="New group name",i.classList.add("input","contactsGroupInput");const s=Ye(n,r),d=We(n,r,"contactsGroupCreationCloseButton");return r.appendChild(a),r.appendChild(i),r.appendChild(s),r.appendChild(d),r},Ye=(n,e)=>{const t=n.dom.createElement("button");return t.setAttribute("id","contacts-create-group-button"),t.setAttribute("type","button"),t.setAttribute("role","button"),t.setAttribute("aria-label","Create a new group in the selected address book"),t.setAttribute("tabindex","0"),t.textContent="Create Group",t.classList.add("contactsActionButton","contactsCreateGroupCreationButton"),t.addEventListener("click",async n=>{n.preventDefault(),e.requestSubmit()}),t},Ze=(n,e,t,o,r,a)=>{if(r)return Se(n,Rn),!0;if(a){const r=n.dom.getElementById("contacts-selector-dialog"),i=n.dom.createElement("div");i.setAttribute("role","alert"),i.setAttribute("aria-live","assertive"),i.setAttribute("tabindex","0"),i.setAttribute("aria-label","Alert message indicating that the contact already exists"),i.setAttribute("id","contacts-contact-exists"),i.classList.add("contactsContactExistsAlert"),i.innerHTML=`${o.name} already exists. \n Do you want to add their WebID?`;const s=n.dom.createElement("button");s.setAttribute("id","contacts-confirm-add-webid-button"),s.setAttribute("role","button"),s.setAttribute("type","button"),s.setAttribute("aria-label","Confirm adding the contact webID to the existing contact"),s.setAttribute("tabindex","0"),s.classList.add("contactsConfirmButton"),s.innerHTML="Yes",s.addEventListener("click",async r=>{r.preventDefault(),await ft(n,e,t,o.webID,a),Qe(n,t,o,t.contactWebIDs.get(o.webID)),At(n,t,o)});const d=n.dom.createElement("button");d.setAttribute("id","contacts-cancel-add-webid-button"),d.setAttribute("role","button"),d.setAttribute("type","button"),d.setAttribute("aria-label","Cancel adding the contact webID to the existing contact"),d.setAttribute("tabindex","0"),d.classList.add("contactsCancelButton"),d.innerHTML="No",d.addEventListener("click",e=>{e.preventDefault(),r.remove(),Jn(Xe(n),n,"Contact was not added"),setTimeout(()=>{ee(Xe(n))},2e3),At(n,t,o)});const l=n.dom.createElement("div");return l.setAttribute("id","contacts-contact-exists-actions"),l.setAttribute("role","group"),l.setAttribute("aria-label","Actions for existing contact alert"),l.setAttribute("tabindex","0"),l.classList.add("contactsContactExistsActions"),l.appendChild(s),l.appendChild(d),i.appendChild(l),Je(n),r.appendChild(i),!0}return!1},Qe=(n,e,t,o)=>{e.contactWebIDs.set(t.webID,o);n.dom.getElementById("contacts-selector-dialog").remove();const r=Xe(n);ne(r,"Contact was added!");n.dom.getElementById("add-to-contacts-button").removeAttribute("disabled"),setTimeout(()=>{ee(r)},2e3),At(n,e,t)},Ke=(n,e)=>{const t=n.dom.createElement("button");return t.setAttribute("value",e.name),t.setAttribute("id",e.uri),t.setAttribute("type","button"),t.setAttribute("role","button"),t.setAttribute("aria-label","Select group "+e.name),t.setAttribute("tabindex","0"),t.classList.add("contactsButton"),t.addEventListener("click",async e=>{e.preventDefault();const t=e.target;t.classList.contains("contactsSelectedButton")?(t.classList.remove("contactsSelectedButton","selectedGroup"),((n,e)=>{const t=n.dom.querySelectorAll(".selectedGroup"),o=n.dom.querySelector("#groupNameInput").value;0!==t.length||o||Se(n,e)})(n,_n)):(t.classList.add("contactsSelectedButton","selectedGroup"),je(n))}),t.innerHTML=e.name,t};function Xe(n){return n.dom.getElementById("add-to-contacts-button-container")}const Je=n=>{const e=n.dom.getElementById("contacts-selector-dialog");if(!e)return;e.classList.add(Le);if(e.querySelector(`#${Fe}`))return;const t=n.dom.createElement("div");t.setAttribute("role","popupOverlay"),t.setAttribute("aria-label","Overlay to focus on the active popup message and disable interaction with the rest of the dialog"),t.setAttribute("tabindex","0"),t.setAttribute("id",Fe),t.classList.add("contactsPopupOverlay"),e.appendChild(t)},nt=n=>{const e=n.dom.getElementById("contacts-selector-dialog");if(!e)return;if(e.querySelector(".contactsPopupDialog, .contactsContactExistsAlert"))return;const t=e.querySelector(`#${Fe}`);t&&t.remove(),e.classList.remove(Le)};var et=a(1699),tt={};tt.styleTagTransform=A(),tt.setAttributes=l(),tt.insert=s().bind(null,"head"),tt.domAPI=o(),tt.insertStyleElement=u();e()(et.A,tt);et.A&&et.A.locals&&et.A.locals;var ot=a(3955),rt=a.n(ot);async function at(n,e,t,o,r){const a=((n,e,t,o)=>{const r=n.dom.createElement("dialog");r.setAttribute("role","dialog"),r.setAttribute("aria-live","polite"),r.setAttribute("aria-label","Contact address book selection dialog"),r.setAttribute("aria-describedby","addressbook-contacts-selection"),r.classList.add("contactsAddressBookSelector"),r.setAttribute("id","contacts-selector-dialog"),n.dom.getElementById("add-to-contacts-button").setAttribute("disabled","");const a=We(n,r,"contactsCloseButton"),i=n.dom.createElement("div");i.setAttribute("id","addressbook-creation-div"),i.setAttribute("role","addressBookCreation"),i.setAttribute("aria-live","polite"),i.setAttribute("tabindex","0"),i.setAttribute("aria-label","Address book creation section"),i.setAttribute("aria-describedby","addressbook-details-section"),i.classList.add("contactsAddressBookCreationDiv");const s=qe(n,e,o,t),d=Ie(n),l=Re(n),c=ze(n,e,t,o,d);return d.appendChild(c),i.appendChild(d),i.appendChild(s),r.appendChild(a),r.appendChild(i),r.appendChild(l),r})(n,e,t,o);r.appendChild(a),a.setAttribute("open","")}async function it(n,e,t){let o=null;try{o=await e.readAddressBook(t)}catch(e){Se(n,`There was an error reading your address book.\n${e}`)}return o}async function st(n,e){let t=null,o=null,r=null;try{return await n.session.store.fetcher.load(e.uri.substring(0,e.uri.length-5)),o=new le.NamedNode(e.uri),r=n.session.store.any(o,Cn.ns.vcard("url"),void 0,o.doc()),r?(t=n.session.store.anyValue(r,Cn.ns.vcard("value"),void 0,o.doc()),{webID:t,uri:e.uri}):null}catch(t){Se(n,`There was an error loading the contact: ${e.uri}\n${t}`)}}async function dt(n,e){if(!wn.authn.currentUser())return null;let t=null;try{t=await async function(n,e){const t=[],o=wn.authn.currentUser(),r=n.dom,a={target:o,me:o,noun:"address book",div:r.getElementById("add-to-contacts-button-container"),dom:r};let i={public:new Map,private:new Map,contactWebIDs:new Map,contactNames:new Map};try{await n.session.store.fetcher.load(o);let r={publicUris:((await Cn.login.findAppInstances(a,Cn.ns.vcard("AddressBook"))).instances||[]).map(n=>n.value),privateUris:[]};const s=r.publicUris.map(t=>it(n,e,t));(await Promise.all(s)).map(n=>{n&&(i.public.set(n.uri,{name:n.title,groups:n.groups,contacts:n.contacts}),n.contacts.map(n=>{i.contactNames.set(n.name,n.uri),t.push(n)}))});const d=r.privateUris.map(t=>it(n,e,t));(await Promise.all(d)).map(n=>{n&&(i.private.set(n.uri,{name:n.title,groups:n.groups,contacts:n.contacts}),n.contacts.map(n=>{i.contactNames.set(n.name,n.uri),t.push(n)}))}),i=await lt(n,i,t)}catch(e){Se(n,e)}return i}(n,e)}catch(e){Se(n,`There was an error getting your address books.\n${e}`)}return t}async function lt(n,e,t){const o=t.map(st.bind(null,n));return(await Promise.all(o)).map(n=>{(null==n?void 0:n.webID)&&e.contactWebIDs.set(n.webID.trim(),n.uri)}),e}async function ct(n,e){let t=[],o=[],r=null,a=null,i=null;const s=Cn.utils.label(e),d=n.each(e,Cn.ns.vcard("hasEmail"),null,e.doc())||null,l=n.each(e,Cn.ns.vcard("hasTelephone"),null,e.doc())||null;d.map(o=>{a=n.any(o,Cn.ns.vcard("value"),null,e.doc()),r=n.any(o,Cn.ns.rdf("type"),null,e.doc()),t.push({type:r,email:a})}),l.map(t=>{i=n.any(t,Cn.ns.vcard("value"),null,e.doc()),r=n.any(t,Cn.ns.rdf("type"),null,e.doc()),o.push({type:r,phoneNumber:i})});const c=e.value;return{name:s,emails:t,phoneNumbers:o,webID:c}}async function ut(n,e,t,o){let r=[],a=null;try{const i=await it(n,e,o);if(!i)return{addressBooksData:t,addressBook:null};a={name:i.title,groups:i.groups,contacts:i.contacts},t.private.set(o,a),i.contacts.map(n=>{t.contactNames.set(n.name,n.uri),r.push(n)}),t=await lt(n,t,r)}catch(e){Se(n,"There was an error processing your address book.\n"+e)}return{addressBooksData:t,addressBook:a}}async function pt(n,e,t,o){const r=n.session.store,a=new le.NamedNode(t),i=(0,le.sym)(o),s=r.bnode();let d=null;try{if(null==e?void 0:e.length)for(const t of e){await n.session.store.fetcher.load(t),d=new le.NamedNode(t);const e=d.doc(),o=n.session.store.statementsMatching(d,Cn.ns.vcard("hasMember"),a,e),s=[(0,le.st)(d,Cn.ns.vcard("hasMember"),i,e),(0,le.st)(i,Cn.ns.owl("sameAs"),a,e)];await r.updater.update(o,s)}const t=[(0,le.st)(a,Cn.ns.vcard("url"),s,a.doc()),(0,le.st)(s,Cn.ns.rdf("type"),Cn.ns.vcard("WebID"),a.doc()),(0,le.st)(s,Cn.ns.vcard("value"),(0,le.literal)(o),a.doc())];await r.updater.update([],t)}catch(e){Se(n,e)}}function At(n,e,t){const o=wn.authn.currentUser(),r=n.dom.getElementById("add-to-contacts-button");if(te(o)){const n=mt(e,t.webID),o=ht(e,t.name);n?(r.innerHTML=Vn.toUpperCase(),r.onclick=null):o?(r.innerHTML=Yn.toUpperCase(),r.removeAttribute("disabled")):r.innerHTML=Gn.toUpperCase()}else r.innerHTML=Hn.toUpperCase()}function mt(n,e){return!!(null==e?void 0:e.trim())&&n.contactWebIDs.has(e.trim())}function ht(n,e){let t=null,o=null;const r=e.replace(/\s/g,"").toLowerCase().trim();return n.contactNames.forEach((n,e)=>{if(t=e.replace(/\s/g,"").toLowerCase().trim(),r===t)return o=n}),o}async function ft(n,e,t,o,r){try{const a=await async function(n,e,t){let o=[],r=null,a=[];e.public.forEach((n,e)=>{n.contacts.map(e=>{e.uri===t&&(r=n)})}),e.private.forEach((n,e)=>{n.contacts.map(e=>{e.uri===t&&(r=n)})}),a=r.groups;const i=a.map(async e=>({groupUri:(e=await n.readGroup(e.uri)).uri,group:e}));return(await Promise.all(i)).map(n=>{n.group.members.map(e=>{e.uri===t&&(o.includes(n.groupUri)||o.push(n.groupUri))})}),o}(e,t,r);await pt(n,a,r,o)}catch(e){Se(n,e)}}function gt(n,e,t){const o=n.public.get(e);if(o){return o.groups.some(n=>n.uri===t.uri)||n.public.set(e,{...o,groups:[...o.groups,t]}),!0}const r=n.private.get(e);if(r){return r.groups.some(n=>n.uri===t.uri)||n.private.set(e,{...r,groups:[...r.groups,t]}),!0}return!1}const bt=(0,le.Namespace)("http://www.w3.org/2006/vcard/ns#"),Ct=(0,le.Namespace)("http://purl.org/dc/elements/1.1/");const wt=new(a(8068))({length:10});function yt(){return wt.rnd(6)}class vt{constructor(n,e){this.store=n,this.addressBookNode=e,this.addressBookDoc=e.doc()}proposeNewContactNode(){return this.proposeNewNode("Person")}proposeNewGroupNode(){return this.proposeNewNode("Group")}proposeNewNode(n){const e=yt(),t=this.addressBookNode.dir()?.uri;return(0,le.sym)(`${t}${n}/${e}/index.ttl#this`)}queryTitle(){return this.store.anyValue(this.addressBookNode,Ct("title"),void 0,this.addressBookDoc)??""}queryNameEmailIndex(){const n=this.store.any(this.addressBookNode,bt("nameEmailIndex"),void 0,this.addressBookDoc);return(0,le.isNamedNode)(n)?n:null}queryContacts(){const n=this.queryNameEmailIndex();return n&&(0,le.isNamedNode)(n)?this.store.each(null,bt("inAddressBook"),this.addressBookNode,n).filter(n=>(0,le.isNamedNode)(n)).map(e=>({name:this.store.anyValue(e,bt("fn"),null,n)??"",uri:e.value})):[]}queryGroupIndex(){const n=this.store.any(this.addressBookNode,bt("groupIndex"),void 0,this.addressBookDoc);return(0,le.isNamedNode)(n)?n:null}queryGroups(){const n=this.queryGroupIndex();return n&&(0,le.isNamedNode)(n)?this.store.each(this.addressBookNode,bt("includesGroup"),null,n).filter(n=>(0,le.isNamedNode)(n)).map(e=>({name:this.store.anyValue(e,bt("fn"),null,n)??"",uri:e.value})):[]}}const Et="mailto:",Bt="tel:";class xt{constructor(n,e){this.store=n,this.contactNode=e,this.contactDoc=e.doc()}queryName(){return this.store.anyValue(this.contactNode,bt("fn"),void 0,this.contactDoc)??""}queryEmails(){const n=this.getValuesOf(bt("hasEmail"));return 0===n.length?[]:n.map(n=>{const e=this.getValueNode(n);if(function(n){return(0,le.isNamedNode)(n)&&n.value.startsWith(Et)}(e))return{uri:n,value:e.value.split(Et)[1]}}).filter(n=>!!n)}queryPhoneNumbers(){const n=this.getValuesOf(bt("hasTelephone"));return 0===n.length?[]:n.map(n=>{const e=this.getValueNode(n);if(function(n){return(0,le.isNamedNode)(n)&&n.value.startsWith(Bt)}(e))return{uri:n,value:e.value.split(Bt)[1]}}).filter(n=>!!n)}getValuesOf(n){return this.store.statementsMatching(this.contactNode,n,void 0,this.contactDoc).map(n=>n.object.value)}getValueNode(n){return this.store.any((0,le.sym)(n),bt("value"),void 0,this.contactDoc)}}class kt{constructor(n,e){this.store=n,this.groupNode=e,this.groupDoc=e.doc()}queryName(){return this.store.anyValue(this.groupNode,bt("fn"),void 0,this.groupDoc)??""}queryMembers(){return this.store.each(this.groupNode,bt("hasMember"),null,this.groupDoc).filter(n=>(0,le.isNamedNode)(n)).map(n=>({uri:n.value,name:this.store.anyValue(n,bt("fn"),null,this.groupDoc)??""}))}}async function Pt(n,e,t){await e.updateMany(t.deletions,t.insertions),t.filesToCreate.map(e=>{!function(n,e){n.webOperation("PUT",e,{contentType:"text/turtle"})}(n,e.url)})}const Tt=(0,le.Namespace)("http://www.w3.org/1999/02/22-rdf-syntax-ns#"),Dt=(0,le.Namespace)("http://www.w3.org/ns/solid/terms#"),St=(0,le.Namespace)("http://www.w3.org/ns/pim/space#"),Ft=(0,le.Namespace)("http://www.w3.org/ns/ldp#");class Lt{constructor(n,e,t){this.store=n,this.webIdNode=e,this.preferencesDoc=t}queryPrivateTypeIndex(){const n=this.store.any(this.webIdNode,Dt("privateTypeIndex"),null,this.preferencesDoc);return(0,le.isNamedNode)(n)?n:null}}class It{constructor(n,e){this.webIdNode=n,this.store=e}queryPublicTypeIndex(){const n=Dt("publicTypeIndex");return this.queryNamedNode(n)}queryPreferencesFile(){const n=St("preferencesFile");return this.queryNamedNode(n)}queryNamedNode(n){const e=this.store.any(this.webIdNode,n,null,this.webIdNode.doc());return(0,le.isNamedNode)(e)?e:null}}class Nt{constructor(n,e){this.store=n,this.typeIndexDoc=e}queryInstancesForClass(n){return this.store.each(null,Dt("forClass"),n,this.typeIndexDoc).flatMap(n=>(0,le.isNamedNode)(n)?this.getInstanceValues(n):[])}getInstanceValues(n){return this.store.each(n,Dt("instance"),null,this.typeIndexDoc).map(n=>n.value)}}class _t{constructor(n){this.store=n.store,this.fetcher=n.fetcher,this.updater=n.updater}async fetchNode(n){return async function(n,e){e&&await n.load(e.value)}(this.fetcher,n)}async fetchAll(n){return Promise.all(n.map(n=>this.fetchNode(n)))}async isContainer(n){const e=(0,le.sym)(n);return await this.fetcher.load(e.value),this.store.holds(e,Tt("type"),Ft("Container"),e.doc())}}function Ot(n,e){const t=n.queryName();return{insertions:[(0,le.st)(e.groupNode,bt("hasMember"),n.contactNode,e.groupNode.doc()),(0,le.st)(n.contactNode,bt("fn"),(0,le.lit)(t),e.groupNode.doc())],deletions:[],filesToCreate:[]}}const Ut=bt("AddressBook");const Mt=class{constructor(n){this.support=new _t(n),this.store=n.store,this.fetcher=n.fetcher,this.updater=n.updater}async readAddressBook(n){const e=(0,le.sym)(n);await this.support.fetchNode(e);const t=new vt(this.store,e),o=t.queryTitle(),r=t.queryNameEmailIndex(),a=t.queryGroupIndex();await this.support.fetchAll([r,a]);return{uri:n,title:o,contacts:t.queryContacts(),groups:t.queryGroups()}}async createAddressBook({containerUri:n,name:e,ownerWebId:t}){const o=function(n,e){const t=yt(),o=`${n}${t}/index.ttl#this`,r=`${n}${t}/people.ttl`,a=`${n}${t}/groups.ttl`;return{uri:o,deletions:[],insertions:[(0,le.st)((0,le.sym)(o),(0,le.sym)("http://www.w3.org/1999/02/22-rdf-syntax-ns#type"),bt("AddressBook"),(0,le.sym)(o).doc()),(0,le.st)((0,le.sym)(o),Ct("title"),(0,le.lit)(e),(0,le.sym)(o).doc()),(0,le.st)((0,le.sym)(o),bt("nameEmailIndex"),(0,le.sym)(r),(0,le.sym)(o).doc()),(0,le.st)((0,le.sym)(o),bt("groupIndex"),(0,le.sym)(a),(0,le.sym)(o).doc())],filesToCreate:[{url:r},{url:a}]}}(n,e);return await Pt(this.fetcher,this.updater,o),t&&await this.updatePrivateTypeIndex(t,o.uri),o.uri}async updatePrivateTypeIndex(n,e){const t=(0,le.sym)(n);await this.support.fetchNode(t);const o=new It(t,this.store).queryPreferencesFile(),r=await this.fetchPrivateTypeIndex(t,o);if(!r)throw new Error(`Private type not found for WebID ${n}.`);const a=function(n,e,t){const o=(0,le.sym)(`${n.value}#${yt()}`);return{deletions:[],filesToCreate:[],insertions:[(0,le.st)(o,Tt("type"),Dt("TypeRegistration"),n),(0,le.st)(o,Dt("forClass"),t,n),(0,le.st)(o,Dt("instance"),(0,le.sym)(e),n)]}}(r,e,Ut);await Pt(this.fetcher,this.updater,a)}async createNewContact({addressBookUri:n,contact:e,groupUris:t}){const o=await this.executeCreateNewContact(n,e);return await this.executeAddContactToGroups(t,o),o.contactNode.uri}async executeAddContactToGroups(n,e){const t=(n??[]).map(n=>(0,le.sym)(n));await this.support.fetchAll(t);const o=t.map(n=>{const t=new kt(this.store,n),o=Ot(e,t);return Pt(this.fetcher,this.updater,o)});await Promise.allSettled(o)}async executeCreateNewContact(n,e){const t=(0,le.sym)(n);await this.support.fetchNode(t);const o=function(n,e){const t=n.proposeNewContactNode(),o=n.queryNameEmailIndex();if(!o)throw new Error("name-email index is missing or invalid");const r=[(0,le.st)(t,bt("inAddressBook"),n.addressBookNode,o),(0,le.st)(t,bt("fn"),(0,le.lit)(e.name),o),(0,le.st)(t,bt("fn"),(0,le.lit)(e.name),t.doc()),(0,le.st)(t,Tt("type"),bt("Individual"),t.doc())];if(e.email){const n=(0,le.sym)(t.doc().uri+"#email");r.push((0,le.st)(t,bt("hasEmail"),n,t.doc()),(0,le.st)(n,bt("value"),(0,le.sym)("mailto:"+e.email),t.doc()))}if(e.phoneNumber){const n=(0,le.sym)(t.doc().uri+"#phone");r.push((0,le.st)(t,bt("hasTelephone"),n,t.doc()),(0,le.st)(n,bt("value"),(0,le.sym)("tel:"+e.phoneNumber),t.doc()))}return{uri:t.uri,deletions:[],insertions:r,filesToCreate:[]}}(new vt(this.store,t),e);return await Pt(this.fetcher,this.updater,o),new xt(this.store,(0,le.sym)(o.uri))}async readContact(n){const e=(0,le.sym)(n);await this.support.fetchNode(e);const t=new xt(this.store,e);return{uri:n,name:t.queryName(),emails:t.queryEmails(),phoneNumbers:t.queryPhoneNumbers()}}async createNewGroup({addressBookUri:n,groupName:e}){const t=(0,le.sym)(n);await this.support.fetchNode(t);const o=function(n,e){const t=n.queryGroupIndex();if(!t)throw new Error("group index is missing or invalid");const o=n.proposeNewGroupNode(),r=o.doc();return{uri:o.uri,insertions:[(0,le.st)(o,bt("fn"),(0,le.lit)(e),t),(0,le.st)(o,bt("fn"),(0,le.lit)(e),r),(0,le.st)(o,Tt("type"),bt("Group"),r),(0,le.st)(n.addressBookNode,bt("includesGroup"),o,t)],deletions:[],filesToCreate:[]}}(new vt(this.store,t),e);return await Pt(this.fetcher,this.updater,o),o.uri}async readGroup(n){const e=(0,le.sym)(n);await this.support.fetchNode(e);const t=new kt(this.store,e);return{uri:n,name:t.queryName(),members:t.queryMembers()}}async addContactToGroup({contactUri:n,groupUri:e}){const t=(0,le.sym)(n),o=(0,le.sym)(e);await this.support.fetchNode(t);const r=Ot(new xt(this.store,t),new kt(this.store,o));await Pt(this.fetcher,this.updater,r)}async removeContactFromGroup({contactUri:n,groupUri:e}){const t=(0,le.sym)(n),o=(0,le.sym)(e);await this.support.fetchNode(o);const r=function(n,e){const t=n.contactNode.uri,o=e.queryMembers().find(n=>n.uri===t);if(!o)throw new Error("member not found in group");return{insertions:[],deletions:[(0,le.st)(e.groupNode,bt("hasMember"),n.contactNode,e.groupNode.doc()),(0,le.st)(n.contactNode,bt("fn"),(0,le.lit)(o.name),e.groupNode.doc())],filesToCreate:[]}}(new xt(this.store,t),new kt(this.store,o));await Pt(this.fetcher,this.updater,r)}async addNewPhoneNumber({contactUri:n,newPhoneNumber:e}){const t=function(n,e){const t=yt(),o=`${n.doc().uri}#${t}`;return{uri:o,insertions:[(0,le.st)(n,bt("hasTelephone"),(0,le.sym)(o),n.doc()),(0,le.st)((0,le.sym)(o),bt("value"),(0,le.sym)("tel:"+e),n.doc())],deletions:[],filesToCreate:[]}}((0,le.sym)(n),e);return await Pt(this.fetcher,this.updater,t),t.uri}async addNewEmailAddress({contactUri:n,newEmailAddress:e}){const t=function(n,e){const t=yt(),o=`${n.doc().uri}#${t}`;return{uri:o,insertions:[(0,le.st)(n,bt("hasEmail"),(0,le.sym)(o),n.doc()),(0,le.st)((0,le.sym)(o),bt("value"),(0,le.sym)("mailto:"+e),n.doc())],deletions:[],filesToCreate:[]}}((0,le.sym)(n),e);return await Pt(this.fetcher,this.updater,t),t.uri}async removePhoneNumber({contactUri:n,phoneNumberUri:e}){const t=(0,le.sym)(n),o=(0,le.sym)(e);await this.support.fetchNode(o);const r=function(n,e,t){return{insertions:[],deletions:[...t.statementsMatching(e,null,null,e.doc()),(0,le.st)(n,bt("hasTelephone"),e,n.doc())],filesToCreate:[]}}(t,o,this.store);await Pt(this.fetcher,this.updater,r)}async removeEmailAddress({contactUri:n,emailAddressUri:e}){const t=(0,le.sym)(n),o=(0,le.sym)(e);await this.support.fetchNode(o);const r=function(n,e,t){return{insertions:[],deletions:[...t.statementsMatching(e,null,null,e.doc()),(0,le.st)(n,bt("hasEmail"),e,n.doc())],filesToCreate:[]}}(t,o,this.store);await Pt(this.fetcher,this.updater,r)}async updatePhoneNumber({phoneNumberUri:n,newPhoneNumber:e}){const t=(0,le.sym)(n);await this.support.fetchNode(t);const o=function(n,e,t){const o=t.any(n,bt("value")),r=o?[(0,le.st)(n,bt("value"),o,n.doc())]:[];return{insertions:[(0,le.st)(n,bt("value"),(0,le.sym)("tel:"+e),n.doc())],deletions:r,filesToCreate:[]}}(t,e,this.store);await Pt(this.fetcher,this.updater,o)}async updateEmailAddress({emailAddressUri:n,newEmailAddress:e}){const t=(0,le.sym)(n);await this.support.fetchNode(t);const o=function(n,e,t){const o=t.any(n,bt("value")),r=o?[(0,le.st)(n,bt("value"),o,n.doc())]:[];return{insertions:[(0,le.st)(n,bt("value"),(0,le.sym)("mailto:"+e),n.doc())],deletions:r,filesToCreate:[]}}(t,e,this.store);await Pt(this.fetcher,this.updater,o)}async listAddressBooks(n){const e=(0,le.sym)(n);await this.support.fetchNode(e);const t=new It(e,this.store),o=t.queryPublicTypeIndex(),r=t.queryPreferencesFile(),a=this.fetchIndexedAddressBooks(o),i=this.fetchPrivateTypeIndex(e,r),[s,d]=await Promise.allSettled([a,i]),l="fulfilled"===d.status?await this.fetchIndexedAddressBooks(d.value):[];return{publicUris:"fulfilled"===s.status?s.value:[],privateUris:l}}async fetchIndexedAddressBooks(n){return n?(await this.support.fetchNode(n),new Nt(this.store,n).queryInstancesForClass(Ut)):[]}async fetchPrivateTypeIndex(n,e){if(!e)return null;await this.support.fetchNode(e);return new Lt(this.store,n,e).queryPrivateTypeIndex()}async renameContact({contactUri:n,newName:e}){const t=(0,le.sym)(n);await this.support.fetchNode(t);const o=function(n,e,t){const o=n.statementsMatching(e,bt("fn"),null,null);return{insertions:o.map(n=>(0,le.st)(n.subject,n.predicate,(0,le.lit)(t),n.graph)),deletions:o,filesToCreate:[]}}(this.store,t,e);await Pt(this.fetcher,this.updater,o)}};let zt=document.createElement("section");const $t=async(n,e)=>{const t=wn.authn.currentUser();let o=null,r=null;const a=e.session.store,i=a.fetcher,s=a.updater,d=new Mt({store:a,fetcher:i,updater:s});try{o=await dt(e,d),r=await ct(a,n)}catch(n){Se(e,n)}let l=te(t)?Gn.toUpperCase():Hn.toUpperCase();const c=Cn.widgets.button(e.dom,void 0,l,function(t){t.preventDefault(),async function(n,e,t,o){const r=wn.authn.currentUser(),a=e.session.store;if(!te(r))throw new Error(Nn);if(mt(o,n.value))throw new Error(Rn);await a.fetcher.load(r);try{const r=await ct(a,n),i=ht(o,r.name);i?await ft(e,t,o,r.webID,i):await at(e,t,r,o,zt)}catch(n){let e=n;throw e.toString().includes("Unauthenticated")&&(e=Nn),new Error(e)}}(n,e,d,o).catch(n=>{ee(zt),Jn(zt,e,n)})},{needsBorder:!0});return c.setAttribute("id","add-to-contacts-button"),c.refresh=function(){if(te(t)){const n=!!r&&mt(o,r.webID),e=!!r&&ht(o,r.name);n?(c.innerHTML=Vn.toUpperCase(),c.onclick=null,c.setAttribute("disabled","true")):c.innerHTML=e?Yn.toUpperCase():Gn.toUpperCase()}else c.innerHTML=Hn.toUpperCase()}(),c};function Rt(n){if(3===(n=n.replace(/^#/,"")).length&&(n=n.split("").map(n=>n+n).join("")),6!==n.length)return null;const e=parseInt(n,16);return{r:e>>16&255,g:e>>8&255,b:255&e}}function jt({r:n,g:e,b:t}){const o=[n,e,t].map(function(n){return(n/=255)<=.03928?n/12.92:Math.pow((n+.055)/1.055,2.4)});return.2126*o[0]+.7152*o[1]+.0722*o[2]}const qt=(n,e,t)=>{const o=n||"#000000",r=e||"#ffffff",a=Cn.utils.label(t),i=function(n,e){const t=Rt(n),o=Rt(e);if(!t||!o)return 1;const r=jt(t),a=jt(o);return(Math.max(r,a)+.05)/(Math.min(r,a)+.05)}(o,r);i<4.5&&console.warn(`QRCodeCard: The contrast ratio between highlightColor (${o}) and backgroundColor (${r}) is ${i.toFixed(2)}, which is below the WCAG 2.1 recommended minimum of 4.5:1 for normal text.`);const s="FN:"+a+"\r\n",d="URL:"+t.uri+"r\n";setTimeout(()=>{const n=document.querySelector('.QRCode [role="img"]');if(n){const e=n.hasAttribute("aria-label"),t=n.hasAttribute("alt");e||t||console.warn("QRCodeCard: The QR code element should have an accessible label (aria-label or alt attribute) for screen readers.")}else console.warn('QRCodeCard: No element with role="img" found for the QR code. Ensure the QR code is rendered as an <img> or <canvas> with proper ARIA attributes.')},0);return nn`
|
|
2
2
|
<figure
|
|
3
3
|
class="QRCode"
|
|
4
4
|
data-value="${"BEGIN:VCARD\r\n"+s+d+"END:VCARD\r\nVERSION:4.0\r\n"}"
|