cloud-ide-layout 1.0.166 → 1.0.168

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 (19) hide show
  1. package/fesm2022/{cloud-ide-layout-cloud-ide-layout-BGVK8JFk.mjs → cloud-ide-layout-cloud-ide-layout-TXOQ0tip.mjs} +28 -9
  2. package/fesm2022/cloud-ide-layout-cloud-ide-layout-TXOQ0tip.mjs.map +1 -0
  3. package/fesm2022/{cloud-ide-layout-dashboard-manager.component-BFXNvqCW.mjs → cloud-ide-layout-dashboard-manager.component-ik-G60a-.mjs} +2 -2
  4. package/fesm2022/{cloud-ide-layout-dashboard-manager.component-BFXNvqCW.mjs.map → cloud-ide-layout-dashboard-manager.component-ik-G60a-.mjs.map} +1 -1
  5. package/fesm2022/{cloud-ide-layout-drawer-theme.component-CzGTCVg9.mjs → cloud-ide-layout-drawer-theme.component-Dzt70vGh.mjs} +21 -5
  6. package/fesm2022/cloud-ide-layout-drawer-theme.component-Dzt70vGh.mjs.map +1 -0
  7. package/fesm2022/{cloud-ide-layout-floating-entity-selection.component-DGj8AnSO.mjs → cloud-ide-layout-floating-entity-selection.component-CFvHxAw7.mjs} +2 -2
  8. package/fesm2022/{cloud-ide-layout-floating-entity-selection.component-DGj8AnSO.mjs.map → cloud-ide-layout-floating-entity-selection.component-CFvHxAw7.mjs.map} +1 -1
  9. package/fesm2022/cloud-ide-layout-home-wrapper.component-C4YxNQIe.mjs +330 -0
  10. package/fesm2022/cloud-ide-layout-home-wrapper.component-C4YxNQIe.mjs.map +1 -0
  11. package/fesm2022/{cloud-ide-layout-sidedrawer-notes.component-CLBjDYA3.mjs → cloud-ide-layout-sidedrawer-notes.component-DKBaKoE7.mjs} +2 -2
  12. package/fesm2022/{cloud-ide-layout-sidedrawer-notes.component-CLBjDYA3.mjs.map → cloud-ide-layout-sidedrawer-notes.component-DKBaKoE7.mjs.map} +1 -1
  13. package/fesm2022/cloud-ide-layout.mjs +1 -1
  14. package/package.json +1 -1
  15. package/src/lib/assets/css/cide-lyt-variable.scss +68 -36
  16. package/fesm2022/cloud-ide-layout-cloud-ide-layout-BGVK8JFk.mjs.map +0 -1
  17. package/fesm2022/cloud-ide-layout-drawer-theme.component-CzGTCVg9.mjs.map +0 -1
  18. package/fesm2022/cloud-ide-layout-home-wrapper.component-BR-ETlty.mjs +0 -324
  19. package/fesm2022/cloud-ide-layout-home-wrapper.component-BR-ETlty.mjs.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"cloud-ide-layout-sidedrawer-notes.component-CLBjDYA3.mjs","sources":["../../../projects/cloud-ide-layout/src/lib/layout/sidedrawer/sidedrawer-notes/sidedrawer-notes.service.ts","../../../projects/cloud-ide-layout/src/lib/layout/sidedrawer/cide-lyt-drawer-base.class.ts","../../../projects/cloud-ide-layout/src/lib/layout/sidedrawer/sidedrawer-notes/sidedrawer-notes.component.ts","../../../projects/cloud-ide-layout/src/lib/layout/sidedrawer/sidedrawer-notes/sidedrawer-notes.component.html"],"sourcesContent":["import { HttpClient } from '@angular/common/http';\r\nimport { Injectable, inject } from '@angular/core';\r\nimport { ICoreSypn, IPageNotesManagerCreateUpdateControllerRespoonse, IPageNotesManagerListControllerRespoonse, cidePath, coreRoutesUrl, hostManagerRoutesUrl } from 'cloud-ide-lms-model';\r\nimport { Observable, of } from 'rxjs';\r\nimport { map } from 'rxjs/operators';\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class CideLytDrawerNotesService {\r\n // Modern Angular v20 dependency injection pattern\r\n private http = inject(HttpClient);\r\n\r\n constructor() {\r\n // Modern Angular v20 pattern: Use constructor for initialization only\r\n }\r\n\r\n getNotes(): Observable<ICoreSypn[]> {\r\n const url = cidePath.join([\r\n hostManagerRoutesUrl.cideSuiteHost,\r\n coreRoutesUrl.module,\r\n coreRoutesUrl.systemPageNotesManager\r\n ]);\r\n return this.http.get<IPageNotesManagerListControllerRespoonse>(url).pipe(map((res) => res.data || []));\r\n }\r\n\r\n addNote(note: ICoreSypn): Observable<unknown> {\r\n const url = cidePath.join([\r\n hostManagerRoutesUrl.cideSuiteHost,\r\n coreRoutesUrl.module,\r\n coreRoutesUrl.systemPageNotesManager\r\n ]);\r\n return this.http.post<IPageNotesManagerCreateUpdateControllerRespoonse>(url, note).pipe(map((res) => res.data));\r\n }\r\n\r\n updateNote(note: ICoreSypn): Observable<unknown> {\r\n const url = cidePath.join([\r\n hostManagerRoutesUrl.cideSuiteHost,\r\n coreRoutesUrl.module,\r\n coreRoutesUrl.systemPageNotesManager\r\n ]);\r\n return this.http.post<IPageNotesManagerCreateUpdateControllerRespoonse>(url, note).pipe(map((res) => res.data));\r\n }\r\n\r\n deleteNote(noteId: string): Observable<unknown> {\r\n // Mock implementation: simulate deleting a note.\r\n console.log('Deleting note with ID:', noteId);\r\n return of({ success: true });\r\n }\r\n\r\n // Additional methods for updating and deleting notes could be added here.\r\n // You might also include error handling or more complex data manipulation.\r\n}","import { Directive, OnInit, inject } from '@angular/core';\r\nimport { CideLytSidedrawerService } from './sidedrawer.service';\r\n\r\n@Directive()\r\nexport abstract class CideLytDrawerBase implements OnInit {\r\n private _pageId: string | null = null;\r\n private _themeId: string | null = null;\r\n protected sidedrawerService = inject(CideLytSidedrawerService);\r\n\r\n ngOnInit(): void {\r\n // Automatically initialize context from the service\r\n const pageId = this.sidedrawerService.pageId;\r\n const themeId = this.sidedrawerService.themeId;\r\n if (pageId && themeId) {\r\n this.setContext(pageId, themeId);\r\n }\r\n this.afterContextInit();\r\n }\r\n\r\n // Child classes can override this for additional setup\r\n protected afterContextInit(): void {}\r\n\r\n setContext(pageId: string, themeId: string) {\r\n this._pageId = pageId;\r\n this._themeId = themeId;\r\n }\r\n\r\n get pageId(): string | null {\r\n return this._pageId;\r\n }\r\n\r\n get themeId(): string | null {\r\n return this._themeId;\r\n }\r\n\r\n protected getStorageKey(suffix: string): string {\r\n return `drawer_${suffix}_${this._pageId || 'unknown'}`;\r\n }\r\n} ","import { CommonModule } from '@angular/common';\r\nimport { Component, OnInit, inject, signal } from '@angular/core';\r\nimport { ReactiveFormsModule, FormBuilder, FormGroup } from '@angular/forms';\r\nimport { CideLytDrawerNotesService } from './sidedrawer-notes.service';\r\nimport { ICoreSypn } from 'cloud-ide-lms-model';\r\nimport { CideInputComponent } from 'cloud-ide-element';\r\nimport { CideEleButtonComponent } from 'cloud-ide-element';\r\nimport { CideTextareaComponent } from 'cloud-ide-element';\r\nimport { AppStateHelperService } from '../../../services/app-state/app-state-helper.service';\r\nimport { CideLytDrawerBase } from '../cide-lyt-drawer-base.class';\r\n\r\nexport interface NewNoteModel {\r\n title: string;\r\n description: string;\r\n isPageSpecific: boolean;\r\n isUserSpecific: boolean;\r\n isEntitySpecific: boolean;\r\n isThemeSpecific: boolean;\r\n}\r\n\r\nexport interface NotesComponentState {\r\n newNoteModel: NewNoteModel;\r\n isFormVisible: boolean;\r\n scrollTop: number;\r\n}\r\n\r\n@Component({\r\n selector: 'cide-lyt-sidedrawer-notes',\r\n standalone: true,\r\n imports: [CommonModule, ReactiveFormsModule, CideInputComponent, CideEleButtonComponent, CideTextareaComponent],\r\n templateUrl: './sidedrawer-notes.component.html',\r\n styleUrl: './sidedrawer-notes.component.css'\r\n})\r\nexport class CideLytSidedrawerNotesComponent extends CideLytDrawerBase implements OnInit {\r\n private notesSignal = signal<ICoreSypn[]>([]);\r\n notes = this.notesSignal.asReadonly();\r\n isFormVisible = false;\r\n isEditing = false;\r\n editingNoteId: string | null = null;\r\n hoveredNoteIndex: number | null = null;\r\n noteForm!: FormGroup;\r\n private notesService = inject(CideLytDrawerNotesService);\r\n private fb = inject(FormBuilder);\r\n private appState = inject(AppStateHelperService);\r\n\r\n override ngOnInit(): void {\r\n super.ngOnInit();\r\n this.initForm();\r\n this.notesService.getNotes().subscribe({\r\n next: (notes) => {\r\n this.notesSignal.set(notes);\r\n },\r\n error: (error) => {\r\n console.error('Error loading notes:', error);\r\n }\r\n });\r\n }\r\n\r\n protected override afterContextInit(): void {\r\n // Any additional setup after context is ready can go here\r\n }\r\n\r\n private initForm(): void {\r\n this.noteForm = this.fb.group({\r\n sypn_title: [''],\r\n sypn_desc: [''],\r\n sypn_is_page_specific: [true],\r\n sypn_is_user_specific: [true],\r\n sypn_is_entity_specific: [false],\r\n sypn_is_theme_specific: [false]\r\n });\r\n }\r\n\r\n showAddForm(): void {\r\n this.isFormVisible = true;\r\n }\r\n\r\n hideAddForm(): void {\r\n this.isFormVisible = false;\r\n this.isEditing = false;\r\n this.editingNoteId = null;\r\n }\r\n\r\n startEdit(note: ICoreSypn): void {\r\n this.isEditing = true;\r\n this.editingNoteId = note._id || '';\r\n this.noteForm.patchValue({\r\n sypn_title: note.sypn_title || '',\r\n sypn_desc: note.sypn_desc || '',\r\n sypn_is_page_specific: note.sypn_is_page_specific || false,\r\n sypn_is_user_specific: note.sypn_is_user_specific || false,\r\n sypn_is_entity_specific: note.sypn_is_entity_specific || false,\r\n sypn_is_theme_specific: note.sypn_is_theme_specific || false\r\n });\r\n this.isFormVisible = true;\r\n }\r\n\r\n cancelEdit(): void {\r\n this.isEditing = false;\r\n this.editingNoteId = null;\r\n this.resetForm();\r\n this.isFormVisible = false;\r\n }\r\n\r\n onNoteHover(index: number): void {\r\n this.hoveredNoteIndex = index;\r\n }\r\n\r\n onNoteLeave(): void {\r\n this.hoveredNoteIndex = null;\r\n }\r\n\r\n onSubmit(): void {\r\n if (this.noteForm.invalid || !this.noteForm.get('sypn_title')?.value?.trim()) {\r\n return;\r\n }\r\n const formValue = this.noteForm.value;\r\n if (this.isEditing && this.editingNoteId) {\r\n console.log('formValue', this.appState.currentUser());\r\n const noteToUpdate: ICoreSypn = {\r\n _id: this.editingNoteId,\r\n sypn_title: formValue.sypn_title,\r\n sypn_desc: formValue.sypn_desc,\r\n sypn_page_id_sypg: this.pageId || \"\",\r\n sypn_user_id_user: this.appState.currentUser()?._id || \"\",\r\n sypn_entity_id_sype: this.appState.getActiveEntityId() || \"\",\r\n sypn_page_them_id_sytm: this.themeId || \"\",\r\n sypn_is_page_specific: formValue.sypn_is_page_specific,\r\n sypn_is_user_specific: formValue.sypn_is_user_specific,\r\n sypn_is_entity_specific: formValue.sypn_is_entity_specific,\r\n sypn_is_theme_specific: formValue.sypn_is_theme_specific,\r\n };\r\n this.notesService.updateNote(noteToUpdate).subscribe({\r\n next: () => {\r\n const currentNotes = this.notesSignal();\r\n const updatedNotes = currentNotes.map((note: ICoreSypn) =>\r\n note._id === this.editingNoteId ? noteToUpdate : note\r\n );\r\n this.notesSignal.set(updatedNotes);\r\n this.resetForm();\r\n this.isFormVisible = false;\r\n this.isEditing = false;\r\n this.editingNoteId = null;\r\n },\r\n error: (err: unknown) => console.error('Failed to update note', err)\r\n });\r\n } else {\r\n const noteToAdd: ICoreSypn = {\r\n sypn_title: formValue.sypn_title,\r\n sypn_desc: formValue.sypn_desc,\r\n sypn_page_id_sypg: this.pageId || \"\",\r\n sypn_user_id_user: this.appState.currentUser()?._id || \"\",\r\n sypn_entity_id_sype: this.appState.getActiveEntityId() || \"\",\r\n sypn_page_them_id_sytm: this.themeId || \"\",\r\n sypn_is_page_specific: formValue.sypn_is_page_specific,\r\n sypn_is_user_specific: formValue.sypn_is_user_specific,\r\n sypn_is_entity_specific: formValue.sypn_is_entity_specific,\r\n sypn_is_theme_specific: formValue.sypn_is_theme_specific,\r\n };\r\n this.notesService.addNote(noteToAdd).subscribe({\r\n next: (response: unknown) => {\r\n const responseData = response as { _id?: string; id?: string };\r\n const newNoteWithId: ICoreSypn = {\r\n ...noteToAdd,\r\n _id: responseData._id || responseData.id || Date.now().toString()\r\n };\r\n const currentNotes = this.notesSignal();\r\n this.notesSignal.set([newNoteWithId, ...currentNotes]);\r\n this.resetForm();\r\n this.isFormVisible = false;\r\n },\r\n error: (err: unknown) => console.error('Failed to add note', err)\r\n });\r\n }\r\n }\r\n\r\n private resetForm(): void {\r\n this.noteForm.reset({\r\n sypn_title: '',\r\n sypn_desc: '',\r\n sypn_is_page_specific: true,\r\n sypn_is_user_specific: true,\r\n sypn_is_entity_specific: false,\r\n sypn_is_theme_specific: false\r\n });\r\n }\r\n\r\n public getState() {\r\n return {\r\n newNoteModel: { ...(this.noteForm?.value ? this.noteForm?.value : {}) },\r\n isFormVisible: this.isFormVisible,\r\n };\r\n }\r\n\r\n public setState(state: NotesComponentState) {\r\n if (state) {\r\n this.noteForm.patchValue(state.newNoteModel);\r\n this.isFormVisible = state.isFormVisible;\r\n }\r\n }\r\n}","<div class=\"tw-relative tw-h-full tw-bg-white tw-overflow-hidden tw-flex tw-flex-col\">\r\n <!-- FIXED HEADER SECTION (ABSOLUTE POSITIONED) -->\r\n <div class=\"tw-bg-white tw-border-b tw-border-gray-200\">\r\n <!-- DYNAMIC HEADING -->\r\n <div class=\"tw-flex tw-justify-between tw-items-center tw-p-2 tw-bg-white tw-border-b tw-border-gray-200\">\r\n <h6 class=\"tw-font-semibold tw-text-gray-800\">\r\n {{ isFormVisible ? (isEditing ? 'Edit Note' : 'Add a New Note') : 'Notes' }}\r\n </h6>\r\n <button *ngIf=\"!isFormVisible\" (click)=\"showAddForm()\" cideEleButton variant=\"primary\"\r\n class=\"tw-p-2 !tw-w-7 !tw-px-0 !tw-rounded-full tw-animate-pulse\" title=\"Add New Note\">\r\n <!-- Using inline SVG for the plus icon for simplicity -->\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 24 24\" fill=\"none\"\r\n stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\r\n <line x1=\"12\" y1=\"5\" x2=\"12\" y2=\"19\"></line>\r\n <line x1=\"5\" y1=\"12\" x2=\"19\" y2=\"12\"></line>\r\n </svg>\r\n </button>\r\n </div>\r\n\r\n <!-- ADD NOTE FORM (ANIMATED WRAPPER) -->\r\n <div class=\"tw-transition-all tw-duration-300 tw-ease-in-out tw-animate-fade-in\" [class.tw-opacity-100]=\"isFormVisible\"\r\n [class.tw-opacity-0]=\"!isFormVisible\" [class.tw-max-h-0]=\"!isFormVisible\">\r\n <form [formGroup]=\"noteForm\" (ngSubmit)=\"onSubmit()\" class=\"tw-p-3 tw-space-y-4\" *ngIf=\"isFormVisible\">\r\n <!-- Title Input -->\r\n <cide-ele-input name=\"sypn_title\" formControlName=\"sypn_title\" placeholder=\"Note Title\" label=\"Note Title\"\r\n [required]=\"true\" [type]=\"'text'\" class=\"tw-w-full tw-transition-all tw-duration-200 focus:tw-scale-[1.02]\"></cide-ele-input>\r\n\r\n <!-- Description Textarea -->\r\n <cide-ele-textarea placeholder=\"What's on your mind? (Optional)\" id=\"sypn_desc\" formControlName=\"sypn_desc\"\r\n rows=\"4\" label=\"Description\" class=\"tw-transition-all tw-duration-200 focus:tw-scale-[1.02]\"></cide-ele-textarea>\r\n\r\n <!-- Toggle Switches -->\r\n <div class=\"tw-grid tw-grid-cols-2 tw-gap-4\">\r\n <cide-ele-input [type]=\"'checkbox'\" formControlName=\"sypn_is_page_specific\" label=\"Page Specific\"\r\n class=\"tw-flex tw-items-center tw-space-x-2\"></cide-ele-input>\r\n\r\n <cide-ele-input [type]=\"'checkbox'\" formControlName=\"sypn_is_user_specific\" label=\"User Specific\"\r\n class=\"tw-flex tw-items-center tw-space-x-2\"></cide-ele-input>\r\n\r\n <cide-ele-input [type]=\"'checkbox'\" formControlName=\"sypn_is_entity_specific\" label=\"Entity Specific\"\r\n class=\"tw-flex tw-items-center tw-space-x-2\"></cide-ele-input>\r\n\r\n <cide-ele-input [type]=\"'checkbox'\" formControlName=\"sypn_is_theme_specific\" label=\"Theme Specific\"\r\n class=\"tw-flex tw-items-center tw-space-x-2\"></cide-ele-input>\r\n </div>\r\n\r\n <!-- Action Buttons -->\r\n <div class=\"tw-flex tw-space-x-3 tw-pt-4\">\r\n <button cideEleButton size=\"xs\" variant=\"primary\" type=\"submit\" [disabled]=\"noteForm.invalid\">\r\n {{ isEditing ? 'Update Note' : 'Add Note' }}\r\n </button>\r\n <button cideEleButton size=\"xs\" variant=\"secondary\" type=\"button\"\r\n (click)=\"isEditing ? cancelEdit() : hideAddForm()\">\r\n {{ isEditing ? 'Cancel Edit' : 'Cancel' }}\r\n </button>\r\n </div>\r\n </form>\r\n </div>\r\n </div>\r\n\r\n <!-- SCROLLABLE NOTES SECTION (BELOW FIXED HEADER) -->\r\n <div class=\"tw-overflow-y-auto tw-scroll-smooth notes-scroll-container\">\r\n <!-- Modern Angular v20 pattern: Use Signals directly -->\r\n <div class=\"\" *ngIf=\"notes() as notes; else loading\">\r\n <!-- Show notes if the array is not empty -->\r\n <div *ngIf=\"notes.length > 0; else noNotes\">\r\n <div *ngFor=\"let note of notes; let i = index\"\r\n class=\"tw-bg-white tw-border-b tw-border-gray-200 tw-p-4 tw-shadow-sm hover:tw-shadow-md tw-transition-all tw-duration-300 tw-ease-in-out tw-relative tw-transform hover:tw-translate-y-[-2px] hover:tw-shadow-lg\"\r\n (mouseenter)=\"onNoteHover(i)\" (mouseleave)=\"onNoteLeave()\">\r\n <!-- Edit Button (visible on hover) -->\r\n <button (click)=\"startEdit(note)\" [class.tw-opacity-100]=\"hoveredNoteIndex === i\"\r\n [class.tw-opacity-0]=\"hoveredNoteIndex !== i\"\r\n class=\"tw-absolute tw-top-2 tw-right-2 tw-transition-all tw-duration-200 tw-p-1 tw-rounded tw-bg-gray-100 hover:tw-bg-gray-200 hover:tw-scale-110 tw-z-10\"\r\n title=\"Edit Note\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"none\"\r\n stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\r\n <path d=\"M11 4H4a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h14a2 2 0 0 0 2-2v-7\"></path>\r\n <path d=\"m18.5 2.5 3 3L12 15l-4 1 1-4 9.5-9.5z\"></path>\r\n </svg>\r\n </button>\r\n\r\n <h6 class=\"tw-font-medium tw-text-gray-900 tw-mb-2 tw-pr-8\">{{ note.sypn_title }}</h6>\r\n <p class=\"tw-text-gray-600 tw-text-sm tw-mb-3\">{{ note.sypn_desc }}</p>\r\n <div class=\"tw-flex tw-flex-wrap tw-gap-2\">\r\n <span *ngIf=\"note.sypn_is_page_specific\"\r\n class=\"tw-px-2 tw-py-1 tw-bg-blue-100 tw-text-blue-800 tw-text-xs tw-rounded-full tw-transition-all tw-duration-200 hover:tw-scale-105 hover:tw-bg-blue-200\">Page Specific</span>\r\n <span *ngIf=\"note.sypn_is_user_specific\"\r\n class=\"tw-px-2 tw-py-1 tw-bg-green-100 tw-text-green-800 tw-text-xs tw-rounded-full tw-transition-all tw-duration-200 hover:tw-scale-105 hover:tw-bg-green-200\">User Specific</span>\r\n <span *ngIf=\"note.sypn_is_entity_specific\"\r\n class=\"tw-px-2 tw-py-1 tw-bg-purple-100 tw-text-purple-800 tw-text-xs tw-rounded-full tw-transition-all tw-duration-200 hover:tw-scale-105 hover:tw-bg-purple-200\">Entity\r\n Specific</span>\r\n <span *ngIf=\"note.sypn_is_theme_specific\"\r\n class=\"tw-px-2 tw-py-1 tw-bg-orange-100 tw-text-orange-800 tw-text-xs tw-rounded-full tw-transition-all tw-duration-200 hover:tw-scale-105 hover:tw-bg-orange-200\">Theme\r\n Specific</span>\r\n </div>\r\n <!-- <p class=\"note-date\">{{ note.createdAt | date:'short' }}</p> -->\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Template to show when there are no notes -->\r\n <ng-template #noNotes>\r\n <div class=\"tw-flex tw-flex-col tw-items-center tw-justify-center tw-p-8 tw-text-center\">\r\n <div class=\"tw-w-12 tw-h-12 tw-bg-gray-100 tw-rounded-full tw-flex tw-items-center tw-justify-center tw-mb-4 tw-animate-bounce\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 24 24\" fill=\"none\"\r\n stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"\r\n class=\"tw-text-gray-400\">\r\n <path d=\"M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z\"></path>\r\n <polyline points=\"14,2 14,8 20,8\"></polyline>\r\n <line x1=\"16\" y1=\"13\" x2=\"8\" y2=\"13\"></line>\r\n <line x1=\"16\" y1=\"17\" x2=\"8\" y2=\"17\"></line>\r\n <polyline points=\"10,9 9,9 8,9\"></polyline>\r\n </svg>\r\n </div>\r\n <p class=\"tw-text-gray-500 tw-mb-2\">No notes found.</p>\r\n <p class=\"tw-text-sm tw-text-gray-400\">Click the '+' to add one!</p>\r\n </div>\r\n </ng-template>\r\n\r\n <!-- Template to show while notes are loading -->\r\n <ng-template #loading>\r\n <div class=\"tw-flex tw-flex-col tw-items-center tw-justify-center tw-p-8\">\r\n <div class=\"tw-w-8 tw-h-8 tw-border-4 tw-border-blue-200 tw-border-t-blue-600 tw-rounded-full tw-animate-spin tw-mb-4\"></div>\r\n <p class=\"tw-text-gray-500 tw-text-sm\">Loading notes...</p>\r\n </div>\r\n </ng-template>\r\n </div>\r\n</div>"],"names":["i2"],"mappings":"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"}
1
+ {"version":3,"file":"cloud-ide-layout-sidedrawer-notes.component-DKBaKoE7.mjs","sources":["../../../projects/cloud-ide-layout/src/lib/layout/sidedrawer/sidedrawer-notes/sidedrawer-notes.service.ts","../../../projects/cloud-ide-layout/src/lib/layout/sidedrawer/cide-lyt-drawer-base.class.ts","../../../projects/cloud-ide-layout/src/lib/layout/sidedrawer/sidedrawer-notes/sidedrawer-notes.component.ts","../../../projects/cloud-ide-layout/src/lib/layout/sidedrawer/sidedrawer-notes/sidedrawer-notes.component.html"],"sourcesContent":["import { HttpClient } from '@angular/common/http';\r\nimport { Injectable, inject } from '@angular/core';\r\nimport { ICoreSypn, IPageNotesManagerCreateUpdateControllerRespoonse, IPageNotesManagerListControllerRespoonse, cidePath, coreRoutesUrl, hostManagerRoutesUrl } from 'cloud-ide-lms-model';\r\nimport { Observable, of } from 'rxjs';\r\nimport { map } from 'rxjs/operators';\r\n\r\n@Injectable({\r\n providedIn: 'root'\r\n})\r\nexport class CideLytDrawerNotesService {\r\n // Modern Angular v20 dependency injection pattern\r\n private http = inject(HttpClient);\r\n\r\n constructor() {\r\n // Modern Angular v20 pattern: Use constructor for initialization only\r\n }\r\n\r\n getNotes(): Observable<ICoreSypn[]> {\r\n const url = cidePath.join([\r\n hostManagerRoutesUrl.cideSuiteHost,\r\n coreRoutesUrl.module,\r\n coreRoutesUrl.systemPageNotesManager\r\n ]);\r\n return this.http.get<IPageNotesManagerListControllerRespoonse>(url).pipe(map((res) => res.data || []));\r\n }\r\n\r\n addNote(note: ICoreSypn): Observable<unknown> {\r\n const url = cidePath.join([\r\n hostManagerRoutesUrl.cideSuiteHost,\r\n coreRoutesUrl.module,\r\n coreRoutesUrl.systemPageNotesManager\r\n ]);\r\n return this.http.post<IPageNotesManagerCreateUpdateControllerRespoonse>(url, note).pipe(map((res) => res.data));\r\n }\r\n\r\n updateNote(note: ICoreSypn): Observable<unknown> {\r\n const url = cidePath.join([\r\n hostManagerRoutesUrl.cideSuiteHost,\r\n coreRoutesUrl.module,\r\n coreRoutesUrl.systemPageNotesManager\r\n ]);\r\n return this.http.post<IPageNotesManagerCreateUpdateControllerRespoonse>(url, note).pipe(map((res) => res.data));\r\n }\r\n\r\n deleteNote(noteId: string): Observable<unknown> {\r\n // Mock implementation: simulate deleting a note.\r\n console.log('Deleting note with ID:', noteId);\r\n return of({ success: true });\r\n }\r\n\r\n // Additional methods for updating and deleting notes could be added here.\r\n // You might also include error handling or more complex data manipulation.\r\n}","import { Directive, OnInit, inject } from '@angular/core';\r\nimport { CideLytSidedrawerService } from './sidedrawer.service';\r\n\r\n@Directive()\r\nexport abstract class CideLytDrawerBase implements OnInit {\r\n private _pageId: string | null = null;\r\n private _themeId: string | null = null;\r\n protected sidedrawerService = inject(CideLytSidedrawerService);\r\n\r\n ngOnInit(): void {\r\n // Automatically initialize context from the service\r\n const pageId = this.sidedrawerService.pageId;\r\n const themeId = this.sidedrawerService.themeId;\r\n if (pageId && themeId) {\r\n this.setContext(pageId, themeId);\r\n }\r\n this.afterContextInit();\r\n }\r\n\r\n // Child classes can override this for additional setup\r\n protected afterContextInit(): void {}\r\n\r\n setContext(pageId: string, themeId: string) {\r\n this._pageId = pageId;\r\n this._themeId = themeId;\r\n }\r\n\r\n get pageId(): string | null {\r\n return this._pageId;\r\n }\r\n\r\n get themeId(): string | null {\r\n return this._themeId;\r\n }\r\n\r\n protected getStorageKey(suffix: string): string {\r\n return `drawer_${suffix}_${this._pageId || 'unknown'}`;\r\n }\r\n} ","import { CommonModule } from '@angular/common';\r\nimport { Component, OnInit, inject, signal } from '@angular/core';\r\nimport { ReactiveFormsModule, FormBuilder, FormGroup } from '@angular/forms';\r\nimport { CideLytDrawerNotesService } from './sidedrawer-notes.service';\r\nimport { ICoreSypn } from 'cloud-ide-lms-model';\r\nimport { CideInputComponent } from 'cloud-ide-element';\r\nimport { CideEleButtonComponent } from 'cloud-ide-element';\r\nimport { CideTextareaComponent } from 'cloud-ide-element';\r\nimport { AppStateHelperService } from '../../../services/app-state/app-state-helper.service';\r\nimport { CideLytDrawerBase } from '../cide-lyt-drawer-base.class';\r\n\r\nexport interface NewNoteModel {\r\n title: string;\r\n description: string;\r\n isPageSpecific: boolean;\r\n isUserSpecific: boolean;\r\n isEntitySpecific: boolean;\r\n isThemeSpecific: boolean;\r\n}\r\n\r\nexport interface NotesComponentState {\r\n newNoteModel: NewNoteModel;\r\n isFormVisible: boolean;\r\n scrollTop: number;\r\n}\r\n\r\n@Component({\r\n selector: 'cide-lyt-sidedrawer-notes',\r\n standalone: true,\r\n imports: [CommonModule, ReactiveFormsModule, CideInputComponent, CideEleButtonComponent, CideTextareaComponent],\r\n templateUrl: './sidedrawer-notes.component.html',\r\n styleUrl: './sidedrawer-notes.component.css'\r\n})\r\nexport class CideLytSidedrawerNotesComponent extends CideLytDrawerBase implements OnInit {\r\n private notesSignal = signal<ICoreSypn[]>([]);\r\n notes = this.notesSignal.asReadonly();\r\n isFormVisible = false;\r\n isEditing = false;\r\n editingNoteId: string | null = null;\r\n hoveredNoteIndex: number | null = null;\r\n noteForm!: FormGroup;\r\n private notesService = inject(CideLytDrawerNotesService);\r\n private fb = inject(FormBuilder);\r\n private appState = inject(AppStateHelperService);\r\n\r\n override ngOnInit(): void {\r\n super.ngOnInit();\r\n this.initForm();\r\n this.notesService.getNotes().subscribe({\r\n next: (notes) => {\r\n this.notesSignal.set(notes);\r\n },\r\n error: (error) => {\r\n console.error('Error loading notes:', error);\r\n }\r\n });\r\n }\r\n\r\n protected override afterContextInit(): void {\r\n // Any additional setup after context is ready can go here\r\n }\r\n\r\n private initForm(): void {\r\n this.noteForm = this.fb.group({\r\n sypn_title: [''],\r\n sypn_desc: [''],\r\n sypn_is_page_specific: [true],\r\n sypn_is_user_specific: [true],\r\n sypn_is_entity_specific: [false],\r\n sypn_is_theme_specific: [false]\r\n });\r\n }\r\n\r\n showAddForm(): void {\r\n this.isFormVisible = true;\r\n }\r\n\r\n hideAddForm(): void {\r\n this.isFormVisible = false;\r\n this.isEditing = false;\r\n this.editingNoteId = null;\r\n }\r\n\r\n startEdit(note: ICoreSypn): void {\r\n this.isEditing = true;\r\n this.editingNoteId = note._id || '';\r\n this.noteForm.patchValue({\r\n sypn_title: note.sypn_title || '',\r\n sypn_desc: note.sypn_desc || '',\r\n sypn_is_page_specific: note.sypn_is_page_specific || false,\r\n sypn_is_user_specific: note.sypn_is_user_specific || false,\r\n sypn_is_entity_specific: note.sypn_is_entity_specific || false,\r\n sypn_is_theme_specific: note.sypn_is_theme_specific || false\r\n });\r\n this.isFormVisible = true;\r\n }\r\n\r\n cancelEdit(): void {\r\n this.isEditing = false;\r\n this.editingNoteId = null;\r\n this.resetForm();\r\n this.isFormVisible = false;\r\n }\r\n\r\n onNoteHover(index: number): void {\r\n this.hoveredNoteIndex = index;\r\n }\r\n\r\n onNoteLeave(): void {\r\n this.hoveredNoteIndex = null;\r\n }\r\n\r\n onSubmit(): void {\r\n if (this.noteForm.invalid || !this.noteForm.get('sypn_title')?.value?.trim()) {\r\n return;\r\n }\r\n const formValue = this.noteForm.value;\r\n if (this.isEditing && this.editingNoteId) {\r\n console.log('formValue', this.appState.currentUser());\r\n const noteToUpdate: ICoreSypn = {\r\n _id: this.editingNoteId,\r\n sypn_title: formValue.sypn_title,\r\n sypn_desc: formValue.sypn_desc,\r\n sypn_page_id_sypg: this.pageId || \"\",\r\n sypn_user_id_user: this.appState.currentUser()?._id || \"\",\r\n sypn_entity_id_sype: this.appState.getActiveEntityId() || \"\",\r\n sypn_page_them_id_sytm: this.themeId || \"\",\r\n sypn_is_page_specific: formValue.sypn_is_page_specific,\r\n sypn_is_user_specific: formValue.sypn_is_user_specific,\r\n sypn_is_entity_specific: formValue.sypn_is_entity_specific,\r\n sypn_is_theme_specific: formValue.sypn_is_theme_specific,\r\n };\r\n this.notesService.updateNote(noteToUpdate).subscribe({\r\n next: () => {\r\n const currentNotes = this.notesSignal();\r\n const updatedNotes = currentNotes.map((note: ICoreSypn) =>\r\n note._id === this.editingNoteId ? noteToUpdate : note\r\n );\r\n this.notesSignal.set(updatedNotes);\r\n this.resetForm();\r\n this.isFormVisible = false;\r\n this.isEditing = false;\r\n this.editingNoteId = null;\r\n },\r\n error: (err: unknown) => console.error('Failed to update note', err)\r\n });\r\n } else {\r\n const noteToAdd: ICoreSypn = {\r\n sypn_title: formValue.sypn_title,\r\n sypn_desc: formValue.sypn_desc,\r\n sypn_page_id_sypg: this.pageId || \"\",\r\n sypn_user_id_user: this.appState.currentUser()?._id || \"\",\r\n sypn_entity_id_sype: this.appState.getActiveEntityId() || \"\",\r\n sypn_page_them_id_sytm: this.themeId || \"\",\r\n sypn_is_page_specific: formValue.sypn_is_page_specific,\r\n sypn_is_user_specific: formValue.sypn_is_user_specific,\r\n sypn_is_entity_specific: formValue.sypn_is_entity_specific,\r\n sypn_is_theme_specific: formValue.sypn_is_theme_specific,\r\n };\r\n this.notesService.addNote(noteToAdd).subscribe({\r\n next: (response: unknown) => {\r\n const responseData = response as { _id?: string; id?: string };\r\n const newNoteWithId: ICoreSypn = {\r\n ...noteToAdd,\r\n _id: responseData._id || responseData.id || Date.now().toString()\r\n };\r\n const currentNotes = this.notesSignal();\r\n this.notesSignal.set([newNoteWithId, ...currentNotes]);\r\n this.resetForm();\r\n this.isFormVisible = false;\r\n },\r\n error: (err: unknown) => console.error('Failed to add note', err)\r\n });\r\n }\r\n }\r\n\r\n private resetForm(): void {\r\n this.noteForm.reset({\r\n sypn_title: '',\r\n sypn_desc: '',\r\n sypn_is_page_specific: true,\r\n sypn_is_user_specific: true,\r\n sypn_is_entity_specific: false,\r\n sypn_is_theme_specific: false\r\n });\r\n }\r\n\r\n public getState() {\r\n return {\r\n newNoteModel: { ...(this.noteForm?.value ? this.noteForm?.value : {}) },\r\n isFormVisible: this.isFormVisible,\r\n };\r\n }\r\n\r\n public setState(state: NotesComponentState) {\r\n if (state) {\r\n this.noteForm.patchValue(state.newNoteModel);\r\n this.isFormVisible = state.isFormVisible;\r\n }\r\n }\r\n}","<div class=\"tw-relative tw-h-full tw-bg-white tw-overflow-hidden tw-flex tw-flex-col\">\r\n <!-- FIXED HEADER SECTION (ABSOLUTE POSITIONED) -->\r\n <div class=\"tw-bg-white tw-border-b tw-border-gray-200\">\r\n <!-- DYNAMIC HEADING -->\r\n <div class=\"tw-flex tw-justify-between tw-items-center tw-p-2 tw-bg-white tw-border-b tw-border-gray-200\">\r\n <h6 class=\"tw-font-semibold tw-text-gray-800\">\r\n {{ isFormVisible ? (isEditing ? 'Edit Note' : 'Add a New Note') : 'Notes' }}\r\n </h6>\r\n <button *ngIf=\"!isFormVisible\" (click)=\"showAddForm()\" cideEleButton variant=\"primary\"\r\n class=\"tw-p-2 !tw-w-7 !tw-px-0 !tw-rounded-full tw-animate-pulse\" title=\"Add New Note\">\r\n <!-- Using inline SVG for the plus icon for simplicity -->\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 24 24\" fill=\"none\"\r\n stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\r\n <line x1=\"12\" y1=\"5\" x2=\"12\" y2=\"19\"></line>\r\n <line x1=\"5\" y1=\"12\" x2=\"19\" y2=\"12\"></line>\r\n </svg>\r\n </button>\r\n </div>\r\n\r\n <!-- ADD NOTE FORM (ANIMATED WRAPPER) -->\r\n <div class=\"tw-transition-all tw-duration-300 tw-ease-in-out tw-animate-fade-in\" [class.tw-opacity-100]=\"isFormVisible\"\r\n [class.tw-opacity-0]=\"!isFormVisible\" [class.tw-max-h-0]=\"!isFormVisible\">\r\n <form [formGroup]=\"noteForm\" (ngSubmit)=\"onSubmit()\" class=\"tw-p-3 tw-space-y-4\" *ngIf=\"isFormVisible\">\r\n <!-- Title Input -->\r\n <cide-ele-input name=\"sypn_title\" formControlName=\"sypn_title\" placeholder=\"Note Title\" label=\"Note Title\"\r\n [required]=\"true\" [type]=\"'text'\" class=\"tw-w-full tw-transition-all tw-duration-200 focus:tw-scale-[1.02]\"></cide-ele-input>\r\n\r\n <!-- Description Textarea -->\r\n <cide-ele-textarea placeholder=\"What's on your mind? (Optional)\" id=\"sypn_desc\" formControlName=\"sypn_desc\"\r\n rows=\"4\" label=\"Description\" class=\"tw-transition-all tw-duration-200 focus:tw-scale-[1.02]\"></cide-ele-textarea>\r\n\r\n <!-- Toggle Switches -->\r\n <div class=\"tw-grid tw-grid-cols-2 tw-gap-4\">\r\n <cide-ele-input [type]=\"'checkbox'\" formControlName=\"sypn_is_page_specific\" label=\"Page Specific\"\r\n class=\"tw-flex tw-items-center tw-space-x-2\"></cide-ele-input>\r\n\r\n <cide-ele-input [type]=\"'checkbox'\" formControlName=\"sypn_is_user_specific\" label=\"User Specific\"\r\n class=\"tw-flex tw-items-center tw-space-x-2\"></cide-ele-input>\r\n\r\n <cide-ele-input [type]=\"'checkbox'\" formControlName=\"sypn_is_entity_specific\" label=\"Entity Specific\"\r\n class=\"tw-flex tw-items-center tw-space-x-2\"></cide-ele-input>\r\n\r\n <cide-ele-input [type]=\"'checkbox'\" formControlName=\"sypn_is_theme_specific\" label=\"Theme Specific\"\r\n class=\"tw-flex tw-items-center tw-space-x-2\"></cide-ele-input>\r\n </div>\r\n\r\n <!-- Action Buttons -->\r\n <div class=\"tw-flex tw-space-x-3 tw-pt-4\">\r\n <button cideEleButton size=\"xs\" variant=\"primary\" type=\"submit\" [disabled]=\"noteForm.invalid\">\r\n {{ isEditing ? 'Update Note' : 'Add Note' }}\r\n </button>\r\n <button cideEleButton size=\"xs\" variant=\"secondary\" type=\"button\"\r\n (click)=\"isEditing ? cancelEdit() : hideAddForm()\">\r\n {{ isEditing ? 'Cancel Edit' : 'Cancel' }}\r\n </button>\r\n </div>\r\n </form>\r\n </div>\r\n </div>\r\n\r\n <!-- SCROLLABLE NOTES SECTION (BELOW FIXED HEADER) -->\r\n <div class=\"tw-overflow-y-auto tw-scroll-smooth notes-scroll-container\">\r\n <!-- Modern Angular v20 pattern: Use Signals directly -->\r\n <div class=\"\" *ngIf=\"notes() as notes; else loading\">\r\n <!-- Show notes if the array is not empty -->\r\n <div *ngIf=\"notes.length > 0; else noNotes\">\r\n <div *ngFor=\"let note of notes; let i = index\"\r\n class=\"tw-bg-white tw-border-b tw-border-gray-200 tw-p-4 tw-shadow-sm hover:tw-shadow-md tw-transition-all tw-duration-300 tw-ease-in-out tw-relative tw-transform hover:tw-translate-y-[-2px] hover:tw-shadow-lg\"\r\n (mouseenter)=\"onNoteHover(i)\" (mouseleave)=\"onNoteLeave()\">\r\n <!-- Edit Button (visible on hover) -->\r\n <button (click)=\"startEdit(note)\" [class.tw-opacity-100]=\"hoveredNoteIndex === i\"\r\n [class.tw-opacity-0]=\"hoveredNoteIndex !== i\"\r\n class=\"tw-absolute tw-top-2 tw-right-2 tw-transition-all tw-duration-200 tw-p-1 tw-rounded tw-bg-gray-100 hover:tw-bg-gray-200 hover:tw-scale-110 tw-z-10\"\r\n title=\"Edit Note\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"16\" viewBox=\"0 0 24 24\" fill=\"none\"\r\n stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\">\r\n <path d=\"M11 4H4a2 2 0 0 0-2 2v14a2 2 0 0 0 2 2h14a2 2 0 0 0 2-2v-7\"></path>\r\n <path d=\"m18.5 2.5 3 3L12 15l-4 1 1-4 9.5-9.5z\"></path>\r\n </svg>\r\n </button>\r\n\r\n <h6 class=\"tw-font-medium tw-text-gray-900 tw-mb-2 tw-pr-8\">{{ note.sypn_title }}</h6>\r\n <p class=\"tw-text-gray-600 tw-text-sm tw-mb-3\">{{ note.sypn_desc }}</p>\r\n <div class=\"tw-flex tw-flex-wrap tw-gap-2\">\r\n <span *ngIf=\"note.sypn_is_page_specific\"\r\n class=\"tw-px-2 tw-py-1 tw-bg-blue-100 tw-text-blue-800 tw-text-xs tw-rounded-full tw-transition-all tw-duration-200 hover:tw-scale-105 hover:tw-bg-blue-200\">Page Specific</span>\r\n <span *ngIf=\"note.sypn_is_user_specific\"\r\n class=\"tw-px-2 tw-py-1 tw-bg-green-100 tw-text-green-800 tw-text-xs tw-rounded-full tw-transition-all tw-duration-200 hover:tw-scale-105 hover:tw-bg-green-200\">User Specific</span>\r\n <span *ngIf=\"note.sypn_is_entity_specific\"\r\n class=\"tw-px-2 tw-py-1 tw-bg-purple-100 tw-text-purple-800 tw-text-xs tw-rounded-full tw-transition-all tw-duration-200 hover:tw-scale-105 hover:tw-bg-purple-200\">Entity\r\n Specific</span>\r\n <span *ngIf=\"note.sypn_is_theme_specific\"\r\n class=\"tw-px-2 tw-py-1 tw-bg-orange-100 tw-text-orange-800 tw-text-xs tw-rounded-full tw-transition-all tw-duration-200 hover:tw-scale-105 hover:tw-bg-orange-200\">Theme\r\n Specific</span>\r\n </div>\r\n <!-- <p class=\"note-date\">{{ note.createdAt | date:'short' }}</p> -->\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <!-- Template to show when there are no notes -->\r\n <ng-template #noNotes>\r\n <div class=\"tw-flex tw-flex-col tw-items-center tw-justify-center tw-p-8 tw-text-center\">\r\n <div class=\"tw-w-12 tw-h-12 tw-bg-gray-100 tw-rounded-full tw-flex tw-items-center tw-justify-center tw-mb-4 tw-animate-bounce\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 24 24\" fill=\"none\"\r\n stroke=\"currentColor\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\"\r\n class=\"tw-text-gray-400\">\r\n <path d=\"M14 2H6a2 2 0 0 0-2 2v16a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V8z\"></path>\r\n <polyline points=\"14,2 14,8 20,8\"></polyline>\r\n <line x1=\"16\" y1=\"13\" x2=\"8\" y2=\"13\"></line>\r\n <line x1=\"16\" y1=\"17\" x2=\"8\" y2=\"17\"></line>\r\n <polyline points=\"10,9 9,9 8,9\"></polyline>\r\n </svg>\r\n </div>\r\n <p class=\"tw-text-gray-500 tw-mb-2\">No notes found.</p>\r\n <p class=\"tw-text-sm tw-text-gray-400\">Click the '+' to add one!</p>\r\n </div>\r\n </ng-template>\r\n\r\n <!-- Template to show while notes are loading -->\r\n <ng-template #loading>\r\n <div class=\"tw-flex tw-flex-col tw-items-center tw-justify-center tw-p-8\">\r\n <div class=\"tw-w-8 tw-h-8 tw-border-4 tw-border-blue-200 tw-border-t-blue-600 tw-rounded-full tw-animate-spin tw-mb-4\"></div>\r\n <p class=\"tw-text-gray-500 tw-text-sm\">Loading notes...</p>\r\n </div>\r\n </ng-template>\r\n </div>\r\n</div>"],"names":["i2"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- export { A as AppStateHelperService, d as AppStateService, m as CacheManagerService, n as CideLytFileManagerService, o as CideLytFloatingEntityRightsSharingComponent, q as CideLytFloatingEntityRightsSharingService, g as CideLytSharedService, C as CideLytSharedWrapperComponent, c as CideLytThemeService, k as CideLytUserStatusService, f as CloudIdeLayoutComponent, e as CloudIdeLayoutService, h as ComponentContextService, j as CustomRouteReuseStrategy, E as ENVIRONMENT_CONFIG, N as NotificationSettingsService, R as RightsService, i as layoutControlPannelChildRoutes, l as layoutRoutes, p as processThemeVariable, s as setCSSVariable, t as themeFactory } from './cloud-ide-layout-cloud-ide-layout-BGVK8JFk.mjs';
1
+ export { A as AppStateHelperService, d as AppStateService, m as CacheManagerService, n as CideLytFileManagerService, o as CideLytFloatingEntityRightsSharingComponent, q as CideLytFloatingEntityRightsSharingService, g as CideLytSharedService, C as CideLytSharedWrapperComponent, c as CideLytThemeService, k as CideLytUserStatusService, f as CloudIdeLayoutComponent, e as CloudIdeLayoutService, h as ComponentContextService, j as CustomRouteReuseStrategy, E as ENVIRONMENT_CONFIG, N as NotificationSettingsService, R as RightsService, i as layoutControlPannelChildRoutes, l as layoutRoutes, p as processThemeVariable, s as setCSSVariable, t as themeFactory } from './cloud-ide-layout-cloud-ide-layout-TXOQ0tip.mjs';
2
2
  //# sourceMappingURL=cloud-ide-layout.mjs.map
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "cloud-ide-layout",
3
- "version": "1.0.166",
3
+ "version": "1.0.168",
4
4
  "peerDependencies": {
5
5
  "@angular/common": "^20.1.0",
6
6
  "@angular/core": "^20.1.0",
@@ -142,16 +142,24 @@
142
142
 
143
143
  /* :root defines variables available globally */
144
144
  :root {
145
- /* Responsive font scale factor - base is 1.0 (desktop) */
146
- --cide-lyt-font-responsive-scale: 1.0;
145
+ /* Responsive font scale factor - base is 1.0 (desktop), can be overridden by theme */
146
+ --cide-lyt-font-responsive-scale: var(--cide-lyt-font-responsive-scale-base, 1.0);
147
147
 
148
- /* 1. TYPOGRAPHIC SCALE */
149
- --cide-theme-font-size-xs: 0.72rem; /* 11.52px */
150
- --cide-theme-font-size-sm: 0.8rem; /* 12.8px */
151
- --cide-theme-font-size-lg: 1.25rem; /* 20px */
152
- --cide-theme-font-size-xl: 1.563rem; /* 25px */
153
- --cide-theme-font-size-xxl: 1.953rem; /* 31.25px */
154
- --cide-theme-font-size-xxxl: 2.441rem; /* 39.06px */
148
+ /* 1. TYPOGRAPHIC SCALE - Base values for desktop (can be overridden by theme) */
149
+ --cide-theme-font-size-xs-base: 0.72rem; /* 11.52px */
150
+ --cide-theme-font-size-sm-base: 0.8rem; /* 12.8px */
151
+ --cide-theme-font-size-lg-base: 1.25rem; /* 20px */
152
+ --cide-theme-font-size-xl-base: 1.563rem; /* 25px */
153
+ --cide-theme-font-size-xxl-base: 1.953rem; /* 31.25px */
154
+ --cide-theme-font-size-xxxl-base: 2.441rem; /* 39.06px */
155
+
156
+ /* 1. TYPOGRAPHIC SCALE - Actual values for desktop (use base values, multiplied by scale) */
157
+ --cide-theme-font-size-xs: calc(var(--cide-theme-font-size-xs-base) * var(--cide-lyt-font-responsive-scale));
158
+ --cide-theme-font-size-sm: calc(var(--cide-theme-font-size-sm-base) * var(--cide-lyt-font-responsive-scale));
159
+ --cide-theme-font-size-lg: calc(var(--cide-theme-font-size-lg-base) * var(--cide-lyt-font-responsive-scale));
160
+ --cide-theme-font-size-xl: calc(var(--cide-theme-font-size-xl-base) * var(--cide-lyt-font-responsive-scale));
161
+ --cide-theme-font-size-xxl: calc(var(--cide-theme-font-size-xxl-base) * var(--cide-lyt-font-responsive-scale));
162
+ --cide-theme-font-size-xxxl: calc(var(--cide-theme-font-size-xxxl-base) * var(--cide-lyt-font-responsive-scale));
155
163
 
156
164
  /* 2. FONT WEIGHTS */
157
165
  --cide-theme-font-weight-regular: 400;
@@ -166,48 +174,72 @@
166
174
  /* Small Mobile Devices (< 480px) - Font scaling */
167
175
  @media screen and (max-width: 479px) {
168
176
  :root {
169
- // Use theme font scale if available, otherwise default to 0.875
170
- --cide-lyt-font-responsive-scale: var(--cide-lyt-font-responsive-scale-sm, 0.875);
177
+ /* Media-specific base font sizes for small mobile (can be overridden by theme) */
178
+ --cide-theme-font-size-xs-base-sm: var(--cide-theme-font-size-xs-base-sm, 0.63rem); /* 10.08px */
179
+ --cide-theme-font-size-sm-base-sm: var(--cide-theme-font-size-sm-base-sm, 0.7rem); /* 11.2px */
180
+ --cide-theme-font-size-lg-base-sm: var(--cide-theme-font-size-lg-base-sm, 1.1rem); /* 17.6px */
181
+ --cide-theme-font-size-xl-base-sm: var(--cide-theme-font-size-xl-base-sm, 1.375rem); /* 22px */
182
+ --cide-theme-font-size-xxl-base-sm: var(--cide-theme-font-size-xxl-base-sm, 1.71875rem); /* 27.5px */
183
+ --cide-theme-font-size-xxxl-base-sm: var(--cide-theme-font-size-xxxl-base-sm, 2.1484375rem); /* 34.375px */
184
+
185
+ /* Use theme scale (same across all media queries) - defaults to base scale if not set */
186
+ --cide-lyt-font-responsive-scale: var(--cide-lyt-font-responsive-scale-base, 1.0);
171
187
 
172
- /* Typographic scale - scaled down using theme scale */
173
- --cide-theme-font-size-xs: calc(0.72rem * var(--cide-lyt-font-responsive-scale));
174
- --cide-theme-font-size-sm: calc(0.8rem * var(--cide-lyt-font-responsive-scale));
175
- --cide-theme-font-size-lg: calc(1.25rem * var(--cide-lyt-font-responsive-scale));
176
- --cide-theme-font-size-xl: calc(1.563rem * var(--cide-lyt-font-responsive-scale));
177
- --cide-theme-font-size-xxl: calc(1.953rem * var(--cide-lyt-font-responsive-scale));
178
- --cide-theme-font-size-xxxl: calc(2.441rem * var(--cide-lyt-font-responsive-scale));
188
+ /* Typographic scale - media base font size multiplied by theme scale */
189
+ --cide-theme-font-size-xs: calc(var(--cide-theme-font-size-xs-base-sm) * var(--cide-lyt-font-responsive-scale));
190
+ --cide-theme-font-size-sm: calc(var(--cide-theme-font-size-sm-base-sm) * var(--cide-lyt-font-responsive-scale));
191
+ --cide-theme-font-size-lg: calc(var(--cide-theme-font-size-lg-base-sm) * var(--cide-lyt-font-responsive-scale));
192
+ --cide-theme-font-size-xl: calc(var(--cide-theme-font-size-xl-base-sm) * var(--cide-lyt-font-responsive-scale));
193
+ --cide-theme-font-size-xxl: calc(var(--cide-theme-font-size-xxl-base-sm) * var(--cide-lyt-font-responsive-scale));
194
+ --cide-theme-font-size-xxxl: calc(var(--cide-theme-font-size-xxxl-base-sm) * var(--cide-lyt-font-responsive-scale));
179
195
  }
180
196
  }
181
197
 
182
198
  /* Mobile Devices (480px - 640px) - Font scaling */
183
199
  @media screen and (min-width: 480px) and (max-width: 640px) {
184
200
  :root {
185
- // Use theme font scale if available, otherwise default to 0.9
186
- --cide-lyt-font-responsive-scale: var(--cide-lyt-font-responsive-scale-md, 0.9);
201
+ /* Media-specific base font sizes for medium mobile (can be overridden by theme) */
202
+ --cide-theme-font-size-xs-base-md: var(--cide-theme-font-size-xs-base-md, 0.65rem); /* 10.4px */
203
+ --cide-theme-font-size-sm-base-md: var(--cide-theme-font-size-sm-base-md, 0.72rem); /* 11.52px */
204
+ --cide-theme-font-size-lg-base-md: var(--cide-theme-font-size-lg-base-md, 1.125rem); /* 18px */
205
+ --cide-theme-font-size-xl-base-md: var(--cide-theme-font-size-xl-base-md, 1.40625rem); /* 22.5px */
206
+ --cide-theme-font-size-xxl-base-md: var(--cide-theme-font-size-xxl-base-md, 1.7578125rem); /* 28.125px */
207
+ --cide-theme-font-size-xxxl-base-md: var(--cide-theme-font-size-xxxl-base-md, 2.197265625rem); /* 35.15625px */
187
208
 
188
- /* Typographic scale - scaled down using theme scale */
189
- --cide-theme-font-size-xs: calc(0.72rem * var(--cide-lyt-font-responsive-scale));
190
- --cide-theme-font-size-sm: calc(0.8rem * var(--cide-lyt-font-responsive-scale));
191
- --cide-theme-font-size-lg: calc(1.25rem * var(--cide-lyt-font-responsive-scale));
192
- --cide-theme-font-size-xl: calc(1.563rem * var(--cide-lyt-font-responsive-scale));
193
- --cide-theme-font-size-xxl: calc(1.953rem * var(--cide-lyt-font-responsive-scale));
194
- --cide-theme-font-size-xxxl: calc(2.441rem * var(--cide-lyt-font-responsive-scale));
209
+ /* Use theme scale (same across all media queries) - defaults to base scale if not set */
210
+ --cide-lyt-font-responsive-scale: var(--cide-lyt-font-responsive-scale-base, 1.0);
211
+
212
+ /* Typographic scale - media base font size multiplied by theme scale */
213
+ --cide-theme-font-size-xs: calc(var(--cide-theme-font-size-xs-base-md) * var(--cide-lyt-font-responsive-scale));
214
+ --cide-theme-font-size-sm: calc(var(--cide-theme-font-size-sm-base-md) * var(--cide-lyt-font-responsive-scale));
215
+ --cide-theme-font-size-lg: calc(var(--cide-theme-font-size-lg-base-md) * var(--cide-lyt-font-responsive-scale));
216
+ --cide-theme-font-size-xl: calc(var(--cide-theme-font-size-xl-base-md) * var(--cide-lyt-font-responsive-scale));
217
+ --cide-theme-font-size-xxl: calc(var(--cide-theme-font-size-xxl-base-md) * var(--cide-lyt-font-responsive-scale));
218
+ --cide-theme-font-size-xxxl: calc(var(--cide-theme-font-size-xxxl-base-md) * var(--cide-lyt-font-responsive-scale));
195
219
  }
196
220
  }
197
221
 
198
222
  /* Tablet Devices (641px - 1024px) - Font scaling */
199
223
  @media screen and (min-width: 641px) and (max-width: 1024px) {
200
224
  :root {
201
- // Use theme font scale if available, otherwise default to 0.95
202
- --cide-lyt-font-responsive-scale: var(--cide-lyt-font-responsive-scale-lg, 0.95);
225
+ /* Media-specific base font sizes for tablet (can be overridden by theme) */
226
+ --cide-theme-font-size-xs-base-lg: var(--cide-theme-font-size-xs-base-lg, 0.68rem); /* 10.88px */
227
+ --cide-theme-font-size-sm-base-lg: var(--cide-theme-font-size-sm-base-lg, 0.76rem); /* 12.16px */
228
+ --cide-theme-font-size-lg-base-lg: var(--cide-theme-font-size-lg-base-lg, 1.1875rem); /* 19px */
229
+ --cide-theme-font-size-xl-base-lg: var(--cide-theme-font-size-xl-base-lg, 1.484375rem); /* 23.75px */
230
+ --cide-theme-font-size-xxl-base-lg: var(--cide-theme-font-size-xxl-base-lg, 1.85546875rem); /* 29.6875px */
231
+ --cide-theme-font-size-xxxl-base-lg: var(--cide-theme-font-size-xxxl-base-lg, 2.3193359375rem); /* 37.109375px */
232
+
233
+ /* Use theme scale (same across all media queries) - defaults to base scale if not set */
234
+ --cide-lyt-font-responsive-scale: var(--cide-lyt-font-responsive-scale-base, 1.0);
203
235
 
204
- /* Typographic scale - slightly scaled down using theme scale */
205
- --cide-theme-font-size-xs: calc(0.72rem * var(--cide-lyt-font-responsive-scale));
206
- --cide-theme-font-size-sm: calc(0.8rem * var(--cide-lyt-font-responsive-scale));
207
- --cide-theme-font-size-lg: calc(1.25rem * var(--cide-lyt-font-responsive-scale));
208
- --cide-theme-font-size-xl: calc(1.563rem * var(--cide-lyt-font-responsive-scale));
209
- --cide-theme-font-size-xxl: calc(1.953rem * var(--cide-lyt-font-responsive-scale));
210
- --cide-theme-font-size-xxxl: calc(2.441rem * var(--cide-lyt-font-responsive-scale));
236
+ /* Typographic scale - media base font size multiplied by theme scale */
237
+ --cide-theme-font-size-xs: calc(var(--cide-theme-font-size-xs-base-lg) * var(--cide-lyt-font-responsive-scale));
238
+ --cide-theme-font-size-sm: calc(var(--cide-theme-font-size-sm-base-lg) * var(--cide-lyt-font-responsive-scale));
239
+ --cide-theme-font-size-lg: calc(var(--cide-theme-font-size-lg-base-lg) * var(--cide-lyt-font-responsive-scale));
240
+ --cide-theme-font-size-xl: calc(var(--cide-theme-font-size-xl-base-lg) * var(--cide-lyt-font-responsive-scale));
241
+ --cide-theme-font-size-xxl: calc(var(--cide-theme-font-size-xxl-base-lg) * var(--cide-lyt-font-responsive-scale));
242
+ --cide-theme-font-size-xxxl: calc(var(--cide-theme-font-size-xxxl-base-lg) * var(--cide-lyt-font-responsive-scale));
211
243
  }
212
244
  }
213
245