@tapni/auth 0.0.170 → 0.0.172

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 (69) hide show
  1. package/README.md +2 -0
  2. package/dist/.vite/manifest.json +18 -10
  3. package/dist/.well-known/assetlinks.json +10 -12
  4. package/dist/.well-known/microsoft-identity-association.json +5 -5
  5. package/dist/{Account-6F9eRo1R.js → Account-BVGvxZ85.js} +31 -32
  6. package/dist/{QR-2Izy5Dj4.js → QR-DwjajyG2.js} +3 -3
  7. package/dist/TapniAuth.es.js +1 -1
  8. package/dist/TapniAuth.umd.js +9 -9
  9. package/dist/blank.html +31 -0
  10. package/dist/{install-co2F1hxN.js → install-B8fBS6C4.js} +752 -996
  11. package/dist/site.webmanifest +11 -1
  12. package/dist/style.css +1 -1
  13. package/dist/{web-NrPZl3qD.js → web-XbruGdlD.js} +2 -5
  14. package/package.json +64 -55
  15. package/src/.prettierrc.json +16 -0
  16. package/src/App.vue +249 -265
  17. package/src/components/Language.vue +66 -143
  18. package/src/components/LinkIcon.vue +174 -225
  19. package/src/components/ModalOverlay.vue +47 -50
  20. package/src/components/OTP.vue +64 -94
  21. package/src/components/SSO.vue +80 -111
  22. package/src/components/SSOPick.vue +93 -148
  23. package/src/eslint.config.js +15 -0
  24. package/src/install.js +9 -10
  25. package/src/main.js +54 -57
  26. package/src/mixins/apple.mixin.js +56 -54
  27. package/src/mixins/auth.mixin.js +21 -74
  28. package/src/mixins/facebook.mixin.js +67 -66
  29. package/src/mixins/global.mixin.js +107 -109
  30. package/src/mixins/google.mixin.js +53 -54
  31. package/src/mixins/mfa-auth.mixin.js +68 -68
  32. package/src/mixins/microsoft.mixin.js +67 -75
  33. package/src/mixins/okta.mixin.js +50 -57
  34. package/src/mixins/qr-auth.mixin.js +111 -107
  35. package/src/mixins/saml.mixin.js +97 -48
  36. package/src/router/index.js +6 -6
  37. package/src/routes.js +60 -66
  38. package/src/services/Api.js +55 -57
  39. package/src/services/AuthService.js +75 -75
  40. package/src/services/CompanyService.js +10 -10
  41. package/src/services/DeviceService.js +3 -3
  42. package/src/services/UserService.js +45 -45
  43. package/src/services/UtilService.js +256 -218
  44. package/src/store/auth.js +471 -543
  45. package/src/store/constants.js +1 -1
  46. package/src/store/event-bus.js +22 -22
  47. package/src/store/locales/cn.js +442 -458
  48. package/src/store/locales/de.js +438 -517
  49. package/src/store/locales/en.js +449 -510
  50. package/src/store/locales/es.js +442 -524
  51. package/src/store/locales/fr.js +442 -516
  52. package/src/store/locales/it.js +442 -514
  53. package/src/store/locales/kr.js +442 -491
  54. package/src/store/locales/lang.js +43 -43
  55. package/src/store/locales/sr.js +439 -492
  56. package/src/store/locales/tr.js +436 -487
  57. package/src/store/store.js +6 -6
  58. package/src/views/Account.vue +169 -207
  59. package/src/views/Callback.vue +36 -33
  60. package/src/views/Login.vue +220 -392
  61. package/src/views/MFA.vue +89 -103
  62. package/src/views/QR.vue +25 -28
  63. package/src/views/Register.vue +201 -205
  64. package/src/views/Reset.vue +132 -135
  65. package/src/views/Verify.vue +153 -151
  66. package/src/views/Welcome.vue +61 -60
  67. /package/dist/{web-L3jORB19.js → web-AXRKjAOB.js} +0 -0
  68. /package/dist/{web-5VtGcKeU.js → web-IFGkBi0t.js} +0 -0
  69. /package/dist/{web-AImUTDQQ.js → web-LIfHmYL2.js} +0 -0
@@ -1,151 +1,101 @@
1
1
  <template>
2
- <a
3
- class="disable-select"
4
- :class="linkStyle + (disabled ? ' opacity-50' : '')"
5
- :style="
6
- (editing ? 'cursor: move' : 'cursor: pointer') +
7
- '!important; overflow: visible; margin-top: 5px;'
8
- "
9
- >
10
-
11
- <span
12
- :class="{
13
- 'user-link-img': true,
14
- 'pulse pulse-border': pulse,
15
- 'link-drag': editing,
16
- }"
17
- :style="{ ...customLinkStyle?.linkIcon }"
18
- >
19
- <img
20
- v-if="!data.custom_icon && data.type !== 'customlink'"
21
- :src="'https://cdn.tapni.co/icons/' + data.type + '.png'"
22
- class="responsive-image"
23
- :alt="data.text"
24
- @load="$emit('loaded')"
25
- @error="$emit('loaded')"
26
- />
27
- <img
28
- v-else-if="
29
- !data.custom_icon && data.type === 'customlink' && linkAdding
30
- "
31
- :src="'https://cdn.tapni.co/icons/custom-icon-128.gif'"
32
- class="responsive-image"
33
- :alt="data.text"
34
- @load="$emit('loaded')"
35
- @error="$emit('loaded')"
36
- />
37
- <img
38
- v-else-if="
39
- !data.custom_icon && data.type === 'customlink' && !linkAdding
40
- "
41
- :src="'https://cdn.tapni.co/icons/customlink.png'"
42
- class="responsive-image"
43
- :alt="data.text"
44
- @load="$emit('loaded')"
45
- @error="$emit('loaded')"
46
- />
47
- <img
48
- v-else
49
- :src="data.style.custom_icon"
50
- style="border-radius: 22.46%"
51
- class="responsive-image"
52
- :alt="data.text"
53
- @load="$emit('loaded')"
54
- @error="$emit('loaded')"
55
- />
56
- </span>
57
-
58
- <span
59
- class="link-text link-drag color-black"
60
- :style="{ color: customLinkStyle?.color }"
61
- >
62
- {{ linkText }}
63
- </span>
64
- </a>
2
+ <a class="disable-select" :class="linkStyle + (disabled ? ' opacity-50' : '')" :style="(editing ? 'cursor: move' : 'cursor: pointer') + '!important; overflow: visible; margin-top: 5px;'">
3
+ <span
4
+ :class="{
5
+ 'user-link-img': true,
6
+ 'pulse pulse-border': pulse,
7
+ 'link-drag': editing
8
+ }"
9
+ :style="{ ...customLinkStyle?.linkIcon }"
10
+ >
11
+ <img v-if="!data.custom_icon && data.type !== 'customlink'" :src="'https://cdn.tapni.co/icons/' + data.type + '.png'" class="responsive-image" :alt="data.text" @load="$emit('loaded')" @error="$emit('loaded')" />
12
+ <img v-else-if="!data.custom_icon && data.type === 'customlink' && linkAdding" :src="'https://cdn.tapni.co/icons/custom-icon-128.gif'" class="responsive-image" :alt="data.text" @load="$emit('loaded')" @error="$emit('loaded')" />
13
+ <img v-else-if="!data.custom_icon && data.type === 'customlink' && !linkAdding" :src="'https://cdn.tapni.co/icons/customlink.png'" class="responsive-image" :alt="data.text" @load="$emit('loaded')" @error="$emit('loaded')" />
14
+ <img v-else :src="data.style.custom_icon" style="border-radius: 22.46%" class="responsive-image" :alt="data.text" @load="$emit('loaded')" @error="$emit('loaded')" />
15
+ </span>
16
+
17
+ <span class="link-text link-drag color-black" :style="{ color: customLinkStyle?.color }">
18
+ {{ linkText }}
19
+ </span>
20
+ </a>
65
21
  </template>
66
22
 
67
23
  <script>
68
24
  import AuthMixin from '../mixins/auth.mixin';
69
25
 
70
26
  export default {
71
- name: "LinkIcon",
72
- mixins: [AuthMixin],
73
- props: {
74
- linkAdding: {
75
- type: Boolean,
76
- required: false,
77
- default: false,
78
- },
79
- hideExternalIcon: {
80
- type: Boolean,
81
- required: false,
82
- default: false,
83
- },
84
- switching: {
85
- type: Boolean,
86
- required: false,
87
- default: false,
88
- },
89
- pulse: {
90
- type: Boolean,
91
- required: false,
92
- default: false,
93
- },
94
- editing: {
95
- type: Boolean,
96
- required: false,
97
- default: true,
98
- },
99
- directPick: {
100
- type: Boolean,
101
- required: false,
102
- default: false,
103
- },
104
- disabled: {
105
- type: Boolean,
106
- required: false,
107
- default: false,
108
- },
109
- to: {
110
- type: String,
111
- required: false,
112
- default: "",
113
- },
114
- linkStyle: {
115
- type: String,
116
- required: false,
117
- default: "link-grid",
118
- },
119
- data: {
120
- type: Object,
121
- required: true,
122
- },
123
- customLinkStyle: {
124
- type: Object,
125
- required: false,
126
- default: () => {},
127
- },
128
- shareIconStyle: {
129
- type: Object,
130
- required: false,
131
- default: () => {},
132
- },
133
- },
134
- computed: {
135
- linkText() {
136
- if (this.appLanguage !== "en" && this.data.text) {
137
- return (
138
- this.ssoLang[this.appLanguage][
139
- "link_text_" +
140
- this.data.text.toLowerCase().trim().replace(/ /g, "_")
141
- ] || this.data.text
142
- );
143
- }
144
- return this.data.text;
145
- },
146
- },
147
- methods: {
148
- },
27
+ name: 'LinkIcon',
28
+ mixins: [AuthMixin],
29
+ props: {
30
+ linkAdding: {
31
+ type: Boolean,
32
+ required: false,
33
+ default: false
34
+ },
35
+ hideExternalIcon: {
36
+ type: Boolean,
37
+ required: false,
38
+ default: false
39
+ },
40
+ switching: {
41
+ type: Boolean,
42
+ required: false,
43
+ default: false
44
+ },
45
+ pulse: {
46
+ type: Boolean,
47
+ required: false,
48
+ default: false
49
+ },
50
+ editing: {
51
+ type: Boolean,
52
+ required: false,
53
+ default: true
54
+ },
55
+ directPick: {
56
+ type: Boolean,
57
+ required: false,
58
+ default: false
59
+ },
60
+ disabled: {
61
+ type: Boolean,
62
+ required: false,
63
+ default: false
64
+ },
65
+ to: {
66
+ type: String,
67
+ required: false,
68
+ default: ''
69
+ },
70
+ linkStyle: {
71
+ type: String,
72
+ required: false,
73
+ default: 'link-grid'
74
+ },
75
+ data: {
76
+ type: Object,
77
+ required: true
78
+ },
79
+ customLinkStyle: {
80
+ type: Object,
81
+ required: false,
82
+ default: () => {}
83
+ },
84
+ shareIconStyle: {
85
+ type: Object,
86
+ required: false,
87
+ default: () => {}
88
+ }
89
+ },
90
+ computed: {
91
+ linkText() {
92
+ if (this.appLanguage !== 'en' && this.data.text) {
93
+ return this.ssoLang[this.appLanguage]['link_text_' + this.data.text.toLowerCase().trim().replace(/ /g, '_')] || this.data.text;
94
+ }
95
+ return this.data.text;
96
+ }
97
+ },
98
+ methods: {}
149
99
  };
150
100
  </script>
151
101
 
@@ -155,134 +105,133 @@ export default {
155
105
  /* ********* */
156
106
  .link-grid,
157
107
  .user-link-img {
158
- width: 100%;
159
- display: inline-table;
160
- position: relative;
108
+ width: 100%;
109
+ display: inline-table;
110
+ position: relative;
161
111
  }
162
112
 
163
113
  .link-grid {
164
- width: 30%;
165
- margin: 1.6%;
166
- padding: 1.6%;
114
+ width: 30%;
115
+ margin: 1.6%;
116
+ padding: 1.6%;
167
117
  }
168
118
 
169
119
  .link-grid .user-link-img img {
170
- /* box-shadow: 0px 2px 10px rgba(200,200,200,0.8); */
171
- /* border: 1px solid #e8e8e8; */
172
- border-radius: 25% !important;
120
+ /* box-shadow: 0px 2px 10px rgba(200,200,200,0.8); */
121
+ /* border: 1px solid #e8e8e8; */
122
+ border-radius: 25% !important;
173
123
  }
174
124
 
175
125
  .link-grid .edit-icon {
176
- border-radius: 20px;
177
- right: -3%;
178
- top: -3%;
179
- position: absolute;
180
- z-index: 3;
181
- max-width: 23%;
182
- overflow: hidden;
183
- min-width: 30px;
126
+ border-radius: 20px;
127
+ right: -3%;
128
+ top: -3%;
129
+ position: absolute;
130
+ z-index: 3;
131
+ max-width: 23%;
132
+ overflow: hidden;
133
+ min-width: 30px;
184
134
  }
185
135
 
186
136
  .link-grid .direct-icon {
187
- border-radius: 20px;
188
- left: -3%;
189
- top: -3%;
190
- position: absolute;
191
- z-index: 555;
192
- max-width: 23%;
193
- overflow: hidden;
194
- min-width: 30px;
137
+ border-radius: 20px;
138
+ left: -3%;
139
+ top: -3%;
140
+ position: absolute;
141
+ z-index: 555;
142
+ max-width: 23%;
143
+ overflow: hidden;
144
+ min-width: 30px;
195
145
  }
196
146
 
197
147
  .link-grid .link-text {
198
- min-height: 20px;
199
- margin-top: 3px !important;
200
- display: block;
201
- text-align: center;
202
- line-height: normal;
203
- overflow-wrap: anywhere;
148
+ min-height: 20px;
149
+ margin-top: 3px !important;
150
+ display: block;
151
+ text-align: center;
152
+ line-height: normal;
153
+ overflow-wrap: anywhere;
204
154
  }
205
155
 
206
156
  /* ********* */
207
157
  /* Link List */
208
158
  /* ********* */
209
159
  .link-list {
210
- width: 93%;
211
- max-height: 67px !important;
212
- margin: 0px auto;
213
- display: flex;
214
- border-radius: 15px !important;
215
- background-color: #ffffff;
216
- /* box-shadow: 0px 2px 5px rgba(0,0,0,0.15); */
217
- border: solid 1px #e8e8e8;
218
- position: relative;
219
- align-items: center;
160
+ width: 93%;
161
+ max-height: 67px !important;
162
+ margin: 0px auto;
163
+ display: flex;
164
+ border-radius: 15px !important;
165
+ background-color: #ffffff;
166
+ /* box-shadow: 0px 2px 5px rgba(0,0,0,0.15); */
167
+ border: solid 1px #e8e8e8;
168
+ position: relative;
169
+ align-items: center;
220
170
  }
221
171
 
222
172
  .link-list .user-link-img {
223
- display: inline-block;
224
- width: 65px;
225
- /* box-shadow: 0px 3px 6px rgba(0,0,0,0.16); */
226
- border-radius: 25% !important;
173
+ display: inline-block;
174
+ width: 65px;
175
+ /* box-shadow: 0px 3px 6px rgba(0,0,0,0.16); */
176
+ border-radius: 25% !important;
227
177
  }
228
178
 
229
179
  .link-list .link-text {
230
- display: inline-block;
231
- padding: 18px 0% 17px 10%;
232
- font-size: 15px;
233
- font-weight: 500;
234
- white-space: nowrap;
235
- text-overflow: ellipsis;
236
- overflow: hidden;
237
- flex: 1;
238
- text-align: left;
239
- border-radius: 15px !important;
180
+ display: inline-block;
181
+ padding: 18px 0% 17px 10%;
182
+ font-size: 15px;
183
+ font-weight: 500;
184
+ white-space: nowrap;
185
+ text-overflow: ellipsis;
186
+ overflow: hidden;
187
+ flex: 1;
188
+ text-align: left;
189
+ border-radius: 15px !important;
240
190
  }
241
191
 
242
192
  .link-list .edit-icon {
243
- border-radius: 20px;
244
- right: 7%;
245
- top: 30%;
246
- position: absolute;
247
- z-index: 3;
248
- width: 26px;
249
- overflow: hidden;
193
+ border-radius: 20px;
194
+ right: 7%;
195
+ top: 30%;
196
+ position: absolute;
197
+ z-index: 3;
198
+ width: 26px;
199
+ overflow: hidden;
250
200
  }
251
201
 
252
202
  .link-list .switching {
253
- width: 45px;
203
+ width: 45px;
254
204
  }
255
205
 
256
206
  .link-list .direct-icon {
257
- border-radius: 20px;
258
- left: -2%;
259
- top: -13%;
260
- position: absolute;
261
- z-index: 555;
262
- width: 26px;
263
- overflow: hidden;
207
+ border-radius: 20px;
208
+ left: -2%;
209
+ top: -13%;
210
+ position: absolute;
211
+ z-index: 555;
212
+ width: 26px;
213
+ overflow: hidden;
264
214
  }
265
215
  /* ********* */
266
216
 
267
217
  .small {
268
- width: 22% !important;
269
- margin: 2% 4% 0%;
270
- padding: 0%;
218
+ width: 22% !important;
219
+ margin: 2% 4% 0%;
220
+ padding: 0%;
271
221
  }
272
222
  .small .link-text {
273
- margin-top: 0px !important;
274
- font-size: 13px;
223
+ margin-top: 0px !important;
224
+ font-size: 13px;
275
225
  }
276
226
 
277
227
  .linkExternal {
278
- margin-right: 20px;
279
- width: 20px;
280
- display: inline-block !important;
281
- height: 20px;
282
- background: black;
283
- -webkit-mask: url(https://cdn.tapni.co/icons/link-external.svg) no-repeat
284
- center;
285
- mask: url(https://cdn.tapni.co/icons/link-external.svg) no-repeat center;
286
- transform: scale(1.5);
228
+ margin-right: 20px;
229
+ width: 20px;
230
+ display: inline-block !important;
231
+ height: 20px;
232
+ background: black;
233
+ -webkit-mask: url(https://cdn.tapni.co/icons/link-external.svg) no-repeat center;
234
+ mask: url(https://cdn.tapni.co/icons/link-external.svg) no-repeat center;
235
+ transform: scale(1.5);
287
236
  }
288
237
  </style>
@@ -1,10 +1,7 @@
1
1
  <template>
2
- <div
3
- :class="{ 'pointer delete-menu': true, 'delete-menu-active': toggle }"
4
- @click="toggleEmit"
5
- ></div>
2
+ <div :class="{ 'pointer delete-menu': true, 'delete-menu-active': toggle }" @click="toggleEmit"></div>
6
3
 
7
- <!--
4
+ <!--
8
5
  <transition name="fade">
9
6
  <div v-if="toggle" class="pointer delete-menu" @click="toggleEmit"></div>
10
7
  </transition>
@@ -12,57 +9,57 @@
12
9
  </template>
13
10
 
14
11
  <script>
15
- import { EventBus } from "../store/event-bus";
16
- import AuthMixin from "../mixins/auth.mixin";
12
+ import { EventBus } from '../store/event-bus';
13
+ import AuthMixin from '../mixins/auth.mixin';
17
14
 
18
15
  export default {
19
- name: "ModalOverlay",
20
- mixins: [AuthMixin],
21
- data() {
22
- return {
23
- toggle: false,
24
- };
25
- },
26
- mounted() {
27
- EventBus.$on("closeModal", () => {
28
- this.toggle = false;
29
- window.document.body.style.overflow = "auto";
30
- window.document.body.style.height = "auto";
31
- });
32
- EventBus.$on("openModalOverlay", () => {
33
- this.toggle = true;
34
- });
35
- // EventBus.$on('togglePasswordModal', this.toggleModal)
36
- // EventBus.$on('toggleAddAccountModal', this.toggleModal)
37
- // EventBus.$on("toggleAccountSettingsModal", this.toggleModal);
38
- EventBus.$on("toggleSSOLanguageModal", this.toggleModal);
39
- EventBus.$on("toggleOTPModal", this.toggleModal);
40
- EventBus.$on("toggleSSOModal", this.toggleModal);
41
- EventBus.$on("toggleSSOPickModal", this.toggleModal);
42
- },
43
- methods: {
44
- toggleModal(shouldToggle = true) {
45
- if (shouldToggle) {
46
- this.toggle = !this.toggle;
47
- if (this.toggle) {
48
- window.document.body.style.overflow = "hidden";
49
- window.document.body.style.height = "100vh";
50
- } else {
51
- window.document.body.style.overflow = "auto";
52
- window.document.body.style.height = "auto";
53
- }
54
- }
55
- },
56
- toggleEmit() {
57
- if(!this.isLoggedIn && this.user?.lead_form?.forceFilling) return;
58
- EventBus.$emit("closeModal");
59
- },
60
- },
16
+ name: 'ModalOverlay',
17
+ mixins: [AuthMixin],
18
+ data() {
19
+ return {
20
+ toggle: false
21
+ };
22
+ },
23
+ mounted() {
24
+ EventBus.$on('closeModal', () => {
25
+ this.toggle = false;
26
+ window.document.body.style.overflow = 'auto';
27
+ window.document.body.style.height = 'auto';
28
+ });
29
+ EventBus.$on('openModalOverlay', () => {
30
+ this.toggle = true;
31
+ });
32
+ // EventBus.$on('togglePasswordModal', this.toggleModal)
33
+ // EventBus.$on('toggleAddAccountModal', this.toggleModal)
34
+ // EventBus.$on("toggleAccountSettingsModal", this.toggleModal);
35
+ EventBus.$on('toggleSSOLanguageModal', this.toggleModal);
36
+ EventBus.$on('toggleOTPModal', this.toggleModal);
37
+ EventBus.$on('toggleSSOModal', this.toggleModal);
38
+ EventBus.$on('toggleSSOPickModal', this.toggleModal);
39
+ },
40
+ methods: {
41
+ toggleModal(shouldToggle = true) {
42
+ if (shouldToggle) {
43
+ this.toggle = !this.toggle;
44
+ if (this.toggle) {
45
+ window.document.body.style.overflow = 'hidden';
46
+ window.document.body.style.height = '100vh';
47
+ } else {
48
+ window.document.body.style.overflow = 'auto';
49
+ window.document.body.style.height = 'auto';
50
+ }
51
+ }
52
+ },
53
+ toggleEmit() {
54
+ if (!this.isLoggedIn && this.user?.lead_form?.forceFilling) return;
55
+ EventBus.$emit('closeModal');
56
+ }
57
+ }
61
58
  };
62
59
  </script>
63
60
 
64
61
  <style scoped>
65
62
  .fade-enter-to /* .fade-leave-active below version 2.1.8 */ {
66
- opacity: 1;
63
+ opacity: 1;
67
64
  }
68
65
  </style>