pgo-ui 1.0.0

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 (178) hide show
  1. package/README.md +195 -0
  2. package/dist/InputSearch-CHSoQ7GH.js +155 -0
  3. package/dist/favicon.ico +0 -0
  4. package/dist/index-B7ko30VS.js +5899 -0
  5. package/dist/index-BKsLeoKP.js +4781 -0
  6. package/dist/index-BeW0KHDT.js +34237 -0
  7. package/dist/index-DjwGqWIf.js +5086 -0
  8. package/dist/index-jnIKSPXM.js +4949 -0
  9. package/dist/index.es.js +58 -0
  10. package/dist/index.umd.js +111 -0
  11. package/dist/pgo-ui.css +1 -0
  12. package/package.json +99 -0
  13. package/src/App.vue +369 -0
  14. package/src/assets/fonts/Faruma.ttf +0 -0
  15. package/src/assets/logo.png +0 -0
  16. package/src/components/examples/AppBarExample.vue +100 -0
  17. package/src/components/examples/AvatarExample.vue +47 -0
  18. package/src/components/examples/BannerExample.vue +287 -0
  19. package/src/components/examples/BaseInputExample.vue +25 -0
  20. package/src/components/examples/BreadcrumbExample.vue +53 -0
  21. package/src/components/examples/CardExample.vue +77 -0
  22. package/src/components/examples/ChipExample.vue +225 -0
  23. package/src/components/examples/DatePickerExample.vue +31 -0
  24. package/src/components/examples/DropdownExample.vue +84 -0
  25. package/src/components/examples/EditorExample.vue +200 -0
  26. package/src/components/examples/ExpansionPanelExample.vue +42 -0
  27. package/src/components/examples/FileUploadExample.vue +40 -0
  28. package/src/components/examples/FormExample.vue +121 -0
  29. package/src/components/examples/HugeTest.vue +8 -0
  30. package/src/components/examples/LayoutContainerExample.vue +80 -0
  31. package/src/components/examples/ModalExample.vue +82 -0
  32. package/src/components/examples/NavDrawerExample.vue +171 -0
  33. package/src/components/examples/NumberFieldExample.vue +145 -0
  34. package/src/components/examples/RadioButtonExample.vue +161 -0
  35. package/src/components/examples/SearchExample.vue +322 -0
  36. package/src/components/examples/SelectExample.vue +121 -0
  37. package/src/components/examples/StackedTableViewExample.vue +53 -0
  38. package/src/components/examples/TabExample.vue +336 -0
  39. package/src/components/examples/TableExample.vue +228 -0
  40. package/src/components/examples/TextFieldExample.vue +181 -0
  41. package/src/components/examples/TextareaExample.vue +173 -0
  42. package/src/components/examples/ThemeToggle.vue +50 -0
  43. package/src/components/examples/TimelineExample.vue +66 -0
  44. package/src/components/examples/TipTapEditorExample.vue +20 -0
  45. package/src/components/examples/TooltipExample.vue +53 -0
  46. package/src/components/examples/VueDatePickerShowcase.vue +214 -0
  47. package/src/components/examples/_DatePickerExample.vue +33 -0
  48. package/src/components/examples/__FormExample.vue +77 -0
  49. package/src/components/index.ts +25 -0
  50. package/src/components/pgo/AppBar.vue +348 -0
  51. package/src/components/pgo/Avatar.vue +139 -0
  52. package/src/components/pgo/Banner.vue +300 -0
  53. package/src/components/pgo/Breadcrumb.vue +103 -0
  54. package/src/components/pgo/Button.vue +171 -0
  55. package/src/components/pgo/Card.vue +179 -0
  56. package/src/components/pgo/ConfirmationModel.vue +32 -0
  57. package/src/components/pgo/DataTable.vue +845 -0
  58. package/src/components/pgo/DatePicker/CalendarPanel.vue +43 -0
  59. package/src/components/pgo/DatePicker/__DatePicker.vue +122 -0
  60. package/src/components/pgo/DatePicker/types.ts +11 -0
  61. package/src/components/pgo/DatePicker/useCalendar.ts +39 -0
  62. package/src/components/pgo/DatePicker/useDatePicker.ts +31 -0
  63. package/src/components/pgo/Deprecated/ToastContainer.vue +51 -0
  64. package/src/components/pgo/Deprecated/ToastItem.vue +55 -0
  65. package/src/components/pgo/Dropdown.vue +296 -0
  66. package/src/components/pgo/DropdownItem.vue +40 -0
  67. package/src/components/pgo/Editor.vue +511 -0
  68. package/src/components/pgo/ExpansionPanel.vue +185 -0
  69. package/src/components/pgo/Footer.vue +39 -0
  70. package/src/components/pgo/HeroIcon.vue +124 -0
  71. package/src/components/pgo/LayoutContainer.vue +104 -0
  72. package/src/components/pgo/Main.vue +37 -0
  73. package/src/components/pgo/Modal.vue +261 -0
  74. package/src/components/pgo/NavDrawer.vue +127 -0
  75. package/src/components/pgo/NavDrawerItem.vue +161 -0
  76. package/src/components/pgo/NavigationDrawer.vue +850 -0
  77. package/src/components/pgo/OLDNavDrawer.vue +661 -0
  78. package/src/components/pgo/OldAppBar.vue +223 -0
  79. package/src/components/pgo/PApp.vue +102 -0
  80. package/src/components/pgo/Pagination.vue +242 -0
  81. package/src/components/pgo/Search copy.vue +310 -0
  82. package/src/components/pgo/Search.vue +411 -0
  83. package/src/components/pgo/StackedTableView.vue +167 -0
  84. package/src/components/pgo/Tab.vue +617 -0
  85. package/src/components/pgo/TestInput.vue +395 -0
  86. package/src/components/pgo/Timeline.vue +367 -0
  87. package/src/components/pgo/TimelineItem.vue +80 -0
  88. package/src/components/pgo/TipTapEditor.vue +315 -0
  89. package/src/components/pgo/Tooltip.NOTES.md +12 -0
  90. package/src/components/pgo/Tooltip.PROPS.md +21 -0
  91. package/src/components/pgo/Tooltip.vue +281 -0
  92. package/src/components/pgo/base/Base.vue +444 -0
  93. package/src/components/pgo/buttons/Chip.vue +324 -0
  94. package/src/components/pgo/buttons/ChipGroup.vue +224 -0
  95. package/src/components/pgo/buttons/Radio.vue +424 -0
  96. package/src/components/pgo/filters/FilterSection.vue +188 -0
  97. package/src/components/pgo/filters/Searchbar.vue +216 -0
  98. package/src/components/pgo/forms/DynamicForm.vue +45 -0
  99. package/src/components/pgo/forms/Form.vue +132 -0
  100. package/src/components/pgo/index.ts +89 -0
  101. package/src/components/pgo/inputs/Checkbox.vue +320 -0
  102. package/src/components/pgo/inputs/DatePicker.vue +395 -0
  103. package/src/components/pgo/inputs/FileUpload.vue +326 -0
  104. package/src/components/pgo/inputs/InputSearch.vue +194 -0
  105. package/src/components/pgo/inputs/NumberField.vue +243 -0
  106. package/src/components/pgo/inputs/Radio.vue +162 -0
  107. package/src/components/pgo/inputs/RadioGroup.vue +188 -0
  108. package/src/components/pgo/inputs/Select.vue +535 -0
  109. package/src/components/pgo/inputs/TextField.vue +194 -0
  110. package/src/components/pgo/inputs/Textarea.vue +181 -0
  111. package/src/index.js +81 -0
  112. package/src/main.js +12 -0
  113. package/src/pgo-components/__index.js +104 -0
  114. package/src/pgo-components/_index.js +31 -0
  115. package/src/pgo-components/assets/fonts/Faruma.ttf +0 -0
  116. package/src/pgo-components/assets/fonts/logo.png +0 -0
  117. package/src/pgo-components/composables/useTheme.js +10 -0
  118. package/src/pgo-components/directives/tooltip-directive.ts +393 -0
  119. package/src/pgo-components/lib/componentConfig.js +147 -0
  120. package/src/pgo-components/lib/core/composables/_useCalendar.ts +127 -0
  121. package/src/pgo-components/lib/core/composables/useDefaults.ts +15 -0
  122. package/src/pgo-components/lib/core/composables/useLanguageSelect.js +0 -0
  123. package/src/pgo-components/lib/core/composables/useRtl.ts +12 -0
  124. package/src/pgo-components/lib/core/defaults/createDefaults.ts +5 -0
  125. package/src/pgo-components/lib/core/defaults/defaults.ts +7 -0
  126. package/src/pgo-components/lib/core/rtl/rtl.ts +3 -0
  127. package/src/pgo-components/lib/core/rtl/setRtl.ts +19 -0
  128. package/src/pgo-components/lib/drawerState.ts +3 -0
  129. package/src/pgo-components/lib/i18n/defaultLables.js +71 -0
  130. package/src/pgo-components/lib/i18n/i18nPlugin.js +52 -0
  131. package/src/pgo-components/lib/i18n/useI18n.js +35 -0
  132. package/src/pgo-components/lib/index.ts +38 -0
  133. package/src/pgo-components/pages/Component.vue +7 -0
  134. package/src/pgo-components/pages/ComponentRenderer.vue +99 -0
  135. package/src/pgo-components/pages/Home.vue +125 -0
  136. package/src/pgo-components/pages/ListView.vue +372 -0
  137. package/src/pgo-components/pages/Page1.vue +296 -0
  138. package/src/pgo-components/pages/_Page1.vue +180 -0
  139. package/src/pgo-components/plugins/SnackBar.vue +251 -0
  140. package/src/pgo-components/plugins/SnackBarContainer.vue +53 -0
  141. package/src/pgo-components/plugins/SnackBarPlugin.ts +136 -0
  142. package/src/pgo-components/plugins/theme-plugin.js +114 -0
  143. package/src/pgo-components/plugins/types.ts +46 -0
  144. package/src/pgo-components/plugins/useSnackBar.js +11 -0
  145. package/src/pgo-components/plugins/useSnackBar.ts +21 -0
  146. package/src/pgo-components/plugins/validation-plugin.js +11 -0
  147. package/src/pgo-components/services/Entry.json +813 -0
  148. package/src/pgo-components/services/axios.js +54 -0
  149. package/src/pgo-components/services/data.json +90 -0
  150. package/src/pgo-components/services/person.json +260 -0
  151. package/src/pgo-components/services/toast.ts +44 -0
  152. package/src/pgo-components/styles/global.css +234 -0
  153. package/src/pgo-components/styles/reset.css +96 -0
  154. package/src/pgo-components/styles/tokens.css +18 -0
  155. package/src/pgo-components/styles/utilities/border-radius.css +57 -0
  156. package/src/pgo-components/styles/utilities/borders.css +85 -0
  157. package/src/pgo-components/styles/utilities/colors.css +38 -0
  158. package/src/pgo-components/styles/utilities/cursor.css +19 -0
  159. package/src/pgo-components/styles/utilities/display.css +78 -0
  160. package/src/pgo-components/styles/utilities/elevation.css +33 -0
  161. package/src/pgo-components/styles/utilities/flex.css +403 -0
  162. package/src/pgo-components/styles/utilities/float.css +41 -0
  163. package/src/pgo-components/styles/utilities/hover.css +9 -0
  164. package/src/pgo-components/styles/utilities/index.css +18 -0
  165. package/src/pgo-components/styles/utilities/opacity.css +27 -0
  166. package/src/pgo-components/styles/utilities/overflow.css +26 -0
  167. package/src/pgo-components/styles/utilities/palette.css +515 -0
  168. package/src/pgo-components/styles/utilities/position.css +14 -0
  169. package/src/pgo-components/styles/utilities/sizing.css +70 -0
  170. package/src/pgo-components/styles/utilities/spacing.css +578 -0
  171. package/src/pgo-components/styles/utilities/transitions.css +58 -0
  172. package/src/pgo-components/styles/utilities/typography.css +91 -0
  173. package/src/pgo-components/styles/utilities/z-index.css +11 -0
  174. package/src/pgo-components/tokens/index.js +337 -0
  175. package/src/router/index.js +88 -0
  176. package/src/shims-vue.d.ts +14 -0
  177. package/src/validations/validationRules.js +50 -0
  178. package/tailwind.config.js +73 -0
package/package.json ADDED
@@ -0,0 +1,99 @@
1
+ {
2
+ "name": "pgo-ui",
3
+ "version": "1.0.0",
4
+ "description": "A Vue 3 component library with PGO design system",
5
+ "private": false,
6
+ "type": "module",
7
+ "engines": {
8
+ "node": "^20.19.0 || >=22.12.0"
9
+ },
10
+ "main": "./dist/index.umd.js",
11
+ "module": "./dist/index.es.js",
12
+ "exports": {
13
+ ".": {
14
+ "import": "./dist/index.es.js",
15
+ "require": "./dist/index.umd.js"
16
+ },
17
+ "./style.css": {
18
+ "import": "./dist/pgo-ui.css",
19
+ "style": "./dist/pgo-ui.css"
20
+ },
21
+ "./pgoIndex.js": {
22
+ "import": "./src/index.js"
23
+ },
24
+ "./validations": {
25
+ "import": "./src/validations/validationRules.js"
26
+ },
27
+ "./components/*": {
28
+ "import": "./src/components/pgo/*.vue"
29
+ },
30
+ "./examples/*": {
31
+ "import": "./src/components/examples/*.vue"
32
+ }
33
+ },
34
+ "files": [
35
+ "dist",
36
+ "src",
37
+ "tailwind.config.js",
38
+ "README.md"
39
+ ],
40
+ "scripts": {
41
+ "dev": "vite",
42
+ "build": "vite build",
43
+ "preview": "vite preview"
44
+ },
45
+ "dependencies": {
46
+ "@heroicons/vue": "^2.2.0",
47
+ "@tailwindcss/vite": "^4.1.17",
48
+ "@tiptap/extension-character-count": "^3.13.0",
49
+ "@tiptap/extension-table": "^3.13.0",
50
+ "@tiptap/extension-table-cell": "^3.13.0",
51
+ "@tiptap/extension-table-header": "^3.13.0",
52
+ "@tiptap/extension-table-row": "^3.13.0",
53
+ "@tiptap/extension-text-align": "^3.13.0",
54
+ "@tiptap/pm": "^3.13.0",
55
+ "@tiptap/starter-kit": "^3.13.0",
56
+ "@tiptap/vue-3": "^3.13.0",
57
+ "@vuepic/vue-datepicker": "^12.1.0",
58
+ "@vueuse/components": "^14.0.0",
59
+ "@vueuse/core": "^14.0.0",
60
+ "axios": "^1.13.2",
61
+ "date-fns": "^4.1.0",
62
+ "vue": "^3.5.22",
63
+ "vue3-tailwind-components": "^0.3.3"
64
+ },
65
+ "devDependencies": {
66
+ "@vitejs/plugin-vue": "^6.0.1",
67
+ "autoprefixer": "^10.4.22",
68
+ "eslint": "^9.39.2",
69
+ "eslint-plugin-vue": "^10.6.2",
70
+ "postcss": "^8.5.6",
71
+ "sass-embedded": "^1.96.0",
72
+ "tailwindcss": "^4.1.17",
73
+ "typescript": "^5.9.3",
74
+ "vite": "^7.1.11",
75
+ "vite-plugin-dts": "^4.5.4",
76
+ "vite-plugin-vue-devtools": "^8.0.3",
77
+ "vue-router": "^4.6.4"
78
+ },
79
+ "peerDependencies": {
80
+ "vue": "^3.0.0",
81
+ "vue-router": "^4.0.0",
82
+ "tailwindcss": "^4.1.0"
83
+ },
84
+ "keywords": [
85
+ "vue",
86
+ "vue3",
87
+ "components",
88
+ "ui",
89
+ "pgo",
90
+ "tailwind",
91
+ "design-system"
92
+ ],
93
+ "author": "PGO",
94
+ "license": "MIT",
95
+ "repository": {
96
+ "type": "git",
97
+ "url": "https://github.com/Laamin95/ui.git"
98
+ }
99
+ }
package/src/App.vue ADDED
@@ -0,0 +1,369 @@
1
+ <template>
2
+ <div >
3
+ <PApp>
4
+ <!-- <AppBar :dense="false" :collapseOnScroll="true">
5
+ <div class="flex items-center px-4 h-full">
6
+ <button @click="toggleDrawer" class="mr-3">☰</button>
7
+ <h1 class="text-lg font-medium">My App</h1>
8
+ </div>
9
+ </AppBar> -->
10
+
11
+ <AppBar
12
+ id="appbar"
13
+ title="My Awesome Dashboard"
14
+ title-align="center"
15
+ title-class="text-lg font-bold text-indigo-600"
16
+ :drawer="true"
17
+ :menu="false"
18
+ fixed
19
+ :dense="isDense"
20
+ elevation="4"
21
+ border="border-b"
22
+ p="px-4"
23
+ :rtl="rtl || isRtl"
24
+ :overflow-actions="overflowActions"
25
+ :collapse-on-scroll="collapse"
26
+ :z-index="30"
27
+ custom-class="shadow-md"
28
+ @toggle-drawer="drawerOpen = !drawerOpen"
29
+ >
30
+ <!-- PREPEND -->
31
+ <template #prepend>
32
+ <button
33
+ class="md:inline-flex hidden items-center gap-1 px-3 py-1 rounded-md bg-indigo-100 hover:bg-indigo-200 text-indigo-700 dark:bg-indigo-900 dark:hover:bg-indigo-800"
34
+ >
35
+ <HeroIcon
36
+ name="home"
37
+ size="20"
38
+ />
39
+ ގެޔަށް
40
+ </button>
41
+ </template>
42
+
43
+ <!-- TITLE (custom slot) -->
44
+ <template #title>
45
+ <div class="flex items-center gap-2">
46
+ <HeroIcon
47
+ name="sparkles"
48
+ size="22"
49
+ class="text-yellow-500"
50
+ />
51
+ <span class="font-bold text-xl">ޕްރޮޖެކްޓުގެ ނަން</span>
52
+ </div>
53
+ </template>
54
+
55
+ <!-- NAV -->
56
+ <template #nav>
57
+ <button class="px-3 py-2 rounded-md hover:bg-gray-100 dark:hover:bg-slate-700">
58
+ އެއަށްފަސް
59
+ </button>
60
+ <button class="px-3 py-2 rounded-md hover:bg-gray-100 dark:hover:bg-slate-700">
61
+ ދެންއިން މެނޫ
62
+ </button>
63
+ <button class="px-3 py-2 rounded-md hover:bg-gray-100 dark:hover:bg-slate-700">
64
+ ފުރަތަމަ
65
+ </button>
66
+ </template>
67
+
68
+ <!-- ACTIONS -->
69
+ <template #actions>
70
+ <button class="p-2 rounded-full hover:bg-gray-100 dark:hover:bg-slate-700">
71
+ <HeroIcon
72
+ name="bell"
73
+ size="22"
74
+ />
75
+ </button>
76
+
77
+ <button class="hidden md:block p-2 rounded-full hover:bg-gray-100 dark:hover:bg-slate-700">
78
+ <HeroIcon
79
+ name="cog-6-tooth"
80
+ size="22"
81
+ />
82
+ </button>
83
+ </template>
84
+
85
+ <!-- APPEND -->
86
+ <template #append>
87
+ <button class="px-3 py-1 rounded-md bg-indigo-600 text-white hover:bg-indigo-700">
88
+ ލޮގްއައުޓް
89
+ </button>
90
+ </template>
91
+
92
+ <!-- MOBILE NAV -->
93
+ <template #mobile-nav>
94
+ <button class="block w-full px-3 py-2 rounded-md hover:bg-gray-100 dark:hover:bg-slate-700">
95
+ ޑޭޝްބޯޑު
96
+ </button>
97
+ <button class="block w-full px-3 py-2 rounded-md hover:bg-gray-100 dark:hover:bg-slate-700">
98
+ Analytics
99
+ </button>
100
+ <button class="block w-full px-3 py-2 rounded-md hover:bg-gray-100 dark:hover:bg-slate-700">
101
+ Users
102
+ </button>
103
+ </template>
104
+ </AppBar>
105
+
106
+ <NavigationDrawer
107
+ v-model="drawerOpen"
108
+ v-model:items="sampleItems"
109
+ :temporary="temporary"
110
+ :rail="rail"
111
+ :hover-expand="hoverExpand"
112
+ :persistent="persistent"
113
+ :permanent="permanent"
114
+ :location="location"
115
+ :is-stuck="isStuck"
116
+ :filterable="true"
117
+ :group-by="'group'"
118
+ ref="el"
119
+ :draggable="true"
120
+ search-placeholder="ހޯދާ"
121
+ :group-icons="{
122
+ އާންމު: 'home',
123
+ 'ތަފާސް ހިސާބު': 'document',
124
+ އެޑްމިން: 'cog'
125
+ }"
126
+ color="bg-blue-500"
127
+ width="w-64"
128
+ rail-width="w-16"
129
+ :close-on-scrim-click="true"
130
+ :overlay-app-bar="overlayAppBar"
131
+ :z-index="zIndex"
132
+ :app-bar-offset="appBarOffset"
133
+ >
134
+ <template #prepend>
135
+ <div class="px-3 py-2 text-sm font-semibold">
136
+ މިފިނި
137
+ </div>
138
+ </template>
139
+
140
+ <template #default>
141
+ <ul class="py-4">
142
+ <NavDrawerItem
143
+ class="px-4"
144
+ href="#/"
145
+ >
146
+ <HeroIcon
147
+ name="home"
148
+ size="20"
149
+ />
150
+ ޑޭޝްބޯޑް
151
+ </NavDrawerItem>
152
+ <NavDrawerItem
153
+ class="px-4"
154
+ href="/page/Person/listView"
155
+ >
156
+ <HeroIcon
157
+ name="user"
158
+ size="20"
159
+ />
160
+ މީހުން
161
+ </NavDrawerItem>
162
+ <NavDrawerItem
163
+ class="px-4"
164
+ href="#/reports"
165
+ >
166
+ <HeroIcon
167
+ name="document"
168
+ size="20"
169
+ />
170
+ ރިޕޯޓް
171
+ </NavDrawerItem>
172
+ <NavDrawerItem
173
+ class="px-4"
174
+ href="#/users"
175
+ >
176
+ <HeroIcon
177
+ name="cog"
178
+ size="20"
179
+ />
180
+ ސެޓިންގްސް
181
+ </NavDrawerItem>
182
+ </ul>
183
+ </template>
184
+
185
+ <!-- <template #footer>
186
+ </template> -->
187
+
188
+ </NavigationDrawer>
189
+
190
+ <Main>
191
+ <!-- CONTENT -->
192
+
193
+ <router-view />
194
+ </Main>
195
+
196
+ <!-- <Footer>
197
+ <div class="p-3 text-center">
198
+ © 2025 Footer Example
199
+ </div>
200
+ </Footer> -->
201
+ </PApp>
202
+ </div>
203
+ </template>
204
+
205
+ <script setup>
206
+ import { onMounted, ref, watch, inject, computed, toRaw } from 'vue'
207
+ import {PApp, AppBar, NavigationDrawer, Main, NavDrawerItem, Modal,} from './'
208
+ // import AppBar from './components/pgo/AppBar.vue'
209
+ //import Button from './components/pgo/Button.vue'
210
+ //import OldAppBar from './components/pgo/OldAppBar.vue'
211
+ //import NavigationDrawer from './components/pgo/NavigationDrawer.vue'
212
+ // import Main from './components/pgo/Main.vue'
213
+ // import Footer from './components/pgo/Footer.vue'
214
+ // import HeroIcon from "./components/pgo/HeroIcon.vue";
215
+ // import NavDrawer from "./components/pgo/NavDrawer.vue";
216
+ // import NavDrawerItem from "./components/pgo/NavDrawerItem.vue";
217
+ // import { globalRtl } from './pgo-components/lib/core/rtl/rtl.ts'
218
+ // import { setRtl } from './pgo-components/lib/core/rtl/setRtl.ts'
219
+ // import { drawerOpen } from './pgo-components/lib/drawerState.ts'
220
+
221
+
222
+ // import DatePickerExample from './components/examples/DatePickerExample.vue'
223
+ // import DatePickerExample from './components/examples/DatePickerExample.vue'
224
+
225
+ // import EditorExample from './components/examples/EditorExample.vue'
226
+ // import TipTapEditorExample from './components/examples/TipTapEditorExample.vue'
227
+
228
+ // import BreadcrumbExample from './components/examples/BreadcrumbExample.vue'
229
+ // import ModalExample from './components/examples/ModalExample.vue'
230
+
231
+ // import { useSnackBar } from './pgo-components/plugins/useSnackBar.js'
232
+
233
+ // import ThemeToggle from './components/examples/ThemeToggle.vue'
234
+ // import { useTheme } from './pgo-components/composables/useTheme.js'
235
+
236
+ // const theme = useTheme()
237
+
238
+ const globalRtl = inject('globalRtl')
239
+ // const setRtl = inject('setRtl')
240
+ const drawerOpen = inject('drawerOpen')
241
+
242
+ // function onClick() {
243
+ // alert('Clicked')
244
+ // }
245
+
246
+ const dataTheme = computed(() => document.documentElement.getAttribute('data-theme') || 'none')
247
+
248
+ const snackbar = inject('snackbar')
249
+
250
+ // const { t, setLanguage, language } = inject('i18n')
251
+
252
+ onMounted(() => {
253
+ // const savedRtl = localStorage.getItem('rtlSetting')
254
+ // console.log('savedRtl', savedRtl)
255
+ snackbar.show({ message: 'ވަރަށް', variant: 'warning' })
256
+
257
+ // snack.show({
258
+ // message: 'File deleted',
259
+ // // variant: 'info',
260
+ // actions: [{ label: 'Undo', onClick: () => { /* undo logic */ } }],
261
+ // })
262
+
263
+ // if (savedRtl !== null) {
264
+ // globalRtl.value = JSON.parse(savedRtl)
265
+ // setRtl(globalRtl.value)
266
+ // } else {
267
+ // globalRtl.value = true
268
+ // setRtl(globalRtl.value)
269
+ // }
270
+ })
271
+
272
+ // const drawerOpen = ref(true);
273
+ const drawerMode = ref('permanent')
274
+
275
+ function toggleDrawer() {
276
+ drawerOpen.value = !drawerOpen.value
277
+ }
278
+
279
+ const rtl = ref(false)
280
+ const isDense = ref(false)
281
+ const collapse = ref(false)
282
+
283
+ const overflowActions = [
284
+ {
285
+ label: 'Profile',
286
+ icon: 'UserIcon',
287
+ onClick: () => alert('Profile clicked')
288
+ },
289
+ {
290
+ label: 'Settings',
291
+ icon: 'Cog6ToothIcon',
292
+ onClick: () => alert('Settings clicked')
293
+ },
294
+ {
295
+ label: 'Sign out',
296
+ icon: 'ArrowRightStartOnRectangleIcon',
297
+ onClick: () => alert('Logout clicked')
298
+ }
299
+ ]
300
+
301
+ const temporary = ref(false)
302
+ const rail = ref(false)
303
+ const hoverExpand = ref(false)
304
+ const persistent = ref(false)
305
+ const permanent = ref(true)
306
+ const isStuck = ref(true)
307
+ const location = ref(globalRtl.value ? 'right' : 'left')
308
+ const overlayAppBar = ref(true)
309
+ const zIndex = ref(undefined)
310
+ const appBarOffset = ref(false)
311
+
312
+ const sampleItems = ref([
313
+ { id: 1, label: 'އެޑްމިން', href: '#/', group: 'އާންމު' },
314
+ { id: 2, label: "މީހުން", href: "/page/Person/listView", group: "އާންމު" },
315
+ { id: 2, label: "އެންޓްރީ", href: "/page/Entry/listView", group: "އާންމު" },
316
+ { id: 3, label: 'ރިޕޯޓް', href: '#/reports', group: 'ތަފާސް ހިސާބު' },
317
+ { id: 4, label: 'ސެޓިންގްސް', href: '#/settings', group: 'އެޑްމިން' }
318
+ ])
319
+
320
+ onMounted(() => {
321
+ const savedRtl = localStorage.getItem('rtlSetting')
322
+ if (savedRtl !== null) {
323
+ // Convert string to boolean
324
+ location.value = savedRtl === 'true' ? 'right' : 'left'
325
+ // console.log('Loaded saved RTL setting:', savedRtl)
326
+ } else {
327
+ // Fallback to globalRtl if no saved setting
328
+ location.value = globalRtl.value ? 'right' : 'left'
329
+ // console.log('No saved RTL setting, using globalRtl:', globalRtl.value)
330
+ }
331
+ })
332
+
333
+ // watch(globalRtl, () => {
334
+ // if (globalRtl.value) {
335
+ // location.value = 'right'
336
+ // rtl.value = true
337
+ // } else {
338
+ // location.value = 'left'
339
+ // rtl.value = false
340
+ // }
341
+ // })
342
+
343
+ const isRtl = ref(true)
344
+
345
+ onMounted(() => {
346
+ const savedRtl = localStorage.getItem('rtlSetting')
347
+ if (savedRtl !== null) {
348
+ isRtl.value = savedRtl === 'true'
349
+ } else {
350
+ isRtl.value = globalRtl.value
351
+ }
352
+ // console.log('Initial RTL setting on mount:', isRtl.value)
353
+ })
354
+
355
+ // watch(isRtl, v => {
356
+ // setRtl(v)
357
+ // if (isRtl.value == true) {
358
+ // setLanguage('dv')
359
+ // } else {
360
+ // setLanguage('en')
361
+ // }
362
+ // })
363
+ </script>
364
+
365
+ <style scoped>
366
+ #app {
367
+ min-height: 100vh;
368
+ }
369
+ </style>
Binary file
Binary file
@@ -0,0 +1,100 @@
1
+ <template>
2
+ <AppBar
3
+ title="އެޕްގެ ނަން"
4
+ title-align="center"
5
+ title-class="text-xl font-bold"
6
+ fixed
7
+ elevation="2"
8
+ drawer
9
+ :rtl="isRtl"
10
+ >
11
+ <!-- Prepend slot: logo -->
12
+ <template #prepend>
13
+ <img src="../../assets/logo.png" alt="Logo" class="h-8 w-8 mr-2" />
14
+ </template>
15
+
16
+ <!-- Main nav slot -->
17
+ <template #nav>
18
+ <!-- <a href="#" class="px-3 py-2 text-blue-700 hover:text-blue-900">Home</a> -->
19
+ </template>
20
+
21
+ <!-- Actions slot: buttons/icons -->
22
+ <template #actions>
23
+ <button class="p-2 rounded hover:bg-gray-100" @click="drawerOpen = !drawerOpen" aria-label="Toggle drawer">
24
+ <HeroIcon name="bars-3" size="20" color="text-blue-700" />
25
+ </button>
26
+ </template>
27
+
28
+ <!-- Append slot: custom icon -->
29
+ <template #append>
30
+ <!-- <HeroIcon name="bell" size="24" color="text-blue-700" /> -->
31
+ </template>
32
+
33
+ <!-- Mobile nav slot -->
34
+ <template #mobile-nav>
35
+ <a href="#" class="block px-3 py-2 text-blue-700">Home</a>
36
+ <a href="#" class="block px-3 py-2 text-blue-700">About</a>
37
+ <a href="#" class="block px-3 py-2 text-blue-700">Contact</a>
38
+ </template>
39
+ </AppBar>
40
+
41
+ <div class="flex pr-100 pl-100 gap-2">
42
+ <label class="inline-flex items-center gap-2">
43
+ <input type="checkbox" v-model="isRtl" class="form-checkbox" />
44
+ <span class="text-sm text-gray-700">RTL</span>
45
+ </label>
46
+ <div class="flex gap-2">
47
+ <Button :color="language === 'en'? 'primary': 'gray'" @click="$setLanguage('en')">English</Button>
48
+ <Button class="faruma" :color="language =='dv'? 'primary': 'gray'" @click="$setLanguage('dv')">ދިވެހި</Button>
49
+ </div>
50
+ <p>Current language: {{ language }}</p>
51
+ </div>
52
+ </template>
53
+
54
+ <script setup>
55
+ import AppBar from "../pgo/AppBar.vue";
56
+ // import HeroIcon from "../pgo/HeroIcon.vue";
57
+ import { ref, watch, inject, onMounted } from "vue";
58
+ import { drawerOpen } from '../../pgo-components/lib/drawerState';
59
+ const setRtl = inject('setRtl')
60
+ const { t, setLanguage, language } = inject('i18n')
61
+
62
+ // const overflowActions = [
63
+ // {
64
+ // label: "Settings",
65
+ // icon: null, // You can use an icon component here
66
+ // onClick: () => alert("Settings clicked"),
67
+ // },
68
+ // {
69
+ // label: "Profile",
70
+ // icon: null,
71
+ // onClick: () => alert("Profile clicked"),
72
+ // },
73
+ // {
74
+ // label: "Logout",
75
+ // icon: null,
76
+ // onClick: () => alert("Logout clicked"),
77
+ // },
78
+ // ];
79
+ const isRtl = ref(true);
80
+
81
+ onMounted(() => {
82
+ const savedRtl = localStorage.getItem('rtlSetting');
83
+ if (savedRtl !== null) {
84
+ isRtl.value = savedRtl === 'true';
85
+ } else {
86
+ isRtl.value = globalRtl.value;
87
+ }
88
+ console.log("Initial RTL setting on mount:", isRtl.value);
89
+ });
90
+
91
+ watch(isRtl, (v) => {
92
+ setRtl(v);
93
+ if (isRtl.value == true) {
94
+ setLanguage('dv')
95
+ } else {
96
+ setLanguage('en')
97
+ }
98
+ });
99
+
100
+ </script>
@@ -0,0 +1,47 @@
1
+ <template>
2
+ <div class="grid place-items-center space-y-6 p-6">
3
+ <h2 class="text-xl font-semibold mb-2 text-center">Avatar Example Usage</h2>
4
+
5
+ <!-- Row: image + initials -->
6
+ <div class="flex items-center gap-8">
7
+ <Avatar src="https://i.pravatar.cc/100?img=5" alt="Alice" />
8
+ <Avatar text="Ahmed Shareef" :bordered="true" />
9
+ <Avatar text="P G O" size="lg" shape="rounded" :bordered="true" />
10
+ <Avatar text="UI" size="xl" :bordered="true" />
11
+ </div>
12
+
13
+ <!-- Shapes -->
14
+ <div class="flex items-center gap-8">
15
+ <Avatar text="CS" shape="circular" :bordered="true" />
16
+ <Avatar text="CS" shape="rounded" :bordered="true" />
17
+ <Avatar text="CS" shape="square" :bordered="true" />
18
+ </div>
19
+
20
+ <!-- Sizes -->
21
+ <div class="flex items-center gap-8">
22
+ <Avatar text="xs" size="xs" :bordered="true" />
23
+ <Avatar text="sm" size="sm" :bordered="true" />
24
+ <Avatar text="md" size="md" :bordered="true" />
25
+ <Avatar text="lg" size="lg" :bordered="true" />
26
+ <Avatar text="xl" size="xl" :bordered="true" />
27
+ </div>
28
+
29
+ <!-- Status -->
30
+ <!-- <div class="flex items-center gap-4">
31
+ <Avatar text="ON" status="online" />
32
+ <Avatar text="AW" status="away" />
33
+ <Avatar text="BZ" status="busy" />
34
+ <Avatar text="OF" status="offline" />
35
+ </div> -->
36
+
37
+ <!-- Disabled + Bordered -->
38
+ <!-- <div class="flex items-center gap-4">
39
+ <Avatar text="DB" :bordered="true" :disabled="true" />
40
+ <Avatar src="https://i.pravatar.cc/100?img=8" :bordered="true" />
41
+ </div> -->
42
+ </div>
43
+ </template>
44
+
45
+ <script setup lang="ts">
46
+ import Avatar from '../pgo/Avatar.vue'
47
+ </script>