@wizishop/img-manager-webelement 1.0.4 → 14.0.5
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.
- package/README.md +13 -113
- package/esm2020/lib/environments/environment.mjs +99 -0
- package/esm2020/lib/img-manager-web-element.component.mjs +177 -0
- package/esm2020/lib/img-manager-web-element.module.mjs +47 -0
- package/esm2020/lib/services/auth-credentials.service.mjs +43 -0
- package/esm2020/lib/services/event.service.mjs +37 -0
- package/esm2020/lib/services/fiche_products.service.mjs +237 -0
- package/esm2020/lib/services/storage.service.mjs +53 -0
- package/esm2020/public-api.mjs +6 -0
- package/esm2020/wizishop-img-manager-webelement.mjs +5 -0
- package/fesm2015/wizishop-img-manager-webelement.mjs +671 -0
- package/fesm2015/wizishop-img-manager-webelement.mjs.map +1 -0
- package/fesm2020/wizishop-img-manager-webelement.mjs +673 -0
- package/fesm2020/wizishop-img-manager-webelement.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/environments/environment.d.ts +19 -0
- package/lib/img-manager-web-element.component.d.ts +50 -0
- package/lib/img-manager-web-element.module.d.ts +11 -0
- package/lib/services/auth-credentials.service.d.ts +19 -0
- package/lib/services/event.service.d.ts +11 -0
- package/lib/services/fiche_products.service.d.ts +51 -0
- package/lib/services/storage.service.d.ts +14 -0
- package/package.json +25 -10
- package/public-api.d.ts +2 -0
- package/3rdpartylicenses.txt +0 -665
- package/4.js +0 -1
- package/assets/img-manager/canva/icon_canva.svg +0 -4
- package/assets/img-manager/i18n/en.json +0 -1
- package/assets/img-manager/i18n/es.json +0 -1
- package/assets/img-manager/i18n/fr.json +0 -1
- package/assets/img-manager/i18n/it.json +0 -1
- package/assets/img-manager/img/fake.png +0 -0
- package/assets/img-manager/img/icon_picture.svg +0 -11
- package/favicon.ico +0 -0
- package/img-manager-webelement.1.0.4.js +0 -1
- package/index.html +0 -25
- package/main.js +0 -1
- package/polyfills.js +0 -1
- package/runtime.js +0 -1
- package/styles.1.0.4.css +0 -2
package/README.md
CHANGED
|
@@ -1,124 +1,24 @@
|
|
|
1
|
-
#
|
|
1
|
+
# ImgManagerWebElement
|
|
2
2
|
|
|
3
|
-
[
|
|
4
|
-
[](https://www.npmjs.com/package/@wizishop/img-manager-webelement)
|
|
3
|
+
This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 9.0.7.
|
|
5
4
|
|
|
6
|
-
##
|
|
5
|
+
## Code scaffolding
|
|
7
6
|
|
|
8
|
-
|
|
7
|
+
Run `ng generate component component-name --project ImgManagerWebElement` to generate a new component. You can also use `ng generate directive|pipe|service|class|guard|interface|enum|module --project ImgManagerWebElement`.
|
|
8
|
+
> Note: Don't forget to add `--project ImgManagerWebElement` or else it will be added to the default project in your `angular.json` file.
|
|
9
9
|
|
|
10
|
-
|
|
11
|
-
npm i @wizishop/img-manager-webelement
|
|
12
|
-
```
|
|
10
|
+
## Build
|
|
13
11
|
|
|
14
|
-
|
|
12
|
+
Run `ng build ImgManagerWebElement` to build the project. The build artifacts will be stored in the `dist/` directory.
|
|
15
13
|
|
|
16
|
-
|
|
17
|
-
In the following file : `src/environments/environment.ts`, update the shop token for 131.
|
|
14
|
+
## Publishing
|
|
18
15
|
|
|
19
|
-
|
|
16
|
+
After building your library with `ng build ImgManagerWebElement`, go to the dist folder `cd dist/img-manager-web-element` and run `npm publish`.
|
|
20
17
|
|
|
21
|
-
|
|
22
|
-
Run the following commande from package.json :
|
|
23
|
-
```
|
|
24
|
-
npm run update:img-manager
|
|
25
|
-
```
|
|
26
|
-
Or install the lastest version :
|
|
27
|
-
```
|
|
28
|
-
npm i @wizishop/img-manager-webelement@latest
|
|
29
|
-
```
|
|
18
|
+
## Running unit tests
|
|
30
19
|
|
|
31
|
-
|
|
32
|
-
Increment the package version number, then run the publish command:
|
|
20
|
+
Run `ng test ImgManagerWebElement` to execute the unit tests via [Karma](https://karma-runner.github.io).
|
|
33
21
|
|
|
34
|
-
|
|
35
|
-
npm run publish
|
|
36
|
-
```
|
|
22
|
+
## Further help
|
|
37
23
|
|
|
38
|
-
|
|
39
|
-
In order to retrieve the template data call the query : `ImageManagerTemplateQuery->getData()`.
|
|
40
|
-
Then display the data in the template.
|
|
41
|
-
|
|
42
|
-
Exemples :
|
|
43
|
-
|
|
44
|
-
In twig Controller :
|
|
45
|
-
```
|
|
46
|
-
return new Response(
|
|
47
|
-
TwigTool::render(
|
|
48
|
-
'...',
|
|
49
|
-
[
|
|
50
|
-
...
|
|
51
|
-
'imgManagerWebelement' => $this->imageManagerTemplateQuery->getData()
|
|
52
|
-
|
|
53
|
-
],
|
|
54
|
-
'...'
|
|
55
|
-
)
|
|
56
|
-
);
|
|
57
|
-
```
|
|
58
|
-
|
|
59
|
-
In twig Template :
|
|
60
|
-
```
|
|
61
|
-
{# Img manager webelement #}
|
|
62
|
-
{{ imgManagerWebelement |raw }}
|
|
63
|
-
```
|
|
64
|
-
|
|
65
|
-
In old php files :
|
|
66
|
-
```
|
|
67
|
-
<?= \_c\ContainerService\ContainerService::getImageManagerTemplateQuery()->getData()?>
|
|
68
|
-
```
|
|
69
|
-
|
|
70
|
-
## Open and retrieve img
|
|
71
|
-
This project works with events.
|
|
72
|
-
|
|
73
|
-
### Open the img manager module
|
|
74
|
-
Dispatch the `openImgManager` event
|
|
75
|
-
```
|
|
76
|
-
var value = {
|
|
77
|
-
detail: {
|
|
78
|
-
"fileId": fileId, // Optional : Not used yet
|
|
79
|
-
"from": "persoCss" // Optional : Use when the img manager is called from different place
|
|
80
|
-
}
|
|
81
|
-
};
|
|
82
|
-
var event = new CustomEvent('openImgManager', value);
|
|
83
|
-
var imgManagerModule= document.getElementById('imgManagerModule');
|
|
84
|
-
imgManagerModule.dispatchEvent(event);
|
|
85
|
-
```
|
|
86
|
-
|
|
87
|
-
### Retrieve Img selected
|
|
88
|
-
Listen to the event `imgSelected` from the element `imgManagerModule`.
|
|
89
|
-
```
|
|
90
|
-
// Listen event imgSelected from the img manager, and display the img selected
|
|
91
|
-
const imgManagerModule= document.getElementById('imgManagerModule');
|
|
92
|
-
imgManagerModule.addEventListener("imgSelected", (e) => {
|
|
93
|
-
// Optional : Add a check on from property to know which place expected an img : "e.detail.from === 'persoCss'"
|
|
94
|
-
if (e && e.detail && e.detail.file && e.detail.file.id_file) {
|
|
95
|
-
var fileId = e.detail.file.id_file;
|
|
96
|
-
// Display the img
|
|
97
|
-
}
|
|
98
|
-
} );
|
|
99
|
-
```
|
|
100
|
-
|
|
101
|
-
File object retrieved properties :
|
|
102
|
-
```
|
|
103
|
-
export interface ImgPictureDTO {
|
|
104
|
-
big_miniature: string;
|
|
105
|
-
category: string;
|
|
106
|
-
cropped: string;
|
|
107
|
-
date: string;
|
|
108
|
-
display_name: string;
|
|
109
|
-
file_name: string;
|
|
110
|
-
g_id: string;
|
|
111
|
-
id_file: string;
|
|
112
|
-
id_shop: string;
|
|
113
|
-
nb_used: string;
|
|
114
|
-
old_file_name: string;
|
|
115
|
-
raw_height: string;
|
|
116
|
-
raw_width: string;
|
|
117
|
-
size: string;
|
|
118
|
-
checked?: boolean;
|
|
119
|
-
selected?: boolean;
|
|
120
|
-
delSelected?: boolean;
|
|
121
|
-
deleted?: boolean;
|
|
122
|
-
imgNotLoaded?: boolean;
|
|
123
|
-
}
|
|
124
|
-
```
|
|
24
|
+
To get more help on the Angular CLI use `ng help` or go check out the [Angular CLI README](https://github.com/angular/angular-cli/blob/master/README.md).
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
// Use locally for this project
|
|
2
|
+
export const environmentWiziDevLocal = {
|
|
3
|
+
isWizishopcom: false,
|
|
4
|
+
production: false,
|
|
5
|
+
wizi_admin_api: "https://admin.wizilocal.com/",
|
|
6
|
+
wizi_api: "https://api.wizilocal.com/v3",
|
|
7
|
+
CDN_URL: "http://debugshop.wizilocal.com/_i/",
|
|
8
|
+
assets_route: "assets/img-manager/",
|
|
9
|
+
translations_route: "./assets/img-manager/i18n/",
|
|
10
|
+
wiziApiCredentialsKey: 'wizi_api_credentials_key',
|
|
11
|
+
local: {
|
|
12
|
+
shopId: 131,
|
|
13
|
+
token: 'eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJ1c2VyX2lkIjo2LCJ1c2VyX2xvY2FsZSI6ImZyX0ZSIiwiaXNVc2VyQ29ubmVjdGVkRnJvbVZwbiI6dHJ1ZSwiZXhwIjoxNjY3NTY3NDYwLCJpYXQiOjE2NjQ5NzU0NjB9.lapOlCngJBPszMTtwgjhYHu9et-Tcg-xCUBcu_h_lNfaAzYrG2EdSGAwJiF7_jJSuueO0pXpfBdNGVopVlEb9aR9gXai3IlKeM4h3VdhZIunNJ3niuZjXcMlQgeTkreYYBrulbSQZSToz2cDeGbCZpN_HVP4E2kLpDabtmcfrGE380zjF6wLRIAbWvj2z7UP509AW1A_JM-CrM99CVuZB0EoowPRk5nCKZoY9x4MYMGdW1rSgRvwuWjBn-y8J7wJfRHezx-7FkVIpulq4mmxOi6KAgLZTOFFKAxMCnTEeyW7kJOEmu5Lm3R9bKmjzQra1ikIYLT2-WCSFPbiEmaIzQ'
|
|
14
|
+
},
|
|
15
|
+
product_sheet_endpoint: "/products/ajax",
|
|
16
|
+
isPhotosTab: true
|
|
17
|
+
};
|
|
18
|
+
export const environmentWiziDev = {
|
|
19
|
+
isWizishopcom: true,
|
|
20
|
+
production: false,
|
|
21
|
+
wizi_admin_api: "https://admin.wizilocal.com/",
|
|
22
|
+
wizi_api: "https://api.wizilocal.com/v3",
|
|
23
|
+
CDN_URL: "https://media.wizilocal.com/_i/",
|
|
24
|
+
assets_route: "https://js.wizilocal.com/a/libs/img-manager-webelement/assets/img-manager/",
|
|
25
|
+
translations_route: "https://js.wizilocal.com/a/libs/img-manager-webelement/assets/img-manager/i18n/",
|
|
26
|
+
wiziApiCredentialsKey: 'wizi_api_credentials_key',
|
|
27
|
+
local: {
|
|
28
|
+
shopId: null,
|
|
29
|
+
token: null
|
|
30
|
+
},
|
|
31
|
+
product_sheet_endpoint: "/products/ajax"
|
|
32
|
+
};
|
|
33
|
+
export const environmentProd = {
|
|
34
|
+
isWizishopcom: true,
|
|
35
|
+
production: true,
|
|
36
|
+
wizi_admin_api: "https://admin.wizishop.com/",
|
|
37
|
+
wizi_api: "https://api.wizishop.com/v3",
|
|
38
|
+
CDN_URL: "https://media.cdnws.com/_i/",
|
|
39
|
+
assets_route: "https://js.wizishop.com/a/libs/img-manager-webelement/assets/img-manager/",
|
|
40
|
+
translations_route: "https://js.wizishop.com/a/libs/img-manager-webelement/assets/img-manager/i18n/",
|
|
41
|
+
wiziApiCredentialsKey: 'wizi_api_credentials_key',
|
|
42
|
+
local: {
|
|
43
|
+
shopId: null,
|
|
44
|
+
token: null
|
|
45
|
+
},
|
|
46
|
+
product_sheet_endpoint: "/products/ajax"
|
|
47
|
+
};
|
|
48
|
+
export const environmentDropiziDev = {
|
|
49
|
+
isWizishopcom: true,
|
|
50
|
+
production: false,
|
|
51
|
+
wizi_admin_api: "https://admin.dropilocal.com/",
|
|
52
|
+
wizi_api: "https://api.dropilocal.com/v3",
|
|
53
|
+
CDN_URL: "https://media.dropilocal.com/_i/",
|
|
54
|
+
assets_route: "https://js.dropilocal.fr/a/libs/img-manager-webelement/assets/img-manager/",
|
|
55
|
+
translations_route: "https://js.dropilocal.com/a/libs/img-manager-webelement/assets/img-manager/i18n/",
|
|
56
|
+
wiziApiCredentialsKey: 'wizi_api_credentials_key',
|
|
57
|
+
local: {
|
|
58
|
+
shopId: null,
|
|
59
|
+
token: null
|
|
60
|
+
},
|
|
61
|
+
product_sheet_endpoint: "/products/ajax"
|
|
62
|
+
};
|
|
63
|
+
export const environmentDropiziProd = {
|
|
64
|
+
isWizishopcom: true,
|
|
65
|
+
production: true,
|
|
66
|
+
wizi_admin_api: "https://admin.dropizi.fr/",
|
|
67
|
+
wizi_api: "https://api.wizishop.com/v3",
|
|
68
|
+
CDN_URL: "https://media.cdnws.com/_i/",
|
|
69
|
+
assets_route: "https://js.dropizi.fr/a/libs/img-manager-webelement/assets/img-manager/",
|
|
70
|
+
translations_route: "https://js.dropizi.fr/a/libs/img-manager-webelement/assets/img-manager/i18n/",
|
|
71
|
+
wiziApiCredentialsKey: 'wizi_api_credentials_key',
|
|
72
|
+
local: {
|
|
73
|
+
shopId: null,
|
|
74
|
+
token: null
|
|
75
|
+
},
|
|
76
|
+
product_sheet_endpoint: "/products/ajax"
|
|
77
|
+
};
|
|
78
|
+
function getCurrentEnv() {
|
|
79
|
+
const isDev = !!window.location.hostname.match(/local/);
|
|
80
|
+
const isWizi = !!window.location.hostname.match(/wizi/);
|
|
81
|
+
const serverLocal = !!window.location.port;
|
|
82
|
+
if (serverLocal) {
|
|
83
|
+
return environmentWiziDevLocal;
|
|
84
|
+
}
|
|
85
|
+
if (isDev) {
|
|
86
|
+
if (isWizi) {
|
|
87
|
+
return environmentWiziDev;
|
|
88
|
+
}
|
|
89
|
+
return environmentDropiziDev;
|
|
90
|
+
}
|
|
91
|
+
else {
|
|
92
|
+
if (isWizi) {
|
|
93
|
+
return environmentProd;
|
|
94
|
+
}
|
|
95
|
+
return environmentDropiziProd;
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
export const environment = Object.assign({}, getCurrentEnv());
|
|
99
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"environment.js","sourceRoot":"","sources":["../../../../../../projects/img-manager-web-element/src/lib/environments/environment.ts"],"names":[],"mappings":"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","sourcesContent":["export interface Environment {\n  isWizishopcom: boolean;\n  production: boolean;\n  wizi_admin_api: string;\n  wizi_api: string;\n  CDN_URL: string;\n  assets_route: string;\n  translations_route: string;\n  wiziApiCredentialsKey: string;\n  local: any;\n  product_sheet_endpoint: string;\n  isPhotosTab?: boolean;\n}\n\n// Use locally for this project\nexport const environmentWiziDevLocal: Environment = {\n  isWizishopcom: false,\n  production: false,\n  wizi_admin_api: \"https://admin.wizilocal.com/\",\n  wizi_api: \"https://api.wizilocal.com/v3\",\n  CDN_URL: \"http://debugshop.wizilocal.com/_i/\",\n  assets_route : \"assets/img-manager/\",\n  translations_route : \"./assets/img-manager/i18n/\",\n  wiziApiCredentialsKey: 'wizi_api_credentials_key',\n  local: {\n    shopId: 131,\n    token : 'eyJ0eXAiOiJKV1QiLCJhbGciOiJSUzI1NiJ9.eyJ1c2VyX2lkIjo2LCJ1c2VyX2xvY2FsZSI6ImZyX0ZSIiwiaXNVc2VyQ29ubmVjdGVkRnJvbVZwbiI6dHJ1ZSwiZXhwIjoxNjY3NTY3NDYwLCJpYXQiOjE2NjQ5NzU0NjB9.lapOlCngJBPszMTtwgjhYHu9et-Tcg-xCUBcu_h_lNfaAzYrG2EdSGAwJiF7_jJSuueO0pXpfBdNGVopVlEb9aR9gXai3IlKeM4h3VdhZIunNJ3niuZjXcMlQgeTkreYYBrulbSQZSToz2cDeGbCZpN_HVP4E2kLpDabtmcfrGE380zjF6wLRIAbWvj2z7UP509AW1A_JM-CrM99CVuZB0EoowPRk5nCKZoY9x4MYMGdW1rSgRvwuWjBn-y8J7wJfRHezx-7FkVIpulq4mmxOi6KAgLZTOFFKAxMCnTEeyW7kJOEmu5Lm3R9bKmjzQra1ikIYLT2-WCSFPbiEmaIzQ'\n  },\n  product_sheet_endpoint: \"/products/ajax\",\n  isPhotosTab: true\n};\n\nexport const environmentWiziDev: Environment = {\n  isWizishopcom: true,\n  production: false,\n  wizi_admin_api: \"https://admin.wizilocal.com/\",\n  wizi_api: \"https://api.wizilocal.com/v3\",\n  CDN_URL: \"https://media.wizilocal.com/_i/\",\n  assets_route : \"https://js.wizilocal.com/a/libs/img-manager-webelement/assets/img-manager/\",\n  translations_route : \"https://js.wizilocal.com/a/libs/img-manager-webelement/assets/img-manager/i18n/\",\n  wiziApiCredentialsKey: 'wizi_api_credentials_key',\n  local: {\n    shopId: null,\n    token : null\n  },\n  product_sheet_endpoint: \"/products/ajax\"\n};\n\nexport const environmentProd: Environment = {\n  isWizishopcom: true,\n  production: true,\n  wizi_admin_api: \"https://admin.wizishop.com/\",\n  wizi_api: \"https://api.wizishop.com/v3\",\n  CDN_URL: \"https://media.cdnws.com/_i/\",\n  assets_route : \"https://js.wizishop.com/a/libs/img-manager-webelement/assets/img-manager/\",\n  translations_route : \"https://js.wizishop.com/a/libs/img-manager-webelement/assets/img-manager/i18n/\",\n  wiziApiCredentialsKey: 'wizi_api_credentials_key',\n  local: {\n    shopId: null,\n    token : null\n  },\n  product_sheet_endpoint: \"/products/ajax\"\n};\n\nexport const environmentDropiziDev: Environment = {\n  isWizishopcom: true,\n  production: false,\n  wizi_admin_api: \"https://admin.dropilocal.com/\",\n  wizi_api: \"https://api.dropilocal.com/v3\",\n  CDN_URL: \"https://media.dropilocal.com/_i/\",\n  assets_route : \"https://js.dropilocal.fr/a/libs/img-manager-webelement/assets/img-manager/\",\n  translations_route : \"https://js.dropilocal.com/a/libs/img-manager-webelement/assets/img-manager/i18n/\",\n  wiziApiCredentialsKey: 'wizi_api_credentials_key',\n  local: {\n    shopId: null,\n    token : null\n  },\n  product_sheet_endpoint: \"/products/ajax\"\n};\n\nexport const environmentDropiziProd: Environment = {\n  isWizishopcom: true,\n  production: true,\n  wizi_admin_api: \"https://admin.dropizi.fr/\",\n  wizi_api: \"https://api.wizishop.com/v3\",\n  CDN_URL: \"https://media.cdnws.com/_i/\",\n  assets_route : \"https://js.dropizi.fr/a/libs/img-manager-webelement/assets/img-manager/\",\n  translations_route : \"https://js.dropizi.fr/a/libs/img-manager-webelement/assets/img-manager/i18n/\",\n  wiziApiCredentialsKey: 'wizi_api_credentials_key',\n  local: {\n    shopId: null,\n    token : null\n  },\n  product_sheet_endpoint: \"/products/ajax\"\n};\n\nfunction getCurrentEnv() {\n  const isDev = !!window.location.hostname.match(/local/);\n  const isWizi = !!window.location.hostname.match(/wizi/);\n  const serverLocal = !!window.location.port;\n\n  if (serverLocal) {\n    return environmentWiziDevLocal;\n  }\n  if (isDev) {\n    if (isWizi) {\n      return environmentWiziDev;\n    }\n    return environmentDropiziDev;\n  } else {\n    if (isWizi) {\n      return environmentProd;\n    }\n    return environmentDropiziProd;\n  }\n}\n\nexport const environment: Environment = Object.assign({}, getCurrentEnv());"]}
|
|
@@ -0,0 +1,177 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import { ImgManagerConfigDto, ImgApiDto, ImgCDNConfigDTO } from '@wizishop/img-manager';
|
|
3
|
+
import { from as fromPromise } from 'rxjs';
|
|
4
|
+
import { HttpHeaders } from '@angular/common/http';
|
|
5
|
+
import { environment } from './environments/environment';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@ngx-translate/core";
|
|
8
|
+
import * as i2 from "@wizishop/img-manager";
|
|
9
|
+
import * as i3 from "./services/fiche_products.service";
|
|
10
|
+
import * as i4 from "./services/auth-credentials.service";
|
|
11
|
+
import * as i5 from "@angular/common/http";
|
|
12
|
+
import * as i6 from "./services/event.service";
|
|
13
|
+
import * as i7 from "@angular/common";
|
|
14
|
+
import * as i8 from "dist/@wizishop/img-manager";
|
|
15
|
+
export class ImgManagerWebElementComponent {
|
|
16
|
+
constructor(translateService, imgSelectionService, canvaService, ficheProductService, authCredentialsService, http, eventService, imgManagerService) {
|
|
17
|
+
this.translateService = translateService;
|
|
18
|
+
this.imgSelectionService = imgSelectionService;
|
|
19
|
+
this.canvaService = canvaService;
|
|
20
|
+
this.ficheProductService = ficheProductService;
|
|
21
|
+
this.authCredentialsService = authCredentialsService;
|
|
22
|
+
this.http = http;
|
|
23
|
+
this.eventService = eventService;
|
|
24
|
+
this.imgManagerService = imgManagerService;
|
|
25
|
+
// img manger config
|
|
26
|
+
this.openImgManager = false;
|
|
27
|
+
this.loading = true;
|
|
28
|
+
// fiche roduct config
|
|
29
|
+
this.isPhotosTab = !!environment.isPhotosTab;
|
|
30
|
+
this.subscriptions = [];
|
|
31
|
+
}
|
|
32
|
+
ngOnInit() {
|
|
33
|
+
this.loading = true;
|
|
34
|
+
this.pageficheProductConfig = this.imgManagerService.getImgManagerDisplayConfig("fiche-product");
|
|
35
|
+
this.pageEventConfig = this.imgManagerService.getImgManagerDisplayConfig("wizi-block");
|
|
36
|
+
this.setCurrentLanguage();
|
|
37
|
+
// Search on which page is display the img manger
|
|
38
|
+
this.setDisplayedPageConfig();
|
|
39
|
+
const subCredentials = this.getCredentials().subscribe(authCredentials => {
|
|
40
|
+
this.loading = false;
|
|
41
|
+
this.initVariables(authCredentials);
|
|
42
|
+
// Fiche product page
|
|
43
|
+
if (this.imgManagerDisplayConfig.pageficheProduct) {
|
|
44
|
+
this.setFicheProductPage();
|
|
45
|
+
}
|
|
46
|
+
else {
|
|
47
|
+
this.setPageWithEvents();
|
|
48
|
+
}
|
|
49
|
+
});
|
|
50
|
+
this.subscriptions.push(subCredentials);
|
|
51
|
+
}
|
|
52
|
+
initVariables(authCredentials) {
|
|
53
|
+
if (!authCredentials) {
|
|
54
|
+
if (environment.isWizishopcom) {
|
|
55
|
+
return;
|
|
56
|
+
}
|
|
57
|
+
// Run on local Server
|
|
58
|
+
this.setAppVars(null, environment.local.shopId, null, environment.local.token);
|
|
59
|
+
this.setImgManagerExtraConfig();
|
|
60
|
+
this.imgManagerDisplayConfig = this.pageficheProductConfig;
|
|
61
|
+
return;
|
|
62
|
+
}
|
|
63
|
+
this.setAppVars(authCredentials.user_id, authCredentials.shop_id, authCredentials.account_id, authCredentials.token);
|
|
64
|
+
this.setImgManagerExtraConfig();
|
|
65
|
+
}
|
|
66
|
+
setFicheProductPage() {
|
|
67
|
+
this.ficheProductService.setApiConfig(this.id_shop, this.token_shop);
|
|
68
|
+
this.handleFicheProductTab(); // Display different img manager config according to the tab
|
|
69
|
+
this.closeImgManagerOnSwitchingTab();
|
|
70
|
+
this.subscribePageAskForImg(); // Use for images in variations tab
|
|
71
|
+
this.ficheProductService.updateImgSelectionOnChange();
|
|
72
|
+
}
|
|
73
|
+
setPageWithEvents() {
|
|
74
|
+
this.subscribePageAskForImg();
|
|
75
|
+
// Send img selected
|
|
76
|
+
const subImgSelection = this.imgSelectionService.getImgSelectionChange().subscribe(imgSelectionList => {
|
|
77
|
+
if (imgSelectionList && imgSelectionList.length) {
|
|
78
|
+
this.eventService.sendImgSelectedToPage(imgSelectionList[0]);
|
|
79
|
+
}
|
|
80
|
+
});
|
|
81
|
+
this.subscriptions.push(subImgSelection);
|
|
82
|
+
}
|
|
83
|
+
subscribePageAskForImg() {
|
|
84
|
+
// Listen to page editor ask for img event
|
|
85
|
+
const subAskForImg = this.eventService.pageAskForImg().subscribe(data => {
|
|
86
|
+
// Retrieve which img manager send the event
|
|
87
|
+
const emitter = data && data["detail"] ? data["detail"]["from"] : null;
|
|
88
|
+
this.eventService.setEmitter(emitter);
|
|
89
|
+
this.imgSelectionService.setImgSelection([]);
|
|
90
|
+
this.open();
|
|
91
|
+
});
|
|
92
|
+
this.subscriptions.push(subAskForImg);
|
|
93
|
+
}
|
|
94
|
+
open() {
|
|
95
|
+
this.openImgManager = true;
|
|
96
|
+
}
|
|
97
|
+
onImgManagerClosed() {
|
|
98
|
+
// Close img manager
|
|
99
|
+
this.openImgManager = false;
|
|
100
|
+
}
|
|
101
|
+
setCurrentLanguage() {
|
|
102
|
+
const matches = window.location.pathname.match(/^\/(\w+)\//);
|
|
103
|
+
this.translateService.use(matches && matches[1] ? matches[1] : 'fr');
|
|
104
|
+
}
|
|
105
|
+
setDisplayedPageConfig() {
|
|
106
|
+
const isFicheProductPage = /\/products\/(\d+\/edit|create)/.test(window.location.pathname);
|
|
107
|
+
this.imgManagerDisplayConfig = isFicheProductPage ? this.pageficheProductConfig : this.pageEventConfig;
|
|
108
|
+
}
|
|
109
|
+
handleFicheProductTab() {
|
|
110
|
+
const tabsSub = this.ficheProductService.handleTabs().subscribe(isPhotosTab => {
|
|
111
|
+
this.imgManagerDisplayConfig = isPhotosTab ? this.pageficheProductConfig : this.pageEventConfig;
|
|
112
|
+
this.isPhotosTab = isPhotosTab;
|
|
113
|
+
});
|
|
114
|
+
this.subscriptions.push(tabsSub);
|
|
115
|
+
}
|
|
116
|
+
closeImgManagerOnSwitchingTab() {
|
|
117
|
+
const tabsCloseSub = this.ficheProductService.switchTabs().subscribe(data => {
|
|
118
|
+
this.openImgManager = false;
|
|
119
|
+
});
|
|
120
|
+
this.subscriptions.push(tabsCloseSub);
|
|
121
|
+
}
|
|
122
|
+
getCredentials() {
|
|
123
|
+
return fromPromise(this.authCredentialsService.get());
|
|
124
|
+
}
|
|
125
|
+
setAppVars(userId, shopId, accountId, token) {
|
|
126
|
+
this.userId = userId;
|
|
127
|
+
this.id_shop = shopId;
|
|
128
|
+
this.accountId = accountId;
|
|
129
|
+
this.token_shop = token;
|
|
130
|
+
}
|
|
131
|
+
setImgManagerExtraConfig() {
|
|
132
|
+
const apiDto = new ImgApiDto();
|
|
133
|
+
apiDto.shop_token = this.token_shop;
|
|
134
|
+
apiDto.image_manager_route = environment.wizi_api + "/image-manager/shops/" + this.id_shop;
|
|
135
|
+
apiDto.canva_token = 'wdByHayF5v57nj2ZSLvu055O';
|
|
136
|
+
apiDto.canva_url = 'https://sdk.canva.com/designbutton/v2/api.js';
|
|
137
|
+
apiDto.pexels_token = '563492ad6f91700001000001e39215727d8b42c1b08498a9ce1e6b94';
|
|
138
|
+
apiDto.pexels_route = 'https://api.pexels.com/v1';
|
|
139
|
+
apiDto.shop_category = 'other'; // The shop categorie is retrieve later with the getShopCategory methode
|
|
140
|
+
apiDto.assets_route = environment.assets_route;
|
|
141
|
+
const imgCDNConfigDTO = new ImgCDNConfigDTO();
|
|
142
|
+
imgCDNConfigDTO.url_raw_image = `${environment.CDN_URL}${this.id_shop}/RAW-`;
|
|
143
|
+
imgCDNConfigDTO.url_100_image = `${environment.CDN_URL}${this.id_shop}/m100-`;
|
|
144
|
+
imgCDNConfigDTO.url_200_image = `${environment.CDN_URL}${this.id_shop}/cs200-`;
|
|
145
|
+
imgCDNConfigDTO.url_400_image = `${environment.CDN_URL}${this.id_shop}/cs400-`;
|
|
146
|
+
imgCDNConfigDTO.url_800_image = `${environment.CDN_URL}${this.id_shop}/cs800-`;
|
|
147
|
+
this.imgExternalConfig = new ImgManagerConfigDto();
|
|
148
|
+
this.imgExternalConfig.api = apiDto;
|
|
149
|
+
this.imgExternalConfig.imgCDNConfig = imgCDNConfigDTO;
|
|
150
|
+
const subShopCategory = this.getShopCategory().subscribe(shop => {
|
|
151
|
+
if (shop && shop['category']) {
|
|
152
|
+
this.imgExternalConfig.api.shop_category = shop['category'];
|
|
153
|
+
}
|
|
154
|
+
});
|
|
155
|
+
this.subscriptions.push(subShopCategory);
|
|
156
|
+
}
|
|
157
|
+
getShopCategory() {
|
|
158
|
+
return this.http.get(`${environment.wizi_api}/shops/${this.id_shop}`, this.getOptionsHeadersWithBearer());
|
|
159
|
+
}
|
|
160
|
+
getOptionsHeadersWithBearer() {
|
|
161
|
+
const header = { headers: new HttpHeaders({
|
|
162
|
+
Authorization: 'Bearer ' + this.token_shop
|
|
163
|
+
})
|
|
164
|
+
};
|
|
165
|
+
return header;
|
|
166
|
+
}
|
|
167
|
+
ngOnDestroy() {
|
|
168
|
+
this.subscriptions.forEach(sub => sub.unsubscribe());
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
ImgManagerWebElementComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.3", ngImport: i0, type: ImgManagerWebElementComponent, deps: [{ token: i1.TranslateService }, { token: i2.ImgSelectionService }, { token: i2.CanvaService }, { token: i3.FicheProductService }, { token: i4.AuthCredentialsService }, { token: i5.HttpClient }, { token: i6.EventService }, { token: i2.ImgManagerService }], target: i0.ɵɵFactoryTarget.Component });
|
|
172
|
+
ImgManagerWebElementComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.3", type: ImgManagerWebElementComponent, selector: "img-manager-webelement", ngImport: i0, template: "<div class=\"info-bulle\">\n <p class=\"info-bulle-content\" [innerHTML]=\"'ImgManager.webElement.infoBulle' | translate\"></p>\n\n <ng-container *ngIf=\"imgManagerDisplayConfig.pageficheProduct && isPhotosTab\">\n <h3 class=\"wizicss-sous-titre\">{{'ImgManager.webElement.photosTitle' | translate }}</h3>\n </ng-container>\n\n <ng-container *ngIf=\"!loading && id_shop && imgManagerDisplayConfig\">\n\n <p class=\"img-manager-open\" *ngIf=\"imgManagerDisplayConfig.displayBtn && isPhotosTab\">\n <a (click)=\"open()\">{{'ImgManager.webElement.OpenBtn' | translate }}</a>\n </p>\n\n <div class=\"imgManagerBox\">\n <wz-img-manager\n #wzImgManager\n [stateDisplayed]=\"imgManagerDisplayConfig.stateDisplayed\"\n [multipleImgMode]=\"imgManagerDisplayConfig.multipleImgMode\"\n [showImgManagerModule]=\"imgManagerDisplayConfig.showImgManagerModule && openImgManager\"\n [showSelection]=\"imgManagerDisplayConfig.showSelection\"\n [externalConfig]=\"imgExternalConfig\"\n (imgManagerClosed)=\"onImgManagerClosed()\">\n </wz-img-manager>\n </div>\n </ng-container>\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i8.WzImgManagerComponent, selector: "wz-img-manager", inputs: ["stateDisplayed", "showSelection", "externalConfig", "forceToOpenCanva", "multipleImgMode", "showImgManagerModule"], outputs: ["imgManagerClosed"] }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }] });
|
|
173
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.3", ngImport: i0, type: ImgManagerWebElementComponent, decorators: [{
|
|
174
|
+
type: Component,
|
|
175
|
+
args: [{ selector: 'img-manager-webelement', template: "<div class=\"info-bulle\">\n <p class=\"info-bulle-content\" [innerHTML]=\"'ImgManager.webElement.infoBulle' | translate\"></p>\n\n <ng-container *ngIf=\"imgManagerDisplayConfig.pageficheProduct && isPhotosTab\">\n <h3 class=\"wizicss-sous-titre\">{{'ImgManager.webElement.photosTitle' | translate }}</h3>\n </ng-container>\n\n <ng-container *ngIf=\"!loading && id_shop && imgManagerDisplayConfig\">\n\n <p class=\"img-manager-open\" *ngIf=\"imgManagerDisplayConfig.displayBtn && isPhotosTab\">\n <a (click)=\"open()\">{{'ImgManager.webElement.OpenBtn' | translate }}</a>\n </p>\n\n <div class=\"imgManagerBox\">\n <wz-img-manager\n #wzImgManager\n [stateDisplayed]=\"imgManagerDisplayConfig.stateDisplayed\"\n [multipleImgMode]=\"imgManagerDisplayConfig.multipleImgMode\"\n [showImgManagerModule]=\"imgManagerDisplayConfig.showImgManagerModule && openImgManager\"\n [showSelection]=\"imgManagerDisplayConfig.showSelection\"\n [externalConfig]=\"imgExternalConfig\"\n (imgManagerClosed)=\"onImgManagerClosed()\">\n </wz-img-manager>\n </div>\n </ng-container>\n</div>" }]
|
|
176
|
+
}], ctorParameters: function () { return [{ type: i1.TranslateService }, { type: i2.ImgSelectionService }, { type: i2.CanvaService }, { type: i3.FicheProductService }, { type: i4.AuthCredentialsService }, { type: i5.HttpClient }, { type: i6.EventService }, { type: i2.ImgManagerService }]; } });
|
|
177
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"img-manager-web-element.component.js","sourceRoot":"","sources":["../../../../../projects/img-manager-web-element/src/lib/img-manager-web-element.component.ts","../../../../../projects/img-manager-web-element/src/lib/img-manager-web-element.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component } from '@angular/core';\nimport { ImgManagerConfigDto, ImgApiDto, ImgCDNConfigDTO, ImgSelectionService, CanvaService, ImgManagerDisplayConfig, ImgManagerService } from '@wizishop/img-manager';\nimport { TranslateService } from '@ngx-translate/core';\nimport { Subscription, from as fromPromise, Observable } from 'rxjs';\nimport { FicheProductService } from './services/fiche_products.service';\nimport { AuthCredentials, AuthCredentialsService } from './services/auth-credentials.service';\nimport { HttpClient, HttpHeaders } from '@angular/common/http';\nimport { EventService } from './services/event.service';\nimport { environment } from './environments/environment';\n\n@Component({\n  selector: 'img-manager-webelement',\n  templateUrl: './img-manager-web-element.component.html',\n  styleUrls: ['./img-manager-web-element.component.scss']\n})\nexport class ImgManagerWebElementComponent {\n  // shop config\n  id_shop: number;\n  token_shop: string;\n  userId: number | null;\n  accountId: number | null;\n\n  // img manger config\n  openImgManager:boolean = false;\n  loading: boolean = true;\n  imgExternalConfig: ImgManagerConfigDto;\n  imgManagerDisplayConfig: ImgManagerDisplayConfig;\n  pageficheProductConfig: ImgManagerDisplayConfig;\n  pageEventConfig: ImgManagerDisplayConfig;\n\n  // fiche roduct config\n  isPhotosTab: boolean = !!environment.isPhotosTab;\n\n  subscriptions: Subscription[] = [];\n\n  constructor(\n    private translateService: TranslateService,\n    private imgSelectionService: ImgSelectionService,\n    private canvaService: CanvaService,\n    private ficheProductService: FicheProductService,\n    private authCredentialsService: AuthCredentialsService,\n    private http: HttpClient,\n    private eventService: EventService,\n    private imgManagerService: ImgManagerService\n  ){}\n\n  ngOnInit() {\n    this.loading = true;\n    this.pageficheProductConfig = this.imgManagerService.getImgManagerDisplayConfig(\"fiche-product\");\n    this.pageEventConfig = this.imgManagerService.getImgManagerDisplayConfig(\"wizi-block\");\n    this.setCurrentLanguage();\n    // Search on which page is display the img manger\n    this.setDisplayedPageConfig();\n\n    const subCredentials =\n      this.getCredentials().subscribe(authCredentials => {\n        this.loading = false;\n        this.initVariables(authCredentials);\n        // Fiche product page\n        if (this.imgManagerDisplayConfig.pageficheProduct) {\n          this.setFicheProductPage();\n        } else {\n          this.setPageWithEvents();\n        }\n      });\n    this.subscriptions.push(subCredentials);\n  }\n\n  initVariables(authCredentials: AuthCredentials | null) {\n    if (!authCredentials) {\n\n      if (environment.isWizishopcom) {\n        return;\n      }\n      // Run on local Server\n      this.setAppVars(null, environment.local.shopId, null,  environment.local.token);\n      this.setImgManagerExtraConfig();\n      this.imgManagerDisplayConfig = this.pageficheProductConfig;\n      return;\n    }\n\n    this.setAppVars(authCredentials.user_id, authCredentials.shop_id, authCredentials.account_id, authCredentials.token);\n    this.setImgManagerExtraConfig();\n  }\n\n  setFicheProductPage() {\n    this.ficheProductService.setApiConfig(this.id_shop, this.token_shop);\n    this.handleFicheProductTab(); // Display different img manager config according to the tab\n    this.closeImgManagerOnSwitchingTab();\n    this.subscribePageAskForImg(); // Use for images in variations tab\n    this.ficheProductService.updateImgSelectionOnChange();\n  }\n\n  setPageWithEvents() {\n    this.subscribePageAskForImg();\n\n    // Send img selected\n    const subImgSelection = this.imgSelectionService.getImgSelectionChange().subscribe(imgSelectionList => {\n      if (imgSelectionList && imgSelectionList.length) {\n        this.eventService.sendImgSelectedToPage(imgSelectionList[0]);\n      }\n    });\n    this.subscriptions.push(subImgSelection);\n  }\n\n  subscribePageAskForImg() {\n    // Listen to page editor ask for img event\n    const subAskForImg = this.eventService.pageAskForImg().subscribe( data => {\n      // Retrieve which img manager send the event\n      const emitter = data && data[\"detail\"] ? data[\"detail\"][\"from\"] : null;\n      this.eventService.setEmitter(emitter);\n\n      this.imgSelectionService.setImgSelection([]);\n\n      this.open();\n    });\n    this.subscriptions.push(subAskForImg);\n  }\n\n  open() {\n    this.openImgManager = true;\n  }\n\n  onImgManagerClosed() {\n    // Close img manager\n    this.openImgManager = false;\n  }\n\n  setCurrentLanguage() {\n    const matches = window.location.pathname.match( /^\\/(\\w+)\\//);\n    this.translateService.use(matches && matches[1] ? matches[1] : 'fr');\n  }\n\n  setDisplayedPageConfig() {\n    const isFicheProductPage = /\\/products\\/(\\d+\\/edit|create)/.test(window.location.pathname);\n    this.imgManagerDisplayConfig = isFicheProductPage ? this.pageficheProductConfig : this.pageEventConfig;\n  }\n\n  handleFicheProductTab() {\n    const tabsSub =\n      this.ficheProductService.handleTabs().subscribe(isPhotosTab => {\n        this.imgManagerDisplayConfig = isPhotosTab ? this.pageficheProductConfig : this.pageEventConfig;\n        this.isPhotosTab = isPhotosTab;\n      });\n    this.subscriptions.push(tabsSub);\n  }\n\n  closeImgManagerOnSwitchingTab() {\n    const tabsCloseSub =\n      this.ficheProductService.switchTabs().subscribe(data => {\n        this.openImgManager = false;\n      });\n\n    this.subscriptions.push(tabsCloseSub);\n  }\n\n  private getCredentials<AuthCredentials>() {\n    return fromPromise(this.authCredentialsService.get());\n  }\n\n  private setAppVars(userId: number | null, shopId: number, accountId: number| null, token: string) {\n    this.userId = userId;\n    this.id_shop = shopId;\n    this.accountId = accountId;\n    this.token_shop = token;\n  }\n\n  private setImgManagerExtraConfig() {\n    const apiDto = new ImgApiDto();\n    apiDto.shop_token = this.token_shop;\n    apiDto.image_manager_route = environment.wizi_api+ \"/image-manager/shops/\" + this.id_shop;\n    apiDto.canva_token = 'wdByHayF5v57nj2ZSLvu055O';\n    apiDto.canva_url = 'https://sdk.canva.com/designbutton/v2/api.js';\n    apiDto.pexels_token = '563492ad6f91700001000001e39215727d8b42c1b08498a9ce1e6b94';\n    apiDto.pexels_route = 'https://api.pexels.com/v1';\n    apiDto.shop_category = 'other'; // The shop categorie is retrieve later with the getShopCategory methode\n    apiDto.assets_route = environment.assets_route;\n\n    const imgCDNConfigDTO = new ImgCDNConfigDTO();\n    imgCDNConfigDTO.url_raw_image = `${environment.CDN_URL}${this.id_shop}/RAW-`;\n    imgCDNConfigDTO.url_100_image = `${environment.CDN_URL}${this.id_shop}/m100-`;\n    imgCDNConfigDTO.url_200_image = `${environment.CDN_URL}${this.id_shop}/cs200-`;\n    imgCDNConfigDTO.url_400_image = `${environment.CDN_URL}${this.id_shop}/cs400-`;\n    imgCDNConfigDTO.url_800_image = `${environment.CDN_URL}${this.id_shop}/cs800-`;\n\n    this.imgExternalConfig = new ImgManagerConfigDto();\n    this.imgExternalConfig.api = apiDto;\n    this.imgExternalConfig.imgCDNConfig = imgCDNConfigDTO;\n\n    const subShopCategory = this.getShopCategory().subscribe(shop => {\n      if (shop && shop['category']) {\n        this.imgExternalConfig.api.shop_category = shop['category'];\n      }\n    });\n    this.subscriptions.push(subShopCategory);\n  }\n\n  private getShopCategory(): Observable<any> {\n    return this.http.get(`${environment.wizi_api}/shops/${this.id_shop}`, this.getOptionsHeadersWithBearer());\n  }\n\n  private getOptionsHeadersWithBearer() {\n    const header = { headers: new HttpHeaders({\n      Authorization: 'Bearer ' + this.token_shop\n      })\n    };\n    return header;\n  }\n\n  ngOnDestroy() {\n    this.subscriptions.forEach(sub => sub.unsubscribe());\n  }\n}\n","<div class=\"info-bulle\">\n  <p class=\"info-bulle-content\" [innerHTML]=\"'ImgManager.webElement.infoBulle' | translate\"></p>\n\n  <ng-container *ngIf=\"imgManagerDisplayConfig.pageficheProduct && isPhotosTab\">\n    <h3 class=\"wizicss-sous-titre\">{{'ImgManager.webElement.photosTitle' | translate }}</h3>\n  </ng-container>\n\n  <ng-container *ngIf=\"!loading && id_shop && imgManagerDisplayConfig\">\n\n    <p class=\"img-manager-open\" *ngIf=\"imgManagerDisplayConfig.displayBtn && isPhotosTab\">\n      <a (click)=\"open()\">{{'ImgManager.webElement.OpenBtn' | translate }}</a>\n    </p>\n\n    <div class=\"imgManagerBox\">\n      <wz-img-manager\n        #wzImgManager\n        [stateDisplayed]=\"imgManagerDisplayConfig.stateDisplayed\"\n        [multipleImgMode]=\"imgManagerDisplayConfig.multipleImgMode\"\n        [showImgManagerModule]=\"imgManagerDisplayConfig.showImgManagerModule && openImgManager\"\n        [showSelection]=\"imgManagerDisplayConfig.showSelection\"\n        [externalConfig]=\"imgExternalConfig\"\n        (imgManagerClosed)=\"onImgManagerClosed()\">\n      </wz-img-manager>\n    </div>\n  </ng-container>\n</div>"]}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { HttpClientModule } from '@angular/common/http';
|
|
3
|
+
import { NgModule } from '@angular/core';
|
|
4
|
+
import { TranslateModule } from '@ngx-translate/core';
|
|
5
|
+
import { WzImgManagerModule } from 'dist/@wizishop/img-manager';
|
|
6
|
+
import { ImgManagerWebElementComponent } from './img-manager-web-element.component';
|
|
7
|
+
import { AuthCredentialsService } from './services/auth-credentials.service';
|
|
8
|
+
import { EventService } from './services/event.service';
|
|
9
|
+
import { FicheProductService } from './services/fiche_products.service';
|
|
10
|
+
import { StorageService } from './services/storage.service';
|
|
11
|
+
import * as i0 from "@angular/core";
|
|
12
|
+
export class ImgManagerWebElementModule {
|
|
13
|
+
}
|
|
14
|
+
ImgManagerWebElementModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.3", ngImport: i0, type: ImgManagerWebElementModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
15
|
+
ImgManagerWebElementModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.1.3", ngImport: i0, type: ImgManagerWebElementModule, declarations: [ImgManagerWebElementComponent], imports: [CommonModule,
|
|
16
|
+
HttpClientModule,
|
|
17
|
+
WzImgManagerModule,
|
|
18
|
+
TranslateModule], exports: [ImgManagerWebElementComponent] });
|
|
19
|
+
ImgManagerWebElementModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.1.3", ngImport: i0, type: ImgManagerWebElementModule, providers: [
|
|
20
|
+
StorageService,
|
|
21
|
+
FicheProductService,
|
|
22
|
+
EventService,
|
|
23
|
+
AuthCredentialsService
|
|
24
|
+
], imports: [CommonModule,
|
|
25
|
+
HttpClientModule,
|
|
26
|
+
WzImgManagerModule,
|
|
27
|
+
TranslateModule] });
|
|
28
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.3", ngImport: i0, type: ImgManagerWebElementModule, decorators: [{
|
|
29
|
+
type: NgModule,
|
|
30
|
+
args: [{
|
|
31
|
+
declarations: [ImgManagerWebElementComponent],
|
|
32
|
+
imports: [
|
|
33
|
+
CommonModule,
|
|
34
|
+
HttpClientModule,
|
|
35
|
+
WzImgManagerModule,
|
|
36
|
+
TranslateModule,
|
|
37
|
+
],
|
|
38
|
+
exports: [ImgManagerWebElementComponent],
|
|
39
|
+
providers: [
|
|
40
|
+
StorageService,
|
|
41
|
+
FicheProductService,
|
|
42
|
+
EventService,
|
|
43
|
+
AuthCredentialsService
|
|
44
|
+
]
|
|
45
|
+
}]
|
|
46
|
+
}] });
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1nLW1hbmFnZXItd2ViLWVsZW1lbnQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaW1nLW1hbmFnZXItd2ViLWVsZW1lbnQvc3JjL2xpYi9pbWctbWFuYWdlci13ZWItZWxlbWVudC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3RELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ2hFLE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQ3BGLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQzdFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUN4RCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUN4RSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sNEJBQTRCLENBQUM7O0FBb0I1RCxNQUFNLE9BQU8sMEJBQTBCOzt1SEFBMUIsMEJBQTBCO3dIQUExQiwwQkFBMEIsaUJBZnRCLDZCQUE2QixhQUUxQyxZQUFZO1FBQ1osZ0JBQWdCO1FBQ2hCLGtCQUFrQjtRQUNsQixlQUFlLGFBRVAsNkJBQTZCO3dIQVE1QiwwQkFBMEIsYUFQMUI7UUFDVCxjQUFjO1FBQ2QsbUJBQW1CO1FBQ25CLFlBQVk7UUFDWixzQkFBc0I7S0FDdkIsWUFYQyxZQUFZO1FBQ1osZ0JBQWdCO1FBQ2hCLGtCQUFrQjtRQUNsQixlQUFlOzJGQVVOLDBCQUEwQjtrQkFoQnRDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLENBQUMsNkJBQTZCLENBQUM7b0JBQzdDLE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLGdCQUFnQjt3QkFDaEIsa0JBQWtCO3dCQUNsQixlQUFlO3FCQUNoQjtvQkFDRCxPQUFPLEVBQUUsQ0FBQyw2QkFBNkIsQ0FBQztvQkFDeEMsU0FBUyxFQUFFO3dCQUNULGNBQWM7d0JBQ2QsbUJBQW1CO3dCQUNuQixZQUFZO3dCQUNaLHNCQUFzQjtxQkFDdkI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgSHR0cENsaWVudE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUcmFuc2xhdGVNb2R1bGUgfSBmcm9tICdAbmd4LXRyYW5zbGF0ZS9jb3JlJztcbmltcG9ydCB7IFd6SW1nTWFuYWdlck1vZHVsZSB9IGZyb20gJ2Rpc3QvQHdpemlzaG9wL2ltZy1tYW5hZ2VyJztcbmltcG9ydCB7IEltZ01hbmFnZXJXZWJFbGVtZW50Q29tcG9uZW50IH0gZnJvbSAnLi9pbWctbWFuYWdlci13ZWItZWxlbWVudC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQXV0aENyZWRlbnRpYWxzU2VydmljZSB9IGZyb20gJy4vc2VydmljZXMvYXV0aC1jcmVkZW50aWFscy5zZXJ2aWNlJztcbmltcG9ydCB7IEV2ZW50U2VydmljZSB9IGZyb20gJy4vc2VydmljZXMvZXZlbnQuc2VydmljZSc7XG5pbXBvcnQgeyBGaWNoZVByb2R1Y3RTZXJ2aWNlIH0gZnJvbSAnLi9zZXJ2aWNlcy9maWNoZV9wcm9kdWN0cy5zZXJ2aWNlJztcbmltcG9ydCB7IFN0b3JhZ2VTZXJ2aWNlIH0gZnJvbSAnLi9zZXJ2aWNlcy9zdG9yYWdlLnNlcnZpY2UnO1xuXG5cblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbSW1nTWFuYWdlcldlYkVsZW1lbnRDb21wb25lbnRdLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEh0dHBDbGllbnRNb2R1bGUsXG4gICAgV3pJbWdNYW5hZ2VyTW9kdWxlLFxuICAgIFRyYW5zbGF0ZU1vZHVsZSxcbiAgXSxcbiAgZXhwb3J0czogW0ltZ01hbmFnZXJXZWJFbGVtZW50Q29tcG9uZW50XSxcbiAgcHJvdmlkZXJzOiBbXG4gICAgU3RvcmFnZVNlcnZpY2UsXG4gICAgRmljaGVQcm9kdWN0U2VydmljZSxcbiAgICBFdmVudFNlcnZpY2UsXG4gICAgQXV0aENyZWRlbnRpYWxzU2VydmljZVxuICBdXG59KVxuZXhwb3J0IGNsYXNzIEltZ01hbmFnZXJXZWJFbGVtZW50TW9kdWxlIHsgfVxuIl19
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { environment } from '../environments/environment';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "./storage.service";
|
|
5
|
+
export class AuthCredentialsService {
|
|
6
|
+
constructor(storage) {
|
|
7
|
+
this.storage = storage;
|
|
8
|
+
this.credentials = null;
|
|
9
|
+
this.credentials$ = this.storage.subscribe(environment.wiziApiCredentialsKey);
|
|
10
|
+
}
|
|
11
|
+
get() {
|
|
12
|
+
if (this.credentials) {
|
|
13
|
+
return Promise.resolve(this.credentials);
|
|
14
|
+
}
|
|
15
|
+
return this.storage.get(environment.wiziApiCredentialsKey).then(token => {
|
|
16
|
+
this.credentials = token;
|
|
17
|
+
return this.credentials;
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
set(credentials) {
|
|
21
|
+
return this.storage.set(environment.wiziApiCredentialsKey, credentials).then(set => {
|
|
22
|
+
if (set) {
|
|
23
|
+
this.credentials = credentials;
|
|
24
|
+
}
|
|
25
|
+
return set;
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
remove() {
|
|
29
|
+
return this.storage.remove(environment.wiziApiCredentialsKey).then(removed => {
|
|
30
|
+
if (removed) {
|
|
31
|
+
this.credentials = null;
|
|
32
|
+
}
|
|
33
|
+
return removed;
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
AuthCredentialsService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.3", ngImport: i0, type: AuthCredentialsService, deps: [{ token: i1.StorageService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
38
|
+
AuthCredentialsService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.1.3", ngImport: i0, type: AuthCredentialsService });
|
|
39
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.3", ngImport: i0, type: AuthCredentialsService, decorators: [{
|
|
40
|
+
type: Injectable
|
|
41
|
+
}], ctorParameters: function () { return [{ type: i1.StorageService }]; } });
|
|
42
|
+
;
|
|
43
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC1jcmVkZW50aWFscy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaW1nLW1hbmFnZXItd2ViLWVsZW1lbnQvc3JjL2xpYi9zZXJ2aWNlcy9hdXRoLWNyZWRlbnRpYWxzLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUzQyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sNkJBQTZCLENBQUM7OztBQUkxRCxNQUFNLE9BQU8sc0JBQXNCO0lBS2pDLFlBQW9CLE9BQXVCO1FBQXZCLFlBQU8sR0FBUCxPQUFPLENBQWdCO1FBSm5DLGdCQUFXLEdBQTJCLElBQUksQ0FBQztRQUtqRCxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFrQixXQUFXLENBQUMscUJBQXFCLENBQUMsQ0FBQztJQUNqRyxDQUFDO0lBRUQsR0FBRztRQUNELElBQUksSUFBSSxDQUFDLFdBQVcsRUFBRTtZQUNwQixPQUFPLE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1NBQzFDO1FBQ0QsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsQ0FBUyxXQUFXLENBQUMscUJBQXFCLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEVBQUU7WUFDOUUsSUFBSSxDQUFDLFdBQVcsR0FBRyxLQUFLLENBQUM7WUFFekIsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDO1FBQzFCLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELEdBQUcsQ0FBQyxXQUE0QjtRQUM5QixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLFdBQVcsQ0FBQyxxQkFBcUIsRUFBRSxXQUFXLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUU7WUFDakYsSUFBSSxHQUFHLEVBQUU7Z0JBQ1AsSUFBSSxDQUFDLFdBQVcsR0FBRyxXQUFXLENBQUM7YUFDaEM7WUFDRCxPQUFPLEdBQUcsQ0FBQztRQUNiLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELE1BQU07UUFDSixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsRUFBRTtZQUMzRSxJQUFJLE9BQU8sRUFBRTtnQkFDWCxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQzthQUN6QjtZQUNELE9BQU8sT0FBTyxDQUFDO1FBQ2pCLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQzs7bUhBcENVLHNCQUFzQjt1SEFBdEIsc0JBQXNCOzJGQUF0QixzQkFBc0I7a0JBRGxDLFVBQVU7O0FBNkNWLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IGVudmlyb25tZW50IH0gZnJvbSAnLi4vZW52aXJvbm1lbnRzL2Vudmlyb25tZW50JztcbmltcG9ydCB7IFN0b3JhZ2VTZXJ2aWNlIH0gZnJvbSAnLi9zdG9yYWdlLnNlcnZpY2UnO1xuXG5ASW5qZWN0YWJsZSgpIC8vIHRvZG9cbmV4cG9ydCBjbGFzcyBBdXRoQ3JlZGVudGlhbHNTZXJ2aWNlIHtcbiAgcHJpdmF0ZSBjcmVkZW50aWFsczogQXV0aENyZWRlbnRpYWxzIHwgbnVsbCA9IG51bGw7XG5cbiAgY3JlZGVudGlhbHMkO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgc3RvcmFnZTogU3RvcmFnZVNlcnZpY2UpIHtcbiAgICB0aGlzLmNyZWRlbnRpYWxzJCA9IHRoaXMuc3RvcmFnZS5zdWJzY3JpYmU8QXV0aENyZWRlbnRpYWxzPihlbnZpcm9ubWVudC53aXppQXBpQ3JlZGVudGlhbHNLZXkpO1xuICB9XG5cbiAgZ2V0KCk6IFByb21pc2U8QXV0aENyZWRlbnRpYWxzIHwgbnVsbD4ge1xuICAgIGlmICh0aGlzLmNyZWRlbnRpYWxzKSB7XG4gICAgICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKHRoaXMuY3JlZGVudGlhbHMpO1xuICAgIH1cbiAgICByZXR1cm4gdGhpcy5zdG9yYWdlLmdldDxzdHJpbmc+KGVudmlyb25tZW50LndpemlBcGlDcmVkZW50aWFsc0tleSkudGhlbih0b2tlbiA9PiB7XG4gICAgICB0aGlzLmNyZWRlbnRpYWxzID0gdG9rZW47XG5cbiAgICAgIHJldHVybiB0aGlzLmNyZWRlbnRpYWxzO1xuICAgIH0pO1xuICB9XG5cbiAgc2V0KGNyZWRlbnRpYWxzOiBBdXRoQ3JlZGVudGlhbHMpOiBQcm9taXNlPGJvb2xlYW4+IHtcbiAgICByZXR1cm4gdGhpcy5zdG9yYWdlLnNldChlbnZpcm9ubWVudC53aXppQXBpQ3JlZGVudGlhbHNLZXksIGNyZWRlbnRpYWxzKS50aGVuKHNldCA9PiB7XG4gICAgICBpZiAoc2V0KSB7XG4gICAgICAgIHRoaXMuY3JlZGVudGlhbHMgPSBjcmVkZW50aWFscztcbiAgICAgIH1cbiAgICAgIHJldHVybiBzZXQ7XG4gICAgfSk7XG4gIH1cblxuICByZW1vdmUoKTogUHJvbWlzZTxib29sZWFuPiB7XG4gICAgcmV0dXJuIHRoaXMuc3RvcmFnZS5yZW1vdmUoZW52aXJvbm1lbnQud2l6aUFwaUNyZWRlbnRpYWxzS2V5KS50aGVuKHJlbW92ZWQgPT4ge1xuICAgICAgaWYgKHJlbW92ZWQpIHtcbiAgICAgICAgdGhpcy5jcmVkZW50aWFscyA9IG51bGw7XG4gICAgICB9XG4gICAgICByZXR1cm4gcmVtb3ZlZDtcbiAgICB9KTtcbiAgfVxufVxuXG5leHBvcnQgaW50ZXJmYWNlIEF1dGhDcmVkZW50aWFscyB7XG4gIHRva2VuOiBzdHJpbmc7XG4gIHVzZXJfaWQ6IG51bWJlcjtcbiAgYWNjb3VudF9pZDogbnVtYmVyO1xuICBzaG9wX2lkOiBudW1iZXI7XG59O1xuIl19
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { fromEvent } from 'rxjs';
|
|
3
|
+
import { environment } from '../environments/environment';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class EventService {
|
|
6
|
+
constructor() { }
|
|
7
|
+
sendImgSelectedToPage(file) {
|
|
8
|
+
const sendedFile = {
|
|
9
|
+
...file,
|
|
10
|
+
cdn_img_src: ''
|
|
11
|
+
};
|
|
12
|
+
if (sendedFile) {
|
|
13
|
+
sendedFile.cdn_img_src = `${environment.CDN_URL}${file.id_shop}/`;
|
|
14
|
+
}
|
|
15
|
+
const value = {
|
|
16
|
+
detail: {
|
|
17
|
+
sendedFile,
|
|
18
|
+
"from": this.emitter
|
|
19
|
+
}
|
|
20
|
+
};
|
|
21
|
+
const event = new CustomEvent('imgSelected', value);
|
|
22
|
+
const imgManagerModule = document.getElementById('imgManagerModule');
|
|
23
|
+
imgManagerModule?.dispatchEvent(event);
|
|
24
|
+
}
|
|
25
|
+
pageAskForImg() {
|
|
26
|
+
return fromEvent(document.getElementById('imgManagerModule'), "openImgManager");
|
|
27
|
+
}
|
|
28
|
+
setEmitter(emitter) {
|
|
29
|
+
this.emitter = emitter;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
EventService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.3", ngImport: i0, type: EventService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
33
|
+
EventService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.1.3", ngImport: i0, type: EventService });
|
|
34
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.3", ngImport: i0, type: EventService, decorators: [{
|
|
35
|
+
type: Injectable
|
|
36
|
+
}], ctorParameters: function () { return []; } });
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2ltZy1tYW5hZ2VyLXdlYi1lbGVtZW50L3NyYy9saWIvc2VydmljZXMvZXZlbnQuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTNDLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDakMsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLDZCQUE2QixDQUFDOztBQUcxRCxNQUFNLE9BQU8sWUFBWTtJQU12QixnQkFBZ0IsQ0FBQztJQUVqQixxQkFBcUIsQ0FBQyxJQUFvQjtRQUN4QyxNQUFNLFVBQVUsR0FBRztZQUNqQixHQUFHLElBQUk7WUFDUCxXQUFXLEVBQUUsRUFBRTtTQUNoQixDQUFDO1FBQ0YsSUFBSSxVQUFVLEVBQUU7WUFDZCxVQUFVLENBQUMsV0FBVyxHQUFHLEdBQUcsV0FBVyxDQUFDLE9BQU8sR0FBRyxJQUFJLENBQUMsT0FBTyxHQUFHLENBQUM7U0FDbkU7UUFFRCxNQUFNLEtBQUssR0FBRztZQUNFLE1BQU0sRUFBRTtnQkFDTixVQUFVO2dCQUNWLE1BQU0sRUFBRSxJQUFJLENBQUMsT0FBTzthQUNyQjtTQUNGLENBQUM7UUFDaEIsTUFBTSxLQUFLLEdBQUcsSUFBSSxXQUFXLENBQUMsYUFBYSxFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQ3BELE1BQU0sZ0JBQWdCLEdBQUUsUUFBUSxDQUFDLGNBQWMsQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1FBQ3BFLGdCQUFnQixFQUFFLGFBQWEsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN6QyxDQUFDO0lBRUQsYUFBYTtRQUNYLE9BQU8sU0FBUyxDQUFNLFFBQVEsQ0FBQyxjQUFjLENBQUMsa0JBQWtCLENBQVEsRUFBRSxnQkFBZ0IsQ0FBQyxDQUFDO0lBQzlGLENBQUM7SUFFRCxVQUFVLENBQUMsT0FBZTtRQUN4QixJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQztJQUN6QixDQUFDOzt5R0FsQ1UsWUFBWTs2R0FBWixZQUFZOzJGQUFaLFlBQVk7a0JBRHhCLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBJbWdQaWN0dXJlRFRPIH0gZnJvbSAnQHdpemlzaG9wL2ltZy1tYW5hZ2VyJztcbmltcG9ydCB7IGZyb21FdmVudCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgZW52aXJvbm1lbnQgfSBmcm9tICcuLi9lbnZpcm9ubWVudHMvZW52aXJvbm1lbnQnO1xuXG5ASW5qZWN0YWJsZSgpIC8vIHRvZG9cbmV4cG9ydCBjbGFzcyBFdmVudFNlcnZpY2Uge1xuXG4gIC8vIFNvbWV0aW1lcywgdGhlcmUgYXJlIG11bHRpcGxlIGltZyBtYW5hZ2VyIHRoYXQgbGlzdGVuIGF0IHRoZSBzYW1lIHRpbWUgYXQgaW1nU2VsZWN0ZWQgZXZlbnRcbiAgLy8gSXQgdXNlIGJ5IHRoZSBsaXN0ZW5lciwgdG8ga25vdyBpZiB0aGUgZXZlbnQgaXMgZm9yIGhpbVxuICBlbWl0dGVyOiBzdHJpbmc7XG5cbiAgY29uc3RydWN0b3IoKSB7IH1cblxuICBzZW5kSW1nU2VsZWN0ZWRUb1BhZ2UoZmlsZSA6IEltZ1BpY3R1cmVEVE8pIHtcbiAgICBjb25zdCBzZW5kZWRGaWxlID0ge1xuICAgICAgLi4uZmlsZSxcbiAgICAgIGNkbl9pbWdfc3JjOiAnJ1xuICAgIH07XG4gICAgaWYgKHNlbmRlZEZpbGUpIHtcbiAgICAgIHNlbmRlZEZpbGUuY2RuX2ltZ19zcmMgPSBgJHtlbnZpcm9ubWVudC5DRE5fVVJMfSR7ZmlsZS5pZF9zaG9wfS9gO1xuICAgIH1cblxuICAgIGNvbnN0IHZhbHVlID0ge1xuICAgICAgICAgICAgICAgICAgICBkZXRhaWw6IHtcbiAgICAgICAgICAgICAgICAgICAgICBzZW5kZWRGaWxlLFxuICAgICAgICAgICAgICAgICAgICAgIFwiZnJvbVwiOiB0aGlzLmVtaXR0ZXJcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgICAgfTtcbiAgICBjb25zdCBldmVudCA9IG5ldyBDdXN0b21FdmVudCgnaW1nU2VsZWN0ZWQnLCB2YWx1ZSk7XG4gICAgY29uc3QgaW1nTWFuYWdlck1vZHVsZT0gZG9jdW1lbnQuZ2V0RWxlbWVudEJ5SWQoJ2ltZ01hbmFnZXJNb2R1bGUnKTtcbiAgICBpbWdNYW5hZ2VyTW9kdWxlPy5kaXNwYXRjaEV2ZW50KGV2ZW50KTtcbiAgfVxuXG4gIHBhZ2VBc2tGb3JJbWcoKSB7XG4gICAgcmV0dXJuIGZyb21FdmVudDxhbnk+KGRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCdpbWdNYW5hZ2VyTW9kdWxlJykgYXMgYW55LCBcIm9wZW5JbWdNYW5hZ2VyXCIpO1xuICB9XG5cbiAgc2V0RW1pdHRlcihlbWl0dGVyOiBzdHJpbmcpIHtcbiAgICB0aGlzLmVtaXR0ZXIgPSBlbWl0dGVyO1xuICB9XG59Il19
|