oip-common 0.0.1

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 (127) hide show
  1. package/README.md +25 -0
  2. package/ng-package.json +8 -0
  3. package/package.json +16 -0
  4. package/src/api/FolderModule.ts +124 -0
  5. package/src/api/Menu.ts +134 -0
  6. package/src/api/Module.ts +92 -0
  7. package/src/api/Security.ts +40 -0
  8. package/src/api/Service.ts +57 -0
  9. package/src/api/data-contracts.ts +186 -0
  10. package/src/api/http-client.ts +276 -0
  11. package/src/assets/demo/code.scss +17 -0
  12. package/src/assets/demo/data/products-small.json +124 -0
  13. package/src/assets/demo/demo.scss +2 -0
  14. package/src/assets/demo/flags/flags.scss +740 -0
  15. package/src/assets/demo/flags/flags_responsive.png +0 -0
  16. package/src/assets/demo/images/access/asset-access.svg +46 -0
  17. package/src/assets/demo/images/blocks/hero/hero-1.png +0 -0
  18. package/src/assets/demo/images/blocks/logos/hyper.svg +3 -0
  19. package/src/assets/demo/images/error/asset-error.svg +74 -0
  20. package/src/assets/demo/images/flag/flag_placeholder.png +0 -0
  21. package/src/assets/demo/images/product/bamboo-watch.jpg +0 -0
  22. package/src/assets/demo/images/product/black-watch.jpg +0 -0
  23. package/src/assets/demo/images/product/blue-band.jpg +0 -0
  24. package/src/assets/demo/images/product/blue-t-shirt.jpg +0 -0
  25. package/src/assets/demo/images/product/bracelet.jpg +0 -0
  26. package/src/assets/demo/images/product/brown-purse.jpg +0 -0
  27. package/src/assets/demo/images/product/chakra-bracelet.jpg +0 -0
  28. package/src/assets/demo/images/product/galaxy-earrings.jpg +0 -0
  29. package/src/assets/demo/images/product/game-controller.jpg +0 -0
  30. package/src/assets/demo/images/product/gaming-set.jpg +0 -0
  31. package/src/assets/demo/images/product/gold-phone-case.jpg +0 -0
  32. package/src/assets/demo/images/product/green-earbuds.jpg +0 -0
  33. package/src/assets/demo/images/product/green-t-shirt.jpg +0 -0
  34. package/src/assets/demo/images/product/grey-t-shirt.jpg +0 -0
  35. package/src/assets/demo/images/product/headphones.jpg +0 -0
  36. package/src/assets/demo/images/product/light-green-t-shirt.jpg +0 -0
  37. package/src/assets/demo/images/product/lime-band.jpg +0 -0
  38. package/src/assets/demo/images/product/mini-speakers.jpg +0 -0
  39. package/src/assets/demo/images/product/painted-phone-case.jpg +0 -0
  40. package/src/assets/demo/images/product/pink-band.jpg +0 -0
  41. package/src/assets/demo/images/product/pink-purse.jpg +0 -0
  42. package/src/assets/demo/images/product/product-placeholder.svg +10 -0
  43. package/src/assets/demo/images/product/purple-band.jpg +0 -0
  44. package/src/assets/demo/images/product/purple-gemstone-necklace.jpg +0 -0
  45. package/src/assets/demo/images/product/purple-t-shirt.jpg +0 -0
  46. package/src/assets/demo/images/product/shoes.jpg +0 -0
  47. package/src/assets/demo/images/product/sneakers.jpg +0 -0
  48. package/src/assets/demo/images/product/teal-t-shirt.jpg +0 -0
  49. package/src/assets/demo/images/product/yellow-earbuds.jpg +0 -0
  50. package/src/assets/demo/images/product/yoga-mat.jpg +0 -0
  51. package/src/assets/demo/images/product/yoga-set.jpg +0 -0
  52. package/src/assets/favicon.svg +14 -0
  53. package/src/assets/i18n/app-modules.en.json +23 -0
  54. package/src/assets/i18n/app-modules.ru.json +23 -0
  55. package/src/assets/i18n/config.en.json +14 -0
  56. package/src/assets/i18n/config.ru.json +14 -0
  57. package/src/assets/layout/_core.scss +24 -0
  58. package/src/assets/layout/_footer.scss +8 -0
  59. package/src/assets/layout/_logo.scss +7 -0
  60. package/src/assets/layout/_main.scss +12 -0
  61. package/src/assets/layout/_menu.scss +159 -0
  62. package/src/assets/layout/_mixins.scss +15 -0
  63. package/src/assets/layout/_preloading.scss +49 -0
  64. package/src/assets/layout/_responsive.scss +108 -0
  65. package/src/assets/layout/_topbar.scss +168 -0
  66. package/src/assets/layout/_typography.scss +68 -0
  67. package/src/assets/layout/_utils.scss +25 -0
  68. package/src/assets/layout/layout.scss +14 -0
  69. package/src/assets/layout/variables/_common.scss +20 -0
  70. package/src/assets/layout/variables/_dark.scss +5 -0
  71. package/src/assets/layout/variables/_light.scss +5 -0
  72. package/src/assets/oip-common.scss +5 -0
  73. package/src/assets/tailwind.css +3 -0
  74. package/src/components/app-configurator.component.ts +491 -0
  75. package/src/components/app-floating-configurator.component.ts +47 -0
  76. package/src/components/app-modules.component.ts +144 -0
  77. package/src/components/app.layout.component.ts +130 -0
  78. package/src/components/auth/access/access.component.ts +42 -0
  79. package/src/components/auth/error/error.component.ts +42 -0
  80. package/src/components/auth/login/login.component.ts +120 -0
  81. package/src/components/auth/unauthorized/unauthorized.component.ts +51 -0
  82. package/src/components/base-module.component.ts +258 -0
  83. package/src/components/config.component.ts +131 -0
  84. package/src/components/db-migration/db-migration.component.ts +162 -0
  85. package/src/components/db-migration.component.ts +154 -0
  86. package/src/components/footer.component.ts +17 -0
  87. package/src/components/logo.component.ts +34 -0
  88. package/src/components/menu/menu-item-create-dialog.component.ts +119 -0
  89. package/src/components/menu/menu-item-edit-dialog.component.ts +123 -0
  90. package/src/components/menu/menu-item.component.ts +295 -0
  91. package/src/components/menu/menu.component.ts +85 -0
  92. package/src/components/notfound.component.ts +31 -0
  93. package/src/components/profile.component.ts +43 -0
  94. package/src/components/security.component.ts +102 -0
  95. package/src/components/sidebar.component.ts +12 -0
  96. package/src/components/top-bar.component.ts +147 -0
  97. package/src/dtos/context-menu-item.dto.ts +23 -0
  98. package/src/dtos/edit-module-instance.dto.ts +8 -0
  99. package/src/dtos/no-settings.dto.ts +4 -0
  100. package/src/dtos/put-security.dto.ts +6 -0
  101. package/src/dtos/security.dto.ts +6 -0
  102. package/src/dtos/top-bar.dto.ts +13 -0
  103. package/src/events/menu-change.event.ts +23 -0
  104. package/src/helpers/date.helper.ts +94 -0
  105. package/src/intercepts/i18n-intercept.service.ts +13 -0
  106. package/src/modules/http-loader.factory.ts +40 -0
  107. package/src/modules/secure.pipe.ts +19 -0
  108. package/src/public-api.ts +42 -0
  109. package/src/services/app-title.service.ts +22 -0
  110. package/src/services/app.layout.service.ts +236 -0
  111. package/src/services/app.menu.service.ts +64 -0
  112. package/src/services/auth.service.ts +58 -0
  113. package/src/services/base-data.service.ts +74 -0
  114. package/src/services/l10n.service.ts +71 -0
  115. package/src/services/msg.service.ts +76 -0
  116. package/src/services/security-data.service.ts +19 -0
  117. package/src/services/security-storage.service.ts +21 -0
  118. package/src/services/security.service.ts +116 -0
  119. package/src/services/top-bar.service.ts +44 -0
  120. package/src/services/user.service.ts +77 -0
  121. package/src/test.ts +11 -0
  122. package/src/user-api/UserProfile.ts +85 -0
  123. package/src/user-api/data-contracts.ts +42 -0
  124. package/src/user-api/http-client.ts +251 -0
  125. package/tsconfig.lib.json +12 -0
  126. package/tsconfig.lib.prod.json +10 -0
  127. package/tsconfig.spec.json +9 -0
@@ -0,0 +1,49 @@
1
+ .preloader {
2
+ position: fixed;
3
+ z-index: 999999;
4
+ background: #edf1f5;
5
+ width: 100%;
6
+ height: 100%;
7
+ }
8
+
9
+ .preloader-content {
10
+ border: 0 solid transparent;
11
+ border-radius: 50%;
12
+ width: 150px;
13
+ height: 150px;
14
+ position: absolute;
15
+ top: calc(50vh - 75px);
16
+ left: calc(50vw - 75px);
17
+ }
18
+
19
+ .preloader-content:before,
20
+ .preloader-content:after {
21
+ content: "";
22
+ border: 1em solid var(--primary-color);
23
+ border-radius: 50%;
24
+ width: inherit;
25
+ height: inherit;
26
+ position: absolute;
27
+ top: 0;
28
+ left: 0;
29
+ animation: loader 2s linear infinite;
30
+ opacity: 0;
31
+ }
32
+
33
+ .preloader-content:before {
34
+ animation-delay: 0.5s;
35
+ }
36
+
37
+ @keyframes loader {
38
+ 0% {
39
+ transform: scale(0);
40
+ opacity: 0;
41
+ }
42
+ 50% {
43
+ opacity: 1;
44
+ }
45
+ 100% {
46
+ transform: scale(1);
47
+ opacity: 0;
48
+ }
49
+ }
@@ -0,0 +1,108 @@
1
+ @media screen and (min-width: 1960px) {
2
+ .layout-main,
3
+ .landing-wrapper {
4
+ width: 1504px;
5
+ margin-left: auto !important;
6
+ margin-right: auto !important;
7
+ }
8
+ }
9
+
10
+ @media (min-width: 992px) {
11
+ .layout-wrapper {
12
+ &.layout-overlay {
13
+ .layout-main-container {
14
+ margin-left: 0;
15
+ }
16
+
17
+ .layout-sidebar {
18
+ transform: translateX(-100%);
19
+ left: 0;
20
+ top: 0;
21
+ height: 100vh;
22
+ z-index: 996;
23
+ border-top-left-radius: 0;
24
+ border-bottom-left-radius: 0;
25
+ border-right: 1px solid var(--surface-border);
26
+ transition:
27
+ transform 0.4s cubic-bezier(0.05, 0.74, 0.2, 0.99),
28
+ left 0.4s cubic-bezier(0.05, 0.74, 0.2, 0.99);
29
+ box-shadow:
30
+ 0 3px 5px rgba(0, 0, 0, 0.02),
31
+ 0 0 2px rgba(0, 0, 0, 0.05),
32
+ 0 1px 4px rgba(0, 0, 0, 0.08);
33
+ }
34
+
35
+ &.layout-overlay-active {
36
+ .layout-sidebar {
37
+ transform: translateX(0);
38
+ }
39
+ }
40
+ }
41
+
42
+ &.layout-static {
43
+ .layout-main-container {
44
+ margin-left: 21rem;
45
+ }
46
+
47
+ &.layout-static-inactive {
48
+ .layout-sidebar {
49
+ transform: translateX(-100%);
50
+ left: 0;
51
+ }
52
+
53
+ .layout-main-container {
54
+ margin-left: 0;
55
+ padding-left: 1rem;
56
+ }
57
+ }
58
+ }
59
+
60
+ .layout-mask {
61
+ display: none;
62
+ }
63
+ }
64
+ }
65
+
66
+ // tablet
67
+ @media (max-width: 991px) {
68
+ .blocked-scroll {
69
+ overflow: hidden;
70
+ }
71
+
72
+ .layout-wrapper {
73
+ .layout-main-container {
74
+ margin-left: 0;
75
+ }
76
+
77
+ .layout-sidebar {
78
+ transform: translateX(-100%);
79
+ left: 0;
80
+ top: 0;
81
+ height: 100vh;
82
+ border-top-left-radius: 0;
83
+ border-bottom-left-radius: 0;
84
+ padding: 4.5rem 1.5rem;
85
+ }
86
+
87
+ .layout-mask {
88
+ display: none;
89
+ position: fixed;
90
+ top: 0;
91
+ left: 0;
92
+ z-index: 995;
93
+ width: 100%;
94
+ height: 100%;
95
+ background-color: var(--maskbg);
96
+ }
97
+
98
+ &.layout-mobile-active {
99
+ .layout-sidebar {
100
+ transform: translateX(0);
101
+ }
102
+
103
+ .layout-mask {
104
+ display: block;
105
+ }
106
+ }
107
+ }
108
+ }
@@ -0,0 +1,168 @@
1
+ @use "./mixins" as *;
2
+
3
+ .layout-topbar {
4
+ position: fixed;
5
+ height: 4rem;
6
+ z-index: 997;
7
+ left: 0;
8
+ top: 0;
9
+ width: 100%;
10
+ padding: 0 1rem;
11
+ background-color: var(--surface-card);
12
+ transition: left var(--layout-section-transition-duration);
13
+ display: flex;
14
+ align-items: center;
15
+
16
+ .layout-topbar-logo-container {
17
+ width: 20rem;
18
+ display: flex;
19
+ align-items: center;
20
+ }
21
+
22
+ .layout-topbar-logo {
23
+ display: inline-flex;
24
+ align-items: center;
25
+ font-size: 1.5rem;
26
+ border-radius: var(--content-border-radius);
27
+ color: var(--text-color);
28
+ font-weight: 500;
29
+ gap: 0.5rem;
30
+
31
+ svg {
32
+ width: 3rem;
33
+ }
34
+
35
+ &:focus-visible {
36
+ @include focused();
37
+ }
38
+ }
39
+
40
+ .layout-topbar-action {
41
+ display: inline-flex;
42
+ justify-content: center;
43
+ align-items: center;
44
+ border-radius: 50%;
45
+ width: 2.5rem;
46
+ height: 2.5rem;
47
+ color: var(--text-color);
48
+ transition: background-color var(--element-transition-duration);
49
+ cursor: pointer;
50
+
51
+ &:hover {
52
+ background-color: var(--surface-hover);
53
+ }
54
+
55
+ &:focus-visible {
56
+ @include focused();
57
+ }
58
+
59
+ i {
60
+ font-size: 1.25rem;
61
+ }
62
+
63
+ span {
64
+ font-size: 1rem;
65
+ display: none;
66
+ }
67
+
68
+ &.layout-topbar-action-highlight {
69
+ background-color: var(--primary-color);
70
+ color: var(--primary-contrast-color);
71
+ }
72
+ }
73
+
74
+ .layout-menu-button {
75
+ margin-right: 0.5rem;
76
+ }
77
+
78
+ .layout-topbar-menu-button {
79
+ display: none;
80
+ }
81
+
82
+ .layout-topbar-actions {
83
+ margin-left: auto;
84
+ display: flex;
85
+ gap: 1rem;
86
+ }
87
+
88
+ .layout-topbar-menu-content {
89
+ display: flex;
90
+ gap: 1rem;
91
+ }
92
+
93
+ .layout-config-menu {
94
+ display: flex;
95
+ gap: 1rem;
96
+ }
97
+ }
98
+
99
+ @media (max-width: 991px) {
100
+ .layout-topbar {
101
+ padding: 0 1rem;
102
+
103
+ .layout-topbar-logo-container {
104
+ width: auto;
105
+ }
106
+
107
+ .layout-menu-button {
108
+ margin-left: 0;
109
+ margin-right: 0.5rem;
110
+ }
111
+
112
+ .layout-topbar-menu-button {
113
+ display: inline-flex;
114
+ }
115
+
116
+ .layout-topbar-menu {
117
+ position: absolute;
118
+ background-color: var(--surface-overlay);
119
+ transform-origin: top;
120
+ box-shadow:
121
+ 0px 3px 5px rgba(0, 0, 0, 0.02),
122
+ 0px 0px 2px rgba(0, 0, 0, 0.05),
123
+ 0px 1px 4px rgba(0, 0, 0, 0.08);
124
+ border-radius: var(--content-border-radius);
125
+ padding: 1rem;
126
+ right: 2rem;
127
+ top: 4rem;
128
+ min-width: 15rem;
129
+ border: 1px solid var(--surface-border);
130
+
131
+ .layout-topbar-menu-content {
132
+ gap: 0.5rem;
133
+ }
134
+
135
+ .layout-topbar-action {
136
+ display: flex;
137
+ width: 100%;
138
+ height: auto;
139
+ justify-content: flex-start;
140
+ border-radius: var(--content-border-radius);
141
+ padding: 0.5rem 1rem;
142
+
143
+ i {
144
+ font-size: 1rem;
145
+ margin-right: 0.5rem;
146
+ }
147
+
148
+ span {
149
+ display: block;
150
+ }
151
+ }
152
+ }
153
+
154
+ .layout-topbar-tabs {
155
+ span {
156
+ display: none;
157
+ }
158
+ }
159
+
160
+ .layout-topbar-logo {
161
+ display: none;
162
+ }
163
+
164
+ .layout-topbar-menu-content {
165
+ flex-direction: column;
166
+ }
167
+ }
168
+ }
@@ -0,0 +1,68 @@
1
+ h1,
2
+ h2,
3
+ h3,
4
+ h4,
5
+ h5,
6
+ h6 {
7
+ margin: 1.5rem 0 1rem 0;
8
+ font-family: inherit;
9
+ font-weight: 700;
10
+ line-height: 1.5;
11
+ color: var(--text-color);
12
+
13
+ &:first-child {
14
+ margin-top: 0;
15
+ }
16
+ }
17
+
18
+ h1 {
19
+ font-size: 2.5rem;
20
+ }
21
+
22
+ h2 {
23
+ font-size: 2rem;
24
+ }
25
+
26
+ h3 {
27
+ font-size: 1.75rem;
28
+ }
29
+
30
+ h4 {
31
+ font-size: 1.5rem;
32
+ }
33
+
34
+ h5 {
35
+ font-size: 1.25rem;
36
+ }
37
+
38
+ h6 {
39
+ font-size: 1rem;
40
+ }
41
+
42
+ mark {
43
+ background: #fff8e1;
44
+ padding: 0.25rem 0.4rem;
45
+ border-radius: var(--content-border-radius);
46
+ font-family: monospace;
47
+ }
48
+
49
+ blockquote {
50
+ margin: 1rem 0;
51
+ padding: 0 2rem;
52
+ border-left: 4px solid #90a4ae;
53
+ }
54
+
55
+ hr {
56
+ border-top: solid var(--surface-border);
57
+ border-width: 1px 0 0 0;
58
+ margin: 1rem 0;
59
+ }
60
+
61
+ p {
62
+ margin: 0 0 1rem 0;
63
+ line-height: 1.5;
64
+
65
+ &:last-child {
66
+ margin-bottom: 0;
67
+ }
68
+ }
@@ -0,0 +1,25 @@
1
+ /* Utils */
2
+ .clearfix:after {
3
+ content: " ";
4
+ display: block;
5
+ clear: both;
6
+ }
7
+
8
+ .card {
9
+ background: var(--surface-card);
10
+ padding: 1rem;
11
+ margin-bottom: 1rem;
12
+ border-radius: var(--content-border-radius);
13
+
14
+ &:last-child {
15
+ margin-bottom: 0;
16
+ }
17
+ }
18
+
19
+ .p-toast {
20
+ &.p-toast-top-right,
21
+ &.p-toast-top-left,
22
+ &.p-toast-top-center {
23
+ top: 100px;
24
+ }
25
+ }
@@ -0,0 +1,14 @@
1
+ @use "./variables/_common";
2
+ @use "./variables/_light";
3
+ @use "./variables/_dark";
4
+ @use "./_mixins";
5
+ @use "./_preloading";
6
+ @use "./_core";
7
+ @use "./_main";
8
+ @use "./_topbar";
9
+ @use "./_menu";
10
+ @use "./_footer";
11
+ @use "./_responsive";
12
+ @use "./_utils";
13
+ @use "./_typography";
14
+ @use "./_logo";
@@ -0,0 +1,20 @@
1
+ :root {
2
+ --primary-color: var(--p-primary-color);
3
+ --primary-contrast-color: var(--p-primary-contrast-color);
4
+ --text-color: var(--p-text-color);
5
+ --text-color-secondary: var(--p-text-muted-color);
6
+ --surface-border: var(--p-content-border-color);
7
+ --surface-card: var(--p-content-background);
8
+ --surface-hover: var(--p-content-hover-background);
9
+ --surface-overlay: var(--p-overlay-popover-background);
10
+ --transition-duration: var(--p-transition-duration);
11
+ --maskbg: var(--p-mask-background);
12
+ --content-border-radius: var(--p-content-border-radius);
13
+ --layout-section-transition-duration: 0.2s;
14
+ --element-transition-duration: var(--p-transition-duration);
15
+ --focus-ring-width: var(--p-focus-ring-width);
16
+ --focus-ring-style: var(--p-focus-ring-style);
17
+ --focus-ring-color: var(--p-focus-ring-color);
18
+ --focus-ring-offset: var(--p-focus-ring-offset);
19
+ --focus-ring-shadow: var(--p-focus-ring-shadow);
20
+ }
@@ -0,0 +1,5 @@
1
+ :root[class*="app-dark"] {
2
+ --surface-ground: var(--p-surface-950);
3
+ --code-background: var(--p-surface-800);
4
+ --code-color: var(--p-surface-100);
5
+ }
@@ -0,0 +1,5 @@
1
+ :root {
2
+ --surface-ground: var(--p-surface-100);
3
+ --code-background: var(--p-surface-900);
4
+ --code-color: var(--p-surface-200);
5
+ }
@@ -0,0 +1,5 @@
1
+ /* You can add global styles to this file, and also import other style files */
2
+ @use "./tailwind.css";
3
+ @use "./layout/layout.scss";
4
+ @use "primeicons/primeicons.css";
5
+ @use "./demo/demo.scss";
@@ -0,0 +1,3 @@
1
+ @tailwind base;
2
+ @tailwind components;
3
+ @tailwind utilities;