
    b6i                     j    d dl mZ d dlmZ d dlmZ d dlmZ d dlm	Z	  e	e
      Zdededee   fd	Zy
)    )Path)Optional)Image)PSDImage)setup_loggerpsd_pathpreview_pathreturnc                 z   	 t        j                  |       }|j                         j                  d      }|j	                  |d       |S # t
        $ rg t        j                  d       	 t        j                  |       }|j	                  |d       |cY S # t
        $ r t        j                  d       Y Y yw xY ww xY w)zk
    Generate a PNG preview for the given PSD.
    Returns preview_path on success or None on failure.
    RGBAPNGz$PSD -> PNG preview generation failedz+Fallback PSD preview generation also failedN)	r   open	compositeconvertsave	Exceptionlogger	exceptionr   )r   r	   psdr   imgs        F/var/www/html/story-book/Story-Book-python-api/app/utils/psd_shared.pygenerate_psd_previewr      s    mmH%MMO++F3	|U+ 
?@	**X&CHH\5) 	JK	
s0   AA
 
B:)(BB:B62B:5B66B:N)pathlibr   typingr   PILr   	psd_toolsr   app.core.loggingr   __name__r   r        r   <module>r!      s<        )	h	4 t  r    