web-mojo 2.1.46 → 2.1.70

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.
Files changed (70) hide show
  1. package/dist/admin.cjs.js +1 -1
  2. package/dist/admin.cjs.js.map +1 -1
  3. package/dist/admin.es.js +12 -11
  4. package/dist/admin.es.js.map +1 -1
  5. package/dist/auth.cjs.js +1 -1
  6. package/dist/auth.es.js +3 -3
  7. package/dist/charts.cjs.js +1 -1
  8. package/dist/charts.es.js +2 -2
  9. package/dist/chunks/{ContextMenu-gEcpSz56.js → ContextMenu-CD5yoYTS.js} +2 -2
  10. package/dist/chunks/{ContextMenu-gEcpSz56.js.map → ContextMenu-CD5yoYTS.js.map} +1 -1
  11. package/dist/chunks/{ContextMenu-BrHqj0fn.js → ContextMenu-Cds78Jny.js} +2 -2
  12. package/dist/chunks/{ContextMenu-BrHqj0fn.js.map → ContextMenu-Cds78Jny.js.map} +1 -1
  13. package/dist/chunks/{DataView-DPryYpEW.js → DataView-CfPr57_R.js} +2 -2
  14. package/dist/chunks/{DataView-DPryYpEW.js.map → DataView-CfPr57_R.js.map} +1 -1
  15. package/dist/chunks/{DataView-DjZQrpba.js → DataView-DPSnw5Nb.js} +2 -2
  16. package/dist/chunks/{DataView-DjZQrpba.js.map → DataView-DPSnw5Nb.js.map} +1 -1
  17. package/dist/chunks/{Dialog-DSlctbon.js → Dialog-B9C-Tivh.js} +5 -5
  18. package/dist/chunks/{Dialog-DSlctbon.js.map → Dialog-B9C-Tivh.js.map} +1 -1
  19. package/dist/chunks/{Dialog-BsRx4eg3.js → Dialog-BqNrby-G.js} +2 -2
  20. package/dist/chunks/{Dialog-BsRx4eg3.js.map → Dialog-BqNrby-G.js.map} +1 -1
  21. package/dist/chunks/{FilePreviewView-BmFHzK5K.js → FilePreviewView-Bp09ZiEw.js} +54 -32
  22. package/dist/chunks/FilePreviewView-Bp09ZiEw.js.map +1 -0
  23. package/dist/chunks/FilePreviewView-CnZhI3Yw.js +2 -0
  24. package/dist/chunks/FilePreviewView-CnZhI3Yw.js.map +1 -0
  25. package/dist/chunks/{FormView-CmBuwKGD.js → FormView-D0dUMQGM.js} +2 -2
  26. package/dist/chunks/FormView-D0dUMQGM.js.map +1 -0
  27. package/dist/chunks/{FormView-DqUBMPJ9.js → FormView-DWR9Albb.js} +55 -34
  28. package/dist/chunks/FormView-DWR9Albb.js.map +1 -0
  29. package/dist/chunks/{MetricsChart-CPidSMaN.js → MetricsChart-BHv1mj0l.js} +2 -2
  30. package/dist/chunks/{MetricsChart-CPidSMaN.js.map → MetricsChart-BHv1mj0l.js.map} +1 -1
  31. package/dist/chunks/{MetricsChart-CM4CI6eA.js → MetricsChart-Du8mtBlY.js} +3 -3
  32. package/dist/chunks/{MetricsChart-CM4CI6eA.js.map → MetricsChart-Du8mtBlY.js.map} +1 -1
  33. package/dist/chunks/{PDFViewer-Dyo-Oeyd.js → PDFViewer-9beaQaeq.js} +3 -3
  34. package/dist/chunks/{PDFViewer-Dyo-Oeyd.js.map → PDFViewer-9beaQaeq.js.map} +1 -1
  35. package/dist/chunks/{PDFViewer-BNQlnS83.js → PDFViewer-C-RkFhlV.js} +2 -2
  36. package/dist/chunks/{PDFViewer-BNQlnS83.js.map → PDFViewer-C-RkFhlV.js.map} +1 -1
  37. package/dist/chunks/{Page-B524zSQs.js → Page-Dg7X1BML.js} +2 -2
  38. package/dist/chunks/{Page-B524zSQs.js.map → Page-Dg7X1BML.js.map} +1 -1
  39. package/dist/chunks/{Page-BFgj0pAA.js → Page-KLwFxSBF.js} +2 -2
  40. package/dist/chunks/{Page-BFgj0pAA.js.map → Page-KLwFxSBF.js.map} +1 -1
  41. package/dist/chunks/{TopNav-D3I3_25f.js → TopNav-47rWUwBU.js} +2 -2
  42. package/dist/chunks/{TopNav-D3I3_25f.js.map → TopNav-47rWUwBU.js.map} +1 -1
  43. package/dist/chunks/{TopNav-MDjL4kV0.js → TopNav-DAB4M5C6.js} +2 -2
  44. package/dist/chunks/{TopNav-MDjL4kV0.js.map → TopNav-DAB4M5C6.js.map} +1 -1
  45. package/dist/chunks/{User-DwIT-CTQ.js → User-DNxU39NR.js} +2 -2
  46. package/dist/chunks/{User-DwIT-CTQ.js.map → User-DNxU39NR.js.map} +1 -1
  47. package/dist/chunks/{User-BalfYTEF.js → User-lVECCjCu.js} +2 -2
  48. package/dist/chunks/{User-BalfYTEF.js.map → User-lVECCjCu.js.map} +1 -1
  49. package/dist/chunks/WebApp-Bci5ZTRS.js +2 -0
  50. package/dist/chunks/WebApp-Bci5ZTRS.js.map +1 -0
  51. package/dist/chunks/{WebApp-B6mgbNn2.js → WebApp-No-qysKc.js} +17 -17
  52. package/dist/chunks/WebApp-No-qysKc.js.map +1 -0
  53. package/dist/docit.cjs.js +1 -1
  54. package/dist/docit.css +531 -0
  55. package/dist/docit.es.js +6 -6
  56. package/dist/index.cjs.js +1 -1
  57. package/dist/index.cjs.js.map +1 -1
  58. package/dist/index.es.js +34 -14
  59. package/dist/index.es.js.map +1 -1
  60. package/dist/lightbox.cjs.js +1 -1
  61. package/dist/lightbox.es.js +4 -4
  62. package/package.json +2 -10
  63. package/dist/chunks/FilePreviewView-BmFHzK5K.js.map +0 -1
  64. package/dist/chunks/FilePreviewView-DcdRl_ta.js +0 -2
  65. package/dist/chunks/FilePreviewView-DcdRl_ta.js.map +0 -1
  66. package/dist/chunks/FormView-CmBuwKGD.js.map +0 -1
  67. package/dist/chunks/FormView-DqUBMPJ9.js.map +0 -1
  68. package/dist/chunks/WebApp-B6mgbNn2.js.map +0 -1
  69. package/dist/chunks/WebApp-DqDowtkl.js +0 -2
  70. package/dist/chunks/WebApp-DqDowtkl.js.map +0 -1
package/dist/docit.cjs.js CHANGED
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("./chunks/WebApp-DqDowtkl.js"),e=require("./chunks/TopNav-MDjL4kV0.js"),o=require("./chunks/Page-BFgj0pAA.js"),i=require("./chunks/ContextMenu-gEcpSz56.js"),s=require("./chunks/User-BalfYTEF.js"),a=require("./chunks/TokenManager-Bzn4guFm.js");class DocNavSidebar extends t.View{constructor(t={}){super({className:"docit-sidebar-nav",tagName:"nav",...t}),this.singleBookMode=t.singleBookMode||!1,this.books=t.books,this.docPages=t.docPages,this.activeUser=t.activeUser,this.currentBook=null,this.currentDocPage=null}async onInit(){await super.onInit(),this.getApp().events.on("page:show",this._onPageShow.bind(this))}async _onPageShow({query:t}){const e=t.doc_book,o=t.doc_page,i=this.getApp();if(e){const t=this.books.findWhere({slug:e});!t||this.currentBook&&this.currentBook.id===t.id||(await i.setActiveBook(t),this.currentBook=i.currentBook)}else this.currentBook&&(await i.setActiveBook(null),this.currentBook=null);this.currentDocPage=o?this.docPages.findWhere({slug:o}):null,this.render()}getTemplate(){return'\n <div class="docit-nav-body pt-3">\n {{#currentBook}}\n {{#docPages.models}}\n <a href="#" class="docit-page-link {{#isActive}}active{{/isActive}}"\n data-action="select-page" data-page-slug="{{slug}}">\n <i class="{{#metadata.icon}}{{metadata.icon}}{{/metadata.icon}}{{^metadata.icon}}bi bi-file-earmark-text{{/metadata.icon}} me-2"></i>\n <span>{{title|capitalize}}</span>\n </a>\n {{/docPages.models}}\n {{^docPages.models}}\n <div class="docit-nav-empty"><p>No pages in this book.</p></div>\n {{/docPages.models}}\n {{/currentBook}}\n {{^currentBook}}\n {{#books.models}}\n <a href="#" class="docit-book-item" data-action="select-book" data-book-slug="{{slug}}">\n <i class="bi bi-book me-2"></i>\n <span class="book-title">{{title}}</span>\n <span class="badge bg-secondary ms-auto">{{page_count}}</span>\n </a>\n {{/books.models}}\n {{/currentBook}}\n </div>\n {{#currentBook}}\n <div class="docit-nav-footer">\n {{#canEdit}}\n <button class="btn btn-link w-100 mb-2" data-action="create-page">\n <i class="bi bi-plus-circle me-2"></i>\n Create New Page\n </button>\n {{/canEdit}}\n <button class="btn btn-link w-100" data-action="back-to-books">\n <i class="bi bi-arrow-left me-2"></i>\n Back to Books\n </button>\n </div>\n {{/currentBook}}\n {{^currentBook}}\n {{#canEdit}}\n <div class="docit-nav-footer">\n <button class="btn btn-link w-100" data-action="create-book">\n <i class="bi bi-plus-circle me-2"></i>\n Create New Book\n </button>\n </div>\n {{/canEdit}}\n {{/currentBook}}\n '}async onBeforeRender(){await super.onBeforeRender(),this.canEdit=this.getApp().canEdit(),this.docPages&&this.currentDocPage&&this.docPages.forEach(t=>{t.isActive=t.id===this.currentDocPage.id})}async onActionSelectBook(t,e){t.preventDefault();const o=e.dataset.bookSlug,i=this.books.findWhere({slug:o});if(i){await this.getApp().setActiveBook(i);const t=this.docPages.at(0),e={doc_book:i.get("slug")};t&&(e.doc_page=t.get("slug")),this.getApp().showPage("docs",e,{})}}onActionSelectPage(t,e){t.preventDefault();const o=e.dataset.pageSlug;this.currentBook&&o&&this.getApp().showPage("docs",{doc_book:this.currentBook.get("slug"),doc_page:o},{})}async onActionBackToBooks(t,e){t.preventDefault(),await this.getApp().setActiveBook(null),this.getApp().showPage("home")}async onActionCreateBook(){await this.getApp().createNewBook()}async onActionCreatePage(){this.currentBook&&await this.getApp().createNewPage(this.currentBook)}setBooks(t){this.books=t,this.render()}setDocPages(t){this.docPages=t,this.render()}setCurrentBook(t){this.currentBook=t,this.render(),this.getApp().topnav&&(t?this.getApp().topnav.setBrand(t.get("title")):this.getApp().topnav.setBrand("Documentation"))}setUser(t){this.activeUser=t,this.render()}}class DocHomePage extends o.Page{constructor(t={}){super({pageName:"home",title:"Documentation",className:"docit-home-page",...t})}async getTemplate(){return'\n <div class="docit-empty-state vh-100 d-flex flex-column align-items-center justify-content-center">\n <i class="bi bi-collection" style="font-size: 4rem;"></i>\n <h3 class="mt-4">Welcome to the Documentation Portal</h3>\n <p class="text-muted">Please select a book from the sidebar to get started.</p>\n </div>\n '}}class DocitBook extends s.Model{static endpoint="/api/docit/book";buildUrl(t=null){return this.get("slug")&&!this.id?`/api/docit/book/slug/${this.get("slug")}`:this.id?`/api/docit/book/${this.id}`:this.endpoint}}class DocitBookList extends s.Collection{constructor(t={}){super({ModelClass:DocitBook,endpoint:"/api/docit/book",...t})}parse(t){return t.data&&t.data.status?(this.meta={...this.meta,total:t.data.count||0,graph:t.data.graph},t.data.data||[]):super.parse(t)}}class DocitPage extends s.Model{static endpoint="/api/docit/page";buildUrl(t=null){return this.get("slug")&&!this.id?`/api/docit/page/slug/${this.get("slug")}`:this.id?`/api/docit/page/${this.id}`:this.endpoint}}class DocitPageList extends s.Collection{constructor(t={}){super({ModelClass:DocitPage,endpoint:"/api/docit/page",...t})}parse(t){return t.data&&t.data.status?(this.meta={...this.meta,total:t.data.count||0,graph:t.data.graph,book:t.data.book},t.data.data||[]):super.parse(t)}}class DocPage extends o.Page{constructor(t={}){super({pageName:"docs",title:"Documentation",className:"docit-page",...t}),this.bookModel=null,this.model=null}async onInit(){await super.onInit(),this.pageContextMenu=new i.ContextMenu({config:this.getPageContextMenuConfig(),containerId:"page-context-menu"}),this.addChild(this.pageContextMenu)}getPageContextMenuConfig(){return{icon:"bi-three-dots",buttonClass:"btn btn-outline-secondary btn-sm",items:[{label:"View History",action:"view-history",icon:"bi-clock-history"},{type:"divider"},{label:"Edit Page Content",action:"edit-page",icon:"bi-pencil"},{label:"Edit Page Info",action:"edit-page-info",icon:"bi-list-ol"},{type:"divider"},{label:"Edit Book Info",action:"edit-book",icon:"bi-book"},{type:"divider"},{label:"Delete Page",action:"delete-page",icon:"bi-trash",danger:!0}]}}async getTemplate(){return'\n <div class="docit-page-container position-relative">\n {{#loading}}\n <div class="docit-loading">\n <div class="spinner-border" role="status">\n <span class="visually-hidden">Loading...</span>\n </div>\n </div>\n {{/loading}}\n\n {{^loading}}\n {{#model|bool}}\n <div class="docit-page-toolbar">\n <div class="row">\n <div class="col d-flex justify-content-end">\n <div data-container="page-context-menu"></div>\n </div>\n </div>\n </div>\n <article class="docit-page-content">\n {{{model.html}}}\n </article>\n\n <nav class="docit-page-nav">\n {{#prevPage}}\n <a href="#" class="docit-nav-prev" data-action="navigate-to-page" data-page-slug="{{slug}}">\n <i class="bi bi-arrow-left"></i>\n <div>\n <small>Previous</small>\n <span>{{title}}</span>\n </div>\n </a>\n {{/prevPage}}\n {{^prevPage}}\n <div></div>\n {{/prevPage}}\n\n {{#nextPage}}\n <a href="#" class="docit-nav-next" data-action="navigate-to-page" data-page-slug="{{slug}}">\n <div>\n <small>Next</small>\n <span>{{title}}</span>\n </div>\n <i class="bi bi-arrow-right"></i>\n </a>\n {{/nextPage}}\n\n <div class="my-3">\n <span class="text-muted">Last updated: {{model.modified|datetime}}</span>\n </div>\n </nav>\n {{/model|bool}}\n\n {{^model|bool}}\n <div class="docit-empty-state">\n <i class="bi bi-file-earmark-text"></i>\n <h3>Select a page</h3>\n <p>Choose a page from the sidebar to view its content.</p>\n </div>\n {{/model|bool}}\n {{/loading}}\n </div>\n '}async onParams(t={},e={}){await super.onParams(t,e),this.loading=!0,await this.render();const o=this.getApp(),i=o.bookSlug||e.doc_book,s=e.doc_page;if(i)try{if(i){if(!o.currentBook||o.currentBook.get("slug")!==i){const t=new DocitBook({slug:i});await t.fetch(),await o.setActiveBook(t)}if(this.bookModel=o.currentBook,s)this.model=new DocitPage({slug:s}),await this.model.fetch({graph:"html"});else{const t=o.docPages.at(0);t?(this.model=new DocitPage({id:t.id}),await this.model.fetch({graph:"html"})):this.model=null}}else this.bookModel=null,this.model=null;this.canEdit=o.canEdit(),this.setupNavigation()}catch(a){console.error("Failed to load page:",a),this.showError("Failed to load documentation page"),this.model=null}finally{this.loading=!1,await this.render(),o.events.emit("docit:page-rendered",{book:this.bookModel,page:this.model})}else setTimeout(()=>{o.showPage("home")},100)}setupNavigation(){if(!this.model)return this.prevPage=null,void(this.nextPage=null);const t=this.getApp().docPages.models,e=t.findIndex(t=>t.id===this.model.id);this.prevPage=e>0?{slug:t[e-1].get("slug"),title:t[e-1].get("title")}:null,this.nextPage=e<t.length-1?{slug:t[e+1].get("slug"),title:t[e+1].get("title")}:null}async onActionNavigateToPage(t,e){t.preventDefault();const o=e.dataset.pageSlug;o&&this.getApp().showPage("docs",{},{doc_book:this.bookModel.get("slug"),doc_page:o})}async onActionEditPage(t,e){t.preventDefault(),this.model&&this.getApp().showPage("edit",{id:this.model.id,doc_book:this.bookModel.get("slug"),doc_page:this.model.get("slug")},{})}async onActionViewHistory(t,e){this.showInfo("Revision history coming soon.")}async onActionEditPageInfo(t,e){this.model&&this.getApp().showModelForm({model:this.model,fields:[{label:"Title",name:"title",type:"text"},{label:"Order Priority",name:"order_priority"},{label:"Slug",name:"slug"}]})}async onActionEditBook(t,e){if(this.model){const t=this.getApp().sidebar.currentBook;if(!t)return;this.getApp().showModelForm({model:t,fields:[{label:"Title",name:"title",type:"text"},{label:"Order Priority",name:"order_priority"},{label:"Slug",name:"slug"},{label:"Is Active",name:"is_active",type:"switch"}]})}}async onActionDeletePage(t,e){if(this.model&&await this.getApp().showConfirm({title:"Delete Page",body:`Are you sure you want to delete "${this.model.get("title")}"?`,confirmText:"Delete",confirmClass:"btn-danger"})){await this.model.destroy(),this.showSuccess("Page deleted."),await this.getApp().setActiveBook(this.bookModel);const t=this.getApp().docPages.at(0);t?this.getApp().showPage("docs",{},{doc_book:this.bookModel.get("slug"),doc_page:t.get("slug")}):this.getApp().showPage("docs",{},{doc_book:this.bookModel.get("slug")})}}async onAfterRender(){await super.onAfterRender(),"undefined"!=typeof Prism&&this.model&&Prism.highlightAll()}}class DocEditPage extends o.Page{constructor(t={}){super({pageName:"edit",title:"Edit Page",className:"docit-edit-page",...t}),this.model=null,this.editor=null,this.isDirty=!1}async getTemplate(){return'\n <div class="docit-edit-container vh-100">\n {{#loading}}\n <div class="docit-loading"><div class="spinner-border"></div></div>\n {{/loading}}\n\n {{^loading}}{{#model}}\n <header class="docit-edit-header">\n <div class="docit-edit-title-row">\n <h2>Editing: {{model.title}}</h2>\n <div class="docit-edit-actions">\n <button class="btn btn-outline-secondary" data-action="cancel-edit">Cancel</button>\n <button class="btn btn-success" data-action="save-page">\n <i class="bi bi-check-lg"></i> Save Changes\n </button>\n </div>\n </div>\n </header>\n <div class="docit-edit-body flex-grow-1">\n <div id="editor"></div>\n </div>\n {{/model}}\n {{^model}}\n <div class="docit-error-state">\n <h3>Page Not Found</h3>\n <p>The page you\'re trying to edit could not be found.</p>\n <button class="btn btn-primary" data-action="go-back">Go Back</button>\n </div>\n {{/model}}{{/loading}}\n </div>\n '}async onParams(t={},e={}){await super.onParams(t,e);let o=null;e.id?o=new DocitPage({id:e.id}):e.doc_page&&(o=new DocitPage({slug:e.doc_page})),this.model=o,this.model&&await this.model.fetch({graph:"detail"})}initEditor(){!this.editor&&this.element.querySelector("#editor")&&(this.editor=new toastui.Editor({el:this.element.querySelector("#editor"),height:"100%",initialEditType:"markdown",previewStyle:"tab",initialValue:this.model.get("content")||""}),this.editor.on("change",()=>{this.isDirty=!0}))}async onActionSavePage(){if(this.model&&this.editor){this.saving=!0,this.getApp().showLoading("saving...");try{const t=this.editor.getMarkdown();await this.model.save({content:t}),this.isDirty=!1,this.getApp().toast.success("Page saved successfully."),this.getApp().showPage("docs",this.query)}catch(t){console.error("Failed to save page:",t),this.getApp().toast.error("Failed to save page.")}finally{this.saving=!1,this.getApp().hideLoading()}}}async onActionCancelEdit(){this.getApp().showPage("docs",this.query)}onActionGoBack(){this.getApp().showPage("docs")}async onBeforeRender(){await super.onBeforeRender(),this.editor&&(this.editor.destroy(),this.editor=null)}async onAfterRender(){await super.onAfterRender(),this.model&&this.initEditor()}async onBeforeDestroy(){this.editor?.destroy(),await super.onBeforeDestroy()}}class DocItApp extends t.WebApp{constructor(t={}){super({name:t.title||"DocIt Portal",version:t.version||"1.0.0",debug:t.debug||!1,container:t.container||"#app",defaultRoute:"home",basePath:t.basePath||"",...t}),this.bookSlug=t.bookSlug||null,this.showBookNav=void 0!==t.showBookNav?t.showBookNav:!this.bookSlug,this.theme=t.theme||"light",this.editPermissions=t.permissions?.edit||["manage_docit"],this.sidebarConfig={showSearch:!0,defaultCollapsed:!1,...t.sidebar},this.books=new DocitBookList,this.books.params.sort="-order_priority",this.docPages=new DocitPageList,this.docPages.params.sort="-order_priority",this.toast=new s.ToastService,this.currentBook=null,this.sidebar=null,this.isDocItReady=!1,this.tokenManager=new a.TokenManager,this.activeUser=null}async start(){try{console.log("Starting DocIt Portal..."),this.setupDocItLayout(),await this.setupTopNav(),await this.setupSidebar(),await this.checkAuthStatus(),this.registerDocItPages(),await super.start(),await this.loadInitialData(),this.isDocItReady=!0,this.events.emit("docit:ready",{app:this}),console.log("✅ DocIt Portal ready")}catch(t){throw console.error("Failed to start DocIt:",t),this.showError("Failed to initialize documentation portal"),t}}setupDocItLayout(){const t="string"==typeof this.container?document.querySelector(this.container):this.container;if(!t)throw new Error(`Container not found: ${this.container}`);t.classList.add("docit-app",`docit-theme-${this.theme}`),t.innerHTML='\n <div class="docit-app-layout">\n <div id="topnav-container"></div>\n <div class="docit-body-layout">\n <div class="docit-sidebar" id="docit-sidebar"></div>\n <div class="docit-main">\n <div class="docit-content" id="page-container"></div>\n </div>\n </div>\n </div>\n ',this.pageContainer="#page-container"}async setupTopNav(){this.topnav=new e.TopNav({containerId:"topnav-container",brand:this.name,theme:"navbar navbar-expand-lg bg-dark navbar-dark",showSidebarToggle:!1,displayMode:"brand",rightItems:[{id:"login",icon:"bi-box-arrow-in-right",href:"/examples/auth/",label:"Login"}],userMenu:{label:"User",icon:"bi-person-circle",items:[{label:"Profile",icon:"bi-person",action:"profile"},{divider:!0},{label:"Logout",icon:"bi-box-arrow-right",action:"logout"}]}}),await this.topnav.render()}onActionToggleSidebar(){document.querySelector(".docit-layout").classList.toggle("sidebar-collapsed")}async setupSidebar(){this.sidebar=new DocNavSidebar({containerId:"docit-sidebar",app:this,singleBookMode:!!this.bookSlug,showBookNav:this.showBookNav,books:this.books,docPages:this.docPages,activeUser:this.activeUser,...this.sidebarConfig}),await this.sidebar.render()}registerDocItPages(){this.registerPage("home",DocHomePage,{route:"/",permissions:null}),this.registerPage("docs",DocPage,{route:"/docs",permissions:null}),this.registerPage("edit",DocEditPage,{route:"/edit",permissions:this.editPermissions})}async loadInitialData(){try{if(this.bookSlug){const t=new DocitBook({slug:this.bookSlug});if(await t.fetch(),!t.id)throw new Error(`Book with slug '${this.bookSlug}' not found.`);this.books.add(t),await this.setActiveBook(t)}else await this.books.fetch({graph:"list"}),this.sidebar.render()}catch(t){console.error("Failed to load initial data:",t),this.showError("Failed to load documentation")}}async setActiveBook(t){this.currentBook&&t&&this.currentBook.id===t.id||(this.currentBook=t,this.docPages.reset(),t&&await this.docPages.fetch({book:t.get("id"),graph:"list"}),this.sidebar.setCurrentBook(t),this.sidebar.setDocPages(this.docPages),this.events.emit("docit:book-changed",{book:t}))}async saveDocPageContent(t,e){const o=this.docPages.get(t)||new DocitPage({id:t});o.set("content",e);const i=await o.save();if(!i.success||!i.data.status)throw new Error("Failed to save doc page");return o}canEdit(){const t=this.activeUser;return!!t&&this.editPermissions.some(e=>!!t.hasPermission&&t.hasPermission(e))}async checkAuthStatus(){try{const t=this.tokenManager.getTokenInstance();if(!t||!t.isValid())return void this.events.emit("auth:unauthorized",{app:this});if(t.isExpired())return void this.events.emit("auth:expired",{app:this});this.tokenManager.startAutoRefresh(this),this.rest.setAuthToken(t.token);const e=new s.User({id:t.getUserId()});await e.fetch(),this.setActiveUser(e)}catch(t){console.error("Failed to check auth status:",t),this.events.emit("auth:error",{error:t,app:this})}}setActiveUser(t){return this.activeUser=t,this.sidebar&&this.sidebar.setUser(t),this.topnav&&(this.topnav.setUser(t),this.tonnav.render()),this.events.emit("user:changed",{user:t,app:this}),this}clearActiveUser(){return this.activeUser=null,this.tokenManager.clearTokens(),this.rest.clearAuth(),this.sidebar&&this.sidebar.setUser(null),this.events.emit("user:cleared",{app:this}),this}async logout(){this.clearActiveUser(),this.books.reset(),this.docPages.reset(),this.currentBook=null,this.events.emit("auth:logout",{app:this}),window.location.reload()}async createNewBook(){const t=await this.showModelForm({title:"Create New Book",model:new DocitBook,fields:[{name:"title",label:"Title",required:!0},{name:"slug",label:"Slug",required:!0,helpText:"A URL-friendly identifier."}]});t&&t.success&&(this.books.add(t.data),this.sidebar.render(),this.showSuccess("Book created successfully."))}async createNewPage(t){if(!t)return;const e=await this.showForm({title:"Create New Page",fields:[{name:"title",label:"Title",required:!0},{name:"slug",label:"Slug",required:!0,helpText:"A URL-friendly identifier."}]});e&&e.slug&&(e.book=t.id);const o=new DocitPage,i=await o.save(e);i&&i.success&&(this.docPages.add(o),this.sidebar.render(),this.showPage("edit",{id:o.id,doc_book:t.get("slug"),doc_page:o.get("slug")},{}))}static create(t={}){return new DocItApp(t)}static createForBook(t,e={}){return new DocItApp({...e,bookSlug:t,showBookNav:!1})}}exports.BUILD_TIME=t.BUILD_TIME,exports.VERSION=t.VERSION,exports.VERSION_INFO=t.VERSION_INFO,exports.VERSION_MAJOR=t.VERSION_MAJOR,exports.VERSION_MINOR=t.VERSION_MINOR,exports.VERSION_REVISION=t.VERSION_REVISION,exports.WebApp=t.WebApp,exports.DocEditPage=DocEditPage,exports.DocHomePage=DocHomePage,exports.DocItApp=DocItApp,exports.DocNavSidebar=DocNavSidebar,exports.DocPage=DocPage,exports.DocitBook=DocitBook,exports.DocitBookList=DocitBookList,exports.DocitPage=DocitPage,exports.DocitPageList=DocitPageList;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const t=require("./chunks/WebApp-Bci5ZTRS.js"),e=require("./chunks/TopNav-DAB4M5C6.js"),o=require("./chunks/Page-KLwFxSBF.js"),i=require("./chunks/ContextMenu-CD5yoYTS.js"),s=require("./chunks/User-lVECCjCu.js"),a=require("./chunks/TokenManager-Bzn4guFm.js");class DocNavSidebar extends t.View{constructor(t={}){super({className:"docit-sidebar-nav",tagName:"nav",...t}),this.singleBookMode=t.singleBookMode||!1,this.books=t.books,this.docPages=t.docPages,this.activeUser=t.activeUser,this.currentBook=null,this.currentDocPage=null}async onInit(){await super.onInit(),this.getApp().events.on("page:show",this._onPageShow.bind(this))}async _onPageShow({query:t}){const e=t.doc_book,o=t.doc_page,i=this.getApp();if(e){const t=this.books.findWhere({slug:e});!t||this.currentBook&&this.currentBook.id===t.id||(await i.setActiveBook(t),this.currentBook=i.currentBook)}else this.currentBook&&(await i.setActiveBook(null),this.currentBook=null);this.currentDocPage=o?this.docPages.findWhere({slug:o}):null,this.render()}getTemplate(){return'\n <div class="docit-nav-body pt-3">\n {{#currentBook}}\n {{#docPages.models}}\n <a href="#" class="docit-page-link {{#isActive}}active{{/isActive}}"\n data-action="select-page" data-page-slug="{{slug}}">\n <i class="{{#metadata.icon}}{{metadata.icon}}{{/metadata.icon}}{{^metadata.icon}}bi bi-file-earmark-text{{/metadata.icon}} me-2"></i>\n <span>{{title|capitalize}}</span>\n </a>\n {{/docPages.models}}\n {{^docPages.models}}\n <div class="docit-nav-empty"><p>No pages in this book.</p></div>\n {{/docPages.models}}\n {{/currentBook}}\n {{^currentBook}}\n {{#books.models}}\n <a href="#" class="docit-book-item" data-action="select-book" data-book-slug="{{slug}}">\n <i class="bi bi-book me-2"></i>\n <span class="book-title">{{title}}</span>\n <span class="badge bg-secondary ms-auto">{{page_count}}</span>\n </a>\n {{/books.models}}\n {{/currentBook}}\n </div>\n {{#currentBook}}\n <div class="docit-nav-footer">\n {{#canEdit}}\n <button class="btn btn-link w-100 mb-2" data-action="create-page">\n <i class="bi bi-plus-circle me-2"></i>\n Create New Page\n </button>\n {{/canEdit}}\n <button class="btn btn-link w-100" data-action="back-to-books">\n <i class="bi bi-arrow-left me-2"></i>\n Back to Books\n </button>\n </div>\n {{/currentBook}}\n {{^currentBook}}\n {{#canEdit}}\n <div class="docit-nav-footer">\n <button class="btn btn-link w-100" data-action="create-book">\n <i class="bi bi-plus-circle me-2"></i>\n Create New Book\n </button>\n </div>\n {{/canEdit}}\n {{/currentBook}}\n '}async onBeforeRender(){await super.onBeforeRender(),this.canEdit=this.getApp().canEdit(),this.docPages&&this.currentDocPage&&this.docPages.forEach(t=>{t.isActive=t.id===this.currentDocPage.id})}async onActionSelectBook(t,e){t.preventDefault();const o=e.dataset.bookSlug,i=this.books.findWhere({slug:o});if(i){await this.getApp().setActiveBook(i);const t=this.docPages.at(0),e={doc_book:i.get("slug")};t&&(e.doc_page=t.get("slug")),this.getApp().showPage("docs",e,{})}}onActionSelectPage(t,e){t.preventDefault();const o=e.dataset.pageSlug;this.currentBook&&o&&this.getApp().showPage("docs",{doc_book:this.currentBook.get("slug"),doc_page:o},{})}async onActionBackToBooks(t,e){t.preventDefault(),await this.getApp().setActiveBook(null),this.getApp().showPage("home")}async onActionCreateBook(){await this.getApp().createNewBook()}async onActionCreatePage(){this.currentBook&&await this.getApp().createNewPage(this.currentBook)}setBooks(t){this.books=t,this.render()}setDocPages(t){this.docPages=t,this.render()}setCurrentBook(t){this.currentBook=t,this.render(),this.getApp().topnav&&(t?this.getApp().topnav.setBrand(t.get("title")):this.getApp().topnav.setBrand("Documentation"))}setUser(t){this.activeUser=t,this.render()}}class DocHomePage extends o.Page{constructor(t={}){super({pageName:"home",title:"Documentation",className:"docit-home-page",...t})}async getTemplate(){return'\n <div class="docit-empty-state vh-100 d-flex flex-column align-items-center justify-content-center">\n <i class="bi bi-collection" style="font-size: 4rem;"></i>\n <h3 class="mt-4">Welcome to the Documentation Portal</h3>\n <p class="text-muted">Please select a book from the sidebar to get started.</p>\n </div>\n '}}class DocitBook extends s.Model{static endpoint="/api/docit/book";buildUrl(t=null){return this.get("slug")&&!this.id?`/api/docit/book/slug/${this.get("slug")}`:this.id?`/api/docit/book/${this.id}`:this.endpoint}}class DocitBookList extends s.Collection{constructor(t={}){super({ModelClass:DocitBook,endpoint:"/api/docit/book",...t})}parse(t){return t.data&&t.data.status?(this.meta={...this.meta,total:t.data.count||0,graph:t.data.graph},t.data.data||[]):super.parse(t)}}class DocitPage extends s.Model{static endpoint="/api/docit/page";buildUrl(t=null){return this.get("slug")&&!this.id?`/api/docit/page/slug/${this.get("slug")}`:this.id?`/api/docit/page/${this.id}`:this.endpoint}}class DocitPageList extends s.Collection{constructor(t={}){super({ModelClass:DocitPage,endpoint:"/api/docit/page",...t})}parse(t){return t.data&&t.data.status?(this.meta={...this.meta,total:t.data.count||0,graph:t.data.graph,book:t.data.book},t.data.data||[]):super.parse(t)}}class DocPage extends o.Page{constructor(t={}){super({pageName:"docs",title:"Documentation",className:"docit-page",...t}),this.bookModel=null,this.model=null}async onInit(){await super.onInit(),this.pageContextMenu=new i.ContextMenu({config:this.getPageContextMenuConfig(),containerId:"page-context-menu"}),this.addChild(this.pageContextMenu)}getPageContextMenuConfig(){return{icon:"bi-three-dots",buttonClass:"btn btn-outline-secondary btn-sm",items:[{label:"View History",action:"view-history",icon:"bi-clock-history"},{type:"divider"},{label:"Edit Page Content",action:"edit-page",icon:"bi-pencil"},{label:"Edit Page Info",action:"edit-page-info",icon:"bi-list-ol"},{type:"divider"},{label:"Edit Book Info",action:"edit-book",icon:"bi-book"},{type:"divider"},{label:"Delete Page",action:"delete-page",icon:"bi-trash",danger:!0}]}}async getTemplate(){return'\n <div class="docit-page-container position-relative">\n {{#loading}}\n <div class="docit-loading">\n <div class="spinner-border" role="status">\n <span class="visually-hidden">Loading...</span>\n </div>\n </div>\n {{/loading}}\n\n {{^loading}}\n {{#model|bool}}\n <div class="docit-page-toolbar">\n <div class="row">\n <div class="col d-flex justify-content-end">\n <div data-container="page-context-menu"></div>\n </div>\n </div>\n </div>\n <article class="docit-page-content">\n {{{model.html}}}\n </article>\n\n <nav class="docit-page-nav">\n {{#prevPage}}\n <a href="#" class="docit-nav-prev" data-action="navigate-to-page" data-page-slug="{{slug}}">\n <i class="bi bi-arrow-left"></i>\n <div>\n <small>Previous</small>\n <span>{{title}}</span>\n </div>\n </a>\n {{/prevPage}}\n {{^prevPage}}\n <div></div>\n {{/prevPage}}\n\n {{#nextPage}}\n <a href="#" class="docit-nav-next" data-action="navigate-to-page" data-page-slug="{{slug}}">\n <div>\n <small>Next</small>\n <span>{{title}}</span>\n </div>\n <i class="bi bi-arrow-right"></i>\n </a>\n {{/nextPage}}\n\n <div class="my-3">\n <span class="text-muted">Last updated: {{model.modified|datetime}}</span>\n </div>\n </nav>\n {{/model|bool}}\n\n {{^model|bool}}\n <div class="docit-empty-state">\n <i class="bi bi-file-earmark-text"></i>\n <h3>Select a page</h3>\n <p>Choose a page from the sidebar to view its content.</p>\n </div>\n {{/model|bool}}\n {{/loading}}\n </div>\n '}async onParams(t={},e={}){await super.onParams(t,e),this.loading=!0,await this.render();const o=this.getApp(),i=o.bookSlug||e.doc_book,s=e.doc_page;if(i)try{if(i){if(!o.currentBook||o.currentBook.get("slug")!==i){const t=new DocitBook({slug:i});await t.fetch(),await o.setActiveBook(t)}if(this.bookModel=o.currentBook,s)this.model=new DocitPage({slug:s}),await this.model.fetch({graph:"html"});else{const t=o.docPages.at(0);t?(this.model=new DocitPage({id:t.id}),await this.model.fetch({graph:"html"})):this.model=null}}else this.bookModel=null,this.model=null;this.canEdit=o.canEdit(),this.setupNavigation()}catch(a){console.error("Failed to load page:",a),this.showError("Failed to load documentation page"),this.model=null}finally{this.loading=!1,await this.render(),o.events.emit("docit:page-rendered",{book:this.bookModel,page:this.model})}else setTimeout(()=>{o.showPage("home")},100)}setupNavigation(){if(!this.model)return this.prevPage=null,void(this.nextPage=null);const t=this.getApp().docPages.models,e=t.findIndex(t=>t.id===this.model.id);this.prevPage=e>0?{slug:t[e-1].get("slug"),title:t[e-1].get("title")}:null,this.nextPage=e<t.length-1?{slug:t[e+1].get("slug"),title:t[e+1].get("title")}:null}async onActionNavigateToPage(t,e){t.preventDefault();const o=e.dataset.pageSlug;o&&this.getApp().showPage("docs",{},{doc_book:this.bookModel.get("slug"),doc_page:o})}async onActionEditPage(t,e){t.preventDefault(),this.model&&this.getApp().showPage("edit",{id:this.model.id,doc_book:this.bookModel.get("slug"),doc_page:this.model.get("slug")},{})}async onActionViewHistory(t,e){this.showInfo("Revision history coming soon.")}async onActionEditPageInfo(t,e){this.model&&this.getApp().showModelForm({model:this.model,fields:[{label:"Title",name:"title",type:"text"},{label:"Order Priority",name:"order_priority"},{label:"Slug",name:"slug"}]})}async onActionEditBook(t,e){if(this.model){const t=this.getApp().sidebar.currentBook;if(!t)return;this.getApp().showModelForm({model:t,fields:[{label:"Title",name:"title",type:"text"},{label:"Order Priority",name:"order_priority"},{label:"Slug",name:"slug"},{label:"Is Active",name:"is_active",type:"switch"}]})}}async onActionDeletePage(t,e){if(this.model&&await this.getApp().showConfirm({title:"Delete Page",body:`Are you sure you want to delete "${this.model.get("title")}"?`,confirmText:"Delete",confirmClass:"btn-danger"})){await this.model.destroy(),this.showSuccess("Page deleted."),await this.getApp().setActiveBook(this.bookModel);const t=this.getApp().docPages.at(0);t?this.getApp().showPage("docs",{},{doc_book:this.bookModel.get("slug"),doc_page:t.get("slug")}):this.getApp().showPage("docs",{},{doc_book:this.bookModel.get("slug")})}}async onAfterRender(){await super.onAfterRender(),"undefined"!=typeof Prism&&this.model&&Prism.highlightAll()}}class DocEditPage extends o.Page{constructor(t={}){super({pageName:"edit",title:"Edit Page",className:"docit-edit-page",...t}),this.model=null,this.editor=null,this.isDirty=!1}async getTemplate(){return'\n <div class="docit-edit-container vh-100">\n {{#loading}}\n <div class="docit-loading"><div class="spinner-border"></div></div>\n {{/loading}}\n\n {{^loading}}{{#model}}\n <header class="docit-edit-header">\n <div class="docit-edit-title-row">\n <h2>Editing: {{model.title}}</h2>\n <div class="docit-edit-actions">\n <button class="btn btn-outline-secondary" data-action="cancel-edit">Cancel</button>\n <button class="btn btn-success" data-action="save-page">\n <i class="bi bi-check-lg"></i> Save Changes\n </button>\n </div>\n </div>\n </header>\n <div class="docit-edit-body flex-grow-1">\n <div id="editor"></div>\n </div>\n {{/model}}\n {{^model}}\n <div class="docit-error-state">\n <h3>Page Not Found</h3>\n <p>The page you\'re trying to edit could not be found.</p>\n <button class="btn btn-primary" data-action="go-back">Go Back</button>\n </div>\n {{/model}}{{/loading}}\n </div>\n '}async onParams(t={},e={}){await super.onParams(t,e);let o=null;e.id?o=new DocitPage({id:e.id}):e.doc_page&&(o=new DocitPage({slug:e.doc_page})),this.model=o,this.model&&await this.model.fetch({graph:"detail"})}initEditor(){!this.editor&&this.element.querySelector("#editor")&&(this.editor=new toastui.Editor({el:this.element.querySelector("#editor"),height:"100%",initialEditType:"markdown",previewStyle:"tab",initialValue:this.model.get("content")||""}),this.editor.on("change",()=>{this.isDirty=!0}))}async onActionSavePage(){if(this.model&&this.editor){this.saving=!0,this.getApp().showLoading("saving...");try{const t=this.editor.getMarkdown();await this.model.save({content:t}),this.isDirty=!1,this.getApp().toast.success("Page saved successfully."),this.getApp().showPage("docs",this.query)}catch(t){console.error("Failed to save page:",t),this.getApp().toast.error("Failed to save page.")}finally{this.saving=!1,this.getApp().hideLoading()}}}async onActionCancelEdit(){this.getApp().showPage("docs",this.query)}onActionGoBack(){this.getApp().showPage("docs")}async onBeforeRender(){await super.onBeforeRender(),this.editor&&(this.editor.destroy(),this.editor=null)}async onAfterRender(){await super.onAfterRender(),this.model&&this.initEditor()}async onBeforeDestroy(){this.editor?.destroy(),await super.onBeforeDestroy()}}class DocItApp extends t.WebApp{constructor(t={}){super({name:t.title||"DocIt Portal",version:t.version||"1.0.0",debug:t.debug||!1,container:t.container||"#app",defaultRoute:"home",basePath:t.basePath||"",...t}),this.bookSlug=t.bookSlug||null,this.showBookNav=void 0!==t.showBookNav?t.showBookNav:!this.bookSlug,this.theme=t.theme||"light",this.editPermissions=t.permissions?.edit||["manage_docit"],this.sidebarConfig={showSearch:!0,defaultCollapsed:!1,...t.sidebar},this.books=new DocitBookList,this.books.params.sort="-order_priority",this.docPages=new DocitPageList,this.docPages.params.sort="-order_priority",this.toast=new s.ToastService,this.currentBook=null,this.sidebar=null,this.isDocItReady=!1,this.tokenManager=new a.TokenManager,this.activeUser=null}async start(){try{console.log("Starting DocIt Portal..."),this.setupDocItLayout(),await this.setupTopNav(),await this.setupSidebar(),await this.checkAuthStatus(),this.registerDocItPages(),await super.start(),await this.loadInitialData(),this.isDocItReady=!0,this.events.emit("docit:ready",{app:this}),console.log("✅ DocIt Portal ready")}catch(t){throw console.error("Failed to start DocIt:",t),this.showError("Failed to initialize documentation portal"),t}}setupDocItLayout(){const t="string"==typeof this.container?document.querySelector(this.container):this.container;if(!t)throw new Error(`Container not found: ${this.container}`);t.classList.add("docit-app",`docit-theme-${this.theme}`),t.innerHTML='\n <div class="docit-app-layout">\n <div id="topnav-container"></div>\n <div class="docit-body-layout">\n <div class="docit-sidebar" id="docit-sidebar"></div>\n <div class="docit-main">\n <div class="docit-content" id="page-container"></div>\n </div>\n </div>\n </div>\n ',this.pageContainer="#page-container"}async setupTopNav(){this.topnav=new e.TopNav({containerId:"topnav-container",brand:this.name,theme:"navbar navbar-expand-lg bg-dark navbar-dark",showSidebarToggle:!1,displayMode:"brand",rightItems:[{id:"login",icon:"bi-box-arrow-in-right",href:"/examples/auth/",label:"Login"}],userMenu:{label:"User",icon:"bi-person-circle",items:[{label:"Profile",icon:"bi-person",action:"profile"},{divider:!0},{label:"Logout",icon:"bi-box-arrow-right",action:"logout"}]}}),await this.topnav.render()}onActionToggleSidebar(){document.querySelector(".docit-layout").classList.toggle("sidebar-collapsed")}async setupSidebar(){this.sidebar=new DocNavSidebar({containerId:"docit-sidebar",app:this,singleBookMode:!!this.bookSlug,showBookNav:this.showBookNav,books:this.books,docPages:this.docPages,activeUser:this.activeUser,...this.sidebarConfig}),await this.sidebar.render()}registerDocItPages(){this.registerPage("home",DocHomePage,{route:"/",permissions:null}),this.registerPage("docs",DocPage,{route:"/docs",permissions:null}),this.registerPage("edit",DocEditPage,{route:"/edit",permissions:this.editPermissions})}async loadInitialData(){try{if(this.bookSlug){const t=new DocitBook({slug:this.bookSlug});if(await t.fetch(),!t.id)throw new Error(`Book with slug '${this.bookSlug}' not found.`);this.books.add(t),await this.setActiveBook(t)}else await this.books.fetch({graph:"list"}),this.sidebar.render()}catch(t){console.error("Failed to load initial data:",t),this.showError("Failed to load documentation")}}async setActiveBook(t){this.currentBook&&t&&this.currentBook.id===t.id||(this.currentBook=t,this.docPages.reset(),t&&await this.docPages.fetch({book:t.get("id"),graph:"list"}),this.sidebar.setCurrentBook(t),this.sidebar.setDocPages(this.docPages),this.events.emit("docit:book-changed",{book:t}))}async saveDocPageContent(t,e){const o=this.docPages.get(t)||new DocitPage({id:t});o.set("content",e);const i=await o.save();if(!i.success||!i.data.status)throw new Error("Failed to save doc page");return o}canEdit(){const t=this.activeUser;return!!t&&this.editPermissions.some(e=>!!t.hasPermission&&t.hasPermission(e))}async checkAuthStatus(){try{const t=this.tokenManager.getTokenInstance();if(!t||!t.isValid())return void this.events.emit("auth:unauthorized",{app:this});if(t.isExpired())return void this.events.emit("auth:expired",{app:this});this.tokenManager.startAutoRefresh(this),this.rest.setAuthToken(t.token);const e=new s.User({id:t.getUserId()});await e.fetch(),this.setActiveUser(e)}catch(t){console.error("Failed to check auth status:",t),this.events.emit("auth:error",{error:t,app:this})}}setActiveUser(t){return this.activeUser=t,this.sidebar&&this.sidebar.setUser(t),this.topnav&&(this.topnav.setUser(t),this.tonnav.render()),this.events.emit("user:changed",{user:t,app:this}),this}clearActiveUser(){return this.activeUser=null,this.tokenManager.clearTokens(),this.rest.clearAuth(),this.sidebar&&this.sidebar.setUser(null),this.events.emit("user:cleared",{app:this}),this}async logout(){this.clearActiveUser(),this.books.reset(),this.docPages.reset(),this.currentBook=null,this.events.emit("auth:logout",{app:this}),window.location.reload()}async createNewBook(){const t=await this.showModelForm({title:"Create New Book",model:new DocitBook,fields:[{name:"title",label:"Title",required:!0},{name:"slug",label:"Slug",required:!0,helpText:"A URL-friendly identifier."}]});t&&t.success&&(this.books.add(t.data),this.sidebar.render(),this.showSuccess("Book created successfully."))}async createNewPage(t){if(!t)return;const e=await this.showForm({title:"Create New Page",fields:[{name:"title",label:"Title",required:!0},{name:"slug",label:"Slug",required:!0,helpText:"A URL-friendly identifier."}]});e&&e.slug&&(e.book=t.id);const o=new DocitPage,i=await o.save(e);i&&i.success&&(this.docPages.add(o),this.sidebar.render(),this.showPage("edit",{id:o.id,doc_book:t.get("slug"),doc_page:o.get("slug")},{}))}static create(t={}){return new DocItApp(t)}static createForBook(t,e={}){return new DocItApp({...e,bookSlug:t,showBookNav:!1})}}exports.BUILD_TIME=t.BUILD_TIME,exports.VERSION=t.VERSION,exports.VERSION_INFO=t.VERSION_INFO,exports.VERSION_MAJOR=t.VERSION_MAJOR,exports.VERSION_MINOR=t.VERSION_MINOR,exports.VERSION_REVISION=t.VERSION_REVISION,exports.WebApp=t.WebApp,exports.DocEditPage=DocEditPage,exports.DocHomePage=DocHomePage,exports.DocItApp=DocItApp,exports.DocNavSidebar=DocNavSidebar,exports.DocPage=DocPage,exports.DocitBook=DocitBook,exports.DocitBookList=DocitBookList,exports.DocitPage=DocitPage,exports.DocitPageList=DocitPageList;
2
2
  //# sourceMappingURL=docit.cjs.js.map
package/dist/docit.css ADDED
@@ -0,0 +1,531 @@
1
+ /**
2
+ * DocIt Documentation Portal Styles
3
+ * Clean, modern styling for documentation viewing and editing
4
+ */
5
+
6
+ /* ============================================
7
+ CSS Variables / Theme
8
+ ============================================ */
9
+ :root {
10
+ --docit-primary: #2563eb;
11
+ --docit-primary-hover: #1d4ed8;
12
+ --docit-primary-light: #dbeafe;
13
+ --docit-bg-primary: #ffffff;
14
+ --docit-bg-secondary: #f8fafc;
15
+ --docit-bg-tertiary: #f1f5f9;
16
+ --docit-text-primary: #1e293b;
17
+ --docit-text-secondary: #64748b;
18
+ --docit-text-muted: #94a3b8;
19
+ --docit-border: #e2e8f0;
20
+ --docit-sidebar-width: 280px;
21
+ --docit-sidebar-collapsed-width: 0px;
22
+ --docit-header-height: 56px;
23
+ --docit-content-max-width: 900px;
24
+ --docit-font-sans:
25
+ -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Helvetica Neue", Arial, sans-serif;
26
+ --docit-font-mono: "SF Mono", Monaco, "Cascadia Code", "Roboto Mono", monospace;
27
+ }
28
+
29
+ /* ============================================
30
+ Base Layout
31
+ ============================================ */
32
+ .docit-app-layout {
33
+ display: flex;
34
+ flex-direction: column;
35
+ height: 100vh;
36
+ }
37
+
38
+ #topnav-container .navbar {
39
+ height: var(--docit-header-height);
40
+ }
41
+
42
+ .docit-body-layout {
43
+ display: flex;
44
+ flex-grow: 1;
45
+ overflow: hidden;
46
+ }
47
+
48
+ .docit-sidebar {
49
+ width: var(--docit-sidebar-width);
50
+ background: var(--docit-bg-secondary);
51
+ border-right: 1px solid var(--docit-border);
52
+ overflow-y: auto;
53
+ transition:
54
+ width 0.3s ease,
55
+ transform 0.3s ease;
56
+ height: calc(100vh - var(--docit-header-height));
57
+ position: sticky;
58
+ top: var(--docit-header-height);
59
+ }
60
+
61
+ .docit-main {
62
+ flex-grow: 1;
63
+ overflow-y: auto;
64
+ height: calc(100vh - var(--docit-header-height));
65
+ }
66
+
67
+ .docit-content {
68
+ width: 100%;
69
+ max-width: var(--docit-content-max-width);
70
+ margin: 0 auto;
71
+ padding: 2rem;
72
+ }
73
+
74
+ /* Collapsed sidebar state */
75
+ .sidebar-collapsed .docit-sidebar {
76
+ width: var(--docit-sidebar-collapsed-width);
77
+ transform: translateX(calc(-1 * var(--docit-sidebar-width)));
78
+ }
79
+
80
+ .sidebar-collapsed .toggle-chevron {
81
+ transform: rotate(0deg);
82
+ }
83
+
84
+ /* ============================================
85
+ Sidebar Navigation & TopNav
86
+ ============================================ */
87
+ .topnav-sidebar-toggle {
88
+ background: none;
89
+ border: none;
90
+ color: white;
91
+ padding: 0 0.5rem;
92
+ }
93
+
94
+ .toggle-chevron {
95
+ transition: transform 0.3s ease;
96
+ transform: rotate(180deg);
97
+ }
98
+
99
+ .docit-sidebar-nav {
100
+ height: 100%;
101
+ display: flex;
102
+ flex-direction: column;
103
+ }
104
+
105
+ .docit-nav-header {
106
+ padding: 1.5rem 1.25rem 1rem;
107
+ border-bottom: 1px solid var(--docit-border);
108
+ background: var(--docit-bg-primary);
109
+ position: sticky;
110
+ top: 0;
111
+ z-index: 10;
112
+ display: flex;
113
+ align-items: center;
114
+ }
115
+
116
+ .docit-nav-title {
117
+ font-size: 1.125rem;
118
+ font-weight: 600;
119
+ margin: 0;
120
+ }
121
+
122
+ .docit-nav-body {
123
+ flex: 1;
124
+ overflow-y: auto;
125
+ padding: 1rem 0;
126
+ }
127
+
128
+ .docit-page-toolbar {
129
+ margin-top: -20px;
130
+ }
131
+
132
+ .docit-nav-footer {
133
+ padding: 0.75rem;
134
+ border-top: 1px solid var(--docit-border);
135
+ }
136
+
137
+ .docit-book-item,
138
+ .docit-page-link {
139
+ display: flex;
140
+ align-items: center;
141
+ padding: 0.625rem 1.25rem;
142
+ margin: 0 0.75rem 0.25rem;
143
+ border-radius: 0.375rem;
144
+ cursor: pointer;
145
+ transition:
146
+ background-color 0.15s ease,
147
+ color 0.15s ease;
148
+ color: var(--docit-text-secondary);
149
+ text-decoration: none;
150
+ }
151
+
152
+ .docit-book-item:hover,
153
+ .docit-page-link:hover {
154
+ background: var(--docit-bg-tertiary);
155
+ color: var(--docit-text-primary);
156
+ }
157
+
158
+ .docit-book-item.active,
159
+ .docit-page-link.active {
160
+ font-weight: bold;
161
+ color: var(--docit-text-primary);
162
+ }
163
+
164
+ .docit-book-item .book-title {
165
+ flex: 1;
166
+ font-weight: 500;
167
+ }
168
+
169
+ /* ============================================
170
+ Page Content
171
+ ============================================ */
172
+ .docit-page-container {
173
+ animation: fadeIn 0.3s ease;
174
+ }
175
+
176
+ .docit-page-header {
177
+ margin-bottom: 2rem;
178
+ padding-bottom: 1.5rem;
179
+ border-bottom: 1px solid var(--docit-border);
180
+ }
181
+
182
+ .docit-page-title-row {
183
+ display: flex;
184
+ align-items: flex-start;
185
+ justify-content: space-between;
186
+ gap: 1rem;
187
+ }
188
+
189
+ .docit-page-title {
190
+ font-size: 2.25rem;
191
+ font-weight: 700;
192
+ margin: 0;
193
+ }
194
+
195
+ .docit-page-meta {
196
+ margin-top: 0.75rem;
197
+ font-size: 0.875rem;
198
+ color: var(--docit-text-muted);
199
+ }
200
+
201
+ .docit-page-meta span {
202
+ margin-right: 1rem;
203
+ }
204
+
205
+ /* Content Styling */
206
+ .docit-content h1,
207
+ .docit-content h2,
208
+ .docit-content h3,
209
+ .docit-content h4 {
210
+ margin-bottom: 1rem;
211
+ font-weight: 600;
212
+ }
213
+ .docit-content p {
214
+ margin-bottom: 1.25rem;
215
+ }
216
+ .docit-content a {
217
+ color: var(--docit-primary);
218
+ text-decoration: none;
219
+ }
220
+ .docit-content a:hover {
221
+ text-decoration: underline;
222
+ }
223
+ /*.docit-content ul,
224
+ .docit-content ol {
225
+ margin-bottom: 1.25rem;
226
+ padding-left: 2rem;
227
+ }*/
228
+
229
+ .docit-content code {
230
+ background: var(--docit-bg-tertiary);
231
+ padding: 0.125rem 0.375rem;
232
+ border-radius: 0.25rem;
233
+ font-family: var(--docit-font-mono);
234
+ }
235
+ .docit-content pre {
236
+ background: var(--docit-bg-secondary);
237
+ border: 1px solid var(--docit-border);
238
+ border-radius: 0.5rem;
239
+ padding: 1rem;
240
+ overflow-x: auto;
241
+ }
242
+
243
+ /* ============================================
244
+ Editor Styles
245
+ ============================================ */
246
+ .docit-edit-container {
247
+ display: flex;
248
+ flex-direction: column;
249
+ }
250
+ .docit-edit-header {
251
+ background: var(--docit-bg-secondary);
252
+ border-bottom: 1px solid var(--docit-border);
253
+ padding: 1rem 1.5rem;
254
+ }
255
+ .docit-edit-title-row {
256
+ display: flex;
257
+ align-items: center;
258
+ justify-content: space-between;
259
+ }
260
+ .docit-edit-body {
261
+ flex-grow: 1;
262
+ }
263
+
264
+ /* ============================================
265
+ Loading & Empty States
266
+ ============================================ */
267
+ .docit-loading,
268
+ .docit-empty-state {
269
+ display: flex;
270
+ flex-direction: column;
271
+ align-items: center;
272
+ justify-content: center;
273
+ padding: 3rem 1rem;
274
+ text-align: center;
275
+ color: var(--docit-text-muted);
276
+ }
277
+ .docit-empty-state i {
278
+ font-size: 3rem;
279
+ opacity: 0.5;
280
+ margin-bottom: 1rem;
281
+ }
282
+ .docit-empty-state h3 {
283
+ font-size: 1.5rem;
284
+ margin-bottom: 0.5rem;
285
+ color: var(--docit-text-primary);
286
+ }
287
+
288
+ /* ============================================
289
+ Animations
290
+ ============================================ */
291
+ @keyframes fadeIn {
292
+ from {
293
+ opacity: 0;
294
+ transform: translateY(10px);
295
+ }
296
+ to {
297
+ opacity: 1;
298
+ transform: translateY(0);
299
+ }
300
+ }
301
+
302
+ .highlight .hll {
303
+ background-color: #ffffcc;
304
+ }
305
+ .highlight {
306
+ background: #f8f8f8;
307
+ }
308
+ .highlight .c {
309
+ color: #408080;
310
+ font-style: italic;
311
+ } /* Comment */
312
+ .highlight .err {
313
+ border: 1px solid #ff0000;
314
+ } /* Error */
315
+ .highlight .k {
316
+ color: #008000;
317
+ font-weight: bold;
318
+ } /* Keyword */
319
+ .highlight .o {
320
+ color: #666666;
321
+ } /* Operator */
322
+ .highlight .ch {
323
+ color: #408080;
324
+ font-style: italic;
325
+ } /* Comment.Hashbang */
326
+ .highlight .cm {
327
+ color: #408080;
328
+ font-style: italic;
329
+ } /* Comment.Multiline */
330
+ .highlight .cp {
331
+ color: #bc7a00;
332
+ } /* Comment.Preproc */
333
+ .highlight .cpf {
334
+ color: #408080;
335
+ font-style: italic;
336
+ } /* Comment.PreprocFile */
337
+ .highlight .c1 {
338
+ color: #408080;
339
+ font-style: italic;
340
+ } /* Comment.Single */
341
+ .highlight .cs {
342
+ color: #408080;
343
+ font-style: italic;
344
+ } /* Comment.Special */
345
+ .highlight .gd {
346
+ color: #a00000;
347
+ } /* Generic.Deleted */
348
+ .highlight .ge {
349
+ font-style: italic;
350
+ } /* Generic.Emph */
351
+ .highlight .gr {
352
+ color: #ff0000;
353
+ } /* Generic.Error */
354
+ .highlight .gh {
355
+ color: #000080;
356
+ font-weight: bold;
357
+ } /* Generic.Heading */
358
+ .highlight .gi {
359
+ color: #00a000;
360
+ } /* Generic.Inserted */
361
+ .highlight .go {
362
+ color: #888888;
363
+ } /* Generic.Output */
364
+ .highlight .gp {
365
+ color: #000080;
366
+ font-weight: bold;
367
+ } /* Generic.Prompt */
368
+ .highlight .gs {
369
+ font-weight: bold;
370
+ } /* Generic.Strong */
371
+ .highlight .gu {
372
+ color: #800080;
373
+ font-weight: bold;
374
+ } /* Generic.Subheading */
375
+ .highlight .gt {
376
+ color: #0044dd;
377
+ } /* Generic.Traceback */
378
+ .highlight .kc {
379
+ color: #008000;
380
+ font-weight: bold;
381
+ } /* Keyword.Constant */
382
+ .highlight .kd {
383
+ color: #008000;
384
+ font-weight: bold;
385
+ } /* Keyword.Declaration */
386
+ .highlight .kn {
387
+ color: #008000;
388
+ font-weight: bold;
389
+ } /* Keyword.Namespace */
390
+ .highlight .kp {
391
+ color: #008000;
392
+ } /* Keyword.Pseudo */
393
+ .highlight .kr {
394
+ color: #008000;
395
+ font-weight: bold;
396
+ } /* Keyword.Reserved */
397
+ .highlight .kt {
398
+ color: #b00040;
399
+ } /* Keyword.Type */
400
+ .highlight .m {
401
+ color: #666666;
402
+ } /* Literal.Number */
403
+ .highlight .s {
404
+ color: #ba2121;
405
+ } /* Literal.String */
406
+ .highlight .na {
407
+ color: #7d9029;
408
+ } /* Name.Attribute */
409
+ .highlight .nb {
410
+ color: #008000;
411
+ } /* Name.Builtin */
412
+ .highlight .nc {
413
+ color: #0000ff;
414
+ font-weight: bold;
415
+ } /* Name.Class */
416
+ .highlight .no {
417
+ color: #880000;
418
+ } /* Name.Constant */
419
+ .highlight .nd {
420
+ color: #aa22ff;
421
+ } /* Name.Decorator */
422
+ .highlight .ni {
423
+ color: #999999;
424
+ font-weight: bold;
425
+ } /* Name.Entity */
426
+ .highlight .ne {
427
+ color: #d2413a;
428
+ font-weight: bold;
429
+ } /* Name.Exception */
430
+ .highlight .nf {
431
+ color: #0000ff;
432
+ } /* Name.Function */
433
+ .highlight .nl {
434
+ color: #a0a000;
435
+ } /* Name.Label */
436
+ .highlight .nn {
437
+ color: #0000ff;
438
+ font-weight: bold;
439
+ } /* Name.Namespace */
440
+ .highlight .nt {
441
+ color: #008000;
442
+ font-weight: bold;
443
+ } /* Name.Tag */
444
+ .highlight .nv {
445
+ color: #19177c;
446
+ } /* Name.Variable */
447
+ .highlight .ow {
448
+ color: #aa22ff;
449
+ font-weight: bold;
450
+ } /* Operator.Word */
451
+ .highlight .w {
452
+ color: #bbbbbb;
453
+ } /* Text.Whitespace */
454
+ .highlight .mb {
455
+ color: #666666;
456
+ } /* Literal.Number.Bin */
457
+ .highlight .mf {
458
+ color: #666666;
459
+ } /* Literal.Number.Float */
460
+ .highlight .mh {
461
+ color: #666666;
462
+ } /* Literal.Number.Hex */
463
+ .highlight .mi {
464
+ color: #666666;
465
+ } /* Literal.Number.Integer */
466
+ .highlight .mo {
467
+ color: #666666;
468
+ } /* Literal.Number.Oct */
469
+ .highlight .sa {
470
+ color: #ba2121;
471
+ } /* Literal.String.Affix */
472
+ .highlight .sb {
473
+ color: #ba2121;
474
+ } /* Literal.String.Backtick */
475
+ .highlight .sc {
476
+ color: #ba2121;
477
+ } /* Literal.String.Char */
478
+ .highlight .dl {
479
+ color: #ba2121;
480
+ } /* Literal.String.Delimiter */
481
+ .highlight .sd {
482
+ color: #ba2121;
483
+ font-style: italic;
484
+ } /* Literal.String.Doc */
485
+ .highlight .s2 {
486
+ color: #ba2121;
487
+ } /* Literal.String.Double */
488
+ .highlight .se {
489
+ color: #bb6622;
490
+ font-weight: bold;
491
+ } /* Literal.String.Escape */
492
+ .highlight .sh {
493
+ color: #ba2121;
494
+ } /* Literal.String.Heredoc */
495
+ .highlight .si {
496
+ color: #bb6688;
497
+ font-weight: bold;
498
+ } /* Literal.String.Interpol */
499
+ .highlight .sx {
500
+ color: #008000;
501
+ } /* Literal.String.Other */
502
+ .highlight .sr {
503
+ color: #bb6688;
504
+ } /* Literal.String.Regex */
505
+ .highlight .s1 {
506
+ color: #ba2121;
507
+ } /* Literal.String.Single */
508
+ .highlight .ss {
509
+ color: #19177c;
510
+ } /* Literal.String.Symbol */
511
+ .highlight .bp {
512
+ color: #008000;
513
+ } /* Name.Builtin.Pseudo */
514
+ .highlight .fm {
515
+ color: #0000ff;
516
+ } /* Name.Function.Magic */
517
+ .highlight .vc {
518
+ color: #19177c;
519
+ } /* Name.Variable.Class */
520
+ .highlight .vg {
521
+ color: #19177c;
522
+ } /* Name.Variable.Global */
523
+ .highlight .vi {
524
+ color: #19177c;
525
+ } /* Name.Variable.Instance */
526
+ .highlight .vm {
527
+ color: #19177c;
528
+ } /* Name.Variable.Magic */
529
+ .highlight .il {
530
+ color: #666666;
531
+ } /* Literal.Number.Integer.Long */
package/dist/docit.es.js CHANGED
@@ -1,9 +1,9 @@
1
- import { V as View, W as WebApp } from "./chunks/WebApp-B6mgbNn2.js";
2
- import { B, b, a, c, e, f } from "./chunks/WebApp-B6mgbNn2.js";
3
- import { T as TopNav } from "./chunks/TopNav-D3I3_25f.js";
4
- import { P as Page } from "./chunks/Page-B524zSQs.js";
5
- import { C as ContextMenu } from "./chunks/ContextMenu-BrHqj0fn.js";
6
- import { M as Model, C as Collection, T as ToastService, U as User } from "./chunks/User-DwIT-CTQ.js";
1
+ import { V as View, W as WebApp } from "./chunks/WebApp-No-qysKc.js";
2
+ import { B, b, a, c, e, f } from "./chunks/WebApp-No-qysKc.js";
3
+ import { T as TopNav } from "./chunks/TopNav-47rWUwBU.js";
4
+ import { P as Page } from "./chunks/Page-Dg7X1BML.js";
5
+ import { C as ContextMenu } from "./chunks/ContextMenu-Cds78Jny.js";
6
+ import { M as Model, C as Collection, T as ToastService, U as User } from "./chunks/User-DNxU39NR.js";
7
7
  import { T as TokenManager } from "./chunks/TokenManager-BXNva8Jk.js";
8
8
  class DocNavSidebar extends View {
9
9
  constructor(options = {}) {