This paper examines how to plan multi-period assortments when customer utility depends on historical assortments. We formulate this problem as a nonlinear integer programming problem and propose solution methodologies for different regimes of this problem. First, we present a sequential revenue-ordered policy and show that it is optimal when historical assortments positively affect customer utility. Second, we show that the problem is NP-hard under the presence of a negative history-dependent effect (such as a satiation effect). In this case, we propose using a lifting-based framework to reformulate the problem as a mixed-integer exponential cone program that state-of-the-art solvers can solve. Additionally, we identify an optimal cyclic policy for an asymptotic regime, and we also relate its length to the customer's memory length. Finally, we present a case study using a catering service dataset that shows that our model demonstrates good fitness and can effectively balance variety and revenue.