/* THIS IS A GENERATED/BUNDLED FILE BY ESBUILD if you want to view the source, please visit the github repository of this plugin */ var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __hasOwnProp = Object.prototype.hasOwnProperty; var __export = (target, all) => { for (var name in all) __defProp(target, name, { get: all[name], enumerable: true }); }; var __copyProps = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); } return to; }; var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); // main.ts var main_exports = {}; __export(main_exports, { FileSuggest: () => FileSuggest, default: () => PinnedNotesPlugin, trimFile: () => trimFile }); module.exports = __toCommonJS(main_exports); var import_obsidian = require("obsidian"); // node_modules/uuid/dist/esm-browser/rng.js var getRandomValues; var rnds8 = new Uint8Array(16); function rng() { if (!getRandomValues) { getRandomValues = typeof crypto !== "undefined" && crypto.getRandomValues && crypto.getRandomValues.bind(crypto); if (!getRandomValues) { throw new Error("crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported"); } } return getRandomValues(rnds8); } // node_modules/uuid/dist/esm-browser/stringify.js var byteToHex = []; for (let i = 0; i < 256; ++i) { byteToHex.push((i + 256).toString(16).slice(1)); } function unsafeStringify(arr, offset = 0) { return byteToHex[arr[offset + 0]] + byteToHex[arr[offset + 1]] + byteToHex[arr[offset + 2]] + byteToHex[arr[offset + 3]] + "-" + byteToHex[arr[offset + 4]] + byteToHex[arr[offset + 5]] + "-" + byteToHex[arr[offset + 6]] + byteToHex[arr[offset + 7]] + "-" + byteToHex[arr[offset + 8]] + byteToHex[arr[offset + 9]] + "-" + byteToHex[arr[offset + 10]] + byteToHex[arr[offset + 11]] + byteToHex[arr[offset + 12]] + byteToHex[arr[offset + 13]] + byteToHex[arr[offset + 14]] + byteToHex[arr[offset + 15]]; } // node_modules/uuid/dist/esm-browser/native.js var randomUUID = typeof crypto !== "undefined" && crypto.randomUUID && crypto.randomUUID.bind(crypto); var native_default = { randomUUID }; // node_modules/uuid/dist/esm-browser/v4.js function v4(options, buf, offset) { if (native_default.randomUUID && !buf && !options) { return native_default.randomUUID(); } options = options || {}; const rnds = options.random || (options.rng || rng)(); rnds[6] = rnds[6] & 15 | 64; rnds[8] = rnds[8] & 63 | 128; if (buf) { offset = offset || 0; for (let i = 0; i < 16; ++i) { buf[offset + i] = rnds[i]; } return buf; } return unsafeStringify(rnds); } var v4_default = v4; // main.ts var PinnedNote = class { constructor(title, path, icon) { this.id = v4_default(); this.icon = icon; this.path = path; this.title = title; } }; var DEFAULT_SETTINGS = { pinnedNotes: [] }; var PinnedNotesPlugin = class extends import_obsidian.Plugin { async onload() { await this.loadSettings(); this.addSettingTab(new SettingTab(this.app, this)); } async addPinnedNote(note) { this.settings.pinnedNotes.push(note); await this.saveSettings(); await this.loadSettings(); } async removePinnedNote(noteId) { const noteIndex = this.settings.pinnedNotes.findIndex((note) => note.id === noteId); delete this.settings.pinnedNotes[noteIndex]; this.settings.pinnedNotes.splice(noteIndex, 1); await this.saveSettings(); await this.loadSettings(); } async loadSettings() { var _a; this.settings = Object.assign({}, DEFAULT_SETTINGS, await this.loadData()); (_a = this.ribbonIcons) == null ? void 0 : _a.forEach((ribbonIcon, index) => { ribbonIcon.remove(); delete this.ribbonIcons[index]; }); this.ribbonIcons = this.settings.pinnedNotes.map( (note) => this.addRibbonIcon( note.icon === "" ? "file" : note.icon, note.title, async (e) => { await this.app.workspace.openLinkText(note.path, ""); } ) ); } async saveSettings() { await this.saveData(this.settings); } }; var SettingTab = class extends import_obsidian.PluginSettingTab { constructor(app, plugin) { super(app, plugin); this.plugin = plugin; } display() { const { containerEl } = this; containerEl.empty(); let isCanBeAddedNewNote = true; let title = ""; let path = ""; let icon = ""; let changedTitle; let changedPath; let changedIcon; const addNoteButton = new import_obsidian.Setting(containerEl).setName("Add pinned note").setDesc(`Provide: 1) file's name that will be displayed on hover 2) path to this file, e.g Folder1/File1 3) Icon name from lucide.dev; if icon won't be provided, default icon "file" will be placed instead. RESTART OBSIDIAN AFTER CHANGES`); isCanBeAddedNewNote && addNoteButton.addButton((button) => { button.setIcon("plus").onClick( () => { isCanBeAddedNewNote = false; this.display(); new import_obsidian.Setting(containerEl).setName("File").addText( (text) => text.setPlaceholder("Title").onChange((value) => title = value) ).addText( (text) => { new FileSuggest(this.app, text.inputEl); text.setPlaceholder("Path").onChange((value) => path = value); } ).addText( (text) => text.setPlaceholder("Icon(optional)").onChange((value) => icon = value) ).addButton((button2) => button2.setIcon("save").onClick( async () => { if (title.length !== 0 && path.length !== 0) { await this.plugin.addPinnedNote(new PinnedNote(title, path, icon)); isCanBeAddedNewNote = true; this.display(); } else { new import_obsidian.Notice("Provide title and path"); } } )); } ); }); this.plugin.settings.pinnedNotes.forEach((note, index) => { new import_obsidian.Setting(containerEl).setName("File " + (index + 1)).addText( (text) => text.setPlaceholder("Title").setValue(note.title).onChange(async (value) => { changedTitle = value; }) ).addText( (text) => { new FileSuggest(this.app, text.inputEl); text.setPlaceholder("Path").setValue(note.path).onChange(async (value) => { changedPath = value; }); } ).addText( (text) => text.setPlaceholder("Icon(optional)").setValue(note.icon).onChange(async (value) => { changedIcon = value; }) ).addButton( (button) => button.setIcon("save").onClick( async () => { if ((changedTitle === void 0 || changedTitle === note.title) && (changedPath === void 0 || changedPath === note.path) && (changedIcon === void 0 || changedIcon === note.icon)) { new import_obsidian.Notice("Provide any data"); return; } if (changedTitle !== void 0) { if (changedTitle.length !== 0) { note.title = changedTitle; changedTitle = void 0; } else new import_obsidian.Notice("Provide title"); } if (changedPath !== void 0) { if (changedPath.length !== 0) { note.path = changedPath; changedPath = void 0; } else new import_obsidian.Notice("Provide path"); } if (changedIcon !== void 0) { note.icon = changedIcon; changedIcon = void 0; } await this.plugin.saveSettings(); await this.plugin.loadSettings(); this.display(); } ) ).addButton((button) => button.setIcon("trash-2").setWarning().onClick( async () => { await this.plugin.removePinnedNote(note.id); this.display(); } )); }); } }; var FileSuggest = class extends import_obsidian.AbstractInputSuggest { getSuggestions(inputStr) { const abstractFiles = this.app.vault.getAllLoadedFiles(); const files = []; const inputLower = inputStr.toLowerCase(); abstractFiles.forEach((file) => { if (file instanceof import_obsidian.TFile && ["md", "canvas"].contains(file.extension) && file.path.toLowerCase().contains(inputLower)) { files.push(file); } }); return files; } renderSuggestion(file, el) { if (file.extension == "md") { el.setText(trimFile(file)); } else { el.setText(file.path.slice(0, -7)); el.insertAdjacentHTML( "beforeend", `
` ); } } selectSuggestion(file) { this.textInputEl.value = trimFile(file); this.textInputEl.trigger("input"); this.close(); } }; function trimFile(file) { if (!file) return ""; return file.extension == "md" ? file.path.slice(0, -3) : file.path; } //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["main.ts", "node_modules/uuid/dist/esm-browser/rng.js", "node_modules/uuid/dist/esm-browser/stringify.js", "node_modules/uuid/dist/esm-browser/native.js", "node_modules/uuid/dist/esm-browser/v4.js"],
  "sourcesContent": ["import {\r\n\tAbstractInputSuggest,\r\n\tApp,\r\n\tIconName,\r\n\tNotice,\r\n\tPlugin,\r\n\tPluginSettingTab,\r\n\tSetting,\r\n\tTAbstractFile,\r\n\tTFile\r\n} from \"obsidian\";\r\nimport {v4 as uuidv4} from \"uuid\";\r\n\r\nclass PinnedNote {\r\n\tid: number;\r\n\ticon: IconName;\r\n\tpath: string;\r\n\ttitle: string;\r\n\r\n\r\n\tconstructor(\r\n\t\ttitle: string,\r\n\t\tpath: string,\r\n\t\ticon: IconName\r\n\t) {\r\n\t\tthis.id = uuidv4()\r\n\t\tthis.icon = icon;\r\n\t\tthis.path = path;\r\n\t\tthis.title = title;\r\n\t}\r\n}\r\n\r\nexport interface IPinnedNotesPluginSettings {\r\n\tpinnedNotes: PinnedNote[]\r\n}\r\n\r\nconst DEFAULT_SETTINGS: IPinnedNotesPluginSettings = {\r\n\tpinnedNotes: []\r\n}\r\n\r\nexport default class PinnedNotesPlugin extends Plugin {\r\n\tsettings: IPinnedNotesPluginSettings\r\n\tribbonIcons: HTMLElement[]\r\n\r\n\tasync onload() {\r\n\t\tawait this.loadSettings();\r\n\t\tthis.addSettingTab(new SettingTab(this.app, this))\r\n\t}\r\n\r\n\tasync addPinnedNote(note: PinnedNote) {\r\n\t\tthis.settings.pinnedNotes.push(note)\r\n\t\tawait this.saveSettings()\r\n\t\tawait this.loadSettings()\r\n\t}\r\n\r\n\tasync removePinnedNote(noteId: number) {\r\n\t\tconst noteIndex = this.settings.pinnedNotes.findIndex((note) => note.id === noteId)\r\n\t\tdelete this.settings.pinnedNotes[noteIndex]\r\n\t\tthis.settings.pinnedNotes.splice(noteIndex, 1)\r\n\t\tawait this.saveSettings()\r\n\t\tawait this.loadSettings()\r\n\t}\r\n\r\n\r\n\tasync loadSettings() {\r\n\t\tthis.settings = Object.assign({}, DEFAULT_SETTINGS, await this.loadData());\r\n\t\tthis.ribbonIcons?.forEach((ribbonIcon, index) => {\r\n\t\t\tribbonIcon.remove()\r\n\t\t\tdelete this.ribbonIcons[index]\r\n\t\t})\r\n\t\tthis.ribbonIcons = this.settings.pinnedNotes.map((note) =>\r\n\t\t\tthis.addRibbonIcon(\r\n\t\t\t\tnote.icon === \"\" ? \"file\" : note.icon,\r\n\t\t\t\tnote.title,\r\n\t\t\t\tasync (e) => {\r\n\t\t\t\t\tawait this.app.workspace.openLinkText(note.path, \"\")\r\n\t\t\t\t}\r\n\t\t\t)\r\n\t\t)\r\n\t}\r\n\r\n\tasync saveSettings() {\r\n\t\tawait this.saveData(this.settings);\r\n\t}\r\n}\r\n\r\nclass SettingTab extends PluginSettingTab {\r\n\tplugin: PinnedNotesPlugin\r\n\r\n\tconstructor(app: App, plugin: PinnedNotesPlugin) {\r\n\t\tsuper(app, plugin);\r\n\t\tthis.plugin = plugin;\r\n\t}\r\n\r\n\tdisplay() {\r\n\t\tconst {containerEl} = this;\r\n\t\tcontainerEl.empty()\r\n\t\tlet isCanBeAddedNewNote = true\r\n\t\tlet title = \"\"\r\n\t\tlet path = \"\"\r\n\t\tlet icon: IconName = \"\"\r\n\t\tlet changedTitle: string | undefined;\r\n\t\tlet changedPath: string | undefined;\r\n\t\tlet changedIcon: string | undefined;\r\n\t\tconst addNoteButton = new Setting(containerEl)\r\n\t\t\t.setName(\"Add pinned note\")\r\n\t\t\t.setDesc(\"Provide: 1) file's name that will be displayed on hover 2) path to this file, e.g Folder1/File1 3) Icon name from lucide.dev; if icon won't be provided, default icon \\\"file\\\" will be placed instead. RESTART OBSIDIAN AFTER CHANGES\")\r\n\t\tisCanBeAddedNewNote && addNoteButton\r\n\t\t\t.addButton((button) => {\r\n\t\t\t\tbutton.setIcon(\"plus\").onClick(\r\n\t\t\t\t\t() => {\r\n\t\t\t\t\t\tisCanBeAddedNewNote = false\r\n\t\t\t\t\t\tthis.display()\r\n\t\t\t\t\t\tnew Setting(containerEl)\r\n\t\t\t\t\t\t\t.setName(\"File\")\r\n\t\t\t\t\t\t\t.addText((text) => text\r\n\t\t\t\t\t\t\t\t.setPlaceholder(\"Title\")\r\n\t\t\t\t\t\t\t\t.onChange((value) => title = value)\r\n\t\t\t\t\t\t\t)\r\n\t\t\t\t\t\t\t.addText((text) => {\r\n\t\t\t\t\t\t\t\tnew FileSuggest(this.app, text.inputEl);\r\n\t\t\t\t\t\t\t\t\ttext\r\n\t\t\t\t\t\t\t\t\t\t.setPlaceholder(\"Path\")\r\n\t\t\t\t\t\t\t\t\t\t.onChange((value) => path = value)\r\n\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t)\r\n\t\t\t\t\t\t\t.addText((text) => text\r\n\t\t\t\t\t\t\t\t.setPlaceholder(\"Icon(optional)\")\r\n\t\t\t\t\t\t\t\t.onChange((value) => icon = value)\r\n\t\t\t\t\t\t\t)\r\n\t\t\t\t\t\t\t.addButton((button) => button.setIcon(\"save\").onClick(\r\n\t\t\t\t\t\t\t\tasync () => {\r\n\t\t\t\t\t\t\t\t\tif (title.length !== 0 && path.length !== 0) {\r\n\t\t\t\t\t\t\t\t\t\tawait this.plugin.addPinnedNote(new PinnedNote(title, path, icon))\r\n\t\t\t\t\t\t\t\t\t\tisCanBeAddedNewNote = true\r\n\t\t\t\t\t\t\t\t\t\tthis.display()\r\n\t\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\t\telse {\r\n\t\t\t\t\t\t\t\t\t\tnew Notice(\"Provide title and path\")\r\n\t\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t))\r\n\t\t\t\t\t}\r\n\t\t\t\t)\r\n\t\t\t})\r\n\r\n\t\tthis.plugin.settings.pinnedNotes.forEach((note, index) => {\r\n\t\t\tnew Setting(containerEl)\r\n\t\t\t\t.setName(\"File \" + (index + 1))\r\n\t\t\t\t.addText((text) => text\r\n\t\t\t\t\t.setPlaceholder(\"Title\")\r\n\t\t\t\t\t.setValue(note.title)\r\n\t\t\t\t\t.onChange(async (value) => {\r\n\t\t\t\t\t\tchangedTitle = value;\r\n\t\t\t\t\t})\r\n\t\t\t\t)\r\n\t\t\t\t.addText((text) => {\r\n\t\t\t\t\tnew FileSuggest(this.app, text.inputEl)\r\n\t\t\t\t\ttext\r\n\t\t\t\t\t\t.setPlaceholder(\"Path\")\r\n\t\t\t\t\t\t.setValue(note.path)\r\n\t\t\t\t\t\t.onChange(async (value) => {\r\n\t\t\t\t\t\t\tchangedPath = value;\r\n\t\t\t\t\t\t})\r\n\t\t\t\t\t}\r\n\t\t\t\t)\r\n\t\t\t\t.addText((text) => text\r\n\t\t\t\t\t.setPlaceholder(\"Icon(optional)\")\r\n\t\t\t\t\t.setValue(note.icon)\r\n\t\t\t\t\t.onChange(async (value) => {\r\n\t\t\t\t\t\tchangedIcon = value;\r\n\t\t\t\t\t})\r\n\t\t\t\t)\r\n\t\t\t\t.addButton((button) => button.setIcon(\"save\").onClick(\r\n\t\t\t\t\tasync () => {\r\n\t\t\t\t\t\tif (\r\n\t\t\t\t\t\t\t(changedTitle === undefined || changedTitle === note.title) &&\r\n\t\t\t\t\t\t\t(changedPath === undefined || changedPath === note.path) &&\r\n\t\t\t\t\t\t\t(changedIcon === undefined || changedIcon === note.icon)\r\n\t\t\t\t\t\t) {\r\n\t\t\t\t\t\t\tnew Notice(\"Provide any data\")\r\n\t\t\t\t\t\t\treturn;\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tif (changedTitle !== undefined) {\r\n\t\t\t\t\t\t\tif (changedTitle.length !== 0) {\r\n\t\t\t\t\t\t\t\tnote.title = changedTitle\r\n\t\t\t\t\t\t\t\tchangedTitle = undefined\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\telse new Notice(\"Provide title\")\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tif (changedPath !== undefined) {\r\n\t\t\t\t\t\t\tif (changedPath.length !== 0) {\r\n\t\t\t\t\t\t\t\tnote.path = changedPath\r\n\t\t\t\t\t\t\t\tchangedPath = undefined\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\telse new Notice(\"Provide path\")\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t\tif (changedIcon !== undefined) {\r\n\t\t\t\t\t\t\tnote.icon = changedIcon\r\n\t\t\t\t\t\t\tchangedIcon = undefined\r\n\t\t\t\t\t\t}\r\n\r\n\t\t\t\t\t\tawait this.plugin.saveSettings()\r\n\t\t\t\t\t\tawait this.plugin.loadSettings()\r\n\t\t\t\t\t\tthis.display()\r\n\t\t\t\t\t})\r\n\t\t\t\t)\r\n\t\t\t\t.addButton((button) => button.setIcon(\"trash-2\").setWarning().onClick(\r\n\t\t\t\t\tasync () => {\r\n\t\t\t\t\t\tawait this.plugin.removePinnedNote(note.id);\r\n\t\t\t\t\t\tthis.display()\r\n\t\t\t\t\t}\r\n\t\t\t\t))\r\n\t\t})\r\n\t}\r\n}\r\n\r\nexport class FileSuggest extends AbstractInputSuggest<TFile> {\r\n\ttextInputEl: HTMLInputElement;\r\n\r\n\tgetSuggestions(inputStr: string): TFile[] {\r\n\t\tconst abstractFiles = this.app.vault.getAllLoadedFiles();\r\n\t\tconst files: TFile[] = [];\r\n\t\tconst inputLower = inputStr.toLowerCase();\r\n\r\n\t\tabstractFiles.forEach((file: TAbstractFile) => {\r\n\t\t\tif (\r\n\t\t\t\tfile instanceof TFile && [\"md\", \"canvas\"].contains(file.extension) &&\r\n\t\t\t\tfile.path.toLowerCase().contains(inputLower)\r\n\t\t\t) {\r\n\t\t\t\tfiles.push(file);\r\n\t\t\t}\r\n\t\t});\r\n\t\treturn files;\r\n\t}\r\n\r\n\trenderSuggestion(file: TFile, el: HTMLElement) {\r\n\t\tif (file.extension == \"md\") {\r\n\t\t\tel.setText(trimFile(file));\r\n\t\t}\r\n\t\telse {\r\n\t\t\t//we don't use trimFile here as the extension isn't displayed here\r\n\t\t\tel.setText(file.path.slice(0, -7))\r\n\t\t\tel.insertAdjacentHTML(\r\n\t\t\t\t\"beforeend\",\r\n\t\t\t\t`<div class=\"nav-file-tag\" style=\"display:inline-block;vertical-align:middle\">canvas</div>`\r\n\t\t\t);\r\n\t\t}\r\n\t}\r\n\r\n\tselectSuggestion(file: TFile) {\r\n\t\tthis.textInputEl.value = trimFile(file);\r\n\t\tthis.textInputEl.trigger(\"input\");\r\n\t\tthis.close();\r\n\t}\r\n}\r\n\r\nexport function trimFile(file: TFile): string {\r\n\tif (!file) return \"\";\r\n\treturn file.extension == \"md\" ? file.path.slice(0, -3): file.path;\r\n}\r\n", "// Unique ID creation requires a high quality random # generator. In the browser we therefore\n// require the crypto API and do not support built-in fallback to lower quality random number\n// generators (like Math.random()).\nlet getRandomValues;\nconst rnds8 = new Uint8Array(16);\nexport default function rng() {\n  // lazy load so that environments that need to polyfill have a chance to do so\n  if (!getRandomValues) {\n    // getRandomValues needs to be invoked in a context where \"this\" is a Crypto implementation.\n    getRandomValues = typeof crypto !== 'undefined' && crypto.getRandomValues && crypto.getRandomValues.bind(crypto);\n\n    if (!getRandomValues) {\n      throw new Error('crypto.getRandomValues() not supported. See https://github.com/uuidjs/uuid#getrandomvalues-not-supported');\n    }\n  }\n\n  return getRandomValues(rnds8);\n}", "import validate from './validate.js';\n/**\n * Convert array of 16 byte values to UUID string format of the form:\n * XXXXXXXX-XXXX-XXXX-XXXX-XXXXXXXXXXXX\n */\n\nconst byteToHex = [];\n\nfor (let i = 0; i < 256; ++i) {\n  byteToHex.push((i + 0x100).toString(16).slice(1));\n}\n\nexport function unsafeStringify(arr, offset = 0) {\n  // Note: Be careful editing this code!  It's been tuned for performance\n  // and works in ways you may not expect. See https://github.com/uuidjs/uuid/pull/434\n  return byteToHex[arr[offset + 0]] + byteToHex[arr[offset + 1]] + byteToHex[arr[offset + 2]] + byteToHex[arr[offset + 3]] + '-' + byteToHex[arr[offset + 4]] + byteToHex[arr[offset + 5]] + '-' + byteToHex[arr[offset + 6]] + byteToHex[arr[offset + 7]] + '-' + byteToHex[arr[offset + 8]] + byteToHex[arr[offset + 9]] + '-' + byteToHex[arr[offset + 10]] + byteToHex[arr[offset + 11]] + byteToHex[arr[offset + 12]] + byteToHex[arr[offset + 13]] + byteToHex[arr[offset + 14]] + byteToHex[arr[offset + 15]];\n}\n\nfunction stringify(arr, offset = 0) {\n  const uuid = unsafeStringify(arr, offset); // Consistency check for valid UUID.  If this throws, it's likely due to one\n  // of the following:\n  // - One or more input array values don't map to a hex octet (leading to\n  // \"undefined\" in the uuid)\n  // - Invalid input values for the RFC `version` or `variant` fields\n\n  if (!validate(uuid)) {\n    throw TypeError('Stringified UUID is invalid');\n  }\n\n  return uuid;\n}\n\nexport default stringify;", "const randomUUID = typeof crypto !== 'undefined' && crypto.randomUUID && crypto.randomUUID.bind(crypto);\nexport default {\n  randomUUID\n};", "import native from './native.js';\nimport rng from './rng.js';\nimport { unsafeStringify } from './stringify.js';\n\nfunction v4(options, buf, offset) {\n  if (native.randomUUID && !buf && !options) {\n    return native.randomUUID();\n  }\n\n  options = options || {};\n  const rnds = options.random || (options.rng || rng)(); // Per 4.4, set bits for version and `clock_seq_hi_and_reserved`\n\n  rnds[6] = rnds[6] & 0x0f | 0x40;\n  rnds[8] = rnds[8] & 0x3f | 0x80; // Copy bytes to buffer, if provided\n\n  if (buf) {\n    offset = offset || 0;\n\n    for (let i = 0; i < 16; ++i) {\n      buf[offset + i] = rnds[i];\n    }\n\n    return buf;\n  }\n\n  return unsafeStringify(rnds);\n}\n\nexport default v4;"],
  "mappings": "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",
  "names": ["button"]
}
