@provoly/dashboard 0.23.8 → 0.23.10
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/assets/svgs/default-dashboard.svg +25 -0
- package/assets/svgs/default-restitution.svg +17 -5
- package/assets/svgs/default.svg +11 -27
- package/esm2022/lib/core/store/config/icon-definitions.interface.mjs +2 -1
- package/esm2022/presentation/components/add-edit-presentation/add-edit-presentation.component.mjs +6 -6
- package/esm2022/restitution/components/restitution-catalog/restitution-catalog.component.mjs +3 -3
- package/esm2022/widgets/widget-map/interaction/interaction-manager.class.mjs +5 -4
- package/fesm2022/provoly-dashboard-presentation.mjs +5 -5
- package/fesm2022/provoly-dashboard-presentation.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-restitution.mjs +2 -2
- package/fesm2022/provoly-dashboard-restitution.mjs.map +1 -1
- package/fesm2022/provoly-dashboard-widgets-widget-map.mjs +3 -2
- package/fesm2022/provoly-dashboard-widgets-widget-map.mjs.map +1 -1
- package/fesm2022/provoly-dashboard.mjs +2 -1
- package/fesm2022/provoly-dashboard.mjs.map +1 -1
- package/lib/core/store/config/icon-definitions.interface.d.ts +1 -0
- package/package.json +12 -12
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
<svg width="335" height="110" viewBox="0 0 335 110" fill="none" xmlns="http://www.w3.org/2000/svg">
|
|
2
|
+
<rect width="335" height="110" fill="#5982B0"/>
|
|
3
|
+
<rect x="118" y="13" width="100" height="83" rx="11" fill="#113B6E"/>
|
|
4
|
+
<g clip-path="url(#clip0_6691_19466)">
|
|
5
|
+
<path d="M159.65 54.9354C159.65 50.3111 163.405 46.5606 168.036 46.5606C168.036 41.7171 168.036 36.8706 168.036 32.027C167.098 31.946 166.175 32.0691 165.243 32.1802C160.194 32.7747 155.759 34.7926 152.186 38.3479C145.325 45.1733 143.412 53.353 146.299 62.5536C147.336 65.8597 149.149 68.8024 151.775 71.1656C155.22 67.7304 158.666 64.2952 162.112 60.86C160.591 59.3436 159.65 57.2476 159.65 54.9324V54.9354Z" fill="#9CCBB9"/>
|
|
6
|
+
<path d="M187.692 43.0143C183.128 35.8796 176.591 32.1141 168.036 32.027C168.036 36.8706 168.036 41.7171 168.036 46.5606C172.667 46.5606 176.419 50.3081 176.422 54.9325C181.276 54.9325 186.129 54.9325 190.979 54.9325C191.168 50.6054 189.993 46.6117 187.692 43.0143Z" fill="#F8A59A"/>
|
|
7
|
+
<path d="M190.979 54.9324C186.126 54.9324 181.273 54.9324 176.422 54.9324C176.422 54.9324 176.422 54.9324 176.422 54.9354C176.422 58.3857 174.333 61.3494 171.347 62.6316C173.256 67.1118 175.165 71.592 177.075 76.0722C180.635 74.7299 183.522 72.4568 185.876 69.5231C189.286 65.2711 191.159 60.4516 190.982 54.9324H190.979Z" fill="#A4C6F0"/>
|
|
8
|
+
<path d="M171.347 62.6316C170.33 63.067 169.212 63.3103 168.036 63.3103C165.724 63.3103 163.628 62.3764 162.112 60.863C158.667 64.2982 155.221 67.7334 151.775 71.1686C151.916 71.3398 152.039 71.5259 152.202 71.6791C156.381 75.5947 161.37 77.6817 167.059 77.97C170.52 78.1471 173.915 77.6246 177.078 76.0722C175.169 71.592 173.259 67.1118 171.35 62.6316H171.347Z" fill="#FFE5BA"/>
|
|
9
|
+
</g>
|
|
10
|
+
<rect x="13" y="13" width="100" height="83" rx="11" fill="#113B6E"/>
|
|
11
|
+
<path d="M72.8498 50.7837C60.9579 44.5293 46.719 51.0875 43.7329 64.1986C42.8738 67.9649 42.3132 68.4101 38.4418 68.4154C37.0693 68.4154 35.702 68.4206 34.3294 68.4154C30.9767 68.3944 29.5622 66.7653 30.1175 63.4496C30.9767 58.2952 32.8574 53.5495 35.8696 49.2594C47.0333 33.3563 69.586 30.2344 84.5531 42.5336C80.6502 45.2836 76.7526 48.0389 72.855 50.7889L72.8498 50.7837Z" fill="#9CCBB9"/>
|
|
12
|
+
<path d="M72.8497 50.7837C76.7474 48.0336 80.6502 45.2784 84.5478 42.5283C85.1084 42.2193 85.6846 41.9364 86.2242 41.6012C86.9943 41.1193 87.7591 40.8678 88.503 41.5907C89.1631 42.235 89.0007 42.9893 88.6445 43.7226C88.393 44.2412 88.1206 44.7545 87.8587 45.2679C85.3389 49.4218 82.819 53.5809 80.2992 57.7347C76.6793 62.8472 72.986 67.902 68.7321 72.5221C66.7414 74.6854 64.3683 75.6283 61.5184 74.8478C56.7459 73.5383 55.1743 68.033 58.459 63.9891C60.9736 60.8881 64.0435 58.3214 67.04 55.6971C68.9469 54.0261 70.9167 52.418 72.855 50.7837H72.8497Z" fill="white"/>
|
|
13
|
+
<path d="M80.2993 57.7347C82.8191 53.5809 85.339 49.4217 87.8588 45.2679C91.1749 49.2541 94.0824 53.4761 95.5388 58.5362C96.0993 60.4743 96.6965 62.4072 96.7384 64.4553C96.7908 67.0848 95.6331 68.3577 93.0451 68.4049C91.0858 68.4415 89.1266 68.4363 87.1673 68.4049C84.9775 68.3734 83.8616 67.4358 83.3535 65.2515C82.7301 62.5853 82.1067 59.919 80.2993 57.7295V57.7347Z" fill="#9CCBB9"/>
|
|
14
|
+
<path d="M282.952 68.3583C285.199 68.3583 287.452 68.3583 289.699 68.3583C291.899 68.3583 294.1 68.3635 296.3 68.3688C297.473 68.3792 298.652 68.3164 299.82 68.4159C301.984 68.6045 303.037 69.804 302.984 71.8522C302.932 73.8531 301.732 75.0422 299.59 75.0422C281.846 75.0579 264.108 75.0579 246.364 75.0422C244.237 75.0422 243.043 73.8269 243.001 71.8207C242.959 69.6993 244.164 68.4578 246.359 68.395C247.47 68.3635 248.575 68.3792 249.686 68.3792C251.875 68.3635 254.065 68.3478 256.255 68.3373C258.508 68.3478 260.755 68.3583 263.008 68.374C265.208 68.3688 267.403 68.3635 269.603 68.3583C271.856 68.3583 274.103 68.3635 276.356 68.3688C278.556 68.3688 280.757 68.3688 282.957 68.3688L282.952 68.3583Z" fill="white"/>
|
|
15
|
+
<rect x="223" y="13" width="100" height="83" rx="11" fill="#113B6E"/>
|
|
16
|
+
<path d="M269.603 68.3478C267.403 68.3531 265.208 68.3583 263.008 68.3636C262.987 58.521 262.961 48.6838 262.961 38.8413C262.961 36.395 264.113 35.0593 266.162 35.0017C268.268 34.9441 269.624 36.3688 269.624 38.8203C269.64 48.6628 269.614 58.5053 269.603 68.3478Z" fill="#FFE5BA"/>
|
|
17
|
+
<path d="M296.3 68.3635C294.1 68.3635 291.899 68.3583 289.699 68.3531C289.689 60.7106 289.657 53.0733 289.678 45.4309C289.683 43.0842 290.998 41.6856 293.031 41.6908C295.085 41.6908 296.337 43.058 296.337 45.4413C296.342 53.0838 296.316 60.7211 296.3 68.3635Z" fill="#F8A59A"/>
|
|
18
|
+
<path d="M282.952 68.3583C280.751 68.3583 278.551 68.3583 276.351 68.3583C276.34 61.7634 276.304 55.1686 276.325 48.579C276.33 46.468 277.802 44.9384 279.641 44.9542C281.516 44.9751 282.967 46.4628 282.973 48.5737C282.999 55.1686 282.962 61.7634 282.952 68.3583Z" fill="#A4C6F0"/>
|
|
19
|
+
<path d="M256.25 68.3321C254.06 68.3478 251.87 68.3635 249.681 68.374C249.654 62.832 249.597 57.2953 249.623 51.7533C249.633 49.6528 250.933 48.3904 252.871 48.3747C254.778 48.359 256.224 49.7681 256.266 51.9C256.334 55.42 256.292 58.9401 256.287 62.4654C256.287 64.4192 256.266 66.3783 256.255 68.3321H256.25Z" fill="#5DC19B"/>
|
|
20
|
+
<defs>
|
|
21
|
+
<clipPath id="clip0_6691_19466">
|
|
22
|
+
<rect width="46" height="46" fill="white" transform="translate(145 32)"/>
|
|
23
|
+
</clipPath>
|
|
24
|
+
</defs>
|
|
25
|
+
</svg>
|
|
@@ -1,6 +1,18 @@
|
|
|
1
|
-
<svg width="
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
1
|
+
<svg width="335" height="110" viewBox="0 0 335 110" fill="none" xmlns="http://www.w3.org/2000/svg">
|
|
2
|
+
<rect width="335" height="110" fill="#5982B0"/>
|
|
3
|
+
<g clip-path="url(#clip0_6691_19502)">
|
|
4
|
+
<path d="M76.7008 55.409C76.7008 48.8746 82.0077 43.575 88.5511 43.575C88.5511 36.7309 88.5511 29.8825 88.5511 23.0384C87.2254 22.9238 85.921 23.0978 84.6038 23.2548C77.4699 24.0949 71.2027 26.9463 66.155 31.9701C56.459 41.6147 53.7567 53.1729 57.8356 66.1737C59.3015 70.8454 61.8636 75.0036 65.5729 78.3429C70.4422 73.4888 75.3114 68.6347 80.1807 63.7806C78.0307 61.6378 76.7008 58.6762 76.7008 55.4047V55.409Z" fill="#9CCBB9"/>
|
|
5
|
+
<path d="M116.326 38.5637C109.876 28.4821 100.639 23.1613 88.551 23.0382C88.551 29.8823 88.551 36.7307 88.551 43.5748C95.0944 43.5748 100.397 48.8702 100.401 55.4046C107.259 55.4046 114.117 55.4046 120.97 55.4046C121.238 49.2903 119.577 43.6469 116.326 38.5637Z" fill="#F8A59A"/>
|
|
6
|
+
<path d="M120.97 55.4045C114.112 55.4045 107.255 55.4045 100.401 55.4045C100.401 55.4045 100.401 55.4045 100.401 55.4088C100.401 60.2841 97.4482 64.472 93.229 66.2838C95.9271 72.6145 98.6251 78.9452 101.323 85.2759C106.354 83.3793 110.433 80.1672 113.76 76.0217C118.578 70.0135 121.225 63.2034 120.974 55.4045H120.97Z" fill="#A4C6F0"/>
|
|
7
|
+
<path d="M93.229 66.2839C91.7929 66.8991 90.2123 67.2428 88.5509 67.2428C85.2835 67.2428 82.322 65.9232 80.1805 63.7847C75.3113 68.6388 70.442 73.4929 65.5728 78.347C65.7725 78.5888 65.9467 78.8519 66.1761 79.0683C72.0821 84.6013 79.1311 87.5502 87.17 87.9576C92.0605 88.2079 96.8576 87.4696 101.327 85.276C98.6294 78.9453 95.9313 72.6146 93.2332 66.2839H93.229Z" fill="#FFE5BA"/>
|
|
8
|
+
</g>
|
|
9
|
+
<rect x="153" y="34" width="94" height="6" rx="3" fill="#113B6E"/>
|
|
10
|
+
<rect x="153" y="46" width="94" height="6" rx="3" fill="#113B6E"/>
|
|
11
|
+
<rect x="153" y="58" width="94" height="6" rx="3" fill="#113B6E"/>
|
|
12
|
+
<rect x="153" y="70" width="94" height="6" rx="3" fill="#113B6E"/>
|
|
13
|
+
<defs>
|
|
14
|
+
<clipPath id="clip0_6691_19502">
|
|
15
|
+
<rect width="65" height="65" fill="white" transform="translate(56 23)"/>
|
|
16
|
+
</clipPath>
|
|
17
|
+
</defs>
|
|
6
18
|
</svg>
|
package/assets/svgs/default.svg
CHANGED
|
@@ -1,28 +1,12 @@
|
|
|
1
|
-
|
|
2
|
-
<
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
d="M 83.199219 145.066406 L 83.199219 369.066406 C 83.199219 375.464844 76.800781 381.867188 70.398438 381.867188 C 64 381.867188 57.601562 375.464844 57.601562 369.066406 L 57.601562 145.066406 C 57.601562 138.667969 64 132.265625 70.398438 132.265625 C 76.800781 132.265625 83.199219 136.535156 83.199219 145.066406 Z M 83.199219 145.066406 " />
|
|
13
|
-
<path style=" stroke:none;fill-rule:nonzero;fill:rgb(11.372549%,11.372549%,10.588235%);fill-opacity:1;"
|
|
14
|
-
d="M 91.734375 106.667969 L 49.066406 106.667969 C 40.535156 106.667969 34.132812 100.265625 34.132812 91.734375 L 34.132812 49.066406 C 34.132812 40.535156 40.535156 34.132812 49.066406 34.132812 L 93.867188 34.132812 C 100.265625 32 106.667969 40.535156 106.667969 49.066406 L 106.667969 93.867188 C 106.667969 100.265625 100.265625 106.667969 91.734375 106.667969 Z M 91.734375 106.667969 " />
|
|
15
|
-
<path style=" stroke:none;fill-rule:nonzero;fill:rgb(11.372549%,11.372549%,10.588235%);fill-opacity:1;"
|
|
16
|
-
d="M 462.933594 106.667969 L 418.132812 106.667969 C 411.734375 106.667969 405.332031 100.265625 405.332031 91.734375 L 405.332031 49.066406 C 405.332031 40.535156 411.734375 34.132812 420.265625 34.132812 L 465.066406 34.132812 C 473.601562 34.132812 480 40.535156 480 49.066406 L 480 93.867188 C 477.867188 100.265625 471.464844 106.667969 462.933594 106.667969 Z M 462.933594 106.667969 " />
|
|
17
|
-
<path style=" stroke:none;fill-rule:nonzero;fill:rgb(11.372549%,11.372549%,10.588235%);fill-opacity:1;"
|
|
18
|
-
d="M 462.933594 480 L 418.132812 480 C 409.601562 480 403.199219 473.601562 403.199219 465.066406 L 403.199219 420.265625 C 403.199219 411.734375 409.601562 405.332031 418.132812 405.332031 L 462.933594 405.332031 C 471.464844 405.332031 477.867188 411.734375 477.867188 420.265625 L 477.867188 465.066406 C 477.867188 471.464844 471.464844 480 462.933594 480 Z M 462.933594 480 " />
|
|
19
|
-
<path style=" stroke:none;fill-rule:nonzero;fill:rgb(11.372549%,11.372549%,10.588235%);fill-opacity:1;"
|
|
20
|
-
d="M 91.734375 480 L 49.066406 480 C 40.535156 480 34.132812 473.601562 34.132812 465.066406 L 34.132812 420.265625 C 34.132812 411.734375 40.535156 405.332031 49.066406 405.332031 L 93.867188 405.332031 C 100.265625 405.332031 106.667969 411.734375 106.667969 420.265625 L 106.667969 465.066406 C 106.667969 471.464844 100.265625 480 91.734375 480 Z M 91.734375 480 " />
|
|
21
|
-
<path style=" stroke:none;fill-rule:nonzero;fill:rgb(11.372549%,11.372549%,10.588235%);fill-opacity:1;"
|
|
22
|
-
d="M 168.535156 194.132812 L 256 243.199219 L 345.601562 194.132812 L 260.265625 145.066406 C 260.265625 145.066406 256 142.933594 251.734375 145.066406 C 247.464844 147.199219 168.535156 194.132812 168.535156 194.132812 Z M 168.535156 194.132812 " />
|
|
23
|
-
<path style=" stroke:none;fill-rule:nonzero;fill:rgb(11.372549%,11.372549%,10.588235%);fill-opacity:1;"
|
|
24
|
-
d="M 157.867188 217.601562 L 157.867188 307.199219 C 157.867188 307.199219 157.867188 313.601562 162.132812 315.734375 C 168.535156 320 243.199219 362.667969 243.199219 362.667969 L 243.199219 264.535156 Z M 157.867188 217.601562 " />
|
|
25
|
-
<path style=" stroke:none;fill-rule:nonzero;fill:rgb(11.372549%,11.372549%,10.588235%);fill-opacity:1;"
|
|
26
|
-
d="M 268.800781 264.535156 L 268.800781 362.667969 L 349.867188 315.734375 C 349.867188 315.734375 356.265625 311.464844 356.265625 307.199219 C 356.265625 302.933594 356.265625 217.601562 356.265625 217.601562 Z M 268.800781 264.535156 " />
|
|
27
|
-
</g>
|
|
1
|
+
<svg width="25" height="25" viewBox="0 0 25 25" fill="none" xmlns="http://www.w3.org/2000/svg">
|
|
2
|
+
<g clip-path="url(#clip0_6691_19392)">
|
|
3
|
+
<path d="M25.0001 22.343V2.66035H25.0011C24.9007 2.33339 24.84 1.98411 24.6945 1.68169C24.1881 0.631608 23.3615 0.0736472 22.2554 0.0122715C21.8338 -0.0111628 21.4089 0.00669192 20.9862 0.00669192H2.97074C1.63661 0.00669192 0.566172 0.766635 0.166457 2.03432C0.0618192 2.36463 0.00740767 2.72954 0.00740767 3.07883C-0.000963334 9.36147 -0.000963334 15.6441 0.00217579 21.9267C0.00322217 23.6743 1.23481 24.9944 2.87343 24.9955C9.29294 25 15.7135 25 22.133 24.9955C23.576 24.9944 24.6956 23.9778 24.9582 22.4635C24.9656 22.4222 24.9854 22.3832 25.0001 22.343Z" fill="#113B6E"/>
|
|
4
|
+
<path d="M12.6967 22.208C9.90602 22.208 7.11638 22.208 4.3257 22.2057C4.14049 22.2057 3.94796 22.2013 3.77007 22.1544C3.34315 22.0406 3.14643 21.6734 3.2563 21.2215C3.29502 21.0641 3.35571 20.909 3.42477 20.764C4.93887 17.5613 6.45507 14.3597 7.97127 11.1581C8.10835 10.8691 8.25693 10.5879 8.56875 10.4729C8.86592 10.3636 9.11182 10.4819 9.32737 10.6916C9.42887 10.791 9.51467 10.9081 9.59943 11.0253C11.0978 13.1121 12.5962 15.1977 14.0894 17.2879C14.3992 17.7208 14.7706 18.0456 15.3043 17.9195C15.5659 17.857 15.8275 17.684 16.0336 17.4932C16.4009 17.1528 16.7252 16.76 17.0716 16.3929C17.7109 15.7144 18.4256 15.778 18.9457 16.5659C19.9 18.0121 20.8511 19.4617 21.8002 20.9124C21.9822 21.1914 22.1831 21.486 22.0189 21.8442C21.8462 22.2202 21.4925 22.208 21.1671 22.208C18.344 22.2113 15.5209 22.2102 12.6977 22.2102L12.6967 22.208Z" fill="#A7DDC8"/>
|
|
5
|
+
<path d="M19 8.0069C18.9965 9.65977 17.6508 11.0023 15.9971 11C14.3469 10.9977 12.9977 9.64598 13 7.9977C13.0023 6.35173 14.3618 4.99656 16.0063 5.00001C17.6543 5.00345 19.0023 6.35748 19 8.0069Z" fill="#A7DDC8"/>
|
|
6
|
+
</g>
|
|
7
|
+
<defs>
|
|
8
|
+
<clipPath id="clip0_6691_19392">
|
|
9
|
+
<rect width="25" height="25" fill="white"/>
|
|
10
|
+
</clipPath>
|
|
11
|
+
</defs>
|
|
28
12
|
</svg>
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
export const DEFAULT_ICON_URL = '/assets/svgs/default.svg';
|
|
2
2
|
export const DEFAULT_RESTITUTION_ICON_URL = '/assets/svgs/default-restitution.svg';
|
|
3
|
+
export const DEFAULT_DASHBOARD_ICON_URL = '/assets/svgs/default-dashboard.svg';
|
|
3
4
|
export var IconPosition;
|
|
4
5
|
(function (IconPosition) {
|
|
5
6
|
IconPosition["FULL"] = "FULL";
|
|
@@ -16,4 +17,4 @@ export const compareOperationFunctions = {
|
|
|
16
17
|
LOWER_OR_EQUAL: (a, b) => parseInt(a, 10) <= parseInt(b, 10),
|
|
17
18
|
CONTAINS: (a, b) => (a + '').localeCompare(b + '') === 0
|
|
18
19
|
};
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWNvbi1kZWZpbml0aW9ucy5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9wcm92b2x5L2Rhc2hib2FyZC9saWIvY29yZS9zdG9yZS9jb25maWcvaWNvbi1kZWZpbml0aW9ucy5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBY0EsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQUcsMEJBQTBCLENBQUM7QUFDM0QsTUFBTSxDQUFDLE1BQU0sNEJBQTRCLEdBQUcsc0NBQXNDLENBQUM7QUFDbkYsTUFBTSxDQUFDLE1BQU0sMEJBQTBCLEdBQUcsb0NBQW9DLENBQUM7QUFFL0UsTUFBTSxDQUFOLElBQVksWUFNWDtBQU5ELFdBQVksWUFBWTtJQUN0Qiw2QkFBYSxDQUFBO0lBQ2IscUNBQXFCLENBQUE7SUFDckIsdUNBQXVCLENBQUE7SUFDdkIsMkNBQTJCLENBQUE7SUFDM0IsNkNBQTZCLENBQUE7QUFDL0IsQ0FBQyxFQU5XLFlBQVksS0FBWixZQUFZLFFBTXZCO0FBRUQsTUFBTSxDQUFDLE1BQU0seUJBQXlCLEdBQUc7SUFDdkMsTUFBTSxFQUFFLENBQUMsQ0FBTSxFQUFFLENBQU0sRUFBRSxFQUFFLENBQUMsQ0FBQyxLQUFLLENBQUM7SUFDbkMsT0FBTyxFQUFFLENBQUMsQ0FBTSxFQUFFLENBQU0sRUFBRSxFQUFFLENBQUMsUUFBUSxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsR0FBRyxRQUFRLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQztJQUM5RCxnQkFBZ0IsRUFBRSxDQUFDLENBQU0sRUFBRSxDQUFNLEVBQUUsRUFBRSxDQUFDLFFBQVEsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLElBQUksUUFBUSxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUM7SUFDeEUsS0FBSyxFQUFFLENBQUMsQ0FBTSxFQUFFLENBQU0sRUFBRSxFQUFFLENBQUMsUUFBUSxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsR0FBRyxRQUFRLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQztJQUM1RCxjQUFjLEVBQUUsQ0FBQyxDQUFNLEVBQUUsQ0FBTSxFQUFFLEVBQUUsQ0FBQyxRQUFRLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxJQUFJLFFBQVEsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDO0lBQ3RFLFFBQVEsRUFBRSxDQUFDLENBQU0sRUFBRSxDQUFNLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxDQUFDLEdBQUcsRUFBRSxDQUFDLEtBQUssQ0FBQztDQUNuRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVmFsdWVUeXBlIH0gZnJvbSAnLi4vLi4vbW9kZWwvaXRlbS5pbnRlcmZhY2UnO1xuXG5leHBvcnQgaW50ZXJmYWNlIEljb25PcHRpb25zIHtcbiAgaWNvblVybDogc3RyaW5nO1xuICBpY29uU2l6ZTogW251bWJlciwgbnVtYmVyXTtcbiAgcnVsZT86IEljb25SdWxlO1xuICBwb3NpdGlvbj86IEljb25Qb3NpdGlvbjtcbiAgaXNEZWZhdWx0PzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IHR5cGUgSWNvbkRlZmluaXRpb25zID0ge1xuICBbY2w6IHN0cmluZ106IEljb25PcHRpb25zW107XG59O1xuXG5leHBvcnQgY29uc3QgREVGQVVMVF9JQ09OX1VSTCA9ICcvYXNzZXRzL3N2Z3MvZGVmYXVsdC5zdmcnO1xuZXhwb3J0IGNvbnN0IERFRkFVTFRfUkVTVElUVVRJT05fSUNPTl9VUkwgPSAnL2Fzc2V0cy9zdmdzL2RlZmF1bHQtcmVzdGl0dXRpb24uc3ZnJztcbmV4cG9ydCBjb25zdCBERUZBVUxUX0RBU0hCT0FSRF9JQ09OX1VSTCA9ICcvYXNzZXRzL3N2Z3MvZGVmYXVsdC1kYXNoYm9hcmQuc3ZnJztcblxuZXhwb3J0IGVudW0gSWNvblBvc2l0aW9uIHtcbiAgRlVMTCA9ICdGVUxMJyxcbiAgVE9QX0xFRlQgPSAnVE9QX0xFRlQnLFxuICBUT1BfUklHSFQgPSAnVE9QX1JJR0hUJyxcbiAgQk9UVE9NX0xFRlQgPSAnQk9UVE9NX0xFRlQnLFxuICBCT1RUT01fUklHSFQgPSAnQk9UVE9NX1JJR0hUJ1xufVxuXG5leHBvcnQgY29uc3QgY29tcGFyZU9wZXJhdGlvbkZ1bmN0aW9ucyA9IHtcbiAgRVFVQUxTOiAoYTogYW55LCBiOiBhbnkpID0+IGEgPT09IGIsXG4gIEdSRUFURVI6IChhOiBhbnksIGI6IGFueSkgPT4gcGFyc2VJbnQoYSwgMTApID4gcGFyc2VJbnQoYiwgMTApLFxuICBHUkVBVEVSX09SX0VRVUFMOiAoYTogYW55LCBiOiBhbnkpID0+IHBhcnNlSW50KGEsIDEwKSA+PSBwYXJzZUludChiLCAxMCksXG4gIExPV0VSOiAoYTogYW55LCBiOiBhbnkpID0+IHBhcnNlSW50KGEsIDEwKSA8IHBhcnNlSW50KGIsIDEwKSxcbiAgTE9XRVJfT1JfRVFVQUw6IChhOiBhbnksIGI6IGFueSkgPT4gcGFyc2VJbnQoYSwgMTApIDw9IHBhcnNlSW50KGIsIDEwKSxcbiAgQ09OVEFJTlM6IChhOiBhbnksIGI6IGFueSkgPT4gKGEgKyAnJykubG9jYWxlQ29tcGFyZShiICsgJycpID09PSAwXG59O1xuXG5leHBvcnQgdHlwZSBDb21wYXJlT3BlcmF0aW9uID0ga2V5b2YgdHlwZW9mIGNvbXBhcmVPcGVyYXRpb25GdW5jdGlvbnM7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSWNvblJ1bGUge1xuICBhdHRyaWJ1dGVOYW1lOiBzdHJpbmc7XG4gIHZhbHVlOiBWYWx1ZVR5cGU7XG4gIG9wZXJhdGlvbjogQ29tcGFyZU9wZXJhdGlvbjtcbn1cbiJdfQ==
|
package/esm2022/presentation/components/add-edit-presentation/add-edit-presentation.component.mjs
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Component, EventEmitter, Input, Optional, Output } from '@angular/core';
|
|
2
2
|
import { FormControl, FormGroup, Validators } from '@angular/forms';
|
|
3
|
-
import { DashboardActions, DashboardGridLayout, DashboardSelectors,
|
|
3
|
+
import { DashboardActions, DashboardGridLayout, DashboardSelectors, DEFAULT_DASHBOARD_ICON_URL, LibraryTypes, SubscriptionnerDirective, ViewMode, WidgetPlacementUtils } from '@provoly/dashboard';
|
|
4
4
|
import { BehaviorSubject, combineLatest, take } from 'rxjs';
|
|
5
5
|
import { MetadataActions, MetadataSelectors } from '@provoly/dashboard/components/metadata-editor';
|
|
6
6
|
import { v4 as uuidv4 } from 'uuid';
|
|
@@ -23,7 +23,7 @@ export class PryAddEditPresentationComponent extends SubscriptionnerDirective {
|
|
|
23
23
|
this.selectedPresentation$ = new BehaviorSubject(null);
|
|
24
24
|
this.edition = false;
|
|
25
25
|
this.editionStartUrl = '/';
|
|
26
|
-
this.image =
|
|
26
|
+
this.image = DEFAULT_DASHBOARD_ICON_URL;
|
|
27
27
|
this.goBack = new EventEmitter();
|
|
28
28
|
this.type = LibraryTypes.ILLUSTRATION;
|
|
29
29
|
this.chosenLayout = DashboardGridLayout.FULL;
|
|
@@ -53,7 +53,7 @@ export class PryAddEditPresentationComponent extends SubscriptionnerDirective {
|
|
|
53
53
|
description: new FormControl(undefined, [Validators.maxLength(200)]),
|
|
54
54
|
theme: new FormControl('')
|
|
55
55
|
});
|
|
56
|
-
this.image = this.selectedPresentation$.value?.image ??
|
|
56
|
+
this.image = this.selectedPresentation$.value?.image ?? DEFAULT_DASHBOARD_ICON_URL;
|
|
57
57
|
this.subscriptions.add(this.selectedPresentation$.subscribe((presentation) => {
|
|
58
58
|
const theme = presentation?.metadata?.find((metadata) => metadata.metadataDef.name === '_theme')?.value;
|
|
59
59
|
if (!!theme)
|
|
@@ -82,7 +82,7 @@ export class PryAddEditPresentationComponent extends SubscriptionnerDirective {
|
|
|
82
82
|
id: this.selectedPresentation$.value?.id || uuidv4(),
|
|
83
83
|
name: this.form.value.name ?? '',
|
|
84
84
|
description: this.form.value.description ?? undefined,
|
|
85
|
-
image: this.image ??
|
|
85
|
+
image: this.image ?? DEFAULT_DASHBOARD_ICON_URL,
|
|
86
86
|
metadata: this.metadata()
|
|
87
87
|
};
|
|
88
88
|
this.subscriptions.add(this.staticManifest$.pipe(take(1)).subscribe((staticManifest) => {
|
|
@@ -105,7 +105,7 @@ export class PryAddEditPresentationComponent extends SubscriptionnerDirective {
|
|
|
105
105
|
...this.selectedPresentation$.value,
|
|
106
106
|
name: this.form.value.name ?? '',
|
|
107
107
|
description: this.form.value.description,
|
|
108
|
-
image: this.image ??
|
|
108
|
+
image: this.image ?? DEFAULT_DASHBOARD_ICON_URL,
|
|
109
109
|
metadata: this.metadata()
|
|
110
110
|
};
|
|
111
111
|
if (!this.edition) {
|
|
@@ -188,4 +188,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImpor
|
|
|
188
188
|
}], mode: [{
|
|
189
189
|
type: Input
|
|
190
190
|
}] } });
|
|
191
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-edit-presentation.component.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/presentation/components/add-edit-presentation/add-edit-presentation.component.ts","../../../../../../../projects/provoly/dashboard/presentation/components/add-edit-presentation/add-edit-presentation.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, EventEmitter, Input, OnInit, Optional, Output } from '@angular/core';\nimport { FormControl, FormGroup, Validators } from '@angular/forms';\nimport { Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport {\n  DashboardActions,\n  DashboardGridLayout,\n  DashboardSelectors,\n  DEFAULT_RESTITUTION_ICON_URL,\n  GlobalManifest,\n  IMetadata,\n  LibraryTypes,\n  ManifestDescription,\n  SubscriptionnerDirective,\n  ViewMode,\n  WidgetPlacementUtils\n} from '@provoly/dashboard';\nimport { BehaviorSubject, combineLatest, Observable, take } from 'rxjs';\nimport { MetadataActions, MetadataSelectors, MetaEventType } from '@provoly/dashboard/components/metadata-editor';\nimport { v4 as uuidv4 } from 'uuid';\n\n@Component({\n  selector: 'pry-add-edit-presentation',\n  templateUrl: './add-edit-presentation.component.html'\n})\nexport class PryAddEditPresentationComponent extends SubscriptionnerDirective implements OnInit, AfterViewInit {\n  staticManifest$: Observable<GlobalManifest>;\n  selectedPresentation$ = new BehaviorSubject<ManifestDescription | null>(null);\n  @Input() edition: boolean = false;\n  @Input() editionStartUrl: string = '/';\n  form!: FormGroup;\n  image: string = DEFAULT_RESTITUTION_ICON_URL;\n  @Output() goBack = new EventEmitter<void>();\n  type: LibraryTypes = LibraryTypes.ILLUSTRATION;\n  chosenLayout: string = DashboardGridLayout.FULL;\n  possibleThemes: string[] = [];\n  metadataDefs: IMetadata[] | undefined;\n  metadataThemeId: string = '';\n\n  @Input() set selectedPresentation(presentation: ManifestDescription | null) {\n    this.selectedPresentation$.next(presentation);\n  }\n\n  @Input() mode: 'theme' | 'meta' = 'meta';\n\n  constructor(protected store: Store, @Optional() protected router: Router) {\n    super();\n    this.store.dispatch(MetadataActions.loadMetadata());\n    this.staticManifest$ = this.store.select(DashboardSelectors.staticManifest);\n    combineLatest([this.staticManifest$, this.store.select(DashboardSelectors.gridLayout)]).subscribe(\n      ([staticManifest, gridLayout]) => {\n        this.chosenLayout =\n          this.edition && staticManifest.windows[0]?.grid?.layout !== undefined\n            ? staticManifest.windows[0]?.grid?.layout\n            : gridLayout;\n      }\n    );\n    this.subscriptions.add(\n      this.store.select(MetadataSelectors.metadata).subscribe((metadata) => {\n        this.metadataDefs = metadata;\n        const metadataTheme = metadata?.find((meta) => meta.name === '_theme');\n        if (metadataTheme) {\n          this.metadataThemeId = metadataTheme?.id ?? '';\n          this.possibleThemes = metadataTheme?.allowedValues ?? [];\n        }\n      })\n    );\n  }\n\n  ngOnInit(): void {\n    this.form = new FormGroup({\n      name: new FormControl(null, [Validators.required, Validators.maxLength(50)]),\n      description: new FormControl(undefined, [Validators.maxLength(200)]),\n      theme: new FormControl('')\n    });\n    this.image = this.selectedPresentation$.value?.image ?? DEFAULT_RESTITUTION_ICON_URL;\n    this.subscriptions.add(\n      this.selectedPresentation$.subscribe((presentation) => {\n        const theme = presentation?.metadata?.find((metadata) => metadata.metadataDef.name === '_theme')?.value;\n        if (!!theme) this.form.patchValue({ theme });\n      })\n    );\n  }\n\n  ngAfterViewInit() {\n    setTimeout(() => {\n      if (this.selectedPresentation$.value) this.form.patchValue(this.selectedPresentation$.value);\n    });\n  }\n\n  save() {\n    if (!this.edition) {\n      this.store.dispatch(DashboardActions.updateStaticManifest({ staticManifest: { windows: [] } }));\n    }\n    const presentation = this.dispatchSave();\n    this.store.dispatch(\n      DashboardActions.selectPresentation({\n        presentation,\n        viewMode: ViewMode.EDITION\n      })\n    );\n  }\n\n  dispatchSave(): ManifestDescription {\n    const presentation = {\n      ...this.selectedPresentation$.value!,\n      id: this.selectedPresentation$.value?.id || uuidv4(),\n      name: this.form.value.name ?? '',\n      description: this.form.value.description ?? undefined,\n      image: this.image ?? DEFAULT_RESTITUTION_ICON_URL,\n      metadata: this.metadata()\n    };\n\n    this.subscriptions.add(\n      this.staticManifest$.pipe(take(1)).subscribe((staticManifest) => {\n        this.store.dispatch(\n          DashboardActions.saveManifest({\n            ...presentation,\n            metadata: presentation.metadata?.map((metadata) => ({\n              metadataDefId: metadata.metadataDef.id,\n              value: metadata.value\n            })),\n            manifest: staticManifest\n          })\n        );\n      })\n    );\n    return presentation;\n  }\n\n  configureDashboard(selectedPresentation: ManifestDescription) {\n    if (this.form.valid) {\n      this.dispatchSave();\n    }\n\n    const presentation = {\n      ...this.selectedPresentation$.value!,\n      name: this.form.value.name ?? '',\n      description: this.form.value.description,\n      image: this.image ?? DEFAULT_RESTITUTION_ICON_URL,\n      metadata: this.metadata()\n    };\n\n    if (!this.edition) {\n      this.store.dispatch(\n        DashboardActions.updateManifest({\n          manifest: {\n            windows: [\n              {\n                widgets: [],\n                grid: {\n                  layout: this.chosenLayout,\n                  columns: WidgetPlacementUtils.getLayout(this.chosenLayout)?.columns,\n                  rows: WidgetPlacementUtils.getLayout(this.chosenLayout)?.rows\n                }\n              }\n            ]\n          },\n          selectedIds: [],\n          manifestId: selectedPresentation.id\n        })\n      );\n      this.store.dispatch(\n        DashboardActions.setInitialPresentation({\n          initial: { windows: [{ widgets: [], grid: { layout: this.chosenLayout as DashboardGridLayout } }] }\n        })\n      );\n      this.store.dispatch(\n        DashboardActions.selectPresentation({\n          presentation,\n          viewMode: ViewMode.CREATION\n        })\n      );\n    } else {\n      this.store.dispatch(\n        DashboardActions.loadPresentation({\n          presentation,\n          viewMode: ViewMode.EDITION\n        })\n      );\n    }\n    this.router?.navigateByUrl(this.editionStartUrl);\n  }\n\n  addMetadata(metadata: MetaEventType) {\n    this.store.dispatch(\n      DashboardActions.addManifestMetadata({\n        presentationId: this.selectedPresentation$.value?.id!,\n        metadataId: metadata.metadataId,\n        value: metadata.value ?? ''\n      })\n    );\n  }\n\n  removeMetadata(metadata: MetaEventType) {\n    this.store.dispatch(\n      DashboardActions.deleteManifestMetadata({\n        presentationId: this.selectedPresentation$.value?.id!,\n        metadataId: metadata.metadataId\n      })\n    );\n  }\n\n  close() {\n    this.goBack.emit();\n  }\n\n  metadata() {\n    return this.mode === 'theme'\n      ? !this.form.value.theme || this.form.value.theme === ''\n        ? []\n        : [\n            {\n              metadataDef: this.metadataDefs!.find((metadata) => metadata.id === this.metadataThemeId)!,\n              value: this.form.value.theme ?? ''\n            }\n          ]\n      : this.selectedPresentation$.value?.metadata ?? [];\n  }\n}\n","<div class=\"o-manifest-layout\">\n  <div class=\"o-manifest-layout__toolbox\">\n    <button class=\"a-btn a-btn--secondary\" type=\"button\" (click)=\"close()\">\n      {{ '@pry.toolbox.manifest.close' | i18n }}\n    </button>\n    <button class=\"a-btn a-btn--primary\" type=\"button\" (click)=\"save()\" [disabled]=\"form.invalid\">\n      {{ '@pry.toolbox.manifest.check' | i18n }}\n    </button>\n  </div>\n  <div class=\"o-manifest-layout__content--presentation\">\n    <h1 class=\"a-h1\">{{ '@pry.presentation.add' + '.pageTitle' | i18n }}</h1>\n    <div class=\"o-presentation-form-wrapper\">\n      <form [formGroup]=\"form\" class=\"o-presentation-form\">\n        <div class=\"m-form-label-field -width-full\">\n          <label class=\"a-label\" for=\"presentation_name\">{{ '@pry.presentation.form.name' | i18n }}</label>\n          <input\n            type=\"text\"\n            id=\"presentation_name\"\n            formControlName=\"name\"\n            placeholder=\"{{ '@pry.presentation.form.name' | i18n }}\"\n            class=\"a-form-field\"\n            maxlength=\"50\"\n            required\n          />\n          <label\n            for=\"presentation_name\"\n            *ngIf=\"form.get('name')?.touched && form.get('name')?.hasError('required')\"\n            class=\"a-label a-label--help -error\"\n          >\n            {{ '@pry.presentation.required' | i18n }}\n          </label>\n          <label\n            for=\"presentation_name\"\n            *ngIf=\"form.get('name')?.hasError('maxlength')\"\n            class=\"a-label a-label--help -error\"\n          >\n            {{ '@pry.presentation.maxLength' | i18n : { len: '50' } }}\n          </label>\n        </div>\n        <div class=\"m-form-label-field -width-full\">\n          <label class=\"a-label\" for=\"presentation_description\">{{\n            '@pry.presentation.form.description' | i18n\n          }}</label>\n          <textarea\n            formControlName=\"description\"\n            id=\"presentation_description\"\n            name=\"description\"\n            cols=\"30\"\n            rows=\"5\"\n            maxlength=\"200\"\n            placeholder=\"{{ '@pry.presentation.form.description' | i18n }}\"\n            class=\"a-form-field\"\n          ></textarea>\n          <label\n            for=\"presentation_description\"\n            *ngIf=\"form.get('description')?.hasError('maxlength')\"\n            class=\"a-label a-label--help -error\"\n          >\n            {{ '@pry.presentation.maxLength' | i18n : { len: '200' } }}\n          </label>\n        </div>\n        <div class=\"m-form-label-field -width-full\" *ngIf=\"mode === 'theme'\">\n          <label class=\"a-label\" for=\"presentation_theme\">{{ '@pry.presentation.form.theme' | i18n }}</label>\n          <pry-select\n            id=\"presentation_theme\"\n            [items]=\"possibleThemes\"\n            formControlName=\"theme\"\n            [clearable]=\"true\"\n          ></pry-select>\n        </div>\n        <div class=\"m-form-label-field -width-full\">\n          <label class=\"a-label\" for=\"presentation_image\">{{ '@pry.presentation.form.image' | i18n }}</label>\n          <div class=\"o-file-input\">\n            <pry-select-image\n              id=\"presentation_image\"\n              (changed)=\"image = $event\"\n              [iconUrl]=\"image\"\n              [mode]=\"type\"\n            ></pry-select-image>\n          </div>\n        </div>\n        <div class=\"m-form-label-field -width-full m-form-label-field--inline\">\n          <label class=\"a-label\">{{ '@pry.presentation.form.grid' | i18n }}</label>\n          <span class=\"a-label\">{{ '@pry.toolbox.layout.' + this.chosenLayout | i18n }}</span>\n          <pry-select-grid-layout *ngIf=\"!edition\"></pry-select-grid-layout>\n        </div>\n      </form>\n      <ng-container *ngIf=\"mode === 'meta'\">\n        <div class=\"o-presentation__metadata-editor\" *ngIf=\"selectedPresentation$ | async as selectedPresentation\">\n          <pry-metadata-editor\n            [targetId]=\"selectedPresentation.id\"\n            [isModification]=\"true\"\n            [metadata]=\"selectedPresentation.metadata ?? []\"\n            (removeMeta)=\"removeMetadata($event)\"\n            (addMeta)=\"addMetadata($event)\"\n            [type]=\"'meta'\"\n          ></pry-metadata-editor>\n        </div>\n      </ng-container>\n    </div>\n    <button\n      class=\"a-btn a-btn--primary\"\n      (click)=\"configureDashboard(selectedPresentation$.value!)\"\n      [disabled]=\"form.invalid\"\n    >\n      {{ '@pry.presentation.configuration' | i18n }}\n    </button>\n  </div>\n</div>\n"]}
|
|
191
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"add-edit-presentation.component.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/presentation/components/add-edit-presentation/add-edit-presentation.component.ts","../../../../../../../projects/provoly/dashboard/presentation/components/add-edit-presentation/add-edit-presentation.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAiB,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,QAAQ,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACxG,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAGpE,OAAO,EACL,gBAAgB,EAChB,mBAAmB,EACnB,kBAAkB,EAAE,0BAA0B,EAG9C,YAAY,EAEZ,wBAAwB,EACxB,QAAQ,EACR,oBAAoB,EACrB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,eAAe,EAAE,aAAa,EAAc,IAAI,EAAE,MAAM,MAAM,CAAC;AACxE,OAAO,EAAE,eAAe,EAAE,iBAAiB,EAAiB,MAAM,+CAA+C,CAAC;AAClH,OAAO,EAAE,EAAE,IAAI,MAAM,EAAE,MAAM,MAAM,CAAC;;;;;;;;;AAMpC,MAAM,OAAO,+BAAgC,SAAQ,wBAAwB;IAc3E,IAAa,oBAAoB,CAAC,YAAwC;QACxE,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAChD,CAAC;IAID,YAAsB,KAAY,EAAwB,MAAc;QACtE,KAAK,EAAE,CAAC;QADY,UAAK,GAAL,KAAK,CAAO;QAAwB,WAAM,GAAN,MAAM,CAAQ;QAlBxE,0BAAqB,GAAG,IAAI,eAAe,CAA6B,IAAI,CAAC,CAAC;QACrE,YAAO,GAAY,KAAK,CAAC;QACzB,oBAAe,GAAW,GAAG,CAAC;QAEvC,UAAK,GAAW,0BAA0B,CAAC;QACjC,WAAM,GAAG,IAAI,YAAY,EAAQ,CAAC;QAC5C,SAAI,GAAiB,YAAY,CAAC,YAAY,CAAC;QAC/C,iBAAY,GAAW,mBAAmB,CAAC,IAAI,CAAC;QAChD,mBAAc,GAAa,EAAE,CAAC;QAE9B,oBAAe,GAAW,EAAE,CAAC;QAMpB,SAAI,GAAqB,MAAM,CAAC;QAIvC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,eAAe,CAAC,YAAY,EAAE,CAAC,CAAC;QACpD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,kBAAkB,CAAC,cAAc,CAAC,CAAC;QAC5E,aAAa,CAAC,CAAC,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,kBAAkB,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,SAAS,CAC/F,CAAC,CAAC,cAAc,EAAE,UAAU,CAAC,EAAE,EAAE;YAC/B,IAAI,CAAC,YAAY;gBACf,IAAI,CAAC,OAAO,IAAI,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,KAAK,SAAS;oBACnE,CAAC,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM;oBACzC,CAAC,CAAC,UAAU,CAAC;QACnB,CAAC,CACF,CAAC;QACF,IAAI,CAAC,aAAa,CAAC,GAAG,CACpB,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,CAAC,QAAQ,EAAE,EAAE;YACnE,IAAI,CAAC,YAAY,GAAG,QAAQ,CAAC;YAC7B,MAAM,aAAa,GAAG,QAAQ,EAAE,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC;YACvE,IAAI,aAAa,EAAE,CAAC;gBAClB,IAAI,CAAC,eAAe,GAAG,aAAa,EAAE,EAAE,IAAI,EAAE,CAAC;gBAC/C,IAAI,CAAC,cAAc,GAAG,aAAa,EAAE,aAAa,IAAI,EAAE,CAAC;YAC3D,CAAC;QACH,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,IAAI,GAAG,IAAI,SAAS,CAAC;YACxB,IAAI,EAAE,IAAI,WAAW,CAAC,IAAI,EAAE,CAAC,UAAU,CAAC,QAAQ,EAAE,UAAU,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC;YAC5E,WAAW,EAAE,IAAI,WAAW,CAAC,SAAS,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC;YACpE,KAAK,EAAE,IAAI,WAAW,CAAC,EAAE,CAAC;SAC3B,CAAC,CAAC;QACH,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,qBAAqB,CAAC,KAAK,EAAE,KAAK,IAAI,0BAA0B,CAAC;QACnF,IAAI,CAAC,aAAa,CAAC,GAAG,CACpB,IAAI,CAAC,qBAAqB,CAAC,SAAS,CAAC,CAAC,YAAY,EAAE,EAAE;YACpD,MAAM,KAAK,GAAG,YAAY,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,KAAK,QAAQ,CAAC,EAAE,KAAK,CAAC;YACxG,IAAI,CAAC,CAAC,KAAK;gBAAE,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;QAC/C,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,eAAe;QACb,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,IAAI,CAAC,qBAAqB,CAAC,KAAK;gBAAE,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAC;QAC/F,CAAC,CAAC,CAAC;IACL,CAAC;IAED,IAAI;QACF,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAClB,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,gBAAgB,CAAC,oBAAoB,CAAC,EAAE,cAAc,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;QAClG,CAAC;QACD,MAAM,YAAY,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QACzC,IAAI,CAAC,KAAK,CAAC,QAAQ,CACjB,gBAAgB,CAAC,kBAAkB,CAAC;YAClC,YAAY;YACZ,QAAQ,EAAE,QAAQ,CAAC,OAAO;SAC3B,CAAC,CACH,CAAC;IACJ,CAAC;IAED,YAAY;QACV,MAAM,YAAY,GAAG;YACnB,GAAG,IAAI,CAAC,qBAAqB,CAAC,KAAM;YACpC,EAAE,EAAE,IAAI,CAAC,qBAAqB,CAAC,KAAK,EAAE,EAAE,IAAI,MAAM,EAAE;YACpD,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,IAAI,EAAE;YAChC,WAAW,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,IAAI,SAAS;YACrD,KAAK,EAAE,IAAI,CAAC,KAAK,IAAI,0BAA0B;YAC/C,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE;SAC1B,CAAC;QAEF,IAAI,CAAC,aAAa,CAAC,GAAG,CACpB,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,cAAc,EAAE,EAAE;YAC9D,IAAI,CAAC,KAAK,CAAC,QAAQ,CACjB,gBAAgB,CAAC,YAAY,CAAC;gBAC5B,GAAG,YAAY;gBACf,QAAQ,EAAE,YAAY,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;oBAClD,aAAa,EAAE,QAAQ,CAAC,WAAW,CAAC,EAAE;oBACtC,KAAK,EAAE,QAAQ,CAAC,KAAK;iBACtB,CAAC,CAAC;gBACH,QAAQ,EAAE,cAAc;aACzB,CAAC,CACH,CAAC;QACJ,CAAC,CAAC,CACH,CAAC;QACF,OAAO,YAAY,CAAC;IACtB,CAAC;IAED,kBAAkB,CAAC,oBAAyC;QAC1D,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;YACpB,IAAI,CAAC,YAAY,EAAE,CAAC;QACtB,CAAC;QAED,MAAM,YAAY,GAAG;YACnB,GAAG,IAAI,CAAC,qBAAqB,CAAC,KAAM;YACpC,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,IAAI,EAAE;YAChC,WAAW,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW;YACxC,KAAK,EAAE,IAAI,CAAC,KAAK,IAAI,0BAA0B;YAC/C,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE;SAC1B,CAAC;QAEF,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAClB,IAAI,CAAC,KAAK,CAAC,QAAQ,CACjB,gBAAgB,CAAC,cAAc,CAAC;gBAC9B,QAAQ,EAAE;oBACR,OAAO,EAAE;wBACP;4BACE,OAAO,EAAE,EAAE;4BACX,IAAI,EAAE;gCACJ,MAAM,EAAE,IAAI,CAAC,YAAY;gCACzB,OAAO,EAAE,oBAAoB,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,OAAO;gCACnE,IAAI,EAAE,oBAAoB,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,IAAI;6BAC9D;yBACF;qBACF;iBACF;gBACD,WAAW,EAAE,EAAE;gBACf,UAAU,EAAE,oBAAoB,CAAC,EAAE;aACpC,CAAC,CACH,CAAC;YACF,IAAI,CAAC,KAAK,CAAC,QAAQ,CACjB,gBAAgB,CAAC,sBAAsB,CAAC;gBACtC,OAAO,EAAE,EAAE,OAAO,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,YAAmC,EAAE,EAAE,CAAC,EAAE;aACpG,CAAC,CACH,CAAC;YACF,IAAI,CAAC,KAAK,CAAC,QAAQ,CACjB,gBAAgB,CAAC,kBAAkB,CAAC;gBAClC,YAAY;gBACZ,QAAQ,EAAE,QAAQ,CAAC,QAAQ;aAC5B,CAAC,CACH,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,KAAK,CAAC,QAAQ,CACjB,gBAAgB,CAAC,gBAAgB,CAAC;gBAChC,YAAY;gBACZ,QAAQ,EAAE,QAAQ,CAAC,OAAO;aAC3B,CAAC,CACH,CAAC;QACJ,CAAC;QACD,IAAI,CAAC,MAAM,EAAE,aAAa,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IACnD,CAAC;IAED,WAAW,CAAC,QAAuB;QACjC,IAAI,CAAC,KAAK,CAAC,QAAQ,CACjB,gBAAgB,CAAC,mBAAmB,CAAC;YACnC,cAAc,EAAE,IAAI,CAAC,qBAAqB,CAAC,KAAK,EAAE,EAAG;YACrD,UAAU,EAAE,QAAQ,CAAC,UAAU;YAC/B,KAAK,EAAE,QAAQ,CAAC,KAAK,IAAI,EAAE;SAC5B,CAAC,CACH,CAAC;IACJ,CAAC;IAED,cAAc,CAAC,QAAuB;QACpC,IAAI,CAAC,KAAK,CAAC,QAAQ,CACjB,gBAAgB,CAAC,sBAAsB,CAAC;YACtC,cAAc,EAAE,IAAI,CAAC,qBAAqB,CAAC,KAAK,EAAE,EAAG;YACrD,UAAU,EAAE,QAAQ,CAAC,UAAU;SAChC,CAAC,CACH,CAAC;IACJ,CAAC;IAED,KAAK;QACH,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;IACrB,CAAC;IAED,QAAQ;QACN,OAAO,IAAI,CAAC,IAAI,KAAK,OAAO;YAC1B,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,KAAK,EAAE;gBACtD,CAAC,CAAC,EAAE;gBACJ,CAAC,CAAC;oBACE;wBACE,WAAW,EAAE,IAAI,CAAC,YAAa,CAAC,IAAI,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,EAAE,KAAK,IAAI,CAAC,eAAe,CAAE;wBACzF,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,EAAE;qBACnC;iBACF;YACL,CAAC,CAAC,IAAI,CAAC,qBAAqB,CAAC,KAAK,EAAE,QAAQ,IAAI,EAAE,CAAC;IACvD,CAAC;8GAjMU,+BAA+B;kGAA/B,+BAA+B,uPCxB5C,6jJA6GA;;2FDrFa,+BAA+B;kBAJ3C,SAAS;+BACE,2BAA2B;;0BAuBA,QAAQ;yCAjBpC,OAAO;sBAAf,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBAGI,MAAM;sBAAf,MAAM;gBAOM,oBAAoB;sBAAhC,KAAK;gBAIG,IAAI;sBAAZ,KAAK","sourcesContent":["import { AfterViewInit, Component, EventEmitter, Input, OnInit, Optional, Output } from '@angular/core';\nimport { FormControl, FormGroup, Validators } from '@angular/forms';\nimport { Router } from '@angular/router';\nimport { Store } from '@ngrx/store';\nimport {\n  DashboardActions,\n  DashboardGridLayout,\n  DashboardSelectors, DEFAULT_DASHBOARD_ICON_URL,\n  GlobalManifest,\n  IMetadata,\n  LibraryTypes,\n  ManifestDescription,\n  SubscriptionnerDirective,\n  ViewMode,\n  WidgetPlacementUtils\n} from '@provoly/dashboard';\nimport { BehaviorSubject, combineLatest, Observable, take } from 'rxjs';\nimport { MetadataActions, MetadataSelectors, MetaEventType } from '@provoly/dashboard/components/metadata-editor';\nimport { v4 as uuidv4 } from 'uuid';\n\n@Component({\n  selector: 'pry-add-edit-presentation',\n  templateUrl: './add-edit-presentation.component.html'\n})\nexport class PryAddEditPresentationComponent extends SubscriptionnerDirective implements OnInit, AfterViewInit {\n  staticManifest$: Observable<GlobalManifest>;\n  selectedPresentation$ = new BehaviorSubject<ManifestDescription | null>(null);\n  @Input() edition: boolean = false;\n  @Input() editionStartUrl: string = '/';\n  form!: FormGroup;\n  image: string = DEFAULT_DASHBOARD_ICON_URL;\n  @Output() goBack = new EventEmitter<void>();\n  type: LibraryTypes = LibraryTypes.ILLUSTRATION;\n  chosenLayout: string = DashboardGridLayout.FULL;\n  possibleThemes: string[] = [];\n  metadataDefs: IMetadata[] | undefined;\n  metadataThemeId: string = '';\n\n  @Input() set selectedPresentation(presentation: ManifestDescription | null) {\n    this.selectedPresentation$.next(presentation);\n  }\n\n  @Input() mode: 'theme' | 'meta' = 'meta';\n\n  constructor(protected store: Store, @Optional() protected router: Router) {\n    super();\n    this.store.dispatch(MetadataActions.loadMetadata());\n    this.staticManifest$ = this.store.select(DashboardSelectors.staticManifest);\n    combineLatest([this.staticManifest$, this.store.select(DashboardSelectors.gridLayout)]).subscribe(\n      ([staticManifest, gridLayout]) => {\n        this.chosenLayout =\n          this.edition && staticManifest.windows[0]?.grid?.layout !== undefined\n            ? staticManifest.windows[0]?.grid?.layout\n            : gridLayout;\n      }\n    );\n    this.subscriptions.add(\n      this.store.select(MetadataSelectors.metadata).subscribe((metadata) => {\n        this.metadataDefs = metadata;\n        const metadataTheme = metadata?.find((meta) => meta.name === '_theme');\n        if (metadataTheme) {\n          this.metadataThemeId = metadataTheme?.id ?? '';\n          this.possibleThemes = metadataTheme?.allowedValues ?? [];\n        }\n      })\n    );\n  }\n\n  ngOnInit(): void {\n    this.form = new FormGroup({\n      name: new FormControl(null, [Validators.required, Validators.maxLength(50)]),\n      description: new FormControl(undefined, [Validators.maxLength(200)]),\n      theme: new FormControl('')\n    });\n    this.image = this.selectedPresentation$.value?.image ?? DEFAULT_DASHBOARD_ICON_URL;\n    this.subscriptions.add(\n      this.selectedPresentation$.subscribe((presentation) => {\n        const theme = presentation?.metadata?.find((metadata) => metadata.metadataDef.name === '_theme')?.value;\n        if (!!theme) this.form.patchValue({ theme });\n      })\n    );\n  }\n\n  ngAfterViewInit() {\n    setTimeout(() => {\n      if (this.selectedPresentation$.value) this.form.patchValue(this.selectedPresentation$.value);\n    });\n  }\n\n  save() {\n    if (!this.edition) {\n      this.store.dispatch(DashboardActions.updateStaticManifest({ staticManifest: { windows: [] } }));\n    }\n    const presentation = this.dispatchSave();\n    this.store.dispatch(\n      DashboardActions.selectPresentation({\n        presentation,\n        viewMode: ViewMode.EDITION\n      })\n    );\n  }\n\n  dispatchSave(): ManifestDescription {\n    const presentation = {\n      ...this.selectedPresentation$.value!,\n      id: this.selectedPresentation$.value?.id || uuidv4(),\n      name: this.form.value.name ?? '',\n      description: this.form.value.description ?? undefined,\n      image: this.image ?? DEFAULT_DASHBOARD_ICON_URL,\n      metadata: this.metadata()\n    };\n\n    this.subscriptions.add(\n      this.staticManifest$.pipe(take(1)).subscribe((staticManifest) => {\n        this.store.dispatch(\n          DashboardActions.saveManifest({\n            ...presentation,\n            metadata: presentation.metadata?.map((metadata) => ({\n              metadataDefId: metadata.metadataDef.id,\n              value: metadata.value\n            })),\n            manifest: staticManifest\n          })\n        );\n      })\n    );\n    return presentation;\n  }\n\n  configureDashboard(selectedPresentation: ManifestDescription) {\n    if (this.form.valid) {\n      this.dispatchSave();\n    }\n\n    const presentation = {\n      ...this.selectedPresentation$.value!,\n      name: this.form.value.name ?? '',\n      description: this.form.value.description,\n      image: this.image ?? DEFAULT_DASHBOARD_ICON_URL,\n      metadata: this.metadata()\n    };\n\n    if (!this.edition) {\n      this.store.dispatch(\n        DashboardActions.updateManifest({\n          manifest: {\n            windows: [\n              {\n                widgets: [],\n                grid: {\n                  layout: this.chosenLayout,\n                  columns: WidgetPlacementUtils.getLayout(this.chosenLayout)?.columns,\n                  rows: WidgetPlacementUtils.getLayout(this.chosenLayout)?.rows\n                }\n              }\n            ]\n          },\n          selectedIds: [],\n          manifestId: selectedPresentation.id\n        })\n      );\n      this.store.dispatch(\n        DashboardActions.setInitialPresentation({\n          initial: { windows: [{ widgets: [], grid: { layout: this.chosenLayout as DashboardGridLayout } }] }\n        })\n      );\n      this.store.dispatch(\n        DashboardActions.selectPresentation({\n          presentation,\n          viewMode: ViewMode.CREATION\n        })\n      );\n    } else {\n      this.store.dispatch(\n        DashboardActions.loadPresentation({\n          presentation,\n          viewMode: ViewMode.EDITION\n        })\n      );\n    }\n    this.router?.navigateByUrl(this.editionStartUrl);\n  }\n\n  addMetadata(metadata: MetaEventType) {\n    this.store.dispatch(\n      DashboardActions.addManifestMetadata({\n        presentationId: this.selectedPresentation$.value?.id!,\n        metadataId: metadata.metadataId,\n        value: metadata.value ?? ''\n      })\n    );\n  }\n\n  removeMetadata(metadata: MetaEventType) {\n    this.store.dispatch(\n      DashboardActions.deleteManifestMetadata({\n        presentationId: this.selectedPresentation$.value?.id!,\n        metadataId: metadata.metadataId\n      })\n    );\n  }\n\n  close() {\n    this.goBack.emit();\n  }\n\n  metadata() {\n    return this.mode === 'theme'\n      ? !this.form.value.theme || this.form.value.theme === ''\n        ? []\n        : [\n            {\n              metadataDef: this.metadataDefs!.find((metadata) => metadata.id === this.metadataThemeId)!,\n              value: this.form.value.theme ?? ''\n            }\n          ]\n      : this.selectedPresentation$.value?.metadata ?? [];\n  }\n}\n","<div class=\"o-manifest-layout\">\n  <div class=\"o-manifest-layout__toolbox\">\n    <button class=\"a-btn a-btn--secondary\" type=\"button\" (click)=\"close()\">\n      {{ '@pry.toolbox.manifest.close' | i18n }}\n    </button>\n    <button class=\"a-btn a-btn--primary\" type=\"button\" (click)=\"save()\" [disabled]=\"form.invalid\">\n      {{ '@pry.toolbox.manifest.check' | i18n }}\n    </button>\n  </div>\n  <div class=\"o-manifest-layout__content--presentation\">\n    <h1 class=\"a-h1\">{{ '@pry.presentation.add' + '.pageTitle' | i18n }}</h1>\n    <div class=\"o-presentation-form-wrapper\">\n      <form [formGroup]=\"form\" class=\"o-presentation-form\">\n        <div class=\"m-form-label-field -width-full\">\n          <label class=\"a-label\" for=\"presentation_name\">{{ '@pry.presentation.form.name' | i18n }}</label>\n          <input\n            type=\"text\"\n            id=\"presentation_name\"\n            formControlName=\"name\"\n            placeholder=\"{{ '@pry.presentation.form.name' | i18n }}\"\n            class=\"a-form-field\"\n            maxlength=\"50\"\n            required\n          />\n          <label\n            for=\"presentation_name\"\n            *ngIf=\"form.get('name')?.touched && form.get('name')?.hasError('required')\"\n            class=\"a-label a-label--help -error\"\n          >\n            {{ '@pry.presentation.required' | i18n }}\n          </label>\n          <label\n            for=\"presentation_name\"\n            *ngIf=\"form.get('name')?.hasError('maxlength')\"\n            class=\"a-label a-label--help -error\"\n          >\n            {{ '@pry.presentation.maxLength' | i18n : { len: '50' } }}\n          </label>\n        </div>\n        <div class=\"m-form-label-field -width-full\">\n          <label class=\"a-label\" for=\"presentation_description\">{{\n            '@pry.presentation.form.description' | i18n\n          }}</label>\n          <textarea\n            formControlName=\"description\"\n            id=\"presentation_description\"\n            name=\"description\"\n            cols=\"30\"\n            rows=\"5\"\n            maxlength=\"200\"\n            placeholder=\"{{ '@pry.presentation.form.description' | i18n }}\"\n            class=\"a-form-field\"\n          ></textarea>\n          <label\n            for=\"presentation_description\"\n            *ngIf=\"form.get('description')?.hasError('maxlength')\"\n            class=\"a-label a-label--help -error\"\n          >\n            {{ '@pry.presentation.maxLength' | i18n : { len: '200' } }}\n          </label>\n        </div>\n        <div class=\"m-form-label-field -width-full\" *ngIf=\"mode === 'theme'\">\n          <label class=\"a-label\" for=\"presentation_theme\">{{ '@pry.presentation.form.theme' | i18n }}</label>\n          <pry-select\n            id=\"presentation_theme\"\n            [items]=\"possibleThemes\"\n            formControlName=\"theme\"\n            [clearable]=\"true\"\n          ></pry-select>\n        </div>\n        <div class=\"m-form-label-field -width-full\">\n          <label class=\"a-label\" for=\"presentation_image\">{{ '@pry.presentation.form.image' | i18n }}</label>\n          <div class=\"o-file-input\">\n            <pry-select-image\n              id=\"presentation_image\"\n              (changed)=\"image = $event\"\n              [iconUrl]=\"image\"\n              [mode]=\"type\"\n            ></pry-select-image>\n          </div>\n        </div>\n        <div class=\"m-form-label-field -width-full m-form-label-field--inline\">\n          <label class=\"a-label\">{{ '@pry.presentation.form.grid' | i18n }}</label>\n          <span class=\"a-label\">{{ '@pry.toolbox.layout.' + this.chosenLayout | i18n }}</span>\n          <pry-select-grid-layout *ngIf=\"!edition\"></pry-select-grid-layout>\n        </div>\n      </form>\n      <ng-container *ngIf=\"mode === 'meta'\">\n        <div class=\"o-presentation__metadata-editor\" *ngIf=\"selectedPresentation$ | async as selectedPresentation\">\n          <pry-metadata-editor\n            [targetId]=\"selectedPresentation.id\"\n            [isModification]=\"true\"\n            [metadata]=\"selectedPresentation.metadata ?? []\"\n            (removeMeta)=\"removeMetadata($event)\"\n            (addMeta)=\"addMetadata($event)\"\n            [type]=\"'meta'\"\n          ></pry-metadata-editor>\n        </div>\n      </ng-container>\n    </div>\n    <button\n      class=\"a-btn a-btn--primary\"\n      (click)=\"configureDashboard(selectedPresentation$.value!)\"\n      [disabled]=\"form.invalid\"\n    >\n      {{ '@pry.presentation.configuration' | i18n }}\n    </button>\n  </div>\n</div>\n"]}
|
package/esm2022/restitution/components/restitution-catalog/restitution-catalog.component.mjs
CHANGED
|
@@ -76,13 +76,13 @@ export class PryRestitutionCatalogComponent {
|
|
|
76
76
|
}
|
|
77
77
|
}
|
|
78
78
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: PryRestitutionCatalogComponent, deps: [{ token: i1.Store }, { token: i2.Overlay }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
79
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: PryRestitutionCatalogComponent, selector: "pry-restitution-catalog", viewQueries: [{ propertyName: "templateActions", first: true, predicate: ["modalActions"], descendants: true, read: TemplateRef }], ngImport: i0, template: "<pry-restitution-css></pry-restitution-css>\n<div class=\"o-manifest-layout o-restitution-catalog\">\n <ng-template [ngIf]=\"selectedMode === mode.CATALOG\">\n <div class=\"o-manifest-layout__toolbox\">\n <button\n type=\"button\"\n (click)=\"selectMode(mode.CREATION)\"\n class=\"a-btn a-btn--primary\"\n data-tooltip-position=\"bottom\"\n *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'create' }\"\n >\n <pry-icon iconSvg=\"add\"></pry-icon>\n {{ '@pry.restitution.create' | i18n }}\n </button>\n <div>\n <div class=\"o-catalog__search o-manifest-layout__toolbox__search\">\n <label id=\"catalog-search-label\" for=\"catalog-search\" class=\"u-visually-hidden\">\n <span>{{ '@pry.toolbox.catalog.filter.name' | i18n }}</span>\n </label>\n <input\n id=\"catalog-search\"\n type=\"text\"\n class=\"a-form-field\"\n [placeholder]=\"'@pry.restitution.search' | i18n\"\n [ngModel]=\"search$ | async\"\n (ngModelChange)=\"this.search$.next($event)\"\n />\n\n <pry-icon iconSvg=\"search\" [width]=\"17\" [height]=\"17\"></pry-icon>\n </div>\n </div>\n </div>\n <div class=\"o-manifest-layout__content\">\n <h1 class=\"a-h1\">{{ '@pry.restitution.catalog' | i18n }}</h1>\n\n <div class=\"o-presentation-wrapper\">\n <ul class=\"o-presentation\">\n <li class=\"o-presentation__item\" *ngFor=\"let restitution of filteredRestitution$ | async; let index = index\">\n <div class=\"o-presentation__item__header\">\n <ng-container *ngIf=\"restitution.visibility?.type === PryVisibilityType.PRIVATE\">\n <pry-icon\n iconSvg=\"private\"\n class=\"is-private a-tooltip -tooltip-no-wrap\"\n [attr.data-tooltip]=\"'@pry.restitution.lock' | i18n\"\n [height]=\"17\"\n [width]=\"17\"\n ></pry-icon>\n </ng-container>\n <div\n class=\"a-tooltip -tooltip-no-wrap\"\n (click)=\"selectRestitution(restitution)\"\n [attr.data-tooltip]=\"'@pry.restitution.consultRestitution' | i18n\"\n >\n <div class=\"o-presentation__item__image\">\n <img\n alt=\"\"\n class=\"is-full-width\"\n [src]=\"restitution.image | getSecuredImage : [600, 600] | async\"\n
|
|
79
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.3", type: PryRestitutionCatalogComponent, selector: "pry-restitution-catalog", viewQueries: [{ propertyName: "templateActions", first: true, predicate: ["modalActions"], descendants: true, read: TemplateRef }], ngImport: i0, template: "<pry-restitution-css></pry-restitution-css>\n<div class=\"o-manifest-layout o-restitution-catalog\">\n <ng-template [ngIf]=\"selectedMode === mode.CATALOG\">\n <div class=\"o-manifest-layout__toolbox\">\n <button\n type=\"button\"\n (click)=\"selectMode(mode.CREATION)\"\n class=\"a-btn a-btn--primary\"\n data-tooltip-position=\"bottom\"\n *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'create' }\"\n >\n <pry-icon iconSvg=\"add\"></pry-icon>\n {{ '@pry.restitution.create' | i18n }}\n </button>\n <div>\n <div class=\"o-catalog__search o-manifest-layout__toolbox__search\">\n <label id=\"catalog-search-label\" for=\"catalog-search\" class=\"u-visually-hidden\">\n <span>{{ '@pry.toolbox.catalog.filter.name' | i18n }}</span>\n </label>\n <input\n id=\"catalog-search\"\n type=\"text\"\n class=\"a-form-field\"\n [placeholder]=\"'@pry.restitution.search' | i18n\"\n [ngModel]=\"search$ | async\"\n (ngModelChange)=\"this.search$.next($event)\"\n />\n\n <pry-icon iconSvg=\"search\" [width]=\"17\" [height]=\"17\"></pry-icon>\n </div>\n </div>\n </div>\n <div class=\"o-manifest-layout__content\">\n <h1 class=\"a-h1\">{{ '@pry.restitution.catalog' | i18n }}</h1>\n\n <div class=\"o-presentation-wrapper\">\n <ul class=\"o-presentation\">\n <li class=\"o-presentation__item\" *ngFor=\"let restitution of filteredRestitution$ | async; let index = index\">\n <div class=\"o-presentation__item__header\">\n <ng-container *ngIf=\"restitution.visibility?.type === PryVisibilityType.PRIVATE\">\n <pry-icon\n iconSvg=\"private\"\n class=\"is-private a-tooltip -tooltip-no-wrap\"\n [attr.data-tooltip]=\"'@pry.restitution.lock' | i18n\"\n [height]=\"17\"\n [width]=\"17\"\n ></pry-icon>\n </ng-container>\n <div\n class=\"a-tooltip -tooltip-no-wrap\"\n (click)=\"selectRestitution(restitution)\"\n [attr.data-tooltip]=\"'@pry.restitution.consultRestitution' | i18n\"\n >\n <div class=\"o-presentation__item__image\">\n <img\n alt=\"\"\n class=\"is-full-width\"\n [src]=\"restitution.image | getSecuredImage : [600, 600] | async\"\n />\n </div>\n </div>\n <ng-container *ngIf=\"restitution.owner\">\n <div class=\"more-button\">\n <button\n type=\"button\"\n class=\"a-btn a-btn--more a-tooltip -tooltip-no-wrap\"\n [id]=\"'more-actions-' + index\"\n [attr.data-tooltip]=\"'@pry.restitution.more' | i18n\"\n (click)=\"toggleModalActions(restitution, button)\"\n #button\n >\n <pry-icon [height]=\"25\" [width]=\"25\" iconSvg=\"more_horiz\"></pry-icon>\n </button>\n </div>\n </ng-container>\n </div>\n <div\n class=\"o-presentation__item__txt\"\n (click)=\"selectRestitution(restitution)\"\n [attr.data-tooltip]=\"'@pry.restitution.consultRestitution' | i18n\"\n >\n <div class=\"o-presentation__item__title-container\" ellipsis textElementSelector=\".a-h3\">\n <h3 class=\"a-h3\">{{ restitution.name }}</h3>\n </div>\n <div class=\"o-presentation__item__description-container\" ellipsis textElementSelector=\".a-p\">\n <div class=\"o-presentation__item__description a-p\">\n {{ restitution.description }}\n </div>\n </div>\n <p class=\"a-p -date\">{{ restitution.modificationDate | sinceDate }}</p>\n </div>\n\n <div\n class=\"o-presentation__item__footer a-tooltip -tooltip-no-wrap\"\n (click)=\"selectRestitution(restitution)\"\n [attr.data-tooltip]=\"'@pry.restitution.consultRestitution' | i18n\"\n >\n <button class=\"a-btn\">\n {{ '@pry.restitution.view' | i18n }}\n <pry-icon [width]=\"20\" [height]=\"20\" iconSvg=\"arrow_right\"></pry-icon>\n </button>\n </div>\n </li>\n </ul>\n </div>\n </div>\n </ng-template>\n <ng-template #modalActions>\n <div class=\"m-context-menu\">\n <ul\n *ngIf=\"selectedRestitution\"\n class=\"m-context-menu__list\"\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby=\"dialog restitution options\"\n >\n <li class=\"m-context-menu__list__item\">\n <button\n class=\"a-btn -link-like\"\n (click)=\"editRestitution(selectedRestitution)\"\n [disabled]=\"!selectedRestitution.owner\"\n *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'edit' }\"\n >\n {{ '@pry.restitution.update' | i18n }}\n </button>\n </li>\n <li class=\"m-context-menu__list__item\">\n <button\n class=\"a-btn -link-like\"\n #openModal\n (click)=\"deleteRestitution(selectedRestitution.id)\"\n [disabled]=\"!selectedRestitution.owner\"\n *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'delete' }\"\n >\n {{ '@pry.restitution.delete' | i18n }}\n </button>\n </li>\n </ul>\n </div>\n </ng-template>\n\n <ng-template [ngIf]=\"selectedMode === mode.CONSULT\">\n <div class=\"o-manifest-layout__toolbox\">\n <button type=\"button\" (click)=\"selectMode(mode.CATALOG)\" class=\"a-btn a-btn--primary\">\n {{ '@pry.restitution.backToCatalog' | i18n }}\n </button>\n </div>\n <div class=\"o-manifest-layout__content\">\n <pry-restitution\n [selectedRestitution]=\"selectedRestitution\"\n [edit]=\"false\"\n (restitutionCreated)=\"closeRestitution($event)\"\n class=\"restitution\"\n ></pry-restitution>\n </div>\n </ng-template>\n <ng-template [ngIf]=\"selectedMode === mode.CREATION\">\n <div class=\"o-manifest-layout__toolbox\">\n <button type=\"button\" (click)=\"selectMode(mode.CATALOG)\" class=\"a-btn a-btn--primary\">\n {{ '@pry.restitution.backToCatalog' | i18n }}\n </button>\n </div>\n <div class=\"o-manifest-layout__content\">\n <pry-restitution\n [edit]=\"false\"\n (restitutionCreated)=\"closeRestitution($event)\"\n class=\"restitution\"\n ></pry-restitution>\n </div>\n </ng-template>\n <ng-template [ngIf]=\"selectedMode === mode.EDITION\">\n <div class=\"o-manifest-layout__toolbox\">\n <button type=\"button\" (click)=\"selectMode(mode.CATALOG)\" class=\"a-btn a-btn--primary\">\n {{ '@pry.restitution.backToCatalog' | i18n }}\n </button>\n </div>\n <div class=\"o-manifest-layout__content\">\n <pry-restitution\n (restitutionCreated)=\"closeRestitution($event)\"\n [selectedRestitution]=\"selectedRestitution\"\n class=\"restitution\"\n ></pry-restitution>\n </div>\n </ng-template>\n</div>\n", dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.PryAccessDirective, selector: "[pryAccess]", inputs: ["pryAccess"] }, { kind: "directive", type: i4.EllipsisDirective, selector: "[ellipsis]", inputs: ["textElementSelector"] }, { kind: "component", type: i4.PryIconComponent, selector: "pry-icon", inputs: ["color", "iconSvg", "animation", "iconImage", "alt", "width", "height", "classes"] }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i6.PryRestitutionComponent, selector: "pry-restitution", inputs: ["selectedRestitution", "edit", "isDataSourceSelected", "bindId"], outputs: ["restitutionCreated"] }, { kind: "component", type: i7.PryCatalogCssComponent, selector: "pry-restitution-css" }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.GetSecuredImagePipe, name: "getSecuredImage" }, { kind: "pipe", type: i4.I18nPipe, name: "i18n" }, { kind: "pipe", type: i8.PrySinceDatePipe, name: "sinceDate" }] }); }
|
|
80
80
|
}
|
|
81
81
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.3", ngImport: i0, type: PryRestitutionCatalogComponent, decorators: [{
|
|
82
82
|
type: Component,
|
|
83
|
-
args: [{ selector: 'pry-restitution-catalog', template: "<pry-restitution-css></pry-restitution-css>\n<div class=\"o-manifest-layout o-restitution-catalog\">\n <ng-template [ngIf]=\"selectedMode === mode.CATALOG\">\n <div class=\"o-manifest-layout__toolbox\">\n <button\n type=\"button\"\n (click)=\"selectMode(mode.CREATION)\"\n class=\"a-btn a-btn--primary\"\n data-tooltip-position=\"bottom\"\n *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'create' }\"\n >\n <pry-icon iconSvg=\"add\"></pry-icon>\n {{ '@pry.restitution.create' | i18n }}\n </button>\n <div>\n <div class=\"o-catalog__search o-manifest-layout__toolbox__search\">\n <label id=\"catalog-search-label\" for=\"catalog-search\" class=\"u-visually-hidden\">\n <span>{{ '@pry.toolbox.catalog.filter.name' | i18n }}</span>\n </label>\n <input\n id=\"catalog-search\"\n type=\"text\"\n class=\"a-form-field\"\n [placeholder]=\"'@pry.restitution.search' | i18n\"\n [ngModel]=\"search$ | async\"\n (ngModelChange)=\"this.search$.next($event)\"\n />\n\n <pry-icon iconSvg=\"search\" [width]=\"17\" [height]=\"17\"></pry-icon>\n </div>\n </div>\n </div>\n <div class=\"o-manifest-layout__content\">\n <h1 class=\"a-h1\">{{ '@pry.restitution.catalog' | i18n }}</h1>\n\n <div class=\"o-presentation-wrapper\">\n <ul class=\"o-presentation\">\n <li class=\"o-presentation__item\" *ngFor=\"let restitution of filteredRestitution$ | async; let index = index\">\n <div class=\"o-presentation__item__header\">\n <ng-container *ngIf=\"restitution.visibility?.type === PryVisibilityType.PRIVATE\">\n <pry-icon\n iconSvg=\"private\"\n class=\"is-private a-tooltip -tooltip-no-wrap\"\n [attr.data-tooltip]=\"'@pry.restitution.lock' | i18n\"\n [height]=\"17\"\n [width]=\"17\"\n ></pry-icon>\n </ng-container>\n <div\n class=\"a-tooltip -tooltip-no-wrap\"\n (click)=\"selectRestitution(restitution)\"\n [attr.data-tooltip]=\"'@pry.restitution.consultRestitution' | i18n\"\n >\n <div class=\"o-presentation__item__image\">\n <img\n alt=\"\"\n class=\"is-full-width\"\n [src]=\"restitution.image | getSecuredImage : [600, 600] | async\"\n
|
|
83
|
+
args: [{ selector: 'pry-restitution-catalog', template: "<pry-restitution-css></pry-restitution-css>\n<div class=\"o-manifest-layout o-restitution-catalog\">\n <ng-template [ngIf]=\"selectedMode === mode.CATALOG\">\n <div class=\"o-manifest-layout__toolbox\">\n <button\n type=\"button\"\n (click)=\"selectMode(mode.CREATION)\"\n class=\"a-btn a-btn--primary\"\n data-tooltip-position=\"bottom\"\n *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'create' }\"\n >\n <pry-icon iconSvg=\"add\"></pry-icon>\n {{ '@pry.restitution.create' | i18n }}\n </button>\n <div>\n <div class=\"o-catalog__search o-manifest-layout__toolbox__search\">\n <label id=\"catalog-search-label\" for=\"catalog-search\" class=\"u-visually-hidden\">\n <span>{{ '@pry.toolbox.catalog.filter.name' | i18n }}</span>\n </label>\n <input\n id=\"catalog-search\"\n type=\"text\"\n class=\"a-form-field\"\n [placeholder]=\"'@pry.restitution.search' | i18n\"\n [ngModel]=\"search$ | async\"\n (ngModelChange)=\"this.search$.next($event)\"\n />\n\n <pry-icon iconSvg=\"search\" [width]=\"17\" [height]=\"17\"></pry-icon>\n </div>\n </div>\n </div>\n <div class=\"o-manifest-layout__content\">\n <h1 class=\"a-h1\">{{ '@pry.restitution.catalog' | i18n }}</h1>\n\n <div class=\"o-presentation-wrapper\">\n <ul class=\"o-presentation\">\n <li class=\"o-presentation__item\" *ngFor=\"let restitution of filteredRestitution$ | async; let index = index\">\n <div class=\"o-presentation__item__header\">\n <ng-container *ngIf=\"restitution.visibility?.type === PryVisibilityType.PRIVATE\">\n <pry-icon\n iconSvg=\"private\"\n class=\"is-private a-tooltip -tooltip-no-wrap\"\n [attr.data-tooltip]=\"'@pry.restitution.lock' | i18n\"\n [height]=\"17\"\n [width]=\"17\"\n ></pry-icon>\n </ng-container>\n <div\n class=\"a-tooltip -tooltip-no-wrap\"\n (click)=\"selectRestitution(restitution)\"\n [attr.data-tooltip]=\"'@pry.restitution.consultRestitution' | i18n\"\n >\n <div class=\"o-presentation__item__image\">\n <img\n alt=\"\"\n class=\"is-full-width\"\n [src]=\"restitution.image | getSecuredImage : [600, 600] | async\"\n />\n </div>\n </div>\n <ng-container *ngIf=\"restitution.owner\">\n <div class=\"more-button\">\n <button\n type=\"button\"\n class=\"a-btn a-btn--more a-tooltip -tooltip-no-wrap\"\n [id]=\"'more-actions-' + index\"\n [attr.data-tooltip]=\"'@pry.restitution.more' | i18n\"\n (click)=\"toggleModalActions(restitution, button)\"\n #button\n >\n <pry-icon [height]=\"25\" [width]=\"25\" iconSvg=\"more_horiz\"></pry-icon>\n </button>\n </div>\n </ng-container>\n </div>\n <div\n class=\"o-presentation__item__txt\"\n (click)=\"selectRestitution(restitution)\"\n [attr.data-tooltip]=\"'@pry.restitution.consultRestitution' | i18n\"\n >\n <div class=\"o-presentation__item__title-container\" ellipsis textElementSelector=\".a-h3\">\n <h3 class=\"a-h3\">{{ restitution.name }}</h3>\n </div>\n <div class=\"o-presentation__item__description-container\" ellipsis textElementSelector=\".a-p\">\n <div class=\"o-presentation__item__description a-p\">\n {{ restitution.description }}\n </div>\n </div>\n <p class=\"a-p -date\">{{ restitution.modificationDate | sinceDate }}</p>\n </div>\n\n <div\n class=\"o-presentation__item__footer a-tooltip -tooltip-no-wrap\"\n (click)=\"selectRestitution(restitution)\"\n [attr.data-tooltip]=\"'@pry.restitution.consultRestitution' | i18n\"\n >\n <button class=\"a-btn\">\n {{ '@pry.restitution.view' | i18n }}\n <pry-icon [width]=\"20\" [height]=\"20\" iconSvg=\"arrow_right\"></pry-icon>\n </button>\n </div>\n </li>\n </ul>\n </div>\n </div>\n </ng-template>\n <ng-template #modalActions>\n <div class=\"m-context-menu\">\n <ul\n *ngIf=\"selectedRestitution\"\n class=\"m-context-menu__list\"\n role=\"dialog\"\n aria-modal=\"true\"\n aria-labelledby=\"dialog restitution options\"\n >\n <li class=\"m-context-menu__list__item\">\n <button\n class=\"a-btn -link-like\"\n (click)=\"editRestitution(selectedRestitution)\"\n [disabled]=\"!selectedRestitution.owner\"\n *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'edit' }\"\n >\n {{ '@pry.restitution.update' | i18n }}\n </button>\n </li>\n <li class=\"m-context-menu__list__item\">\n <button\n class=\"a-btn -link-like\"\n #openModal\n (click)=\"deleteRestitution(selectedRestitution.id)\"\n [disabled]=\"!selectedRestitution.owner\"\n *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'delete' }\"\n >\n {{ '@pry.restitution.delete' | i18n }}\n </button>\n </li>\n </ul>\n </div>\n </ng-template>\n\n <ng-template [ngIf]=\"selectedMode === mode.CONSULT\">\n <div class=\"o-manifest-layout__toolbox\">\n <button type=\"button\" (click)=\"selectMode(mode.CATALOG)\" class=\"a-btn a-btn--primary\">\n {{ '@pry.restitution.backToCatalog' | i18n }}\n </button>\n </div>\n <div class=\"o-manifest-layout__content\">\n <pry-restitution\n [selectedRestitution]=\"selectedRestitution\"\n [edit]=\"false\"\n (restitutionCreated)=\"closeRestitution($event)\"\n class=\"restitution\"\n ></pry-restitution>\n </div>\n </ng-template>\n <ng-template [ngIf]=\"selectedMode === mode.CREATION\">\n <div class=\"o-manifest-layout__toolbox\">\n <button type=\"button\" (click)=\"selectMode(mode.CATALOG)\" class=\"a-btn a-btn--primary\">\n {{ '@pry.restitution.backToCatalog' | i18n }}\n </button>\n </div>\n <div class=\"o-manifest-layout__content\">\n <pry-restitution\n [edit]=\"false\"\n (restitutionCreated)=\"closeRestitution($event)\"\n class=\"restitution\"\n ></pry-restitution>\n </div>\n </ng-template>\n <ng-template [ngIf]=\"selectedMode === mode.EDITION\">\n <div class=\"o-manifest-layout__toolbox\">\n <button type=\"button\" (click)=\"selectMode(mode.CATALOG)\" class=\"a-btn a-btn--primary\">\n {{ '@pry.restitution.backToCatalog' | i18n }}\n </button>\n </div>\n <div class=\"o-manifest-layout__content\">\n <pry-restitution\n (restitutionCreated)=\"closeRestitution($event)\"\n [selectedRestitution]=\"selectedRestitution\"\n class=\"restitution\"\n ></pry-restitution>\n </div>\n </ng-template>\n</div>\n" }]
|
|
84
84
|
}], ctorParameters: () => [{ type: i1.Store }, { type: i2.Overlay }, { type: i0.ViewContainerRef }], propDecorators: { templateActions: [{
|
|
85
85
|
type: ViewChild,
|
|
86
86
|
args: ['modalActions', { read: TemplateRef }]
|
|
87
87
|
}] } });
|
|
88
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restitution-catalog.component.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/restitution/components/restitution-catalog/restitution-catalog.component.ts","../../../../../../../projects/provoly/dashboard/restitution/components/restitution-catalog/restitution-catalog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { Component, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport { ConfigActions, ConfigSelectors, PryVisibilityType, ViewMode, Widget } from '@provoly/dashboard';\nimport { BehaviorSubject, combineLatest, map, Observable } from 'rxjs';\nimport { TemplatePortal } from '@angular/cdk/portal';\n\n@Component({\n  selector: 'pry-restitution-catalog',\n  templateUrl: './restitution-catalog.component.html'\n})\nexport class PryRestitutionCatalogComponent {\n  restitutions$: Observable<Widget[]>;\n  search$ = new BehaviorSubject('');\n  filteredRestitution$: Observable<Widget[]>;\n  mode = ViewMode;\n  selectedMode: ViewMode = ViewMode.CATALOG;\n  selectedRestitution: Widget | null = null;\n  restitution?: Widget;\n  PryVisibilityType = PryVisibilityType;\n  overlayRef?: OverlayRef;\n  @ViewChild('modalActions', { read: TemplateRef }) templateActions!: TemplateRef<any>;\n\n  constructor(private store: Store, protected overlay: Overlay, protected viewContainerRef: ViewContainerRef) {\n    this.store.dispatch(ConfigActions.loadWidgets());\n    this.store.dispatch(ConfigActions.getMapStyles());\n\n    this.restitutions$ = this.store\n      .select(ConfigSelectors.catalog)\n      .pipe(\n        map((restitutionList) =>\n          [...restitutionList].sort((a, b) =>\n            a.modificationDate ? b.modificationDate.localeCompare(a.modificationDate) : 1\n          )\n        )\n      );\n    this.filteredRestitution$ = combineLatest([this.restitutions$, this.search$]).pipe(\n      map(([restitutions, search]) =>\n        restitutions.filter(\n          (restitution) => search.length === 0 || restitution.name.toLowerCase().includes(search.toLowerCase())\n        )\n      )\n    );\n  }\n\n  selectMode(newMode: ViewMode) {\n    this.selectedMode = newMode;\n  }\n\n  selectRestitution(restitution: Widget) {\n    this.selectedRestitution = restitution;\n    this.selectMode(this.mode.CONSULT);\n    this.search$.next('');\n  }\n\n  closeRestitution($event: void) {\n    this.selectedRestitution = null;\n    this.selectMode(this.mode.CATALOG);\n  }\n\n  deleteRestitution(id: string) {\n    this.store.dispatch(ConfigActions.confirmRestitutionDeletion({ id }));\n    this.toggleModalActions();\n  }\n\n  editRestitution(restitution: Widget) {\n    this.selectedRestitution = restitution;\n    this.selectMode(ViewMode.EDITION);\n    this.search$.next('');\n    this.overlayRef?.dispose();\n    this.overlayRef = undefined;\n  }\n\n  toggleModalActions(restitution?: Widget, moreButton?: HTMLButtonElement) {\n    if (!this.overlayRef && restitution) {\n      this.selectedRestitution = restitution;\n      this.overlayRef = this.overlay.create(\n        new OverlayConfig({\n          hasBackdrop: true,\n          panelClass: ['m-context-menu-wrapper'],\n          backdropClass: 'backdrop'\n        })\n      );\n      this.overlayRef.backdropClick().subscribe(() => this.toggleModalActions(restitution));\n      this.overlayRef.attach(new TemplatePortal(this.templateActions, this.viewContainerRef));\n      const contextMenu = document.querySelector('div.m-context-menu') as HTMLDivElement;\n      if (!!contextMenu && moreButton) {\n        const rect = moreButton?.getBoundingClientRect();\n        contextMenu.style.left = (rect?.left ?? 0) - (contextMenu?.clientWidth ?? 0) + 23 + 'px';\n        contextMenu.style.top = (rect?.top ?? 0) + 30 + 'px';\n      }\n    } else {\n      this.overlayRef?.dispose();\n      this.overlayRef = undefined;\n      this.selectedRestitution = null;\n    }\n  }\n}\n","<pry-restitution-css></pry-restitution-css>\n<div class=\"o-manifest-layout o-restitution-catalog\">\n  <ng-template [ngIf]=\"selectedMode === mode.CATALOG\">\n    <div class=\"o-manifest-layout__toolbox\">\n      <button\n        type=\"button\"\n        (click)=\"selectMode(mode.CREATION)\"\n        class=\"a-btn a-btn--primary\"\n        data-tooltip-position=\"bottom\"\n        *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'create' }\"\n      >\n        <pry-icon iconSvg=\"add\"></pry-icon>\n        {{ '@pry.restitution.create' | i18n }}\n      </button>\n      <div>\n        <div class=\"o-catalog__search o-manifest-layout__toolbox__search\">\n          <label id=\"catalog-search-label\" for=\"catalog-search\" class=\"u-visually-hidden\">\n            <span>{{ '@pry.toolbox.catalog.filter.name' | i18n }}</span>\n          </label>\n          <input\n            id=\"catalog-search\"\n            type=\"text\"\n            class=\"a-form-field\"\n            [placeholder]=\"'@pry.restitution.search' | i18n\"\n            [ngModel]=\"search$ | async\"\n            (ngModelChange)=\"this.search$.next($event)\"\n          />\n\n          <pry-icon iconSvg=\"search\" [width]=\"17\" [height]=\"17\"></pry-icon>\n        </div>\n      </div>\n    </div>\n    <div class=\"o-manifest-layout__content\">\n      <h1 class=\"a-h1\">{{ '@pry.restitution.catalog' | i18n }}</h1>\n\n      <div class=\"o-presentation-wrapper\">\n        <ul class=\"o-presentation\">\n          <li class=\"o-presentation__item\" *ngFor=\"let restitution of filteredRestitution$ | async; let index = index\">\n            <div class=\"o-presentation__item__header\">\n              <ng-container *ngIf=\"restitution.visibility?.type === PryVisibilityType.PRIVATE\">\n                <pry-icon\n                  iconSvg=\"private\"\n                  class=\"is-private a-tooltip -tooltip-no-wrap\"\n                  [attr.data-tooltip]=\"'@pry.restitution.lock' | i18n\"\n                  [height]=\"17\"\n                  [width]=\"17\"\n                ></pry-icon>\n              </ng-container>\n              <div\n                class=\"a-tooltip -tooltip-no-wrap\"\n                (click)=\"selectRestitution(restitution)\"\n                [attr.data-tooltip]=\"'@pry.restitution.consultRestitution' | i18n\"\n              >\n                <div class=\"o-presentation__item__image\">\n                  <img\n                    alt=\"\"\n                    class=\"is-full-width\"\n                    [src]=\"restitution.image | getSecuredImage : [600, 600] | async\"\n                    class=\"pointer\"\n                  />\n                </div>\n              </div>\n              <ng-container *ngIf=\"restitution.owner\">\n                <div class=\"more-button\">\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn--more a-tooltip -tooltip-no-wrap\"\n                    [id]=\"'more-actions-' + index\"\n                    [attr.data-tooltip]=\"'@pry.restitution.more' | i18n\"\n                    (click)=\"toggleModalActions(restitution, button)\"\n                    #button\n                  >\n                    <pry-icon [height]=\"25\" [width]=\"25\" iconSvg=\"more_horiz\"></pry-icon>\n                  </button>\n                </div>\n              </ng-container>\n            </div>\n            <div\n              class=\"o-presentation__item__txt\"\n              (click)=\"selectRestitution(restitution)\"\n              [attr.data-tooltip]=\"'@pry.restitution.consultRestitution' | i18n\"\n            >\n              <div class=\"o-presentation__item__title-container\" ellipsis textElementSelector=\".a-h3\">\n                <h3 class=\"a-h3\">{{ restitution.name }}</h3>\n              </div>\n              <div class=\"o-presentation__item__description-container\" ellipsis textElementSelector=\".a-p\">\n                <div class=\"o-presentation__item__description a-p\">\n                  {{ restitution.description }}\n                </div>\n              </div>\n              <p class=\"a-p -date\">{{ restitution.modificationDate | sinceDate }}</p>\n            </div>\n\n            <div\n              class=\"o-presentation__item__footer a-tooltip -tooltip-no-wrap\"\n              (click)=\"selectRestitution(restitution)\"\n              [attr.data-tooltip]=\"'@pry.restitution.consultRestitution' | i18n\"\n            >\n              <button class=\"a-btn\">\n                {{ '@pry.restitution.view' | i18n }}\n                <pry-icon [width]=\"20\" [height]=\"20\" iconSvg=\"arrow_right\"></pry-icon>\n              </button>\n            </div>\n          </li>\n        </ul>\n      </div>\n    </div>\n  </ng-template>\n  <ng-template #modalActions>\n    <div class=\"m-context-menu\">\n      <ul\n        *ngIf=\"selectedRestitution\"\n        class=\"m-context-menu__list\"\n        role=\"dialog\"\n        aria-modal=\"true\"\n        aria-labelledby=\"dialog restitution options\"\n      >\n        <li class=\"m-context-menu__list__item\">\n          <button\n            class=\"a-btn -link-like\"\n            (click)=\"editRestitution(selectedRestitution)\"\n            [disabled]=\"!selectedRestitution.owner\"\n            *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'edit' }\"\n          >\n            {{ '@pry.restitution.update' | i18n }}\n          </button>\n        </li>\n        <li class=\"m-context-menu__list__item\">\n          <button\n            class=\"a-btn -link-like\"\n            #openModal\n            (click)=\"deleteRestitution(selectedRestitution.id)\"\n            [disabled]=\"!selectedRestitution.owner\"\n            *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'delete' }\"\n          >\n            {{ '@pry.restitution.delete' | i18n }}\n          </button>\n        </li>\n      </ul>\n    </div>\n  </ng-template>\n\n  <ng-template [ngIf]=\"selectedMode === mode.CONSULT\">\n    <div class=\"o-manifest-layout__toolbox\">\n      <button type=\"button\" (click)=\"selectMode(mode.CATALOG)\" class=\"a-btn a-btn--primary\">\n        {{ '@pry.restitution.backToCatalog' | i18n }}\n      </button>\n    </div>\n    <div class=\"o-manifest-layout__content\">\n      <pry-restitution\n        [selectedRestitution]=\"selectedRestitution\"\n        [edit]=\"false\"\n        (restitutionCreated)=\"closeRestitution($event)\"\n        class=\"restitution\"\n      ></pry-restitution>\n    </div>\n  </ng-template>\n  <ng-template [ngIf]=\"selectedMode === mode.CREATION\">\n    <div class=\"o-manifest-layout__toolbox\">\n      <button type=\"button\" (click)=\"selectMode(mode.CATALOG)\" class=\"a-btn a-btn--primary\">\n        {{ '@pry.restitution.backToCatalog' | i18n }}\n      </button>\n    </div>\n    <div class=\"o-manifest-layout__content\">\n      <pry-restitution\n        [edit]=\"false\"\n        (restitutionCreated)=\"closeRestitution($event)\"\n        class=\"restitution\"\n      ></pry-restitution>\n    </div>\n  </ng-template>\n  <ng-template [ngIf]=\"selectedMode === mode.EDITION\">\n    <div class=\"o-manifest-layout__toolbox\">\n      <button type=\"button\" (click)=\"selectMode(mode.CATALOG)\" class=\"a-btn a-btn--primary\">\n        {{ '@pry.restitution.backToCatalog' | i18n }}\n      </button>\n    </div>\n    <div class=\"o-manifest-layout__content\">\n      <pry-restitution\n        (restitutionCreated)=\"closeRestitution($event)\"\n        [selectedRestitution]=\"selectedRestitution\"\n        class=\"restitution\"\n      ></pry-restitution>\n    </div>\n  </ng-template>\n</div>\n"]}
|
|
88
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"restitution-catalog.component.js","sourceRoot":"","sources":["../../../../../../../projects/provoly/dashboard/restitution/components/restitution-catalog/restitution-catalog.component.ts","../../../../../../../projects/provoly/dashboard/restitution/components/restitution-catalog/restitution-catalog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { Component, TemplateRef, ViewChild, ViewContainerRef } from '@angular/core';\nimport { Store } from '@ngrx/store';\nimport { ConfigActions, ConfigSelectors, PryVisibilityType, ViewMode, Widget } from '@provoly/dashboard';\nimport { BehaviorSubject, combineLatest, map, Observable } from 'rxjs';\nimport { TemplatePortal } from '@angular/cdk/portal';\n\n@Component({\n  selector: 'pry-restitution-catalog',\n  templateUrl: './restitution-catalog.component.html'\n})\nexport class PryRestitutionCatalogComponent {\n  restitutions$: Observable<Widget[]>;\n  search$ = new BehaviorSubject('');\n  filteredRestitution$: Observable<Widget[]>;\n  mode = ViewMode;\n  selectedMode: ViewMode = ViewMode.CATALOG;\n  selectedRestitution: Widget | null = null;\n  restitution?: Widget;\n  PryVisibilityType = PryVisibilityType;\n  overlayRef?: OverlayRef;\n  @ViewChild('modalActions', { read: TemplateRef }) templateActions!: TemplateRef<any>;\n\n  constructor(private store: Store, protected overlay: Overlay, protected viewContainerRef: ViewContainerRef) {\n    this.store.dispatch(ConfigActions.loadWidgets());\n    this.store.dispatch(ConfigActions.getMapStyles());\n\n    this.restitutions$ = this.store\n      .select(ConfigSelectors.catalog)\n      .pipe(\n        map((restitutionList) =>\n          [...restitutionList].sort((a, b) =>\n            a.modificationDate ? b.modificationDate.localeCompare(a.modificationDate) : 1\n          )\n        )\n      );\n    this.filteredRestitution$ = combineLatest([this.restitutions$, this.search$]).pipe(\n      map(([restitutions, search]) =>\n        restitutions.filter(\n          (restitution) => search.length === 0 || restitution.name.toLowerCase().includes(search.toLowerCase())\n        )\n      )\n    );\n  }\n\n  selectMode(newMode: ViewMode) {\n    this.selectedMode = newMode;\n  }\n\n  selectRestitution(restitution: Widget) {\n    this.selectedRestitution = restitution;\n    this.selectMode(this.mode.CONSULT);\n    this.search$.next('');\n  }\n\n  closeRestitution($event: void) {\n    this.selectedRestitution = null;\n    this.selectMode(this.mode.CATALOG);\n  }\n\n  deleteRestitution(id: string) {\n    this.store.dispatch(ConfigActions.confirmRestitutionDeletion({ id }));\n    this.toggleModalActions();\n  }\n\n  editRestitution(restitution: Widget) {\n    this.selectedRestitution = restitution;\n    this.selectMode(ViewMode.EDITION);\n    this.search$.next('');\n    this.overlayRef?.dispose();\n    this.overlayRef = undefined;\n  }\n\n  toggleModalActions(restitution?: Widget, moreButton?: HTMLButtonElement) {\n    if (!this.overlayRef && restitution) {\n      this.selectedRestitution = restitution;\n      this.overlayRef = this.overlay.create(\n        new OverlayConfig({\n          hasBackdrop: true,\n          panelClass: ['m-context-menu-wrapper'],\n          backdropClass: 'backdrop'\n        })\n      );\n      this.overlayRef.backdropClick().subscribe(() => this.toggleModalActions(restitution));\n      this.overlayRef.attach(new TemplatePortal(this.templateActions, this.viewContainerRef));\n      const contextMenu = document.querySelector('div.m-context-menu') as HTMLDivElement;\n      if (!!contextMenu && moreButton) {\n        const rect = moreButton?.getBoundingClientRect();\n        contextMenu.style.left = (rect?.left ?? 0) - (contextMenu?.clientWidth ?? 0) + 23 + 'px';\n        contextMenu.style.top = (rect?.top ?? 0) + 30 + 'px';\n      }\n    } else {\n      this.overlayRef?.dispose();\n      this.overlayRef = undefined;\n      this.selectedRestitution = null;\n    }\n  }\n}\n","<pry-restitution-css></pry-restitution-css>\n<div class=\"o-manifest-layout o-restitution-catalog\">\n  <ng-template [ngIf]=\"selectedMode === mode.CATALOG\">\n    <div class=\"o-manifest-layout__toolbox\">\n      <button\n        type=\"button\"\n        (click)=\"selectMode(mode.CREATION)\"\n        class=\"a-btn a-btn--primary\"\n        data-tooltip-position=\"bottom\"\n        *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'create' }\"\n      >\n        <pry-icon iconSvg=\"add\"></pry-icon>\n        {{ '@pry.restitution.create' | i18n }}\n      </button>\n      <div>\n        <div class=\"o-catalog__search o-manifest-layout__toolbox__search\">\n          <label id=\"catalog-search-label\" for=\"catalog-search\" class=\"u-visually-hidden\">\n            <span>{{ '@pry.toolbox.catalog.filter.name' | i18n }}</span>\n          </label>\n          <input\n            id=\"catalog-search\"\n            type=\"text\"\n            class=\"a-form-field\"\n            [placeholder]=\"'@pry.restitution.search' | i18n\"\n            [ngModel]=\"search$ | async\"\n            (ngModelChange)=\"this.search$.next($event)\"\n          />\n\n          <pry-icon iconSvg=\"search\" [width]=\"17\" [height]=\"17\"></pry-icon>\n        </div>\n      </div>\n    </div>\n    <div class=\"o-manifest-layout__content\">\n      <h1 class=\"a-h1\">{{ '@pry.restitution.catalog' | i18n }}</h1>\n\n      <div class=\"o-presentation-wrapper\">\n        <ul class=\"o-presentation\">\n          <li class=\"o-presentation__item\" *ngFor=\"let restitution of filteredRestitution$ | async; let index = index\">\n            <div class=\"o-presentation__item__header\">\n              <ng-container *ngIf=\"restitution.visibility?.type === PryVisibilityType.PRIVATE\">\n                <pry-icon\n                  iconSvg=\"private\"\n                  class=\"is-private a-tooltip -tooltip-no-wrap\"\n                  [attr.data-tooltip]=\"'@pry.restitution.lock' | i18n\"\n                  [height]=\"17\"\n                  [width]=\"17\"\n                ></pry-icon>\n              </ng-container>\n              <div\n                class=\"a-tooltip -tooltip-no-wrap\"\n                (click)=\"selectRestitution(restitution)\"\n                [attr.data-tooltip]=\"'@pry.restitution.consultRestitution' | i18n\"\n              >\n                <div class=\"o-presentation__item__image\">\n                  <img\n                    alt=\"\"\n                    class=\"is-full-width\"\n                    [src]=\"restitution.image | getSecuredImage : [600, 600] | async\"\n                  />\n                </div>\n              </div>\n              <ng-container *ngIf=\"restitution.owner\">\n                <div class=\"more-button\">\n                  <button\n                    type=\"button\"\n                    class=\"a-btn a-btn--more a-tooltip -tooltip-no-wrap\"\n                    [id]=\"'more-actions-' + index\"\n                    [attr.data-tooltip]=\"'@pry.restitution.more' | i18n\"\n                    (click)=\"toggleModalActions(restitution, button)\"\n                    #button\n                  >\n                    <pry-icon [height]=\"25\" [width]=\"25\" iconSvg=\"more_horiz\"></pry-icon>\n                  </button>\n                </div>\n              </ng-container>\n            </div>\n            <div\n              class=\"o-presentation__item__txt\"\n              (click)=\"selectRestitution(restitution)\"\n              [attr.data-tooltip]=\"'@pry.restitution.consultRestitution' | i18n\"\n            >\n              <div class=\"o-presentation__item__title-container\" ellipsis textElementSelector=\".a-h3\">\n                <h3 class=\"a-h3\">{{ restitution.name }}</h3>\n              </div>\n              <div class=\"o-presentation__item__description-container\" ellipsis textElementSelector=\".a-p\">\n                <div class=\"o-presentation__item__description a-p\">\n                  {{ restitution.description }}\n                </div>\n              </div>\n              <p class=\"a-p -date\">{{ restitution.modificationDate | sinceDate }}</p>\n            </div>\n\n            <div\n              class=\"o-presentation__item__footer a-tooltip -tooltip-no-wrap\"\n              (click)=\"selectRestitution(restitution)\"\n              [attr.data-tooltip]=\"'@pry.restitution.consultRestitution' | i18n\"\n            >\n              <button class=\"a-btn\">\n                {{ '@pry.restitution.view' | i18n }}\n                <pry-icon [width]=\"20\" [height]=\"20\" iconSvg=\"arrow_right\"></pry-icon>\n              </button>\n            </div>\n          </li>\n        </ul>\n      </div>\n    </div>\n  </ng-template>\n  <ng-template #modalActions>\n    <div class=\"m-context-menu\">\n      <ul\n        *ngIf=\"selectedRestitution\"\n        class=\"m-context-menu__list\"\n        role=\"dialog\"\n        aria-modal=\"true\"\n        aria-labelledby=\"dialog restitution options\"\n      >\n        <li class=\"m-context-menu__list__item\">\n          <button\n            class=\"a-btn -link-like\"\n            (click)=\"editRestitution(selectedRestitution)\"\n            [disabled]=\"!selectedRestitution.owner\"\n            *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'edit' }\"\n          >\n            {{ '@pry.restitution.update' | i18n }}\n          </button>\n        </li>\n        <li class=\"m-context-menu__list__item\">\n          <button\n            class=\"a-btn -link-like\"\n            #openModal\n            (click)=\"deleteRestitution(selectedRestitution.id)\"\n            [disabled]=\"!selectedRestitution.owner\"\n            *pryAccess=\"{ module: 'dashboard', page: 'restitution', action: 'delete' }\"\n          >\n            {{ '@pry.restitution.delete' | i18n }}\n          </button>\n        </li>\n      </ul>\n    </div>\n  </ng-template>\n\n  <ng-template [ngIf]=\"selectedMode === mode.CONSULT\">\n    <div class=\"o-manifest-layout__toolbox\">\n      <button type=\"button\" (click)=\"selectMode(mode.CATALOG)\" class=\"a-btn a-btn--primary\">\n        {{ '@pry.restitution.backToCatalog' | i18n }}\n      </button>\n    </div>\n    <div class=\"o-manifest-layout__content\">\n      <pry-restitution\n        [selectedRestitution]=\"selectedRestitution\"\n        [edit]=\"false\"\n        (restitutionCreated)=\"closeRestitution($event)\"\n        class=\"restitution\"\n      ></pry-restitution>\n    </div>\n  </ng-template>\n  <ng-template [ngIf]=\"selectedMode === mode.CREATION\">\n    <div class=\"o-manifest-layout__toolbox\">\n      <button type=\"button\" (click)=\"selectMode(mode.CATALOG)\" class=\"a-btn a-btn--primary\">\n        {{ '@pry.restitution.backToCatalog' | i18n }}\n      </button>\n    </div>\n    <div class=\"o-manifest-layout__content\">\n      <pry-restitution\n        [edit]=\"false\"\n        (restitutionCreated)=\"closeRestitution($event)\"\n        class=\"restitution\"\n      ></pry-restitution>\n    </div>\n  </ng-template>\n  <ng-template [ngIf]=\"selectedMode === mode.EDITION\">\n    <div class=\"o-manifest-layout__toolbox\">\n      <button type=\"button\" (click)=\"selectMode(mode.CATALOG)\" class=\"a-btn a-btn--primary\">\n        {{ '@pry.restitution.backToCatalog' | i18n }}\n      </button>\n    </div>\n    <div class=\"o-manifest-layout__content\">\n      <pry-restitution\n        (restitutionCreated)=\"closeRestitution($event)\"\n        [selectedRestitution]=\"selectedRestitution\"\n        class=\"restitution\"\n      ></pry-restitution>\n    </div>\n  </ng-template>\n</div>\n"]}
|