@thednp/color-picker 2.0.0-alpha7 → 2.0.0-alpha9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -2
 - package/compile.js +6 -3
 - package/cypress/e2e/color-picker.cy.ts +58 -69
 - package/cypress/fixtures/getMarkup.js +8 -1
 - package/dist/css/color-picker.css +7 -15
 - package/dist/css/color-picker.min.css +2 -2
 - package/dist/css/color-picker.rtl.css +7 -15
 - package/dist/css/color-picker.rtl.min.css +2 -2
 - package/dist/js/color-picker.cjs +2 -2
 - package/dist/js/color-picker.cjs.map +1 -1
 - package/dist/js/color-picker.d.ts +23 -7
 - package/dist/js/color-picker.js +2 -2
 - package/dist/js/color-picker.js.map +1 -1
 - package/dist/js/color-picker.mjs +202 -203
 - package/dist/js/color-picker.mjs.map +1 -1
 - package/package.json +115 -114
 - package/src/scss/color-picker.scss +6 -10
 - package/src/ts/index.ts +11 -11
 - package/src/ts/interface/ColorNames.ts +20 -0
 - package/cypress/fixtures/getCEMarkup.js +0 -29
 
    
        package/README.md
    CHANGED
    
    | 
         @@ -6,8 +6,8 @@ 
     | 
|
| 
       6 
6 
     | 
    
         
             
            [](https://www.npmjs.com/package/@thednp/color-picker)
         
     | 
| 
       7 
7 
     | 
    
         
             
            [](https://www.typescriptlang.org/)
         
     | 
| 
       8 
8 
     | 
    
         
             
            [](https://github.com/eslint)
         
     | 
| 
       9 
     | 
    
         
            -
            [](https://prettier.io/)
         
     | 
| 
      
 10 
     | 
    
         
            +
            [](https://cypress.io/)
         
     | 
| 
       11 
11 
     | 
    
         
             
            [](https://github.com/vitejs)
         
     | 
| 
       12 
12 
     | 
    
         | 
| 
       13 
13 
     | 
    
         
             
            The feature rich **ColorPicker** component for the modern web, sourced with TypeScript, Cypress tested, WAI-ARIA compliant and lots of goodies. In addition, it features its own version of [TinyColor](https://github.com/bgrins/TinyColor) called simply [Color](http://github.com/thednp/color).
         
     | 
    
        package/compile.js
    CHANGED
    
    | 
         @@ -2,12 +2,15 @@ 
     | 
|
| 
       2 
2 
     | 
    
         
             
            // Build script to compile and minify the CSS file from SCSS folder
         
     | 
| 
       3 
3 
     | 
    
         
             
            // Usage: npm run compile-scss
         
     | 
| 
       4 
4 
     | 
    
         | 
| 
       5 
     | 
    
         
            -
            const  
     | 
| 
       6 
     | 
    
         
            -
            const writeFileSync = fs.writeFileSync;
         
     | 
| 
      
 5 
     | 
    
         
            +
            const {writeFileSync} = require("fs");
         
     | 
| 
      
 6 
     | 
    
         
            +
            // const writeFileSync = fs.writeFileSync;
         
     | 
| 
      
 7 
     | 
    
         
            +
            // import { writeFileSync } from "fs";
         
     | 
| 
       7 
8 
     | 
    
         
             
            const sass = require("sass");
         
     | 
| 
       8 
9 
     | 
    
         
             
            const pkg = require("./package.json");
         
     | 
| 
       9 
10 
     | 
    
         
             
            const year = new Date().getFullYear();
         
     | 
| 
       10 
11 
     | 
    
         
             
            const args = {};
         
     | 
| 
      
 12 
     | 
    
         
            +
            const pkName = pkg.name.includes(pkg.author) ? pkg.name.replace('@','') : `${pkg.author}/${pkg.name}`;
         
     | 
| 
      
 13 
     | 
    
         
            +
            const home = `https://github.com/${pkName}`;
         
     | 
| 
       11 
14 
     | 
    
         | 
| 
       12 
15 
     | 
    
         
             
            const ARGS = process.argv.slice(-1)[0].split(",");
         
     | 
| 
       13 
16 
     | 
    
         
             
            ARGS.map((x) => {
         
     | 
| 
         @@ -22,7 +25,7 @@ const banner = 
     | 
|
| 
       22 
25 
     | 
    
         
             
                : `/*!
         
     | 
| 
       23 
26 
     | 
    
         
             
            * ColorPicker v${pkg.version} (${pkg.homepage})
         
     | 
| 
       24 
27 
     | 
    
         
             
            * Copyright ${year} © ${pkg.author}
         
     | 
| 
       25 
     | 
    
         
            -
            * Licensed under MIT (${ 
     | 
| 
      
 28 
     | 
    
         
            +
            * Licensed under MIT (${home}/blob/main/LICENSE)
         
     | 
| 
       26 
29 
     | 
    
         
             
            */`;
         
     | 
| 
       27 
30 
     | 
    
         | 
| 
       28 
31 
     | 
    
         
             
            const DIR = args.DIR === "rtl" ? ".rtl" : "";
         
     | 
| 
         @@ -80,11 +80,10 @@ describe('ColorPicker Class Test', () => { 
     | 
|
| 
       80 
80 
     | 
    
         
             
                  });
         
     | 
| 
       81 
81 
     | 
    
         | 
| 
       82 
82 
     | 
    
         
             
                cy.document().should('not.be.undefined')
         
     | 
| 
       83 
     | 
    
         
            -
             
     | 
| 
       84 
     | 
    
         
            -
             
     | 
| 
       85 
     | 
    
         
            -
                  . 
     | 
| 
       86 
     | 
    
         
            -
             
     | 
| 
       87 
     | 
    
         
            -
                  })
         
     | 
| 
      
 83 
     | 
    
         
            +
                cy.get('@input').should('exist')
         
     | 
| 
      
 84 
     | 
    
         
            +
                cy.document().invoke('querySelectorAll', selector).then((nodelist ) => {
         
     | 
| 
      
 85 
     | 
    
         
            +
                  [...nodelist as NodeListOf<HTMLInputElement>].forEach(init);
         
     | 
| 
      
 86 
     | 
    
         
            +
                })
         
     | 
| 
       88 
87 
     | 
    
         | 
| 
       89 
88 
     | 
    
         
             
                cy.get('@input').then(($input) => {
         
     | 
| 
       90 
89 
     | 
    
         
             
                  if ($input.length) {
         
     | 
| 
         @@ -95,8 +94,9 @@ describe('ColorPicker Class Test', () => { 
     | 
|
| 
       95 
94 
     | 
    
         | 
| 
       96 
95 
     | 
    
         
             
                cy.get('@cp').should('exist')
         
     | 
| 
       97 
96 
     | 
    
         
             
                  .get('@cp').then(() => {
         
     | 
| 
       98 
     | 
    
         
            -
                    cy.get('@cp').its('colorLabels').then(( 
     | 
| 
       99 
     | 
    
         
            -
                       
     | 
| 
      
 97 
     | 
    
         
            +
                    cy.get('@cp').its('colorLabels').then((lbls) => {
         
     | 
| 
      
 98 
     | 
    
         
            +
                      // console.log(lbls)
         
     | 
| 
      
 99 
     | 
    
         
            +
                      expect(Object.values(lbls))
         
     | 
| 
       100 
100 
     | 
    
         
             
                        .to.deep.equal(colorNamesFrench.split(','));
         
     | 
| 
       101 
101 
     | 
    
         
             
                    })
         
     | 
| 
       102 
102 
     | 
    
         | 
| 
         @@ -130,17 +130,18 @@ describe('ColorPicker Class Test', () => { 
     | 
|
| 
       130 
130 
     | 
    
         
             
                        colorLabels: colorNamesFrench,
         
     | 
| 
       131 
131 
     | 
    
         
             
                        componentLabels: componentLabelsFrench,
         
     | 
| 
       132 
132 
     | 
    
         
             
                      });
         
     | 
| 
       133 
     | 
    
         
            -
                      console.log(cp)
         
     | 
| 
      
 133 
     | 
    
         
            +
                      // console.log(cp)
         
     | 
| 
       134 
134 
     | 
    
         
             
                      cy.wrap(cp).as('cp');
         
     | 
| 
       135 
135 
     | 
    
         
             
                      cy.get('@cp').then(() => {
         
     | 
| 
       136 
136 
     | 
    
         
             
                        cy.get('@cp').its('input').should('equal', input[0]);
         
     | 
| 
       137 
137 
     | 
    
         
             
                        cy.get('@cp').its('format').should('equal', format);
         
     | 
| 
       138 
138 
     | 
    
         
             
                        cy.get('@cp').its('value').should('equal', value);
         
     | 
| 
       139 
139 
     | 
    
         
             
                        cy.get('@cp').its('colorPresets').should('be.instanceOf', Array);
         
     | 
| 
       140 
     | 
    
         
            -
                        cy.get('@cp').its('colorLabels')
         
     | 
| 
       141 
     | 
    
         
            -
                          . 
     | 
| 
       142 
     | 
    
         
            -
             
     | 
| 
       143 
     | 
    
         
            -
             
     | 
| 
      
 140 
     | 
    
         
            +
                        cy.get('@cp').its('colorLabels').then((lbls) => {
         
     | 
| 
      
 141 
     | 
    
         
            +
                          // console.log(lbls)
         
     | 
| 
      
 142 
     | 
    
         
            +
                          expect(Object.values(lbls))
         
     | 
| 
      
 143 
     | 
    
         
            +
                            .to.deep.equal(colorNamesFrench.split(','));
         
     | 
| 
      
 144 
     | 
    
         
            +
                        })
         
     | 
| 
       144 
145 
     | 
    
         
             
                        cy.get('@cp').its('colorKeywords').should('deep.equal', ['orange', 'lime', 'darkred']);
         
     | 
| 
       145 
146 
     | 
    
         
             
                        cy.get('@cp').its('colorPicker').should('be.instanceOf', HTMLDivElement);
         
     | 
| 
       146 
147 
     | 
    
         
             
                        cy.get('@cp').its('colorMenu').should('be.instanceOf', HTMLDivElement);
         
     | 
| 
         @@ -180,10 +181,7 @@ describe('ColorPicker Class Test', () => { 
     | 
|
| 
       180 
181 
     | 
    
         
             
                      cy.wrap(new ColorPicker(input[0], {
         
     | 
| 
       181 
182 
     | 
    
         
             
                        colorPresets: '#330033, #990099, #ff00ff, #ff66ff, #ffccff'.split(','),
         
     | 
| 
       182 
183 
     | 
    
         
             
                      })).as('cp');
         
     | 
| 
       183 
     | 
    
         
            -
                       
     | 
| 
       184 
     | 
    
         
            -
                      // .then(() => {
         
     | 
| 
       185 
     | 
    
         
            -
                        cy.get('@cp').its('colorPresets').should('be.instanceOf', Array);
         
     | 
| 
       186 
     | 
    
         
            -
                      // });
         
     | 
| 
      
 184 
     | 
    
         
            +
                      cy.get('@cp').its('colorPresets').should('be.instanceOf', Array);
         
     | 
| 
       187 
185 
     | 
    
         
             
                    }
         
     | 
| 
       188 
186 
     | 
    
         
             
                  });
         
     | 
| 
       189 
187 
     | 
    
         
             
                });
         
     | 
| 
         @@ -203,12 +201,15 @@ describe('ColorPicker Class Test', () => { 
     | 
|
| 
       203 
201 
     | 
    
         
             
                        cy.wrap(input[0]).focus().clear().type('hsl 0 100 50{enter}')
         
     | 
| 
       204 
202 
     | 
    
         
             
                        cy.wait(50)
         
     | 
| 
       205 
203 
     | 
    
         
             
                        cy.get('@cp').its('rgb').then((rgb) => {
         
     | 
| 
       206 
     | 
    
         
            -
                            cy. 
     | 
| 
       207 
     | 
    
         
            -
             
     | 
| 
       208 
     | 
    
         
            -
             
     | 
| 
       209 
     | 
    
         
            -
                             
     | 
| 
       210 
     | 
    
         
            -
                             
     | 
| 
       211 
     | 
    
         
            -
             
     | 
| 
      
 204 
     | 
    
         
            +
                            // cy.wait(17)
         
     | 
| 
      
 205 
     | 
    
         
            +
             
     | 
| 
      
 206 
     | 
    
         
            +
                          cy.get('.visual-control').eq(0)
         
     | 
| 
      
 207 
     | 
    
         
            +
                            .trigger('pointerdown', 0, 0, { eventConstructor: 'PointerEvent', force: true, pointerType: 'touch' })
         
     | 
| 
      
 208 
     | 
    
         
            +
                            .trigger('pointermove', -5, -5, { eventConstructor: 'PointerEvent', force: true, pointerType: 'touch' })
         
     | 
| 
      
 209 
     | 
    
         
            +
                            .trigger('pointermove', 500, 500, { eventConstructor: 'PointerEvent', force: true, pointerType: 'touch' })
         
     | 
| 
      
 210 
     | 
    
         
            +
                            .trigger('pointermove', 100, 100, {eventConstructor: 'PointerEvent', force: true, pointerType: 'touch' })
         
     | 
| 
      
 211 
     | 
    
         
            +
                            .trigger('pointerup', 100, 100, {eventConstructor: 'PointerEvent', force: true, pointerType: 'touch' })
         
     | 
| 
      
 212 
     | 
    
         
            +
                            .then(() => {
         
     | 
| 
       212 
213 
     | 
    
         
             
                              cy.get('@cp').its('rgb').should('not.deep.equal', rgb);
         
     | 
| 
       213 
214 
     | 
    
         
             
                            })
         
     | 
| 
       214 
215 
     | 
    
         
             
                        });
         
     | 
| 
         @@ -216,26 +217,25 @@ describe('ColorPicker Class Test', () => { 
     | 
|
| 
       216 
217 
     | 
    
         
             
                        cy.wrap(input[0]).focus().clear().type('hsl 0 100 50{enter}')
         
     | 
| 
       217 
218 
     | 
    
         
             
                          .get('@cp').its('rgb').then((rgb) => {
         
     | 
| 
       218 
219 
     | 
    
         
             
                            cy.get('.visual-control').eq(1)
         
     | 
| 
       219 
     | 
    
         
            -
                              .trigger('pointerdown', 3, 0, { force: true, pointerType: 'touch' })
         
     | 
| 
       220 
     | 
    
         
            -
                              .trigger('pointermove', 0, -5, { force: true, pointerType: 'touch' })
         
     | 
| 
       221 
     | 
    
         
            -
                              .trigger('pointermove', 3, 500, { force: true, pointerType: 'touch' })
         
     | 
| 
       222 
     | 
    
         
            -
                              .trigger('pointermove', 3, 100, { force: true, pointerType: 'touch' })
         
     | 
| 
       223 
     | 
    
         
            -
                              .trigger('pointerup', 3, 100, { force: true, pointerType: 'touch' })
         
     | 
| 
      
 220 
     | 
    
         
            +
                              .trigger('pointerdown', 3, 0, { eventConstructor: 'PointerEvent', force: true, pointerType: 'touch' })
         
     | 
| 
      
 221 
     | 
    
         
            +
                              .trigger('pointermove', 0, -5, { eventConstructor: 'PointerEvent', force: true, pointerType: 'touch' })
         
     | 
| 
      
 222 
     | 
    
         
            +
                              .trigger('pointermove', 3, 500, { eventConstructor: 'PointerEvent', force: true, pointerType: 'touch' })
         
     | 
| 
      
 223 
     | 
    
         
            +
                              .trigger('pointermove', 3, 100, { eventConstructor: 'PointerEvent', force: true, pointerType: 'touch' })
         
     | 
| 
      
 224 
     | 
    
         
            +
                              .trigger('pointerup', 3, 100, { eventConstructor: 'PointerEvent', force: true, pointerType: 'touch' })
         
     | 
| 
       224 
225 
     | 
    
         
             
                              .then(() => {
         
     | 
| 
       225 
     | 
    
         
            -
                                cy. 
     | 
| 
       226 
     | 
    
         
            -
                                  .get('@cp').its('rgb').should('not.deep.equal', rgb);
         
     | 
| 
      
 226 
     | 
    
         
            +
                                cy.get('@cp').its('rgb').should('not.deep.equal', rgb);
         
     | 
| 
       227 
227 
     | 
    
         
             
                              })
         
     | 
| 
       228 
228 
     | 
    
         
             
                          });
         
     | 
| 
       229 
229 
     | 
    
         | 
| 
       230 
230 
     | 
    
         
             
                          cy.wrap(input[0]).focus().clear().type('hsl 0 100 50{enter}')
         
     | 
| 
       231 
     | 
    
         
            -
                          .get('@cp').its('rgb').then((rgb) => {
         
     | 
| 
      
 231 
     | 
    
         
            +
                          cy.get('@cp').its('rgb').then((rgb) => {
         
     | 
| 
       232 
232 
     | 
    
         
             
                            cy.get('.visual-control').eq(2)
         
     | 
| 
       233 
     | 
    
         
            -
                              .trigger('pointerdown', 3, 0, { force: true, pointerType: 'touch' })
         
     | 
| 
       234 
     | 
    
         
            -
                              .trigger('pointermove', 3, -5, { force: true, pointerType: 'touch' })
         
     | 
| 
       235 
     | 
    
         
            -
                              .trigger('pointermove', 3, 200, { force: true, pointerType: 'touch' })
         
     | 
| 
       236 
     | 
    
         
            -
                              .trigger('pointermove', 3, 500, { force: true, pointerType: 'touch' })
         
     | 
| 
       237 
     | 
    
         
            -
                              .trigger('pointermove', 3, 100, { force: true, pointerType: 'touch' })
         
     | 
| 
       238 
     | 
    
         
            -
                              .trigger('pointerup', 3, 100, { force: true, pointerType: 'touch' })
         
     | 
| 
      
 233 
     | 
    
         
            +
                              .trigger('pointerdown', 3, 0, { eventConstructor: 'PointerEvent', force: true, pointerType: 'touch' })
         
     | 
| 
      
 234 
     | 
    
         
            +
                              .trigger('pointermove', 3, -5, { eventConstructor: 'PointerEvent', force: true, pointerType: 'touch' })
         
     | 
| 
      
 235 
     | 
    
         
            +
                              .trigger('pointermove', 3, 200, { eventConstructor: 'PointerEvent', force: true, pointerType: 'touch' })
         
     | 
| 
      
 236 
     | 
    
         
            +
                              .trigger('pointermove', 3, 500, { eventConstructor: 'PointerEvent', force: true, pointerType: 'touch' })
         
     | 
| 
      
 237 
     | 
    
         
            +
                              .trigger('pointermove', 3, 100, { eventConstructor: 'PointerEvent', force: true, pointerType: 'touch' })
         
     | 
| 
      
 238 
     | 
    
         
            +
                              .trigger('pointerup', 3, 100, { eventConstructor: 'PointerEvent', force: true, pointerType: 'touch' })
         
     | 
| 
       239 
239 
     | 
    
         
             
                              .then(() => {
         
     | 
| 
       240 
240 
     | 
    
         
             
                                cy.wait(17)
         
     | 
| 
       241 
241 
     | 
    
         
             
                                .get('@cp').its('rgb').should('not.deep.equal', rgb);
         
     | 
| 
         @@ -253,11 +253,7 @@ describe('ColorPicker Class Test', () => { 
     | 
|
| 
       253 
253 
     | 
    
         
             
                  const format = FORMAT[getRandomInt(0,3)];
         
     | 
| 
       254 
254 
     | 
    
         
             
                  getMarkup(body, id, format);
         
     | 
| 
       255 
255 
     | 
    
         | 
| 
       256 
     | 
    
         
            -
                   
     | 
| 
       257 
     | 
    
         
            -
                  // a.setAttribute('href', '#');
         
     | 
| 
       258 
     | 
    
         
            -
                  a.innerText = 'Some link';
         
     | 
| 
       259 
     | 
    
         
            -
                  body.append(a);
         
     | 
| 
       260 
     | 
    
         
            -
                  cy.wrap(a).as('a');
         
     | 
| 
      
 256 
     | 
    
         
            +
                  // cy.wrap(a).as('a');
         
     | 
| 
       261 
257 
     | 
    
         
             
                  // cy.get(`#color-picker-${id}`).then((input) => {
         
     | 
| 
       262 
258 
     | 
    
         
             
                  cy.get('input').then((input) => {
         
     | 
| 
       263 
259 
     | 
    
         
             
                    cy.wrap(input[0]).as('input');
         
     | 
| 
         @@ -329,16 +325,9 @@ describe('ColorPicker Class Test', () => { 
     | 
|
| 
       329 
325 
     | 
    
         
             
                cy.wait(17);
         
     | 
| 
       330 
326 
     | 
    
         | 
| 
       331 
327 
     | 
    
         
             
                cy.log('Testing `focusout` on `input`');
         
     | 
| 
       332 
     | 
    
         
            -
                cy.get('@a').focus()
         
     | 
| 
       333 
     | 
    
         
            -
                cy.get('@a').blur()
         
     | 
| 
       334 
328 
     | 
    
         | 
| 
       335 
     | 
    
         
            -
                 
     | 
| 
       336 
     | 
    
         
            -
                cy. 
     | 
| 
       337 
     | 
    
         
            -
                // cy.get('@a').trigger('focusin', {force: true})
         
     | 
| 
       338 
     | 
    
         
            -
                // cy.get('@a').trigger('focusout', {force: true})
         
     | 
| 
       339 
     | 
    
         
            -
                  // .then(() => {
         
     | 
| 
       340 
     | 
    
         
            -
                    cy.get('.color-dropdown.picker').should('not.have.class', 'show')
         
     | 
| 
       341 
     | 
    
         
            -
                  // });
         
     | 
| 
      
 329 
     | 
    
         
            +
                cy.get('a.my-link').eq(0).click({force: true})
         
     | 
| 
      
 330 
     | 
    
         
            +
                cy.get('.color-dropdown.picker').should('not.have.class', 'show')
         
     | 
| 
       342 
331 
     | 
    
         | 
| 
       343 
332 
     | 
    
         
             
                cy.wait(17);
         
     | 
| 
       344 
333 
     | 
    
         | 
| 
         @@ -601,12 +590,12 @@ describe('ColorPicker Class Test', () => { 
     | 
|
| 
       601 
590 
     | 
    
         
             
                        const { width, height} = visual[0].getBoundingClientRect();
         
     | 
| 
       602 
591 
     | 
    
         | 
| 
       603 
592 
     | 
    
         
             
                        cy.get('.knob').eq(0)
         
     | 
| 
       604 
     | 
    
         
            -
                          .trigger('pointerdown', { force: true })
         
     | 
| 
       605 
     | 
    
         
            -
                          .trigger('pointermove', -width, -height, { force: true })
         
     | 
| 
       606 
     | 
    
         
            -
                          .trigger('pointermove', -width - 100, -height - 100, { force: true })
         
     | 
| 
       607 
     | 
    
         
            -
                          .trigger('pointermove', 300, 300, { force: true })
         
     | 
| 
       608 
     | 
    
         
            -
                          .trigger('pointermove', -width + 50, -height + 50, { force: true })
         
     | 
| 
       609 
     | 
    
         
            -
                          .wait(17)
         
     | 
| 
      
 593 
     | 
    
         
            +
                          .trigger('pointerdown', { eventConstructor: 'PointerEvent', force: true })
         
     | 
| 
      
 594 
     | 
    
         
            +
                          .trigger('pointermove', -width, -height, { eventConstructor: 'PointerEvent', force: true })
         
     | 
| 
      
 595 
     | 
    
         
            +
                          .trigger('pointermove', -width - 100, -height - 100, { eventConstructor: 'PointerEvent', force: true })
         
     | 
| 
      
 596 
     | 
    
         
            +
                          .trigger('pointermove', 300, 300, { eventConstructor: 'PointerEvent', force: true })
         
     | 
| 
      
 597 
     | 
    
         
            +
                          .trigger('pointermove', -width + 50, -height + 50, { eventConstructor: 'PointerEvent', force: true })
         
     | 
| 
      
 598 
     | 
    
         
            +
                          // .wait(17)
         
     | 
| 
       610 
599 
     | 
    
         
             
                          .get('@cp').its('rgb').should('not.deep.equal', rgb);
         
     | 
| 
       611 
600 
     | 
    
         
             
                      });
         
     | 
| 
       612 
601 
     | 
    
         
             
                    });
         
     | 
| 
         @@ -617,11 +606,11 @@ describe('ColorPicker Class Test', () => { 
     | 
|
| 
       617 
606 
     | 
    
         
             
                        const { width, height } = visual[0].getBoundingClientRect();
         
     | 
| 
       618 
607 
     | 
    
         | 
| 
       619 
608 
     | 
    
         
             
                        cy.get('.knob').eq(1)
         
     | 
| 
       620 
     | 
    
         
            -
                          .trigger('pointerdown', { force: true })
         
     | 
| 
       621 
     | 
    
         
            -
                          .trigger('pointermove', width / 2, -height - 100, { force: true })
         
     | 
| 
       622 
     | 
    
         
            -
                          .trigger('pointermove', width / 2, 300, { force: true })
         
     | 
| 
       623 
     | 
    
         
            -
                          .trigger('pointermove', width / 2, -height + 20, { force: true })
         
     | 
| 
       624 
     | 
    
         
            -
                          .wait(17)
         
     | 
| 
      
 609 
     | 
    
         
            +
                          .trigger('pointerdown', { eventConstructor: 'PointerEvent', force: true })
         
     | 
| 
      
 610 
     | 
    
         
            +
                          .trigger('pointermove', width / 2, -height - 100, { eventConstructor: 'PointerEvent', force: true })
         
     | 
| 
      
 611 
     | 
    
         
            +
                          .trigger('pointermove', width / 2, 300, { eventConstructor: 'PointerEvent', force: true })
         
     | 
| 
      
 612 
     | 
    
         
            +
                          .trigger('pointermove', width / 2, -height + 20, { eventConstructor: 'PointerEvent', force: true })
         
     | 
| 
      
 613 
     | 
    
         
            +
                          // .wait(17)
         
     | 
| 
       625 
614 
     | 
    
         
             
                          .get('@cp').its('rgb').should('not.deep.equal', rgb);
         
     | 
| 
       626 
615 
     | 
    
         
             
                        });
         
     | 
| 
       627 
616 
     | 
    
         
             
                      });
         
     | 
| 
         @@ -632,11 +621,11 @@ describe('ColorPicker Class Test', () => { 
     | 
|
| 
       632 
621 
     | 
    
         
             
                        const { width, height } = visual[0].getBoundingClientRect();
         
     | 
| 
       633 
622 
     | 
    
         | 
| 
       634 
623 
     | 
    
         
             
                        cy.get('.knob').eq(2)
         
     | 
| 
       635 
     | 
    
         
            -
                          .trigger('pointerdown', { force: true })
         
     | 
| 
       636 
     | 
    
         
            -
                          .trigger('pointermove', width / 2, -height - 100, { force: true })
         
     | 
| 
       637 
     | 
    
         
            -
                          .trigger('pointermove', width / 2, 300, { force: true })
         
     | 
| 
       638 
     | 
    
         
            -
                          .trigger('pointermove', width / 2, -height + 20, { force: true })
         
     | 
| 
       639 
     | 
    
         
            -
                          .wait(17)
         
     | 
| 
      
 624 
     | 
    
         
            +
                          .trigger('pointerdown', { eventConstructor: 'PointerEvent', force: true })
         
     | 
| 
      
 625 
     | 
    
         
            +
                          .trigger('pointermove', width / 2, -height - 100, { eventConstructor: 'PointerEvent', force: true })
         
     | 
| 
      
 626 
     | 
    
         
            +
                          .trigger('pointermove', width / 2, 300, { eventConstructor: 'PointerEvent', force: true })
         
     | 
| 
      
 627 
     | 
    
         
            +
                          .trigger('pointermove', width / 2, -height + 20, { eventConstructor: 'PointerEvent', force: true })
         
     | 
| 
      
 628 
     | 
    
         
            +
                          // .wait(17)
         
     | 
| 
       640 
629 
     | 
    
         
             
                          .get('@cp').its('rgb').should('not.deep.equal', rgb);
         
     | 
| 
       641 
630 
     | 
    
         
             
                        });
         
     | 
| 
       642 
631 
     | 
    
         
             
                      });
         
     | 
| 
         @@ -653,7 +642,7 @@ describe('ColorPicker Class Test', () => { 
     | 
|
| 
       653 
642 
     | 
    
         
             
                      .trigger('keydown', { code: 'ArrowRight' })
         
     | 
| 
       654 
643 
     | 
    
         
             
                      .trigger('keydown', { code: 'ArrowRight' })
         
     | 
| 
       655 
644 
     | 
    
         
             
                      .trigger('keydown', { code: 'ArrowLeft' })
         
     | 
| 
       656 
     | 
    
         
            -
                      .wait(17)
         
     | 
| 
      
 645 
     | 
    
         
            +
                      // .wait(17)
         
     | 
| 
       657 
646 
     | 
    
         
             
                      .get('@cp').its('rgb').should('not.deep.equal', rgb);
         
     | 
| 
       658 
647 
     | 
    
         
             
                  });
         
     | 
| 
       659 
648 
     | 
    
         | 
| 
         @@ -667,7 +656,7 @@ describe('ColorPicker Class Test', () => { 
     | 
|
| 
       667 
656 
     | 
    
         
             
                      .trigger('keydown', { code: 'ArrowLeft' })
         
     | 
| 
       668 
657 
     | 
    
         
             
                      .trigger('keydown', { code: 'ArrowLeft' })
         
     | 
| 
       669 
658 
     | 
    
         
             
                      .trigger('keydown', { code: 'ArrowRight' })
         
     | 
| 
       670 
     | 
    
         
            -
                      .wait(17)
         
     | 
| 
      
 659 
     | 
    
         
            +
                      // .wait(17)
         
     | 
| 
       671 
660 
     | 
    
         
             
                      .get('@cp').its('rgb').should('not.deep.equal', rgb);
         
     | 
| 
       672 
661 
     | 
    
         
             
                  });
         
     | 
| 
       673 
662 
     | 
    
         | 
| 
         @@ -681,7 +670,7 @@ describe('ColorPicker Class Test', () => { 
     | 
|
| 
       681 
670 
     | 
    
         
             
                      .trigger('keydown', { code: 'ArrowLeft' })
         
     | 
| 
       682 
671 
     | 
    
         
             
                      .trigger('keydown', { code: 'ArrowLeft' })
         
     | 
| 
       683 
672 
     | 
    
         
             
                      .trigger('keydown', { code: 'ArrowRight' })
         
     | 
| 
       684 
     | 
    
         
            -
                      .wait(17)
         
     | 
| 
      
 673 
     | 
    
         
            +
                      // .wait(17)
         
     | 
| 
       685 
674 
     | 
    
         
             
                      .get('@cp').its('rgb').should('not.deep.equal', rgb);
         
     | 
| 
       686 
675 
     | 
    
         
             
                  });      
         
     | 
| 
       687 
676 
     | 
    
         
             
                });
         
     | 
| 
         @@ -20,9 +20,16 @@ export default function getMarkup(body, id, format) { 
     | 
|
| 
       20 
20 
     | 
    
         
             
              input.setAttribute('autocomplete', "off");
         
     | 
| 
       21 
21 
     | 
    
         
             
              input.setAttribute('spellcheck', "false");
         
     | 
| 
       22 
22 
     | 
    
         
             
              input.setAttribute('data-format', format);
         
     | 
| 
      
 23 
     | 
    
         
            +
             
     | 
| 
      
 24 
     | 
    
         
            +
              const a = document.createElement('a');
         
     | 
| 
      
 25 
     | 
    
         
            +
              a.setAttribute('href', '#');
         
     | 
| 
      
 26 
     | 
    
         
            +
              a.innerText = 'Some link';
         
     | 
| 
      
 27 
     | 
    
         
            +
              a.className = 'my-link';
         
     | 
| 
      
 28 
     | 
    
         
            +
              a.style = 'position: absolute; top: 20px; opacity: 0.015';
         
     | 
| 
      
 29 
     | 
    
         
            +
              // body.append(a);
         
     | 
| 
       23 
30 
     | 
    
         
             
              cpWrapper.append(input);
         
     | 
| 
       24 
31 
     | 
    
         
             
              if (body) {
         
     | 
| 
       25 
     | 
    
         
            -
                body.append(label, cpWrapper);
         
     | 
| 
      
 32 
     | 
    
         
            +
                body.append(label, cpWrapper, a);
         
     | 
| 
       26 
33 
     | 
    
         
             
              }
         
     | 
| 
       27 
34 
     | 
    
         
             
              return {set, value};
         
     | 
| 
       28 
35 
     | 
    
         
             
            }
         
     | 
| 
         @@ -1,7 +1,7 @@ 
     | 
|
| 
       1 
1 
     | 
    
         
             
            /*!
         
     | 
| 
       2 
     | 
    
         
            -
            * ColorPicker v2.0.0- 
     | 
| 
      
 2 
     | 
    
         
            +
            * ColorPicker v2.0.0-alpha9 (http://thednp.github.io/color-picker)
         
     | 
| 
       3 
3 
     | 
    
         
             
            * Copyright 2023 © thednp
         
     | 
| 
       4 
     | 
    
         
            -
            * Licensed under MIT ( 
     | 
| 
      
 4 
     | 
    
         
            +
            * Licensed under MIT (https://github.com/thednp/color-picker/blob/main/LICENSE)
         
     | 
| 
       5 
5 
     | 
    
         
             
            */
         
     | 
| 
       6 
6 
     | 
    
         
             
            /* :host */
         
     | 
| 
       7 
7 
     | 
    
         
             
            .color-picker {
         
     | 
| 
         @@ -293,7 +293,7 @@ 
     | 
|
| 
       293 
293 
     | 
    
         
             
              transition: var(--options-transition);
         
     | 
| 
       294 
294 
     | 
    
         
             
            }
         
     | 
| 
       295 
295 
     | 
    
         | 
| 
       296 
     | 
    
         
            -
            .color- 
     | 
| 
      
 296 
     | 
    
         
            +
            .color-dropdown.menu:hover .scrollable {
         
     | 
| 
       297 
297 
     | 
    
         
             
              height: var(--grid-hover-height);
         
     | 
| 
       298 
298 
     | 
    
         
             
            }
         
     | 
| 
       299 
299 
     | 
    
         | 
| 
         @@ -314,7 +314,7 @@ 
     | 
|
| 
       314 
314 
     | 
    
         
             
              width: var(--grid-item-size);
         
     | 
| 
       315 
315 
     | 
    
         
             
              height: var(--grid-item-size);
         
     | 
| 
       316 
316 
     | 
    
         
             
              overflow: hidden;
         
     | 
| 
       317 
     | 
    
         
            -
               
     | 
| 
      
 317 
     | 
    
         
            +
              color: rgba(0, 0, 0, 0);
         
     | 
| 
       318 
318 
     | 
    
         
             
            }
         
     | 
| 
       319 
319 
     | 
    
         
             
            .color-options .color-option:active, .color-options .color-option:focus {
         
     | 
| 
       320 
320 
     | 
    
         
             
              outline: none;
         
     | 
| 
         @@ -399,14 +399,14 @@ 
     | 
|
| 
       399 
399 
     | 
    
         | 
| 
       400 
400 
     | 
    
         
             
            /* visual control */
         
     | 
| 
       401 
401 
     | 
    
         
             
            .visual-control {
         
     | 
| 
       402 
     | 
    
         
            -
              height:  
     | 
| 
      
 402 
     | 
    
         
            +
              height: 230px;
         
     | 
| 
       403 
403 
     | 
    
         
             
              /* important for mobile devices */
         
     | 
| 
       404 
404 
     | 
    
         
             
              touch-action: none;
         
     | 
| 
       405 
405 
     | 
    
         
             
              box-shadow: var(--visual-shadow);
         
     | 
| 
       406 
406 
     | 
    
         
             
            }
         
     | 
| 
       407 
407 
     | 
    
         | 
| 
       408 
408 
     | 
    
         
             
            .visual-control1 {
         
     | 
| 
       409 
     | 
    
         
            -
              width:  
     | 
| 
      
 409 
     | 
    
         
            +
              width: 230px;
         
     | 
| 
       410 
410 
     | 
    
         
             
            }
         
     | 
| 
       411 
411 
     | 
    
         | 
| 
       412 
412 
     | 
    
         
             
            .visual-control2,
         
     | 
| 
         @@ -415,15 +415,7 @@ 
     | 
|
| 
       415 
415 
     | 
    
         
             
              cursor: ns-resize;
         
     | 
| 
       416 
416 
     | 
    
         
             
            }
         
     | 
| 
       417 
417 
     | 
    
         | 
| 
       418 
     | 
    
         
            -
            @media (width >=  
     | 
| 
       419 
     | 
    
         
            -
              .visual-control {
         
     | 
| 
       420 
     | 
    
         
            -
                height: 230px;
         
     | 
| 
       421 
     | 
    
         
            -
              }
         
     | 
| 
       422 
     | 
    
         
            -
              .visual-control1 {
         
     | 
| 
       423 
     | 
    
         
            -
                width: 230px;
         
     | 
| 
       424 
     | 
    
         
            -
              }
         
     | 
| 
       425 
     | 
    
         
            -
            }
         
     | 
| 
       426 
     | 
    
         
            -
            @media (width >= 1200px) {
         
     | 
| 
      
 418 
     | 
    
         
            +
            @media (width >= 980px) {
         
     | 
| 
       427 
419 
     | 
    
         
             
              .visual-control {
         
     | 
| 
       428 
420 
     | 
    
         
             
                height: 300px;
         
     | 
| 
       429 
421 
     | 
    
         
             
              }
         
     | 
| 
         @@ -1,2 +1,2 @@ 
     | 
|
| 
       1 
     | 
    
         
            -
            /* ColorPicker v2.0.0- 
     | 
| 
       2 
     | 
    
         
            -
            .color-picker{position:relative;display:flex;--white-15: rgba(255, 255, 255, 0.15);--white-25: rgba(255, 255, 255, 0.25);--white-33: rgba(255, 255, 255, 0.33);--white-50: rgba(255, 255, 255, 0.5);--white-75: rgba(255, 255, 255, 0.75);--white-90: rgba(255, 255, 255, 0.9);--black-15: rgba(0, 0, 0, 0.15);--black-25: rgba(0, 0, 0, 0.25);--black-33: rgba(0, 0, 0, 0.33);--black-50: rgba(0, 0, 0, 0.5);--black-75: rgba(0, 0, 0, 0.75);--black-90: rgba(0, 0, 0, 0.9);--dropdown-transition: transform 0.33s ease, opacity 0.33s ease;--btn-transition: box-shadow 0.33s ease, border 0.33s ease;--options-transition: height 0.33s ease;--dropdown-bg: var(--black-75);--dropdown-color: var(--white-75);--dropdown-shadow: 0 6px 12px var(--black-33);--dropdown-scrollbar-bg: var(--white-33);--dropdown-scrollbar-bg-hover: var(--white-50);--knob-bg: #000;--knob-border: 1px solid var(--white-90);--knob-shadow-hover: 0 0 0 6px var(--white-50);--knob-shadow-active: 0 0 0 6px var(--white-90);--input-border: 1px solid var(--white-15);--input-border-hover: 1px solid var(--white-33);--input-bg-hover: var(--black-15);--option-color-hover: var(--black-75);--option-bg-hover: var(--white-50);--option-color-active: var(--black-75);--option-bg-active: var(--white-90);--visual-shadow: 0 0 0 1px var(--white-15) inset}.color-picker *,.color-picker *::before,.color-picker *::after{box-sizing:border-box}.color-picker:focus{outline:none}.color-dropdown{position:absolute;z-index:50;display:none;flex-direction:column;width:min-content;padding:.5rem;color:var(--dropdown-color);background:var(--dropdown-bg);border-radius:.5rem;box-shadow:var(--dropdown-shadow);opacity:0;transition:var(--dropdown-transition)}.color-dropdown.picker{left:0}.color-dropdown.menu{right:0;max-height:230px}.open .color-dropdown.top{top:auto;bottom:100%}.color-dropdown.bottom{top:100%}.open .color-dropdown.top,.open .color-dropdown.bottom{display:flex}.color-dropdown.show{opacity:1}.color-dropdown.show.top{transform:translate(0, -5px)}.color-dropdown.show.bottom{transform:translate(0, 5px)}.color-controls{display:none;flex-wrap:wrap;justify-content:space-between;width:max-content}.btn-appearance{width:100%;padding:.6rem 1rem;font-size:1rem;line-height:1.5;border:0;border-radius:.25rem;outline:none;appearance:none;transition:var(--btn-transition)}.btn-appearance:focus,.btn-appearance:hover{box-shadow:0 0 0 3px var(--black-15)}.color-preview{box-shadow:0 0 0 1px rgba(120,120,120,.33) inset;direction:ltr}.txt-dark .color-preview{color:var(--white-75)}.txt-dark .color-preview:focus{box-shadow:0 0 0 1px #fff inset,0 0 0 3px var(--black-15)}.txt-dark .color-preview::placeholder{color:var(--white-50)}.txt-light .color-preview{color:var(--black-75)}.txt-light .color-preview:focus{color:var(--black-75);box-shadow:0 0 0 1px #000 inset,0 0 0 3px var(--black-15)}.txt-light .color-preview::placeholder{color:var(--black-50)}.picker-toggle{position:absolute;inset:0;width:100%;height:100%;cursor:pointer;background:rgba(0,0,0,0);border:0}.open .picker-toggle{z-index:-1}.menu-toggle{position:absolute;top:0;right:0;display:flex;width:3rem;height:100%;padding:0 .25rem;cursor:pointer;border:0;border-radius:0 .25rem .25rem 0}.txt-light .menu-toggle{background:var(--black-50)}.txt-light .menu-toggle:focus{background:var(--black-75)}.txt-dark .menu-toggle{background:var(--white-33)}.txt-dark .menu-toggle:focus{background:var(--white-50)}.menu-toggle svg{width:auto;height:100%}.scrollable{overflow-x:hidden;overflow-y:auto;scrollbar-width:thin}.scrollable::-webkit-scrollbar{width:.5rem}.scrollable::-webkit-scrollbar-track{background-color:rgba(0,0,0,0)}.scrollable::-webkit-scrollbar-thumb{width:.5rem;background-color:rgba(0,0,0,0);background-clip:content-box;border:0}.scrollable:hover::-webkit-scrollbar-thumb{background-color:var(--dropdown-scrollbar-bg)}.scrollable::-webkit-scrollbar-thumb:hover{background-color:var(--dropdown-scrollbar-bg-hover)}.color-defaults{display:none;flex-flow:column wrap;margin:0;list-style:none;padding-inline:0}.color-dropdown.menu .color-defaults,.color-dropdown.picker .color-controls{display:flex}.color-defaults .color-option{padding:.25rem .5rem;color:inherit}.color-option{cursor:pointer}.color-defaults .color-option:focus,.color-defaults .color-option:hover{color:var(--option-color-hover);background:var(--option-bg-hover);outline:none}.color-defaults .color-option:active,.color-defaults .color-option.active{color:var(--option-color-active);background:var(--option-bg-active)}.color-options{--grid-item-size: 2rem;--grid-fit: 5;--grid-gap: .25rem;--grid-height: auto;--grid-hover-height: auto;display:grid;padding:0;margin:0;list-style:none;grid-template-columns:repeat(var(--grid-fit), var(--grid-item-size));grid-template-rows:repeat(auto-fill, var(--grid-item-size));gap:var(--grid-gap)}.color-options.scrollable{height:var(--grid-height);margin:0 -0.5rem 0 0;overflow-y:scroll;transition:var(--options-transition)}.color- 
     | 
| 
      
 1 
     | 
    
         
            +
            /* ColorPicker v2.0.0-alpha9 | thednp © 2023 | MIT-License */
         
     | 
| 
      
 2 
     | 
    
         
            +
            .color-picker{position:relative;display:flex;--white-15: rgba(255, 255, 255, 0.15);--white-25: rgba(255, 255, 255, 0.25);--white-33: rgba(255, 255, 255, 0.33);--white-50: rgba(255, 255, 255, 0.5);--white-75: rgba(255, 255, 255, 0.75);--white-90: rgba(255, 255, 255, 0.9);--black-15: rgba(0, 0, 0, 0.15);--black-25: rgba(0, 0, 0, 0.25);--black-33: rgba(0, 0, 0, 0.33);--black-50: rgba(0, 0, 0, 0.5);--black-75: rgba(0, 0, 0, 0.75);--black-90: rgba(0, 0, 0, 0.9);--dropdown-transition: transform 0.33s ease, opacity 0.33s ease;--btn-transition: box-shadow 0.33s ease, border 0.33s ease;--options-transition: height 0.33s ease;--dropdown-bg: var(--black-75);--dropdown-color: var(--white-75);--dropdown-shadow: 0 6px 12px var(--black-33);--dropdown-scrollbar-bg: var(--white-33);--dropdown-scrollbar-bg-hover: var(--white-50);--knob-bg: #000;--knob-border: 1px solid var(--white-90);--knob-shadow-hover: 0 0 0 6px var(--white-50);--knob-shadow-active: 0 0 0 6px var(--white-90);--input-border: 1px solid var(--white-15);--input-border-hover: 1px solid var(--white-33);--input-bg-hover: var(--black-15);--option-color-hover: var(--black-75);--option-bg-hover: var(--white-50);--option-color-active: var(--black-75);--option-bg-active: var(--white-90);--visual-shadow: 0 0 0 1px var(--white-15) inset}.color-picker *,.color-picker *::before,.color-picker *::after{box-sizing:border-box}.color-picker:focus{outline:none}.color-dropdown{position:absolute;z-index:50;display:none;flex-direction:column;width:min-content;padding:.5rem;color:var(--dropdown-color);background:var(--dropdown-bg);border-radius:.5rem;box-shadow:var(--dropdown-shadow);opacity:0;transition:var(--dropdown-transition)}.color-dropdown.picker{left:0}.color-dropdown.menu{right:0;max-height:230px}.open .color-dropdown.top{top:auto;bottom:100%}.color-dropdown.bottom{top:100%}.open .color-dropdown.top,.open .color-dropdown.bottom{display:flex}.color-dropdown.show{opacity:1}.color-dropdown.show.top{transform:translate(0, -5px)}.color-dropdown.show.bottom{transform:translate(0, 5px)}.color-controls{display:none;flex-wrap:wrap;justify-content:space-between;width:max-content}.btn-appearance{width:100%;padding:.6rem 1rem;font-size:1rem;line-height:1.5;border:0;border-radius:.25rem;outline:none;appearance:none;transition:var(--btn-transition)}.btn-appearance:focus,.btn-appearance:hover{box-shadow:0 0 0 3px var(--black-15)}.color-preview{box-shadow:0 0 0 1px rgba(120,120,120,.33) inset;direction:ltr}.txt-dark .color-preview{color:var(--white-75)}.txt-dark .color-preview:focus{box-shadow:0 0 0 1px #fff inset,0 0 0 3px var(--black-15)}.txt-dark .color-preview::placeholder{color:var(--white-50)}.txt-light .color-preview{color:var(--black-75)}.txt-light .color-preview:focus{color:var(--black-75);box-shadow:0 0 0 1px #000 inset,0 0 0 3px var(--black-15)}.txt-light .color-preview::placeholder{color:var(--black-50)}.picker-toggle{position:absolute;inset:0;width:100%;height:100%;cursor:pointer;background:rgba(0,0,0,0);border:0}.open .picker-toggle{z-index:-1}.menu-toggle{position:absolute;top:0;right:0;display:flex;width:3rem;height:100%;padding:0 .25rem;cursor:pointer;border:0;border-radius:0 .25rem .25rem 0}.txt-light .menu-toggle{background:var(--black-50)}.txt-light .menu-toggle:focus{background:var(--black-75)}.txt-dark .menu-toggle{background:var(--white-33)}.txt-dark .menu-toggle:focus{background:var(--white-50)}.menu-toggle svg{width:auto;height:100%}.scrollable{overflow-x:hidden;overflow-y:auto;scrollbar-width:thin}.scrollable::-webkit-scrollbar{width:.5rem}.scrollable::-webkit-scrollbar-track{background-color:rgba(0,0,0,0)}.scrollable::-webkit-scrollbar-thumb{width:.5rem;background-color:rgba(0,0,0,0);background-clip:content-box;border:0}.scrollable:hover::-webkit-scrollbar-thumb{background-color:var(--dropdown-scrollbar-bg)}.scrollable::-webkit-scrollbar-thumb:hover{background-color:var(--dropdown-scrollbar-bg-hover)}.color-defaults{display:none;flex-flow:column wrap;margin:0;list-style:none;padding-inline:0}.color-dropdown.menu .color-defaults,.color-dropdown.picker .color-controls{display:flex}.color-defaults .color-option{padding:.25rem .5rem;color:inherit}.color-option{cursor:pointer}.color-defaults .color-option:focus,.color-defaults .color-option:hover{color:var(--option-color-hover);background:var(--option-bg-hover);outline:none}.color-defaults .color-option:active,.color-defaults .color-option.active{color:var(--option-color-active);background:var(--option-bg-active)}.color-options{--grid-item-size: 2rem;--grid-fit: 5;--grid-gap: .25rem;--grid-height: auto;--grid-hover-height: auto;display:grid;padding:0;margin:0;list-style:none;grid-template-columns:repeat(var(--grid-fit), var(--grid-item-size));grid-template-rows:repeat(auto-fill, var(--grid-item-size));gap:var(--grid-gap)}.color-options.scrollable{height:var(--grid-height);margin:0 -0.5rem 0 0;overflow-y:scroll;transition:var(--options-transition)}.color-dropdown.menu:hover .scrollable{height:var(--grid-hover-height)}.color-options+.color-defaults{margin-top:.25rem}.multiline+.color-defaults{flex-flow:row wrap}.multiline+.color-defaults .color-option{padding:.25rem .33rem;font-size:12px}.color-options .color-option{position:relative;width:var(--grid-item-size);height:var(--grid-item-size);overflow:hidden;color:rgba(0,0,0,0)}.color-options .color-option:active,.color-options .color-option:focus{outline:none;box-shadow:0 0 0 4px rgba(125,125,125,.75) inset}.color-options .color-option::before{position:absolute;inset:0}.color-options .color-option:hover::before,.color-options .color-option:active::before,.color-options .color-option:focus::before{content:"";border:3px solid var(--white-75);mix-blend-mode:difference}.color-options .color-option.active::after{position:absolute;top:50%;left:50%;width:4px;height:4px;margin:-2px 0 0 -2px;content:"";border-radius:4px}.txt-dark .color-options .color-option.active::after{box-shadow:0 0 0 4px var(--white-90)}.txt-light .color-options .color-option.active::after{box-shadow:0 0 0 4px var(--black-90)}.color-form{display:flex;flex-flow:row wrap;align-items:center;padding:.25rem 0 0;font:12px sans-serif}.color-form.hex{max-width:initial}.color-form>*{flex:1 0 0%;width:17.5%;max-width:17.5%}.color-form label{width:7.5%;max-width:7.5%;text-align:center}.color-input{color:inherit;text-align:right;background:rgba(0,0,0,0);border:var(--input-border);outline:none}.color-input.hex{width:92.5%;max-width:92.5%}.color-input:active,.color-input:focus{background:var(--input-bg-hover);border:var(--input-border-hover)}.visual-control{height:230px;touch-action:none;box-shadow:var(--visual-shadow)}.visual-control1{width:230px}.visual-control2,.visual-control3{width:21px;cursor:ns-resize}@media(width >= 980px){.visual-control{height:300px}.visual-control1{width:300px}}.color-control{position:relative;display:inline-block}.color-slider{left:0;width:calc(100% - 2px);cursor:ns-resize}.color-control+.color-control{margin-left:.5rem}.knob{position:absolute;top:0;left:0;width:100%;height:7px;touch-action:none;user-select:none;background-color:var(--knob-bg);border:var(--knob-border);border-radius:5px;outline:none;will-change:transform}.knob:hover{box-shadow:var(--knob-shadow-hover)}.knob:focus,.knob:active{z-index:1;box-shadow:var(--knob-shadow-active)}.color-pointer{width:7px;background-color:rgba(0,0,0,0);border:0}.txt-dark .color-pointer{box-shadow:0 0 0 5px var(--white-50)}.txt-light .color-pointer{box-shadow:0 0 0 5px var(--black-50)}.txt-dark .color-pointer:hover{box-shadow:0 0 0 5px var(--white-75)}.txt-light .color-pointer:hover{box-shadow:0 0 0 5px var(--black-75)}.txt-dark .color-pointer:focus,.txt-dark .color-pointer:active{box-shadow:0 0 0 5px var(--white-90)}.txt-light .color-pointer:focus,.txt-light .color-pointer:active{box-shadow:0 0 0 5px var(--black-90)}.v-hidden{position:absolute !important;width:1px !important;height:1px !important;padding:0 !important;margin:-1px !important;overflow:hidden !important;clip:rect(0, 0, 0, 0) !important;white-space:nowrap !important;border:0 !important}
         
     | 
| 
         @@ -1,7 +1,7 @@ 
     | 
|
| 
       1 
1 
     | 
    
         
             
            /*!
         
     | 
| 
       2 
     | 
    
         
            -
            * ColorPicker v2.0.0- 
     | 
| 
      
 2 
     | 
    
         
            +
            * ColorPicker v2.0.0-alpha9 (http://thednp.github.io/color-picker)
         
     | 
| 
       3 
3 
     | 
    
         
             
            * Copyright 2023 © thednp
         
     | 
| 
       4 
     | 
    
         
            -
            * Licensed under MIT ( 
     | 
| 
      
 4 
     | 
    
         
            +
            * Licensed under MIT (https://github.com/thednp/color-picker/blob/main/LICENSE)
         
     | 
| 
       5 
5 
     | 
    
         
             
            */
         
     | 
| 
       6 
6 
     | 
    
         
             
            /* :host */
         
     | 
| 
       7 
7 
     | 
    
         
             
            .color-picker {
         
     | 
| 
         @@ -293,7 +293,7 @@ 
     | 
|
| 
       293 
293 
     | 
    
         
             
              transition: var(--options-transition);
         
     | 
| 
       294 
294 
     | 
    
         
             
            }
         
     | 
| 
       295 
295 
     | 
    
         | 
| 
       296 
     | 
    
         
            -
            .color- 
     | 
| 
      
 296 
     | 
    
         
            +
            .color-dropdown.menu:hover .scrollable {
         
     | 
| 
       297 
297 
     | 
    
         
             
              height: var(--grid-hover-height);
         
     | 
| 
       298 
298 
     | 
    
         
             
            }
         
     | 
| 
       299 
299 
     | 
    
         | 
| 
         @@ -314,7 +314,7 @@ 
     | 
|
| 
       314 
314 
     | 
    
         
             
              width: var(--grid-item-size);
         
     | 
| 
       315 
315 
     | 
    
         
             
              height: var(--grid-item-size);
         
     | 
| 
       316 
316 
     | 
    
         
             
              overflow: hidden;
         
     | 
| 
       317 
     | 
    
         
            -
               
     | 
| 
      
 317 
     | 
    
         
            +
              color: rgba(0, 0, 0, 0);
         
     | 
| 
       318 
318 
     | 
    
         
             
            }
         
     | 
| 
       319 
319 
     | 
    
         
             
            .color-options .color-option:active, .color-options .color-option:focus {
         
     | 
| 
       320 
320 
     | 
    
         
             
              outline: none;
         
     | 
| 
         @@ -399,14 +399,14 @@ 
     | 
|
| 
       399 
399 
     | 
    
         | 
| 
       400 
400 
     | 
    
         
             
            /* visual control */
         
     | 
| 
       401 
401 
     | 
    
         
             
            .visual-control {
         
     | 
| 
       402 
     | 
    
         
            -
              height:  
     | 
| 
      
 402 
     | 
    
         
            +
              height: 230px;
         
     | 
| 
       403 
403 
     | 
    
         
             
              /* important for mobile devices */
         
     | 
| 
       404 
404 
     | 
    
         
             
              touch-action: none;
         
     | 
| 
       405 
405 
     | 
    
         
             
              box-shadow: var(--visual-shadow);
         
     | 
| 
       406 
406 
     | 
    
         
             
            }
         
     | 
| 
       407 
407 
     | 
    
         | 
| 
       408 
408 
     | 
    
         
             
            .visual-control1 {
         
     | 
| 
       409 
     | 
    
         
            -
              width:  
     | 
| 
      
 409 
     | 
    
         
            +
              width: 230px;
         
     | 
| 
       410 
410 
     | 
    
         
             
            }
         
     | 
| 
       411 
411 
     | 
    
         | 
| 
       412 
412 
     | 
    
         
             
            .visual-control2,
         
     | 
| 
         @@ -415,15 +415,7 @@ 
     | 
|
| 
       415 
415 
     | 
    
         
             
              cursor: ns-resize;
         
     | 
| 
       416 
416 
     | 
    
         
             
            }
         
     | 
| 
       417 
417 
     | 
    
         | 
| 
       418 
     | 
    
         
            -
            @media (width >=  
     | 
| 
       419 
     | 
    
         
            -
              .visual-control {
         
     | 
| 
       420 
     | 
    
         
            -
                height: 230px;
         
     | 
| 
       421 
     | 
    
         
            -
              }
         
     | 
| 
       422 
     | 
    
         
            -
              .visual-control1 {
         
     | 
| 
       423 
     | 
    
         
            -
                width: 230px;
         
     | 
| 
       424 
     | 
    
         
            -
              }
         
     | 
| 
       425 
     | 
    
         
            -
            }
         
     | 
| 
       426 
     | 
    
         
            -
            @media (width >= 1200px) {
         
     | 
| 
      
 418 
     | 
    
         
            +
            @media (width >= 980px) {
         
     | 
| 
       427 
419 
     | 
    
         
             
              .visual-control {
         
     | 
| 
       428 
420 
     | 
    
         
             
                height: 300px;
         
     | 
| 
       429 
421 
     | 
    
         
             
              }
         
     | 
| 
         @@ -1,2 +1,2 @@ 
     | 
|
| 
       1 
     | 
    
         
            -
            /* ColorPicker RTL v2.0.0- 
     | 
| 
       2 
     | 
    
         
            -
            .color-picker{position:relative;display:flex;--white-15: rgba(255, 255, 255, 0.15);--white-25: rgba(255, 255, 255, 0.25);--white-33: rgba(255, 255, 255, 0.33);--white-50: rgba(255, 255, 255, 0.5);--white-75: rgba(255, 255, 255, 0.75);--white-90: rgba(255, 255, 255, 0.9);--black-15: rgba(0, 0, 0, 0.15);--black-25: rgba(0, 0, 0, 0.25);--black-33: rgba(0, 0, 0, 0.33);--black-50: rgba(0, 0, 0, 0.5);--black-75: rgba(0, 0, 0, 0.75);--black-90: rgba(0, 0, 0, 0.9);--dropdown-transition: transform 0.33s ease, opacity 0.33s ease;--btn-transition: box-shadow 0.33s ease, border 0.33s ease;--options-transition: height 0.33s ease;--dropdown-bg: var(--black-75);--dropdown-color: var(--white-75);--dropdown-shadow: 0 6px 12px var(--black-33);--dropdown-scrollbar-bg: var(--white-33);--dropdown-scrollbar-bg-hover: var(--white-50);--knob-bg: #000;--knob-border: 1px solid var(--white-90);--knob-shadow-hover: 0 0 0 6px var(--white-50);--knob-shadow-active: 0 0 0 6px var(--white-90);--input-border: 1px solid var(--white-15);--input-border-hover: 1px solid var(--white-33);--input-bg-hover: var(--black-15);--option-color-hover: var(--black-75);--option-bg-hover: var(--white-50);--option-color-active: var(--black-75);--option-bg-active: var(--white-90);--visual-shadow: 0 0 0 1px var(--white-15) inset}.color-picker *,.color-picker *::before,.color-picker *::after{box-sizing:border-box}.color-picker:focus{outline:none}.color-dropdown{position:absolute;z-index:50;display:none;flex-direction:column;width:min-content;padding:.5rem;color:var(--dropdown-color);background:var(--dropdown-bg);border-radius:.5rem;box-shadow:var(--dropdown-shadow);opacity:0;transition:var(--dropdown-transition)}.color-dropdown.picker{left:0}.color-dropdown.menu{right:0;max-height:230px}.open .color-dropdown.top{top:auto;bottom:100%}.color-dropdown.bottom{top:100%}.open .color-dropdown.top,.open .color-dropdown.bottom{display:flex}.color-dropdown.show{opacity:1}.color-dropdown.show.top{transform:translate(0, -5px)}.color-dropdown.show.bottom{transform:translate(0, 5px)}.color-controls{display:none;flex-wrap:wrap;justify-content:space-between;width:max-content}.btn-appearance{width:100%;padding:.6rem 1rem;font-size:1rem;line-height:1.5;border:0;border-radius:.25rem;outline:none;appearance:none;transition:var(--btn-transition)}.btn-appearance:focus,.btn-appearance:hover{box-shadow:0 0 0 3px var(--black-15)}.color-preview{box-shadow:0 0 0 1px rgba(120,120,120,.33) inset;direction:ltr}.txt-dark .color-preview{color:var(--white-75)}.txt-dark .color-preview:focus{box-shadow:0 0 0 1px #fff inset,0 0 0 3px var(--black-15)}.txt-dark .color-preview::placeholder{color:var(--white-50)}.txt-light .color-preview{color:var(--black-75)}.txt-light .color-preview:focus{color:var(--black-75);box-shadow:0 0 0 1px #000 inset,0 0 0 3px var(--black-15)}.txt-light .color-preview::placeholder{color:var(--black-50)}.picker-toggle{position:absolute;inset:0;width:100%;height:100%;cursor:pointer;background:rgba(0,0,0,0);border:0}.open .picker-toggle{z-index:-1}.menu-toggle{position:absolute;top:0;right:0;display:flex;width:3rem;height:100%;padding:0 .25rem;cursor:pointer;border:0;border-radius:0 .25rem .25rem 0}.txt-light .menu-toggle{background:var(--black-50)}.txt-light .menu-toggle:focus{background:var(--black-75)}.txt-dark .menu-toggle{background:var(--white-33)}.txt-dark .menu-toggle:focus{background:var(--white-50)}.menu-toggle svg{width:auto;height:100%}.scrollable{overflow-x:hidden;overflow-y:auto;scrollbar-width:thin}.scrollable::-webkit-scrollbar{width:.5rem}.scrollable::-webkit-scrollbar-track{background-color:rgba(0,0,0,0)}.scrollable::-webkit-scrollbar-thumb{width:.5rem;background-color:rgba(0,0,0,0);background-clip:content-box;border:0}.scrollable:hover::-webkit-scrollbar-thumb{background-color:var(--dropdown-scrollbar-bg)}.scrollable::-webkit-scrollbar-thumb:hover{background-color:var(--dropdown-scrollbar-bg-hover)}.color-defaults{display:none;flex-flow:column wrap;margin:0;list-style:none;padding-inline:0}.color-dropdown.menu .color-defaults,.color-dropdown.picker .color-controls{display:flex}.color-defaults .color-option{padding:.25rem .5rem;color:inherit}.color-option{cursor:pointer}.color-defaults .color-option:focus,.color-defaults .color-option:hover{color:var(--option-color-hover);background:var(--option-bg-hover);outline:none}.color-defaults .color-option:active,.color-defaults .color-option.active{color:var(--option-color-active);background:var(--option-bg-active)}.color-options{--grid-item-size: 2rem;--grid-fit: 5;--grid-gap: .25rem;--grid-height: auto;--grid-hover-height: auto;display:grid;padding:0;margin:0;list-style:none;grid-template-columns:repeat(var(--grid-fit), var(--grid-item-size));grid-template-rows:repeat(auto-fill, var(--grid-item-size));gap:var(--grid-gap)}.color-options.scrollable{height:var(--grid-height);margin:0 -0.5rem 0 0;overflow-y:scroll;transition:var(--options-transition)}.color- 
     | 
| 
      
 1 
     | 
    
         
            +
            /* ColorPicker RTL v2.0.0-alpha9 | thednp © 2023 | MIT-License */
         
     | 
| 
      
 2 
     | 
    
         
            +
            .color-picker{position:relative;display:flex;--white-15: rgba(255, 255, 255, 0.15);--white-25: rgba(255, 255, 255, 0.25);--white-33: rgba(255, 255, 255, 0.33);--white-50: rgba(255, 255, 255, 0.5);--white-75: rgba(255, 255, 255, 0.75);--white-90: rgba(255, 255, 255, 0.9);--black-15: rgba(0, 0, 0, 0.15);--black-25: rgba(0, 0, 0, 0.25);--black-33: rgba(0, 0, 0, 0.33);--black-50: rgba(0, 0, 0, 0.5);--black-75: rgba(0, 0, 0, 0.75);--black-90: rgba(0, 0, 0, 0.9);--dropdown-transition: transform 0.33s ease, opacity 0.33s ease;--btn-transition: box-shadow 0.33s ease, border 0.33s ease;--options-transition: height 0.33s ease;--dropdown-bg: var(--black-75);--dropdown-color: var(--white-75);--dropdown-shadow: 0 6px 12px var(--black-33);--dropdown-scrollbar-bg: var(--white-33);--dropdown-scrollbar-bg-hover: var(--white-50);--knob-bg: #000;--knob-border: 1px solid var(--white-90);--knob-shadow-hover: 0 0 0 6px var(--white-50);--knob-shadow-active: 0 0 0 6px var(--white-90);--input-border: 1px solid var(--white-15);--input-border-hover: 1px solid var(--white-33);--input-bg-hover: var(--black-15);--option-color-hover: var(--black-75);--option-bg-hover: var(--white-50);--option-color-active: var(--black-75);--option-bg-active: var(--white-90);--visual-shadow: 0 0 0 1px var(--white-15) inset}.color-picker *,.color-picker *::before,.color-picker *::after{box-sizing:border-box}.color-picker:focus{outline:none}.color-dropdown{position:absolute;z-index:50;display:none;flex-direction:column;width:min-content;padding:.5rem;color:var(--dropdown-color);background:var(--dropdown-bg);border-radius:.5rem;box-shadow:var(--dropdown-shadow);opacity:0;transition:var(--dropdown-transition)}.color-dropdown.picker{left:0}.color-dropdown.menu{right:0;max-height:230px}.open .color-dropdown.top{top:auto;bottom:100%}.color-dropdown.bottom{top:100%}.open .color-dropdown.top,.open .color-dropdown.bottom{display:flex}.color-dropdown.show{opacity:1}.color-dropdown.show.top{transform:translate(0, -5px)}.color-dropdown.show.bottom{transform:translate(0, 5px)}.color-controls{display:none;flex-wrap:wrap;justify-content:space-between;width:max-content}.btn-appearance{width:100%;padding:.6rem 1rem;font-size:1rem;line-height:1.5;border:0;border-radius:.25rem;outline:none;appearance:none;transition:var(--btn-transition)}.btn-appearance:focus,.btn-appearance:hover{box-shadow:0 0 0 3px var(--black-15)}.color-preview{box-shadow:0 0 0 1px rgba(120,120,120,.33) inset;direction:ltr}.txt-dark .color-preview{color:var(--white-75)}.txt-dark .color-preview:focus{box-shadow:0 0 0 1px #fff inset,0 0 0 3px var(--black-15)}.txt-dark .color-preview::placeholder{color:var(--white-50)}.txt-light .color-preview{color:var(--black-75)}.txt-light .color-preview:focus{color:var(--black-75);box-shadow:0 0 0 1px #000 inset,0 0 0 3px var(--black-15)}.txt-light .color-preview::placeholder{color:var(--black-50)}.picker-toggle{position:absolute;inset:0;width:100%;height:100%;cursor:pointer;background:rgba(0,0,0,0);border:0}.open .picker-toggle{z-index:-1}.menu-toggle{position:absolute;top:0;right:0;display:flex;width:3rem;height:100%;padding:0 .25rem;cursor:pointer;border:0;border-radius:0 .25rem .25rem 0}.txt-light .menu-toggle{background:var(--black-50)}.txt-light .menu-toggle:focus{background:var(--black-75)}.txt-dark .menu-toggle{background:var(--white-33)}.txt-dark .menu-toggle:focus{background:var(--white-50)}.menu-toggle svg{width:auto;height:100%}.scrollable{overflow-x:hidden;overflow-y:auto;scrollbar-width:thin}.scrollable::-webkit-scrollbar{width:.5rem}.scrollable::-webkit-scrollbar-track{background-color:rgba(0,0,0,0)}.scrollable::-webkit-scrollbar-thumb{width:.5rem;background-color:rgba(0,0,0,0);background-clip:content-box;border:0}.scrollable:hover::-webkit-scrollbar-thumb{background-color:var(--dropdown-scrollbar-bg)}.scrollable::-webkit-scrollbar-thumb:hover{background-color:var(--dropdown-scrollbar-bg-hover)}.color-defaults{display:none;flex-flow:column wrap;margin:0;list-style:none;padding-inline:0}.color-dropdown.menu .color-defaults,.color-dropdown.picker .color-controls{display:flex}.color-defaults .color-option{padding:.25rem .5rem;color:inherit}.color-option{cursor:pointer}.color-defaults .color-option:focus,.color-defaults .color-option:hover{color:var(--option-color-hover);background:var(--option-bg-hover);outline:none}.color-defaults .color-option:active,.color-defaults .color-option.active{color:var(--option-color-active);background:var(--option-bg-active)}.color-options{--grid-item-size: 2rem;--grid-fit: 5;--grid-gap: .25rem;--grid-height: auto;--grid-hover-height: auto;display:grid;padding:0;margin:0;list-style:none;grid-template-columns:repeat(var(--grid-fit), var(--grid-item-size));grid-template-rows:repeat(auto-fill, var(--grid-item-size));gap:var(--grid-gap)}.color-options.scrollable{height:var(--grid-height);margin:0 -0.5rem 0 0;overflow-y:scroll;transition:var(--options-transition)}.color-dropdown.menu:hover .scrollable{height:var(--grid-hover-height)}.color-options+.color-defaults{margin-top:.25rem}.multiline+.color-defaults{flex-flow:row wrap}.multiline+.color-defaults .color-option{padding:.25rem .33rem;font-size:12px}.color-options .color-option{position:relative;width:var(--grid-item-size);height:var(--grid-item-size);overflow:hidden;color:rgba(0,0,0,0)}.color-options .color-option:active,.color-options .color-option:focus{outline:none;box-shadow:0 0 0 4px rgba(125,125,125,.75) inset}.color-options .color-option::before{position:absolute;inset:0}.color-options .color-option:hover::before,.color-options .color-option:active::before,.color-options .color-option:focus::before{content:"";border:3px solid var(--white-75);mix-blend-mode:difference}.color-options .color-option.active::after{position:absolute;top:50%;left:50%;width:4px;height:4px;margin:-2px 0 0 -2px;content:"";border-radius:4px}.txt-dark .color-options .color-option.active::after{box-shadow:0 0 0 4px var(--white-90)}.txt-light .color-options .color-option.active::after{box-shadow:0 0 0 4px var(--black-90)}.color-form{display:flex;flex-flow:row wrap;align-items:center;padding:.25rem 0 0;font:12px sans-serif}.color-form.hex{max-width:initial}.color-form>*{flex:1 0 0%;width:17.5%;max-width:17.5%}.color-form label{width:7.5%;max-width:7.5%;text-align:center}.color-input{color:inherit;text-align:right;background:rgba(0,0,0,0);border:var(--input-border);outline:none}.color-input.hex{width:92.5%;max-width:92.5%}.color-input:active,.color-input:focus{background:var(--input-bg-hover);border:var(--input-border-hover)}.visual-control{height:230px;touch-action:none;box-shadow:var(--visual-shadow)}.visual-control1{width:230px}.visual-control2,.visual-control3{width:21px;cursor:ns-resize}@media(width >= 980px){.visual-control{height:300px}.visual-control1{width:300px}}.color-control{position:relative;display:inline-block}.color-slider{left:0;width:calc(100% - 2px);cursor:ns-resize}.color-control+.color-control{margin-left:.5rem}.knob{position:absolute;top:0;left:0;width:100%;height:7px;touch-action:none;user-select:none;background-color:var(--knob-bg);border:var(--knob-border);border-radius:5px;outline:none;will-change:transform}.knob:hover{box-shadow:var(--knob-shadow-hover)}.knob:focus,.knob:active{z-index:1;box-shadow:var(--knob-shadow-active)}.color-pointer{width:7px;background-color:rgba(0,0,0,0);border:0}.txt-dark .color-pointer{box-shadow:0 0 0 5px var(--white-50)}.txt-light .color-pointer{box-shadow:0 0 0 5px var(--black-50)}.txt-dark .color-pointer:hover{box-shadow:0 0 0 5px var(--white-75)}.txt-light .color-pointer:hover{box-shadow:0 0 0 5px var(--black-75)}.txt-dark .color-pointer:focus,.txt-dark .color-pointer:active{box-shadow:0 0 0 5px var(--white-90)}.txt-light .color-pointer:focus,.txt-light .color-pointer:active{box-shadow:0 0 0 5px var(--black-90)}.v-hidden{position:absolute !important;width:1px !important;height:1px !important;padding:0 !important;margin:-1px !important;overflow:hidden !important;clip:rect(0, 0, 0, 0) !important;white-space:nowrap !important;border:0 !important}[dir=rtl] .color-preview{text-align:right}[dir=rtl] .menu-toggle{right:auto;left:0;border-radius:.25rem 0 0 .25rem}[dir=rtl] .color-dropdown.picker{right:0;left:auto}[dir=rtl] .color-dropdown.menu{right:auto;left:0}[dir=rtl] .color-control+.color-control{margin-right:.5rem;margin-left:0}[dir=rtl] .color-options.scrollable{margin:0 0 0 -0.5rem}
         
     |